enhance: 빠른 작업 카드 프리미엄 디자인 대폭 개선

🎨 프리미엄 카드 디자인:
1. 고급스러운 그라데이션 배경
   - 기본: 화이트 → 라이트 그레이 그라데이션
   - 호버: 화이트 → 블루 틴트 그라데이션
   - 부드러운 색상 전환 효과

2. 동적 상단 그라데이션 바
   - 4색 그라데이션 (블루, 퍼플, 시안, 그린)
   - 3초 주기 애니메이션 효과
   - 호버 시 나타나는 시각적 피드백

 3D 호버 효과:
1. 카드 전체:
   - Y축 -8px 이동 + 2% 확대
   - 고급 그림자 효과 (다층 그림자)
   - 0.4초 cubic-bezier 애니메이션

2. 아이콘 개선:
   - 크기 확대 (64px → 80px)
   - 호버 시 15% 확대 + 5도 회전
   - 색상 변화 (라이트 블루 → 다크 블루)
   - 3D 그림자 및 테두리 효과

🎯 인터랙션 개선:
1. 화살표 버튼:
   - 원형 배경 추가 (32px)
   - 슬라이드 + 스케일 애니메이션
   - 호버 시 블루 그라데이션 활성화

2. 텍스트 색상 변화:
   - 제목: 다크 그레이 → 다크 블루
   - 설명: 미디엄 그레이 → 다크 그레이
   - 부드러운 색상 전환

📱 반응형 최적화:
- 모바일: 아이콘 60px, 회전 각도 3도로 조정
- 태블릿: 2열 그리드 유지
- 데스크톱: 4열 그리드 최적화

🚀 성능 최적화:
- GPU 가속 애니메이션 (transform, opacity)
- 최적화된 cubic-bezier 전환
- 레이어 분리를 통한 렌더링 성능 향상

🎨 시각적 효과:
- 방사형 그라데이션 오버레이
- 다층 그림자 시스템
- 부드러운 색상 전환
- 프리미엄 느낌의 시각적 계층

결과: 사용자 경험을 크게 향상시키는 매력적이고 인터랙티브한 카드 디자인

테스트: http://localhost:20000/pages/dashboard/group-leader.html
This commit is contained in:
Hyungi Ahn
2025-11-03 12:25:08 +09:00
parent a99fc78167
commit 0e74ee5fcd

View File

@@ -411,19 +411,20 @@
display: flex;
flex-direction: column;
align-items: center;
gap: var(--space-3);
padding: var(--space-6);
background: linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-tertiary) 100%);
border-radius: var(--radius-xl);
gap: var(--space-4);
padding: var(--space-8);
background: linear-gradient(145deg, #ffffff 0%, #f8fafc 50%, #f1f5f9 100%);
border-radius: var(--radius-2xl);
text-decoration: none;
color: var(--text-primary);
transition: var(--transition-normal);
border: 1px solid var(--border-light);
transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
border: 2px solid transparent;
position: relative;
overflow: hidden;
text-align: center;
min-height: 160px;
min-height: 180px;
justify-content: center;
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}
.quick-action-card::before {
@@ -432,41 +433,91 @@
top: 0;
left: 0;
right: 0;
height: 3px;
background: linear-gradient(90deg, var(--primary-500), var(--primary-600));
height: 4px;
background: linear-gradient(90deg, #3b82f6, #8b5cf6, #06b6d4, #10b981);
background-size: 300% 100%;
animation: gradientShift 3s ease-in-out infinite;
opacity: 0;
transition: var(--transition-normal);
transition: opacity 0.3s ease;
}
.quick-action-card:hover::before {
.quick-action-card::after {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: radial-gradient(circle at 50% 50%, rgba(59, 130, 246, 0.05) 0%, transparent 70%);
opacity: 0;
transition: opacity 0.3s ease;
}
@keyframes gradientShift {
0%, 100% { background-position: 0% 50%; }
50% { background-position: 100% 50%; }
}
.quick-action-card:hover::before,
.quick-action-card:hover::after {
opacity: 1;
}
.quick-action-card:hover {
background: linear-gradient(135deg, var(--bg-primary) 0%, var(--primary-50) 100%);
box-shadow: var(--shadow-lg);
transform: translateY(-4px);
border-color: var(--primary-200);
background: linear-gradient(145deg, #ffffff 0%, #f0f9ff 50%, #e0f2fe 100%);
box-shadow:
0 20px 25px -5px rgba(0, 0, 0, 0.1),
0 10px 10px -5px rgba(0, 0, 0, 0.04),
0 0 0 1px rgba(59, 130, 246, 0.1);
transform: translateY(-8px) scale(1.02);
border-color: rgba(59, 130, 246, 0.2);
}
.action-icon-large {
width: 64px;
height: 64px;
background: linear-gradient(135deg, var(--primary-100), var(--primary-200));
width: 80px;
height: 80px;
background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 50%, #93c5fd 100%);
border-radius: var(--radius-full);
display: flex;
align-items: center;
justify-content: center;
font-size: var(--text-3xl);
font-size: 2.5rem;
flex-shrink: 0;
transition: var(--transition-normal);
box-shadow: var(--shadow-sm);
transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
box-shadow:
0 4px 6px -1px rgba(0, 0, 0, 0.1),
0 2px 4px -1px rgba(0, 0, 0, 0.06),
inset 0 1px 0 rgba(255, 255, 255, 0.1);
position: relative;
overflow: hidden;
}
.action-icon-large::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(147, 197, 253, 0.1) 100%);
border-radius: inherit;
opacity: 0;
transition: opacity 0.3s ease;
}
.quick-action-card:hover .action-icon-large {
background: linear-gradient(135deg, var(--primary-200), var(--primary-300));
transform: scale(1.1);
box-shadow: var(--shadow-md);
background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 50%, #1e40af 100%);
transform: scale(1.15) rotate(5deg);
box-shadow:
0 10px 15px -3px rgba(0, 0, 0, 0.1),
0 4px 6px -2px rgba(0, 0, 0, 0.05),
0 0 0 3px rgba(59, 130, 246, 0.1),
inset 0 1px 0 rgba(255, 255, 255, 0.2);
color: white;
}
.quick-action-card:hover .action-icon-large::before {
opacity: 1;
}
.action-content {
@@ -477,34 +528,55 @@
}
.action-content h3 {
font-size: var(--text-base);
font-weight: var(--font-semibold);
font-size: 1.125rem;
font-weight: 700;
margin: 0;
color: var(--text-primary);
color: #1f2937;
line-height: 1.3;
transition: color 0.3s ease;
}
.action-content p {
font-size: var(--text-sm);
color: var(--text-secondary);
font-size: 0.875rem;
color: #6b7280;
margin: 0;
line-height: 1.4;
line-height: 1.5;
transition: color 0.3s ease;
}
.quick-action-card:hover .action-content h3 {
color: #1e40af;
}
.quick-action-card:hover .action-content p {
color: #374151;
}
.action-arrow {
position: absolute;
top: var(--space-3);
right: var(--space-3);
font-size: var(--text-lg);
color: var(--primary-500);
top: var(--space-4);
right: var(--space-4);
width: 32px;
height: 32px;
background: linear-gradient(135deg, #f3f4f6, #e5e7eb);
border-radius: var(--radius-full);
display: flex;
align-items: center;
justify-content: center;
font-size: 1rem;
color: #6b7280;
opacity: 0;
transition: var(--transition-normal);
transform: translateX(-10px);
transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
transform: translateX(-10px) scale(0.8);
box-shadow: 0 2px 4px -1px rgba(0, 0, 0, 0.1);
}
.quick-action-card:hover .action-arrow {
opacity: 1;
transform: translateX(0);
transform: translateX(0) scale(1);
background: linear-gradient(135deg, #3b82f6, #1d4ed8);
color: white;
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}
.admin-only {
@@ -528,30 +600,42 @@
.quick-actions-grid-full,
.quick-actions-grid {
grid-template-columns: 1fr;
gap: var(--space-3);
}
.quick-action-card {
min-height: 120px;
padding: var(--space-4);
min-height: 140px;
padding: var(--space-6);
gap: var(--space-3);
}
.action-icon-large {
width: 48px;
height: 48px;
font-size: var(--text-2xl);
width: 60px;
height: 60px;
font-size: 2rem;
}
.quick-action-card:hover .action-icon-large {
transform: scale(1.1) rotate(3deg);
}
.action-content h3 {
font-size: var(--text-sm);
font-size: 1rem;
}
.action-content p {
font-size: var(--text-xs);
font-size: 0.8rem;
}
.work-status-container-enhanced {
min-height: 300px;
}
.action-arrow {
width: 28px;
height: 28px;
font-size: 0.875rem;
}
}
/* ========== 작업자 섹션 ========== */