*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:#f5f5f5;min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:20px}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#fff}.login-form{background:#fff;padding:48px;border-radius:16px;box-shadow:0 4px 24px #00000014;border:1px solid #f0f0f0;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:36px}.login-logo{height:48px;width:auto;margin-bottom:16px}.login-subtitle{color:#1e293b;font-size:20px;font-weight:500;margin:0}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;color:#374151;font-weight:500;font-size:14px}.form-group input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s;background:#f9fafb}.form-group input:focus{outline:none;border-color:#f78da7;box-shadow:0 0 0 3px #f78da733;background:#fff}.form-group input::placeholder{color:#9ca3af}.login-btn{width:100%;padding:14px 24px;background:#f78da7;color:#fff;border:none;border-radius:24px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s,box-shadow .2s;margin-top:8px}.login-btn:hover{background:#e57a94;box-shadow:0 4px 12px #f78da766}.login-btn:active{transform:scale(.98)}.login-btn:disabled{background:#f5c6d0;cursor:not-allowed;transform:none;box-shadow:none}.google-login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 24px;background:#fff;color:#374151;border:2px solid #e5e7eb;border-radius:24px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s}.google-login-btn:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 4px 12px #0000001a}.google-login-btn:active{transform:scale(.98)}.google-login-btn:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.google-icon{flex-shrink:0}.login-note{text-align:center;margin-top:24px;color:#6b7280;font-size:13px;line-height:1.5}.error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:24px;text-align:center;font-size:14px;border:1px solid #fecaca}.header{background:#fff;padding:20px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header h1{color:#333;font-size:24px}.header-logo{height:40px;width:auto}.date-picker-container{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;display:flex;gap:20px;align-items:center;flex-wrap:wrap;justify-content:space-between}.date-pickers{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.total-utilization{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.total-utilization-label{font-size:12px;color:#666;text-transform:uppercase;letter-spacing:.5px}.total-utilization-value{font-size:28px;font-weight:700;color:#333}.departments-container{display:flex;flex-direction:column;gap:30px}.department-section{display:flex;flex-direction:column;gap:15px}.department-divider{display:flex;align-items:center;gap:15px;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff}.department-name{font-size:18px;font-weight:600}.department-count{font-size:14px;opacity:.9;background:#fff3;padding:4px 10px;border-radius:12px}.department-avg-utilization{margin-left:auto;font-size:14px;font-weight:600;background:#ffffff40;padding:4px 12px;border-radius:12px}.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.resource-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.resource-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.resource-card h3{color:#333;margin-bottom:15px;font-size:18px}.resource-card .department{color:#666;font-size:14px;margin-bottom:15px;padding:4px 8px;background:#f0f0f0;border-radius:4px;display:inline-block}.resource-card .stats{display:flex;flex-direction:column;gap:10px}.resource-card .stat{display:flex;justify-content:space-between;align-items:center}.resource-card .stat-label{color:#666;font-size:14px}.resource-card .stat-value{font-weight:600;font-size:16px}.resource-card .utilization{padding:4px 12px;border-radius:20px;font-size:14px}.resource-card .utilization.low{background:#ffebee;color:#c62828}.resource-card .utilization.medium{background:#fff3e0;color:#f57c00}.resource-card .utilization.high{background:#e8f5e9;color:#2e7d32}.loading{text-align:center;padding:40px;color:#666}.empty-state{text-align:center;padding:40px;color:#666;background:#fff;border-radius:8px}
