.dashboard-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh;background:#f8fafc}.navbar{background:white;border-bottom:1px solid #e5e7eb;position:-webkit-sticky;position:sticky;top:0;z-index:100}.nav-container{max-width:1200px;margin:0 auto;padding:0 20px;justify-content:space-between;height:70px}.nav-brand,.nav-container{display:flex;align-items:center}.nav-brand{gap:12px;font-weight:700;font-size:20px;color:#1a1a1a;text-decoration:none}.nav-brand .logo{justify-content:center;width:36px;height:36px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:white}.nav-brand .logo,.nav-links{display:flex;align-items:center}.nav-links{gap:20px}.nav-button{padding:8px 16px;border-radius:8px;text-decoration:none;font-weight:500;color:#374151;transition:all .2s ease;border:none;background:none;cursor:pointer;font-size:14px}.nav-button:hover{background:#f3f4f6}.nav-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:white}.nav-button.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(102,126,234,.3)}.nav-button.logout{color:#dc2626}.nav-button.logout:hover{background:#fee2e2}.user-menu{display:flex;align-items:center;gap:16px}.user-greeting{font-size:14px;color:#6b7280;font-weight:500}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:#6b7280}.dashboard-container{max-width:1200px;margin:0 auto;padding:40px 20px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.header-content h1{font-size:2.5rem;font-weight:700;color:#1a1a1a;margin:0 0 8px}.header-content p{font-size:1.125rem;color:#6b7280;margin:0}.cta-button{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:white;text-decoration:none;border-radius:12px;font-weight:600;transition:all .2s ease}.cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(102,126,234,.3)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:20px;gap:20px;margin-bottom:40px}.stat-card{background:white;border-radius:16px;padding:24px;border:1px solid #e5e7eb;display:flex;align-items:center;gap:16px;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.1)}.stat-icon{font-size:2rem;display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:#f0f9ff;border-radius:12px}.stat-number{font-size:2rem;font-weight:700;color:#1a1a1a;line-height:1}.stat-label{font-size:14px;color:#6b7280;margin-top:4px}.quick-actions{margin-bottom:40px}.quick-actions h2{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin-bottom:20px}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:20px;gap:20px}.action-card{background:white;border-radius:16px;padding:24px;border:1px solid #e5e7eb;text-decoration:none;transition:all .2s ease;display:block}.action-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.1);border-color:#667eea}.action-icon{font-size:2rem;margin-bottom:12px}.action-card h3{font-size:1.125rem;font-weight:600;color:#1a1a1a;margin:0 0 8px}.action-card p{color:#6b7280;font-size:14px;line-height:1.5;margin:0}.recent-requests{margin-bottom:40px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin:0}.view-all{color:#667eea;text-decoration:none;font-weight:500;font-size:14px}.view-all:hover{text-decoration:underline}.loading-state{text-align:center;padding:60px 20px;background:white;border-radius:16px;border:1px solid #e5e7eb}.loading-spinner{width:40px;height:40px;border:3px solid #f3f4f6;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.empty-state{text-align:center;padding:60px 20px;background:white;border-radius:16px;border:1px solid #e5e7eb}.empty-icon{font-size:4rem;margin-bottom:16px}.empty-state h3{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0 0 8px}.empty-state p{color:#6b7280;margin:0 0 24px;font-size:16px}.requests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));grid-gap:20px;gap:20px}.request-card{background:white;border-radius:16px;padding:24px;border:1px solid #e5e7eb;transition:all .2s ease;position:relative;display:flex;flex-direction:column}.request-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.1)}.request-image-section{position:relative;margin-bottom:16px;border-radius:12px;overflow:hidden;background:#f3f4f6}.request-preview-image{width:100%;height:180px;object-fit:cover;display:block}.image-count-badge-dashboard{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);color:white;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px}.image-count-badge-dashboard svg{width:10px;height:10px}.request-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.request-category{font-size:12px;color:#667eea}.request-category,.request-status{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.request-status{padding:4px 8px;border-radius:12px;font-size:11px}.status-active{background:#dcfce7;color:#166534}.status-fulfilled{background:#dbeafe;color:#1e40af}.status-expired{background:#fef3c7;color:#92400e}.status-closed{background:#f3f4f6;color:#6b7280}.request-title{margin:0 0 12px}.request-title a{font-size:1.125rem;font-weight:600;color:#1a1a1a;text-decoration:none;line-height:1.4}.request-title a:hover{color:#667eea}.request-description{color:#6b7280;font-size:14px;line-height:1.5;margin:0 0 16px;flex-grow:1}.request-details{margin-bottom:16px}.detail-item{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px}.detail-label{color:#6b7280;font-weight:500}.detail-value{color:#1a1a1a;font-weight:500}.request-stats{display:flex;gap:16px;flex-wrap:wrap;padding-top:16px;border-top:1px solid #f3f4f6;margin-bottom:16px}.stat-item{display:flex;align-items:center;gap:4px;font-size:12px;color:#6b7280}.stat-item svg{width:14px;height:14px}.urgent-badge{position:absolute;top:12px;right:12px;background:#fef3c7;color:#92400e;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600}.request-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;padding-top:16px;border-top:1px solid #f3f4f6}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#f9fafb;color:#374151;min-height:32px;flex:1 1;justify-content:center}.action-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.1)}.action-btn:disabled{opacity:.6;cursor:not-allowed}.fulfill-btn{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.fulfill-btn:hover:not(:disabled){background:#bbf7d0;box-shadow:0 2px 8px rgba(22,101,52,.2)}.close-btn{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.close-btn:hover:not(:disabled){background:#fde68a;box-shadow:0 2px 8px rgba(146,64,14,.2)}.reopen-btn{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}.reopen-btn:hover:not(:disabled){background:#bfdbfe;box-shadow:0 2px 8px rgba(30,64,175,.2)}.btn-spinner{width:14px;height:14px;border:2px solid transparent;border-top-color:currentcolor;border-radius:50%;animation:spin 1s linear infinite}@media (max-width:768px){.dashboard-container{padding:20px 16px}.dashboard-header{flex-direction:column;gap:20px;align-items:flex-start}.header-content h1{font-size:2rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.actions-grid,.requests-grid{grid-template-columns:1fr}.nav-container{padding:0 16px}.nav-links{gap:12px}.user-greeting{display:none}.section-header{gap:12px;align-items:flex-start}.request-actions,.section-header{flex-direction:column}.request-preview-image{height:140px}}