.loading-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb)}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px;padding:40px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:28px;color:#1f2937;margin-bottom:8px}.login-header p{color:#6b7280;font-size:14px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.form-group input{padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background-color:#f9fafb;cursor:not-allowed}.error-message{background-color:#fee2e2;color:#991b1b;padding:12px;border-radius:8px;font-size:14px;border-left:4px solid #dc2626}.login-button{padding:12px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s}.login-button:hover:not(:disabled){opacity:.9}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;margin-top:20px;color:#9ca3af;font-size:13px}.dashboard-container{min-height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5}.dashboard-header{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:20px;box-shadow:0 2px 8px #0000001a}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-content h1{font-size:24px;margin:0}.logout-button{background-color:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.logout-button:hover{background-color:#ffffff4d}.dashboard-content{display:flex;flex:1;max-width:1400px;margin:0 auto;width:100%;gap:20px;padding:20px}.sidebar{width:300px;display:flex;flex-direction:column;gap:20px}.filter-section{background:#fff;padding:16px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.filter-section h3{margin:0 0 16px;font-size:16px;color:#1f2937}.filter-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.filter-group label{font-size:13px;color:#6b7280;font-weight:600}.filter-group input,.filter-group select{padding:8px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.refresh-button{padding:8px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:background-color .2s}.refresh-button:hover{background-color:#2563eb}.requests-list-section{background:#fff;padding:16px;border-radius:8px;box-shadow:0 1px 3px #0000001a;flex:1;display:flex;flex-direction:column;min-height:400px}.requests-list-section h3{margin:0 0 12px;font-size:16px;color:#1f2937}.loading-text,.error-text,.empty-text{text-align:center;padding:20px;color:#6b7280;font-size:14px}.error-text{color:#991b1b;background-color:#fee2e2;border-radius:6px;padding:12px}.main-content{flex:1;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:20px}.empty-detail{display:flex;justify-content:center;align-items:center;height:100%;color:#9ca3af}@media (max-width: 768px){.dashboard-content{flex-direction:column}.sidebar{width:100%}.header-content{flex-direction:column;gap:16px;align-items:flex-start}}# dependencies node_modules/ npm-debug.log* yarn-debug.log* yarn-error.log* # production /dist /build # environment variables .env .env.local .env.*.local # IDE .idea/ .vscode/ *.swp *.swo *~ .DS_Store # misc .cache/ .request-detail{position:fixed;top:0;right:0;width:600px;height:100vh;background:#fff;box-shadow:-4px 0 24px #0000001a;overflow-y:auto;z-index:1000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.detail-header{position:sticky;top:0;background:#fff;border-bottom:1px solid #e5e7eb;padding:24px;display:flex;justify-content:space-between;align-items:flex-start;z-index:10}.detail-header h2{margin:0;font-size:24px;color:#1f2937}.detail-email{margin:4px 0 0;color:#6b7280;font-size:14px}.close-button{background:#f3f4f6;border:none;width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:18px;color:#6b7280;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#e5e7eb;color:#1f2937}.detail-body{padding:24px}.detail-section{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.detail-section:last-child{border-bottom:none}.detail-section h3{margin:0 0 16px;font-size:18px;color:#1f2937;font-weight:600}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.info-item{display:flex;flex-direction:column;gap:6px}.info-item label{font-size:12px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-item span,.info-item code{font-size:14px;color:#1f2937}.info-item code{background:#f3f4f6;padding:4px 8px;border-radius:4px;font-family:Monaco,Courier New,monospace;font-size:13px;display:inline-block}.status-badge{display:inline-block;padding:6px 12px;border-radius:12px;color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.message-box{background:#f9fafb;padding:16px;border-radius:8px;border:1px solid #e5e7eb;line-height:1.6;color:#374151;white-space:pre-wrap}.attachments-info{background:#f9fafb;padding:16px;border-radius:8px;border:1px solid #e5e7eb}.response-form{background:#f9fafb;border-radius:12px;padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#374151;font-size:14px}.form-group select,.form-group textarea{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:14px;transition:all .2s}.form-group select{cursor:pointer;background:#fff}.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:120px}.form-group small{display:block;margin-top:6px;font-size:12px;color:#6b7280}.form-buttons{display:flex;gap:12px}.submit-button,.delete-button{flex:1;padding:12px 24px;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.submit-button{background:#3b82f6;color:#fff}.submit-button:hover:not(:disabled){background:#2563eb}.submit-button:disabled{background:#9ca3af;cursor:not-allowed}.delete-button{background:#fee;color:#dc2626;border:1px solid #fecaca}.delete-button:hover:not(:disabled){background:#fecaca;border-color:#f87171}.delete-button:disabled{opacity:.5;cursor:not-allowed}.chat-section{background:#f9fafb;border-radius:12px;padding:24px}.chat-container{background:#fff;border-radius:8px;border:1px solid #e5e7eb;padding:16px;max-height:500px;overflow-y:auto;margin-bottom:16px}.messages-list{display:flex;flex-direction:column;gap:16px}.message-bubble{display:flex;flex-direction:column;max-width:70%;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-user{align-self:flex-start}.message-admin{align-self:flex-end}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:12px}.message-sender{font-size:12px;font-weight:600;color:#6b7280}.message-time{font-size:11px;color:#9ca3af}.message-text{padding:12px 16px;border-radius:12px;line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.message-user .message-text{background:#f3f4f6;color:#1f2937;border-bottom-left-radius:4px}.message-admin .message-text{background:#3b82f6;color:#fff;border-bottom-right-radius:4px}.chat-input-container{display:flex;gap:12px;align-items:flex-end}.spinner{border:3px solid #f3f4f6;border-top:3px solid #3b82f6;border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chat-container::-webkit-scrollbar{width:8px}.chat-container::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.chat-container::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.chat-container::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 768px){.request-detail{width:100%}.info-grid{grid-template-columns:1fr}.message-bubble{max-width:85%}.chat-input-container{flex-direction:column;align-items:stretch}.chat-input-container button{align-self:stretch!important;margin-left:0!important;margin-top:8px}.form-buttons{flex-direction:column}}body{margin:0;background-color:#f5f5f5}*{box-sizing:border-box}
