/**
 * BUTTON COMPONENT - Simplified & Corrected
 * Based on reference: UI-modernization_documents/financial_dashboard
 * Date: November 12, 2025 - 7:15 PM
 */

/* ==========================================================================
   BASE BUTTON STYLES
   ========================================================================== */

.ds-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 0.875rem;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  
  cursor: pointer;
  user-select: none;
  
  transition: var(--transition-button);
  
  border: none;
  outline: none;
  text-decoration: none;
  
  /* Default size - reduced for more compact UI */
  height: 34px;
  padding: 0 1.25rem;
  border-radius: var(--radius-button);
}

.ds-button:focus {
  outline: none;
}

/* ==========================================================================
   SIZE MODIFIERS
   ========================================================================== */

.ds-button[data-size="xs"] {
  height: 24px;
  padding: 0 0.625rem;
  font-size: 0.75rem;
}

.ds-button[data-size="sm"] {
  height: 28px;
  padding: 0 0.875rem;
  font-size: 0.8125rem;
}

.ds-button[data-size="md"] {
  height: 34px;
  padding: 0 1.125rem;
  font-size: 0.875rem;
}

.ds-button[data-size="lg"] {
  height: 40px;
  padding: 0 1.5rem;
  font-size: 0.9375rem;
}

.ds-button[data-size="xl"] {
  height: 46px;
  padding: 0 2rem;
  font-size: 1rem;
}

/* ==========================================================================
   VARIANT: PRIMARY
   ========================================================================== */

.ds-button[data-variant="primary"] {
  background-color: var(--accent-brown);  /* #8B6F47 Wooden Log Brown */
  color: #FFFFFF;
  border: none;
}

.ds-button[data-variant="primary"]:hover:not(:disabled) {
  opacity: 0.9;
}

.ds-button[data-variant="primary"]:active:not(:disabled) {
  opacity: 0.8;
}

[data-theme="imperial-gold"] .ds-button[data-variant="primary"] {
  background-color: var(--accent-blue);
  color: var(--bg-primary);
}

/* ==========================================================================
   VARIANT: SECONDARY (Outline)
   ========================================================================== */

.ds-button[data-variant="secondary"] {
  background-color: transparent;
  color: var(--text-primary);
  border: 1px solid var(--border-default);
}

.ds-button[data-variant="secondary"]:hover:not(:disabled) {
  background-color: var(--surface-hover);
  border-color: var(--accent-brown);  /* Wooden Log Brown border on hover */
}

/* ==========================================================================
   VARIANT: TERTIARY (Ghost)
   ========================================================================== */

.ds-button[data-variant="tertiary"] {
  background-color: transparent;
  color: var(--accent-brown);  /* Wooden Log Brown */
  border: none;
}

.ds-button[data-variant="tertiary"]:hover:not(:disabled) {
  background-color: var(--surface-hover);
}

/* ==========================================================================
   VARIANT: DANGER
   ========================================================================== */

.ds-button[data-variant="danger"] {
  background-color: var(--accent-red);
  color: #FFFFFF;
  border: none;
}

.ds-button[data-variant="danger"]:hover:not(:disabled) {
  opacity: 0.9;
}

[data-theme="imperial-gold"] .ds-button[data-variant="danger"] {
  color: var(--text-primary);
}

/* ==========================================================================
   VARIANT: SUCCESS
   ========================================================================== */

.ds-button[data-variant="success"] {
  background-color: var(--accent-green);
  color: #FFFFFF;
  border: none;
}

.ds-button[data-variant="success"]:hover:not(:disabled) {
  opacity: 0.9;
}

[data-theme="imperial-gold"] .ds-button[data-variant="success"] {
  color: var(--text-primary);
}

/* ==========================================================================
   VARIANT: WARNING
   ========================================================================== */

.ds-button[data-variant="warning"] {
  background-color: #F39C12;
  color: var(--bg-primary);
  border: none;
}

.ds-button[data-variant="warning"]:hover:not(:disabled) {
  opacity: 0.9;
}

/* ==========================================================================
   DISABLED STATE
   ========================================================================== */

.ds-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ==========================================================================
   FOCUS STYLES
   ========================================================================== */

.ds-button:focus-visible {
  outline: 2px solid var(--accent-blue);
  outline-offset: 2px;
}

/* ==========================================================================
   FULL WIDTH
   ========================================================================== */

.ds-button--fullwidth {
  width: 100%;
}

/* ==========================================================================
   ICON BUTTONS
   ========================================================================== */

.ds-button--icon-only {
  padding: 0;
  width: 40px;
  aspect-ratio: 1;
}

.ds-button--icon-only[data-size="sm"] {
  width: 32px;
}

.ds-button--icon-only[data-size="lg"] {
  width: 48px;
}
