.card-swap-container {
  position: relative;
  width: 100%;
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-2xl) 0;
}

.card-swap-wrapper {
  position: relative;
  width: 100%;
  max-width: 480px;
}

.card-swap-stack {
  position: relative;
  width: 100%;
  height: 380px;
}

.card-swap-card {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--r-xl, 16px);
  background: var(--surface-1, #ffffff);
  border: 1px solid var(--hairline-soft, #e8e4dd);
  box-shadow: var(--shadow-lg, 0 8px 32px rgba(26,26,24,0.08));
  overflow: hidden;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1), 
              opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform, opacity;
}

.card-swap-card[data-position="active"] {
  transform: translateX(0) scale(1) rotate(0deg);
  opacity: 1;
}

.card-swap-card[data-position="next"] {
  transform: translateX(24px) scale(0.95) rotate(2deg);
  opacity: 0.6;
}

.card-swap-card[data-position="prev"] {
  transform: translateX(-24px) scale(0.95) rotate(-2deg);
  opacity: 0.6;
}

.card-swap-card[data-position="hidden"] {
  transform: translateX(0) scale(0.9) rotate(0deg);
  opacity: 0;
  pointer-events: none;
}

.card-swap-card-inner {
  padding: var(--sp-xl, 32px);
  height: 100%;
  display: flex;
  flex-direction: column;
}

.card-swap-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--r-lg, 12px);
  background: var(--accent-soft, rgba(232, 93, 38, 0.08));
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-lg, 24px);
  color: var(--accent, #e85d26);
}

.card-swap-icon svg {
  width: 24px;
  height: 24px;
}

.card-swap-title {
  font-family: var(--font-display, 'Playfair Display', serif);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--ink, #1a1a18);
  margin: 0 0 var(--sp-md, 16px) 0;
  letter-spacing: -0.01em;
}

.card-swap-items {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-xs, 8px);
  flex: 1;
  align-content: flex-start;
}

.card-swap-item {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: var(--r-pill, 9999px);
  background: var(--surface-2, #f0ece6);
  color: var(--ink-muted, #6b6860);
  font-size: 0.85rem;
  font-family: var(--font-mono, 'JetBrains Mono', monospace);
  font-weight: 400;
  letter-spacing: 0;
  transition: background 0.2s, color 0.2s;
}

.card-swap-card[data-position="active"] .card-swap-item {
  background: var(--surface-2, #f0ece6);
  color: var(--ink, #1a1a18);
}

.card-swap-indicators {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: var(--sp-lg, 24px);
}

.card-swap-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: var(--hairline, #d8d3cb);
  cursor: pointer;
  padding: 0;
  transition: background 0.3s, transform 0.3s;
}

.card-swap-dot:hover {
  background: var(--ink-tertiary, #a8a49e);
  transform: scale(1.2);
}

.card-swap-dot.active {
  background: var(--accent, #e85d26);
  transform: scale(1.3);
}

@media (max-width: 768px) {
  .card-swap-stack {
    height: 340px;
  }

  .card-swap-card-inner {
    padding: var(--sp-lg, 24px);
  }

  .card-swap-title {
    font-size: 1.25rem;
  }
}
