*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh;background-color:#f5f5f5;color:#333}#root{width:100%;height:100vh;margin:0;padding:0}.admin-container{max-width:1400px;margin:0 auto;padding:2rem;min-height:100vh;background:#f5f5f5}.admin-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:2rem}.admin-header-left{flex:0 0 auto}.admin-header h1{color:#333;margin:0;flex:1;text-align:center}.admin-header-right{flex:0 0 auto}.back-button{padding:.75rem 1.5rem;background:#fff;border:2px solid #667eea;color:#667eea;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.back-button:hover{background:#667eea;color:#fff}.logout-button{padding:.75rem 1.5rem;background:#fff;border:2px solid #dc3545;color:#dc3545;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.logout-button:hover{background:#dc3545;color:#fff}.admin-error{background:#fee;border:2px solid #f55;color:#c00;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.stat-label{font-size:.9rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.admin-filters{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1.5rem;background:#fff;border:2px solid #ddd;color:#333;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:#667eea;color:#667eea}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.refresh-btn{padding:.75rem 1.5rem;background:#fff;border:2px solid #667eea;color:#667eea;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;margin-left:auto}.refresh-btn:hover:not(:disabled){background:#667eea;color:#fff}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.admin-loading,.admin-empty{text-align:center;padding:3rem;color:#666;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.users-table{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.users-table table{width:100%;border-collapse:collapse}.users-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.users-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.users-table td{padding:1rem;border-bottom:1px solid #eee;font-size:.9rem}.users-table tbody tr:hover{background:#f9f9f9}.users-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-block;padding:.35rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.status-pending{background:#fff3cd;color:#856404}.status-badge.status-approved{background:#d4edda;color:#155724}.status-badge.status-rejected{background:#f8d7da;color:#721c24}.status-badge.admin-badge{background:#fff3e0;color:#e65100;margin-left:.5rem}.actions{display:flex;gap:.5rem;flex-wrap:wrap}.actions button{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.approve-btn{background:#28a745;color:#fff}.approve-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px);box-shadow:0 2px 6px #28a7454d}.reject-btn{background:#dc3545;color:#fff}.reject-btn:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 2px 6px #dc35454d}.make-admin-btn{background:#ff9800;color:#fff}.make-admin-btn:hover:not(:disabled){background:#f57c00;transform:translateY(-1px);box-shadow:0 2px 6px #ff98004d}.demote-admin-btn,.revoke-admin-btn{background:#9e9e9e;color:#fff}.demote-admin-btn:hover:not(:disabled),.revoke-admin-btn:hover:not(:disabled){background:#757575;transform:translateY(-1px);box-shadow:0 2px 6px #9e9e9e4d}.grant-btn{background:#2196f3;color:#fff}.grant-btn:hover:not(:disabled){background:#1976d2;transform:translateY(-1px);box-shadow:0 2px 6px #2196f34d}.revoke-btn{background:#ff5722;color:#fff}.revoke-btn:hover:not(:disabled){background:#e64a19;transform:translateY(-1px);box-shadow:0 2px 6px #ff57224d}.grant-admin-btn{background:#ff9800;color:#fff}.grant-admin-btn:hover:not(:disabled){background:#f57c00;transform:translateY(-1px);box-shadow:0 2px 6px #ff98004d}.user-badge{background:#2196f3;color:#fff;margin-left:.5rem}.delete-btn{background:#6c757d;color:#fff}.delete-btn:hover:not(:disabled){background:#5a6268;transform:translateY(-1px);box-shadow:0 2px 6px #6c757d4d}.actions button:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 768px){.admin-container{padding:.75rem}.admin-header{flex-direction:column;align-items:stretch;gap:.75rem}.admin-header h1{text-align:center;font-size:1.5rem;order:-1}.admin-header-left,.admin-header-right{display:contents}.back-button,.logout-button{flex:1 1 auto;padding:.75rem 1rem;font-size:.9rem}.admin-header{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.admin-header h1{grid-column:1 / -1}.admin-stats{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1rem}.stat-value{font-size:2rem}.admin-filters{flex-direction:row;flex-wrap:wrap;gap:.5rem}.filter-btn{flex:1 1 auto;min-width:fit-content;padding:.75rem 1rem}.refresh-btn{flex:1 1 auto;min-width:fit-content;margin-left:0;padding:.75rem 1rem}.users-table{overflow:visible}.users-table table{display:block}.users-table thead{display:none}.users-table tbody{display:block}.users-table tr{display:block;margin-bottom:1rem;border:1px solid #ddd;border-radius:8px;padding:1rem;background:#fff}.users-table td{display:block;padding:.5rem 0;border-bottom:none;text-align:left}.users-table td:before{content:attr(data-label);font-weight:600;display:block;margin-bottom:.25rem;color:#667eea;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.users-table td:first-child{padding-top:0}.actions{flex-direction:column;gap:.5rem;padding:1.5rem 1rem .5rem!important;margin-top:1rem;border-top:2px solid #e0e0e0}.actions button{width:100%;padding:.75rem}}.app{display:flex;flex-direction:column;height:100vh;max-width:1400px;margin:0 auto;padding:0}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.header h1{margin:0;font-size:2rem}.document-stats{margin-top:.5rem;font-size:.85rem;opacity:.95;background:#ffffff26;display:inline-block;padding:.25rem .75rem;border-radius:12px;cursor:help}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}.user-info{display:flex;align-items:center}.user-email{font-size:.9rem;opacity:.9}.header-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.cache-button{padding:.5rem 1rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s}.cache-button:hover{background:#ffffff40}.clear-chat-button{padding:.5rem 1rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.clear-chat-button:hover{background:#ffffff40}.sign-out-button{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.sign-out-button:hover{background:#ffffff4d}.subtitle{margin:.5rem 0 0;opacity:.9;font-size:1rem}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f5f5f5}.messages{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1rem}.welcome{text-align:center;padding:3rem 2rem;color:#666}.welcome h2{color:#333;margin-bottom:1rem}.welcome-stats{margin:1.5rem 0;padding:1rem;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:12px;max-width:600px;margin-left:auto;margin-right:auto}.welcome-stats p{margin:.5rem 0;color:#555;font-size:.95rem}.welcome-hint{font-size:.85rem!important;opacity:.8;margin-top:1rem!important}.welcome-hint kbd{background:#f5f5f5;border:1px solid #ccc;border-radius:3px;padding:.1rem .4rem;font-family:monospace;font-size:.9em}.examples{margin-top:2rem;text-align:left;max-width:600px;margin-left:auto;margin-right:auto;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.examples ul{list-style:none;padding:0;margin:1rem 0 0}.examples li{padding:.75rem;margin:.5rem 0;background:#f9f9f9;border-radius:8px;border-left:3px solid #667eea;cursor:pointer;transition:all .2s}.examples li:hover{background:#f0f0f0;transform:translate(5px)}.message{display:flex;margin-bottom:1rem;position:relative}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message.maximized{position:fixed;inset:0;margin:0;z-index:1000;background:#000000e6;padding:2rem;overflow-y:auto;justify-content:center;align-items:flex-start}.message.maximized .message-content{max-width:100%;width:100%;max-height:100%;overflow-y:auto}.message-content{max-width:70%;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 2px 5px #0000001a}.message.user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.message.assistant .message-content{background:#fff;color:#333;position:relative}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.message-meta{display:flex;align-items:center;gap:.5rem}.message-actions{margin-top:.75rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem}.message.user .message-actions{justify-content:flex-end}.maximize-button{padding:.5rem 1rem;background:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;min-width:110px;text-align:center;line-height:1;display:inline-flex;align-items:center;justify-content:center}.maximize-button:hover{background:#667eea;color:#fff;border-color:#667eea;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.role{font-weight:700;font-size:.85rem;opacity:.8}.timestamp{font-size:.75rem;opacity:.6;font-weight:400}.cached-badge{background:#ffc107;color:#000;padding:.15rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600}.mode-badge{padding:.15rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600;white-space:nowrap}.mode-badge.fast{background:#e3f2fd;color:#1976d2}.mode-badge.quality{background:#f3e5f5;color:#7b1fa2}.mode-badge.comprehensive{background:#fff3e0;color:#e65100}.response-time{background:#e8f5e9;color:#2e7d32;padding:.15rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600;white-space:nowrap}.copy-button{padding:.5rem 1rem;background:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;min-width:110px;text-align:center;line-height:1;display:inline-flex;align-items:center;justify-content:center}.copy-button:hover{background:#667eea;color:#fff;border-color:#667eea;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.content{line-height:1.6;white-space:pre-wrap}.loading{font-style:italic;opacity:.7;display:flex;align-items:center;gap:.5rem}.typing-indicator{display:inline-flex;gap:.25rem;align-items:center}.typing-indicator span{width:8px;height:8px;background:#667eea;border-radius:50%;display:inline-block;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.sources{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.sources details{cursor:pointer}.sources summary{font-size:.9rem;font-weight:600;color:#667eea}.sources-list{margin-top:.5rem}.source{margin:.75rem 0;padding:.75rem;background:#f9f9f9;border-radius:8px;font-size:.85rem;border-left:3px solid #667eea}.source-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.source-header strong{color:#333;font-size:.9rem;flex:1;min-width:200px}.source-meta{display:flex;gap:.5rem;align-items:center}.source-location{color:#666;margin:.25rem 0;font-size:.8rem}.source-content{margin-top:.5rem;padding:.5rem;background:#fff;border-radius:4px;font-style:italic;line-height:1.4}.source-filename{color:#555;margin:.5rem 0;font-weight:500;font-size:.85rem;font-family:monospace;background:#fff;padding:.25rem .5rem;border-radius:4px}.similarity-score{color:#667eea;font-weight:600;font-size:.75rem;background:#667eea1a;padding:.15rem .5rem;border-radius:10px}.chunk-count{color:#28a745;font-weight:600;font-size:.75rem;background:#28a7451a;padding:.15rem .5rem;border-radius:10px}.chunk-details{margin-top:.5rem}.chunk-details summary{cursor:pointer;color:#667eea;font-weight:600;font-size:.85rem;padding:.5rem;background:#667eea0d;border-radius:6px;transition:background .2s}.chunk-details summary:hover{background:#667eea1a}.chunk-excerpt{padding:.75rem;margin:.5rem 0;background:#f9f9f9;border-radius:6px;border-left:2px solid #667eea;font-size:.85rem;line-height:1.4}.chunk-excerpt strong{color:#667eea;display:block;margin-bottom:.25rem;font-size:.8rem}.file-actions{margin:.75rem 0;display:flex;gap:.5rem;flex-wrap:wrap}.file-action-button{padding:.5rem 1rem;border:2px solid #667eea;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;background:#fff;color:#667eea}.file-action-button:hover{background:#667eea;color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.file-action-button.preview{border-color:#667eea;color:#667eea}.file-action-button.preview:hover{background:#667eea;color:#fff}.file-action-button.download{border-color:#28a745;color:#28a745}.file-action-button.download:hover{background:#28a745;color:#fff}.file-action-button.open{border-color:#17a2b8;color:#17a2b8}.file-action-button.open:hover{background:#17a2b8;color:#fff}.source-image-preview{margin:1rem 0;text-align:center}.source-image-preview img{max-width:100%;max-height:400px;border-radius:8px;border:2px solid #ddd;transition:all .3s ease;object-fit:contain;box-shadow:0 2px 8px #0000001a}.source-image-preview img:hover{transform:scale(1.02);border-color:#667eea;box-shadow:0 4px 16px #667eea4d}.source-pdf-preview{margin:1rem 0}.pdf-iframe{width:100%;height:500px;border:2px solid #ddd;border-radius:8px;background:#f5f5f5}.source-image{margin:1rem 0;text-align:center}.source-image img{max-width:100%;max-height:400px;border-radius:8px;border:2px solid #ddd;cursor:pointer;transition:all .3s ease;object-fit:contain;box-shadow:0 2px 8px #0000001a}.source-image img:hover{transform:scale(1.02);border-color:#667eea;box-shadow:0 4px 16px #667eea4d}.image-caption{margin-top:.5rem;font-size:.75rem;color:#999;font-style:italic}.source-pdf{margin:1rem 0}.pdf-preview{width:100%;height:500px;border:2px solid #ddd;border-radius:8px;background:#f5f5f5}.pdf-actions{margin-top:.75rem;text-align:center;display:flex;gap:.75rem;justify-content:center}.pdf-action-button{padding:.5rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}.pdf-action-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.input-container{padding:1rem 1.5rem;background:#fff;border-top:1px solid #ddd;display:flex;flex-direction:column;gap:.75rem}.input-container textarea{width:100%;padding:1rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;min-height:60px;transition:border-color .2s;box-sizing:border-box}.input-container textarea:focus{outline:none;border-color:#667eea}.input-container textarea:disabled{background:#f5f5f5;cursor:not-allowed}.input-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.mode-selector{display:flex;gap:.5rem;background:#f5f5f5;padding:.25rem;border-radius:8px;border:1px solid #e0e0e0}.mode-button{padding:.5rem 1rem;background:transparent;color:#666;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.mode-button:hover:not(:disabled){background:#667eea1a;color:#667eea}.mode-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 4px #667eea4d}.mode-button:disabled{opacity:.5;cursor:not-allowed}.send-button{padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:100px;white-space:nowrap}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.send-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.config-warning{position:fixed;bottom:20px;right:20px;background:#ff6b6b;color:#fff;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #0003;max-width:400px}.loading-screen{display:flex;justify-content:center;align-items:center;height:100vh;color:#667eea}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.auth-card{background:#fff;border-radius:16px;padding:3rem;max-width:450px;width:100%;box-shadow:0 10px 40px #0003;text-align:center}.auth-card h1{margin:0 0 .5rem;color:#333}.auth-card .subtitle{color:#666;margin-bottom:2rem}.auth-buttons{display:flex;flex-direction:column;gap:1rem;margin:2rem 0}.auth-button{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1.5rem;border:2px solid #ddd;border-radius:8px;background:#fff;color:#333;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.auth-button:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.auth-button.google svg{width:20px;height:20px}.auth-button.apple{background:#000;color:#fff;border-color:#000}.auth-button.apple:hover{background:#333;border-color:#333}.auth-button.cognito{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.auth-button.cognito:hover{opacity:.9}.divider{display:flex;align-items:center;text-align:center;margin:.5rem 0;color:#999}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #ddd}.divider span{padding:0 1rem;font-size:.875rem}.auth-note{margin-top:1.5rem;font-size:.875rem;color:#666;line-height:1.5}@media (max-width: 768px){.messages{padding:1rem .75rem}.welcome{padding:1.5rem .75rem}.message-content{max-width:90%}.input-container{padding:.75rem;gap:.5rem}.input-container textarea{min-height:50px;font-size:.95rem;padding:.75rem}.input-actions{flex-direction:row;gap:.5rem;align-items:center}.mode-selector{flex:1;justify-content:flex-start;padding:.2rem}.mode-button{flex:1;padding:.5rem .4rem;font-size:.75rem}.send-button{flex-shrink:0;padding:.6rem 1rem;min-width:70px;font-size:.9rem}.header{flex-direction:column;text-align:center;gap:.4rem;padding:.75rem 1rem}.header h1{font-size:1.25rem;margin:0}.header>div>.subtitle{display:none}.document-stats{font-size:.75rem;padding:.2rem .5rem;margin-top:.25rem}.header-right{align-items:center;gap:0;width:100%}.user-info{display:none}.header-actions{display:flex;justify-content:center;align-items:center;gap:.35rem;width:100%;flex-wrap:wrap}.header-actions button{padding:.35rem .6rem;font-size:.7rem;white-space:nowrap;flex:0 0 auto}.cache-button{font-size:.65rem}.clear-chat-button,.sign-out-button{flex:1;min-width:70px}.message.maximized{padding:1rem}.message.maximized .message-content{width:100%;max-width:100%}.message-actions{flex-wrap:wrap;gap:.4rem}.maximize-button,.copy-button{font-size:.8rem;padding:.45rem .8rem;min-width:95px}.auth-card{padding:2rem 1.5rem}}.toast{position:fixed;bottom:2rem;right:2rem;padding:1rem 1.5rem;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:10000;max-width:400px;cursor:pointer;animation:slideIn .3s ease-out;font-weight:500}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left:4px solid #28a745;color:#155724}.toast-error{border-left:4px solid #dc3545;color:#721c24}.toast-info{border-left:4px solid #17a2b8;color:#0c5460}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:400px;width:100%;box-shadow:0 8px 24px #0003}.modal-content h3{margin:0 0 1rem;font-size:1.5rem;color:#333}.modal-content p{margin:0 0 1.5rem;color:#666;line-height:1.5}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.modal-button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.modal-button.cancel{background:#f8f9fa;color:#6c757d}.modal-button.cancel:hover{background:#e9ecef}.modal-button.confirm{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-button.confirm:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}@media (max-width: 768px){.toast{bottom:1rem;right:1rem;left:1rem;max-width:none}.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}.modal-button{width:100%}}.preview-modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.preview-modal-content{background:#fff;border-radius:12px;max-width:95vw;max-height:95vh;width:100%;height:100%;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;overflow:hidden}.preview-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #ddd;background:#f8f9fa}.preview-modal-header h3{margin:0;font-size:1.1rem;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;padding-right:1rem}.preview-modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;line-height:1}.preview-modal-close:hover{background:#e9ecef;color:#333}.preview-modal-body{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem;overflow:auto;background:#f8f9fa}.preview-modal-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 16px #0000001a}.preview-modal-iframe{width:100%;height:100%;border:none;border-radius:8px;background:#fff}.preview-modal-actions{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #ddd;background:#f8f9fa;justify-content:flex-end}.preview-modal-button{padding:.75rem 1.5rem;border:2px solid;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;background:#fff}.preview-modal-button.download{border-color:#28a745;color:#28a745}.preview-modal-button.download:hover{background:#28a745;color:#fff}.preview-modal-button.open{border-color:#17a2b8;color:#17a2b8}.preview-modal-button.open:hover{background:#17a2b8;color:#fff}@media (max-width: 768px){.preview-modal-content{max-width:100vw;max-height:100vh;border-radius:0}.preview-modal-header h3{font-size:1rem}.preview-modal-actions{flex-direction:column}.preview-modal-button{width:100%;justify-content:center}}
