/**
 * GBN Email Campaign — Subscribe Base Styles
 *
 * Shared elements used by ALL popup and form style variants:
 * form fields, submit button, result messages, and the
 * unsubscribe / subscription-confirm action pages.
 *
 * Popup overlay and inline form wrapper styles live in their own
 * per-style files (gbn-ec-popup-{style}.css / gbn-ec-form-{style}.css),
 * selected in Settings → General.
 */

:root {
    --gbn-ec-sub-primary:       #2271b1;
    --gbn-ec-sub-primary-hover: #135e96;
    --gbn-ec-sub-bg:            #fff;
    --gbn-ec-sub-text:          #1d2327;
    --gbn-ec-sub-muted:         #646970;
    --gbn-ec-sub-border:        #dcdcde;
    --gbn-ec-sub-success-bg:    #dff0d8;
    --gbn-ec-sub-success-text:  #3a7c42;
    --gbn-ec-sub-error-bg:      #fde8e8;
    --gbn-ec-sub-error-text:    #b32d2e;
    --gbn-ec-sub-radius:        6px;
}

/* ── Shared Typography ──────────────────────────────────────────────────── */

.gbn-ec-subscribe-heading {
    margin: 0 0 6px;
    font-size: 1.25em;
    color: var(--gbn-ec-sub-text);
}

.gbn-ec-subscribe-subhead {
    margin: 0 0 18px;
    color: var(--gbn-ec-sub-muted);
    font-size: 0.9em;
}

/* ── Form Fields ──────────────────────────────────────────────────────── */

.gbn-ec-form-row {
    margin-bottom: 12px;
}

.gbn-ec-sub-input {
    display: block;
    width: 100%;
    padding: 9px 12px;
    font-size: 14px;
    border: 1px solid var(--gbn-ec-sub-border);
    border-radius: 4px;
    background: #fff;
    color: var(--gbn-ec-sub-text);
    box-sizing: border-box;
    transition: border-color 0.15s;
}

.gbn-ec-sub-input:focus {
    border-color: var(--gbn-ec-sub-primary);
    outline: 2px solid transparent;
    box-shadow: 0 0 0 2px rgba(34, 113, 177, 0.25);
}

/* ── Submit Button ──────────────────────────────────────────────────────── */

.gbn-ec-sub-btn {
    display: block;
    width: 100%;
    padding: 10px 16px;
    background: var(--gbn-ec-sub-primary);
    color: #fff;
    border: none;
    border-radius: 4px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s;
}

.gbn-ec-sub-btn:hover:not(:disabled) {
    background: var(--gbn-ec-sub-primary-hover);
}

.gbn-ec-sub-btn:disabled {
    opacity: 0.7;
    cursor: wait;
}

/* ── Result Messages ────────────────────────────────────────────────────── */

.gbn-ec-sub-msg {
    margin-top: 10px;
    padding: 8px 12px;
    border-radius: 4px;
    font-size: 13px;
}

.gbn-ec-sub-msg--success {
    background: var(--gbn-ec-sub-success-bg);
    color: var(--gbn-ec-sub-success-text);
}

.gbn-ec-sub-msg--error {
    background: var(--gbn-ec-sub-error-bg);
    color: var(--gbn-ec-sub-error-text);
}

/* ── Unsubscribe / Confirmation Page ────────────────────────────────────── */

.gbn-ec-action-box {
    padding: 24px;
    border: 1px solid var(--gbn-ec-sub-border);
    border-radius: var(--gbn-ec-sub-radius);
    background: var(--gbn-ec-sub-bg);
}

.gbn-ec-action-success {
    border-color: #3a7c42;
    background: var(--gbn-ec-sub-success-bg);
    color: var(--gbn-ec-sub-success-text);
}

.gbn-ec-action-error {
    border-color: #b32d2e;
    background: var(--gbn-ec-sub-error-bg);
    color: var(--gbn-ec-sub-error-text);
}

.gbn-ec-action-box h2 {
    margin-top: 0;
}
