/* web/static/css/components/_button.css */

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--size-2); /* 8px */
    padding: 0 var(--size-4); /* 0 20px */
    height: calc(var(--size-7) + var(--size-1)); /* 36px to match inputs */
    border-radius: var(--radius-2);
    font-size: var(--font-size-1); /* 1rem */
    font-weight: var(--font-weight-5);
    border: 1px solid transparent;
    cursor: pointer;
    transition: background-color var(--transition-1), border-color var(--transition-1), color var(--transition-1), box-shadow var(--transition-1);
    white-space: nowrap;
    box-sizing: border-box;
}
.button svg {
    width: var(--size-4);
    height: var(--size-4);
    flex-shrink: 0; /* Prevent icon shrinking */
}
.button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Primary Button */
.button--primary {
    background-color: var(--button-primary-bg);
    color: var(--button-primary-text);
    border-color: var(--button-primary-bg);
}
.button--primary:not(:disabled):hover {
    background-color: var(--button-primary-hover-bg);
    border-color: var(--button-primary-hover-bg);
    color: var(--button-primary-text);
}
.button--primary:focus-visible {
    outline: none; /* Use box-shadow for focus */
    box-shadow: 0 0 0 2px var(--surface-1), 0 0 0 4px var(--button-primary-bg);
}
.button--primary:disabled {
     background-color: var(--button-primary-bg); /* Keep color when disabled */
     border-color: var(--button-primary-bg);
     color: var(--button-primary-text);
}

/* Secondary Button */
.button--secondary {
    background-color: var(--button-secondary-bg);
    color: var(--button-secondary-text);
    border-color: var(--button-secondary-border);
    box-shadow: var(--shadow-1); /* Add subtle shadow */
}
.button--secondary:not(:disabled):hover {
    background-color: var(--button-secondary-hover-bg);
    border-color: var(--surface-3);
    color: var(--button-secondary-hover-text);
}
.button--secondary:focus-visible {
    outline: none;
    border-color: var(--brand);
    box-shadow: 0 0 0 2px var(--surface-1), 0 0 0 4px var(--brand);
}
.button--secondary:disabled {
     background-color: var(--button-secondary-bg);
     border-color: var(--button-secondary-border);
     color: var(--button-secondary-text);
     box-shadow: var(--shadow-1);
}


/* Danger Button */
.button--danger {
    background-color: var(--danger-soft);
    color: var(--danger-color);
    border-color: var(--danger-soft);
}
.button--danger:not(:disabled):hover {
    background-color: hsl(var(--red-1-hsl) / 0.8);
    border-color: hsl(var(--red-1-hsl) / 0.8);
    color: var(--red-7);
}
[data-theme="dark"] .button--danger {
    background-color: var(--danger-soft);
    color: var(--danger-color);
    border-color: var(--danger-soft);
}
[data-theme="dark"] .button--danger:not(:disabled):hover {
    background-color: hsl(var(--red-9-hsl) / 0.4);
    border-color: hsl(var(--red-9-hsl) / 0.4);
    color: var(--red-4);
}
.button--danger:focus-visible {
    outline: none;
    border-color: var(--danger-color);
    box-shadow: 0 0 0 2px var(--surface-1), 0 0 0 4px var(--danger-color);
}
.button--danger:disabled {
    background-color: var(--danger-soft);
    border-color: var(--danger-soft);
    color: var(--danger-color);
}

/* Tertiary Button (Link-like) */
.button--tertiary {
    background: none;
    border: none;
    color: var(--button-tertiary-text);
    padding: var(--size-1) var(--size-2); /* Minimal padding */
    font-weight: var(--font-weight-5);
    height: auto; /* Allow height to adjust */
}
.button--tertiary:not(:disabled):hover {
    color: var(--button-tertiary-hover-text);
    background-color: var(--surface-2);
}
.button--tertiary:focus-visible {
    outline: none;
    background-color: var(--surface-2);
    box-shadow: 0 0 0 2px var(--surface-1), 0 0 0 4px var(--brand);
}
.button--tertiary:disabled {
    color: var(--button-tertiary-text);
}

