/* ==========================================================================
   BUTTON SHORTCODE
   ========================================================================== */

.oe-button {
    display: inline-block;
    font-weight: 600;
    text-decoration: none;
    border-radius: 6px;
    text-align: center;
    cursor: pointer;
    transition: background 0.15s, color 0.15s, border-color 0.15s, box-shadow 0.15s;
    line-height: 1.4;
}

/* Sizes */
.oe-button--sm {
    padding: 6px 14px;
    font-size: 12px;
}

.oe-button--md {
    padding: 10px 22px;
    font-size: 14px;
}

.oe-button--lg {
    padding: 14px 32px;
    font-size: 16px;
}

/* Primary (filled green) */
.oe-button--primary {
    background: var(--oe-color-primary);
    color: var(--oe-color-white);
    border: 2px solid var(--oe-color-primary);
}

.oe-button--primary:hover,
.oe-button--primary:focus {
    background: var(--oe-color-primary-dark);
    border-color: var(--oe-color-primary-dark);
    color: var(--oe-color-white);
}

.oe-button--primary:visited {
    color: var(--oe-color-white);
}

/* Ghost (transparent with border) */
.oe-button--ghost {
    background: transparent;
    color: var(--oe-color-primary);
    border: 2px solid var(--oe-color-primary);
}

.oe-button--ghost:hover,
.oe-button--ghost:focus {
    background: var(--oe-color-primary);
    color: var(--oe-color-white);
}

.oe-button--ghost:visited {
    color: var(--oe-color-primary);
}

.oe-button--ghost:hover:visited {
    color: var(--oe-color-white);
}

/* Outline (subtle border, no fill) */
.oe-button--outline {
    background: transparent;
    color: var(--oe-color-text-dark);
    border: 2px solid var(--oe-color-border);
}

.oe-button--outline:hover,
.oe-button--outline:focus {
    border-color: var(--oe-color-primary);
    color: var(--oe-color-primary);
}

.oe-button--outline:visited {
    color: var(--oe-color-text-dark);
}
