/* ==========================================================================
   Module: Button — Mitsubishi Đồng Nai
   BEM: .btn, .btn--*, .btn__*
   Phụ thuộc: variables.css
   ========================================================================== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  height: var(--btn-height-md);
  padding-inline: var(--btn-padding-x);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-radius: var(--radius-sm);
  border: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition:
    background var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    transform var(--transition-fast);
}

.btn:active {
  transform: translateY(1px);
}

/* ===== VARIANTS ===== */

/* Primary — Đỏ Mitsubishi */
.btn--primary {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}
.btn--primary:hover {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
  box-shadow: var(--shadow-primary);
  transform: translateY(-2px);
}

/* Secondary — Viền Gold */
.btn--secondary {
  background: transparent;
  color: var(--color-gold);
  border-color: var(--color-gold);
}
.btn--secondary:hover {
  background: var(--color-gold);
  color: var(--color-black);
  box-shadow: var(--shadow-gold);
  transform: translateY(-2px);
}

/* Ghost — Viền trắng */
.btn--ghost {
  background: transparent;
  color: var(--color-white);
  border-color: rgba(255,255,255,0.4);
}
.btn--ghost:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--color-white);
}

/* Dark — Nền tối */
.btn--dark {
  background: var(--color-dark-3);
  color: var(--color-text-primary);
  border-color: var(--color-dark-3);
}
.btn--dark:hover {
  background: var(--color-dark-4);
  border-color: var(--color-dark-4);
}

/* ===== SIZES ===== */
.btn--sm {
  height: var(--btn-height-sm);
  padding-inline: 1.25rem;
  font-size: var(--text-xs);
}

.btn--lg {
  height: var(--btn-height-lg);
  padding-inline: 2.5rem;
  font-size: var(--text-base);
}

/* ===== MODIFIERS ===== */
.btn--full   { width: 100%; }
.btn--round  { border-radius: var(--radius-full); }
.btn--icon   { padding-inline: var(--space-3); width: var(--btn-height-md); }

/* Loading state */
.btn--loading {
  pointer-events: none;
  opacity: 0.7;
}
.btn--loading::after {
  content: '';
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: btn-spin 0.6s linear infinite;
}

@keyframes btn-spin {
  to { transform: rotate(360deg); }
}
/* View All Buttons (Home Sections) */
.btn--view-all {
  height: 46px;
  padding-inline: 2rem;
  border-radius: 50px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--color-white);
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  transition: all var(--transition-fast);
}

.btn--view-all:hover {
  background: var(--color-gold);
  border-color: var(--color-gold);
  color: var(--color-black);
  transform: translateY(-3px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3);
}

.btn--view-all svg {
  margin-left: 10px;
  transition: transform 0.3s ease;
}

.btn--view-all:hover svg {
  transform: translateX(5px);
}
