/**
 * CockpitOS Light Theme - Buttons
 * 
 * Verantwortlichkeit: Button-Styles
 * Wiederverwendbare Button-Komponenten
 * 
 * @package CockpitOS_Light_Theme
 * @version 1.0.0
 */

/* Base Button */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    line-height: var(--line-height-normal);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast);
    cursor: pointer;
    border: none;
    text-decoration: none;
}

.btn:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* Button Variants */
.btn-primary {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.btn-primary:hover {
    background-color: var(--color-primary-dark);
}

.btn-secondary {
    background-color: var(--color-secondary);
    color: var(--color-white);
}

.btn-secondary:hover {
    background-color: var(--color-secondary-dark);
}

.btn-outline {
    background-color: transparent;
    border: 2px solid var(--color-primary);
    color: var(--color-primary);
}

.btn-outline:hover {
    background-color: var(--color-primary);
    color: var(--color-white);
}

/* Button Sizes */
.btn-sm {
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
}

.btn-lg {
    padding: var(--spacing-md) var(--spacing-xl);
    font-size: var(--font-size-lg);
}

/* Button States */
.btn:disabled,
.btn.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Button with Icon */
.btn-icon {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.btn-icon svg,
.btn-icon i {
    width: 1em;
    height: 1em;
}

/* Link Button (Text-only) */
.btn-link {
    background: none;
    border: none;
    color: var(--color-primary);
    padding: 0;
    text-decoration: underline;
}

.btn-link:hover {
    color: var(--color-primary-dark);
}

/* Widget Button Classes (für Elementor Widgets) */
.widget-button,
.cockpit-content-grid__button,
.cockpit-cta__button,
.cockpit-intro__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 24px;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.5;
    border-radius: 8px;
    transition: all 0.3s ease;
    cursor: pointer;
    border: none;
    text-decoration: none;
    background-color: var(--color-primary);
    color: var(--color-white);
}

.widget-button:hover,
.cockpit-content-grid__button:hover,
.cockpit-cta__button:hover,
.cockpit-intro__button:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(var(--color-primary-rgb, 218, 32, 50), 0.3);
}

/* CM-Immo Style Button (GLOBAL) */
.cm-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm, 0.5rem);
    padding: 1rem 2.5rem;
    font-family: var(--font-family-heading);
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.5;
    color: #ffffff;
    background-color: var(--color-secondary, #F25363);
    border: none;
    border-radius: var(--radius-full, 999px);
    text-decoration: none;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.cm-button:hover {
    background-color: var(--color-secondary-dark, #e03041);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

.cm-button:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.cm-button--primary {
    background-color: var(--color-primary, #da2032);
}

.cm-button--primary:hover {
    background-color: var(--color-primary-dark, #b11a29);
}

.cm-button--outline {
    background-color: transparent;
    border: 2px solid var(--color-secondary, #F25363);
    color: var(--color-secondary, #F25363);
}

.cm-button--outline:hover {
    background-color: var(--color-secondary, #F25363);
    color: #ffffff;
}

.cm-button--large {
    padding: 1.25rem 3rem;
    font-size: 1.25rem;
}

.cm-button--small {
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
}

/* Widget Button Variants */
.widget-button--outline {
    background-color: transparent;
    border: 2px solid var(--color-primary);
    color: var(--color-primary);
}

.widget-button--outline:hover {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.widget-button--secondary {
    background-color: var(--color-gray-800);
    color: var(--color-white);
}

.widget-button--secondary:hover {
    background-color: var(--color-gray-900);
}

