/* ── 카드 ── */
.card {
  background: var(--white);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow-card);
  padding: var(--space-5);
  transition: box-shadow 0.2s ease;
}
.card:hover { box-shadow: var(--shadow-md); }

/* ── 버튼 ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--border-radius-sm);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s ease;
  border: none;
  font-family: inherit;
  text-decoration: none;
}
.btn-primary { background: var(--primary-800); color: var(--white); }
.btn-primary:hover { background: var(--primary-700); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-primary:active { transform: translateY(0); }
.btn-danger  { background: var(--danger); color: var(--white); }
.btn-success { background: var(--success); color: var(--white); }
.btn-outline { background: transparent; border: 1.5px solid var(--gray-300); color: var(--gray-700); }
.btn-outline:hover { border-color: var(--primary-800); color: var(--primary-800); }
.btn-ghost   { background: transparent; color: var(--gray-500); padding: var(--space-2) var(--space-3); }
.btn-ghost:hover { background: var(--gray-100); color: var(--gray-700); }
.btn-lg { padding: var(--space-4) var(--space-8); font-size: 16px; min-height: 56px; }
.btn-sm { padding: var(--space-2) var(--space-4); font-size: 13px; }
@media (max-width: 767px) { .btn-sm { min-height: 44px; } }
.btn-full { width: 100%; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-loading { position: relative; color: transparent; pointer-events: none; }
.btn-loading::after {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  border: 2px solid var(--white);
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}
.btn-icon { width: 40px; height: 40px; padding: 0; border-radius: var(--border-radius-sm); }
.btn-icon-round { width: 40px; height: 40px; padding: 0; border-radius: 50%; }
.btn-destructive { background: var(--danger); color: var(--white); }
.btn-destructive:hover { background: #E5342B; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── 입력 ── */
.input {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--gray-300);
  border-radius: var(--border-radius-sm);
  font-size: 15px;
  background: var(--white);
  font-family: inherit;
  transition: border-color 0.15s;
  box-sizing: border-box;
}
.input:focus { outline: none; border-color: var(--primary-800); box-shadow: 0 0 0 3px rgba(27,58,75,0.1); }
.input-error { border-color: var(--danger); }
.input-label { display: block; margin-bottom: var(--space-2); font-size: 14px; font-weight: 500; color: var(--gray-700); }
.input-hint  { font-size: 12px; color: var(--gray-400); margin-top: var(--space-1); }
.input-error-msg { font-size: 12px; color: var(--danger); margin-top: var(--space-1); }

/* ── 폼 그룹 ── */
.form-group { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-5); }
.form-row { display: flex; gap: var(--space-4); }
.form-row > .form-group { flex: 1; margin-bottom: 0; }
.form-actions { margin-top: var(--space-8); display: flex; gap: var(--space-3); }
@media (max-width: 767px) { .form-row { flex-direction: column; gap: var(--space-5); } }

/* ── 테이블 ── */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table { width: 100%; border-collapse: collapse; font-size: 14px; }
.table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  font-size: 12px;
  font-weight: 600;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 2px solid var(--gray-200);
  background: var(--gray-50);
}
.table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--gray-100);
  color: var(--gray-700);
  vertical-align: middle;
}
.table tr:hover td { background: var(--gray-50); }
.table-compact th, .table-compact td { padding: var(--space-2) var(--space-3); font-size: 13px; }

/* ── 리스트 ── */
.list { list-style: none; padding: 0; margin: 0; }
.list-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border-bottom: 1px solid var(--gray-100);
  transition: background 0.1s;
}
.list-item:hover { background: var(--gray-50); }
.list-item:last-child { border-bottom: none; }
.list-item-clickable { cursor: pointer; }
.list-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.list-dot-draft      { background: var(--status-draft); }
.list-dot-requested  { background: var(--status-requested); }
.list-dot-accepted   { background: var(--status-accepted); }
.list-dot-rejected   { background: var(--status-rejected); }
.list-dot-assigned   { background: var(--status-assigned); }
.list-dot-checked-in { background: var(--status-checked-in); }
.list-dot-completed  { background: var(--status-completed); }
.list-dot-evaluated  { background: var(--status-evaluated); }
.list-item-content { flex: 1; min-width: 0; }
.list-item-title { font-size: 15px; font-weight: 500; color: var(--gray-900); }
.list-item-desc  { font-size: 13px; color: var(--gray-500); margin-top: 2px; }
.list-item-meta  { font-size: 12px; color: var(--gray-400); margin-top: 2px; }
.list-item-action { flex-shrink: 0; }

/* ── 뱃지 ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: var(--border-radius-full);
  font-size: 12px;
  font-weight: 600;
}
.badge-status { color: var(--white); }
.badge-draft      { background: var(--status-draft); }
.badge-requested  { background: var(--status-requested); animation: pulse 2s infinite; }
.badge-accepted   { background: var(--status-accepted); }
.badge-rejected   { background: var(--status-rejected); }
.badge-assigned   { background: var(--status-assigned); }
.badge-checked-in { background: var(--status-checked-in); }
.badge-completed  { background: var(--status-completed); }
.badge-evaluated  { background: var(--status-evaluated); }
.badge-grade-a { background: linear-gradient(135deg, #FFD700, #FFA500); color: #7C2D12; }
.badge-grade-b { background: var(--gray-200); color: var(--gray-700); }
.badge-grade-c { background: #FDE8D8; color: #9A3412; }

/* ── 필터 칩 ── */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 8px 16px;
  border-radius: var(--border-radius-full);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  background: var(--gray-100);
  color: var(--gray-700);
  transition: all 0.15s;
  border: none;
}
.chip-active { background: var(--primary-800); color: var(--white); }
.chip-count {
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  background: var(--danger);
  color: var(--white);
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ── Flash ── */
.flash {
  padding: var(--space-3) var(--space-5);
  border-radius: var(--border-radius-sm);
  font-size: 14px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  animation: slideDown 0.3s ease;
  margin-bottom: var(--space-4);
}
.flash-error   { background: var(--danger-bg); color: var(--danger); border-left: 4px solid var(--danger); }
.flash-success { background: var(--success-bg); color: #166534; border-left: 4px solid var(--success); }
.flash-warning { background: var(--warning-bg); color: #92400E; border-left: 4px solid var(--warning); }

/* ── 빈 상태 ── */
.empty-state { text-align: center; padding: var(--space-16) var(--space-5); color: var(--gray-400); }
.empty-state svg { width: 64px; height: 64px; margin: 0 auto var(--space-4); opacity: 0.4; display: block; }
.empty-state .empty-title { font-size: 16px; font-weight: 600; color: var(--gray-500); margin-bottom: var(--space-2); }
.empty-state .empty-desc  { font-size: 14px; color: var(--gray-400); margin-bottom: var(--space-5); }

/* ── 스켈레톤 ── */
.skeleton {
  background: linear-gradient(90deg, var(--gray-200) 25%, var(--gray-100) 50%, var(--gray-200) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--border-radius-sm);
}

/* ── FAB ── */
.fab {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  width: 56px;
  height: 56px;
  border-radius: 28px;
  background: var(--primary-800);
  color: var(--white);
  font-size: 24px;
  border: none;
  cursor: pointer;
  box-shadow: var(--shadow-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.15s;
  z-index: var(--z-fab);
}
.fab:hover { transform: scale(1.05); }
@media (max-width: 767px) { .fab { bottom: calc(var(--mobile-tab-height) + var(--space-4)); } }

/* ── 포커스 접근성 ── */
:focus-visible { outline: 2px solid var(--primary-800); outline-offset: 2px; }
:focus:not(:focus-visible) { outline: none; }

/* ── 애니메이션 ── */
@keyframes pulse     { 0%,100% { opacity:1; } 50% { opacity:0.7; } }
@keyframes shimmer   { 0% { background-position:200% 0; } 100% { background-position:-200% 0; } }
@keyframes slideDown { from { transform:translateY(-10px); opacity:0; } to { transform:translateY(0); opacity:1; } }
@keyframes fadeIn    { from { opacity:0; } to { opacity:1; } }
