/**
 * WP Notify Pro — Frontend Forms CSS
 * All styles use high-specificity to prevent theme override.
 */

/* ── CSS Variables ──────────────────────────────────────────────────────── */
.wpnp-form-wrap,
.wpnp-soft-ask,
#wpnp-popup-overlay {
    --wpnp-primary:       #4F46E5;
    --wpnp-primary-dark:  #3730A3;
    --wpnp-bg:            #FFFFFF;
    --wpnp-border:        #E5E7EB;
    --wpnp-text:          #111827;
    --wpnp-muted:         #6B7280;
    --wpnp-radius:        8px;
    --wpnp-font:          -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    --wpnp-shadow:        0 20px 60px rgba(0,0,0,0.3), 0 4px 16px rgba(0,0,0,0.15);
    color-scheme:         light;
}

/* ── Base reset — all our elements ─────────────────────────────────────── */
.wpnp-form-wrap * {
    box-sizing: border-box !important;
    font-family: var(--wpnp-font) !important;
}

/* ── Overlay backdrop ───────────────────────────────────────────────────── */
#wpnp-popup-overlay {
    display: none;
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.6) !important;
    z-index: 999998 !important;
    backdrop-filter: blur(2px);
}
#wpnp-popup-overlay.wpnp-overlay--visible { display: block !important; }

/* ── INLINE form ────────────────────────────────────────────────────────── */
.wpnp-form-wrap.wpnp-form--inline {
    display: none;
    max-width: 560px;
    width: 100%;
}
.wpnp-form-wrap.wpnp-form--inline.wpnp-form-wrap--visible {
    display: block !important;
}
.wpnp-form--inline .wpnp-form-inner {
    background: #FFFFFF !important;
    border: 1px solid #E5E7EB !important;
    border-radius: 12px !important;
    padding: 28px 24px !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
}

/* ── POPUP form ─────────────────────────────────────────────────────────── */
.wpnp-form-wrap.wpnp-form--popup {
    display: none !important;
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 999999 !important;
    width: 92% !important;
    max-width: 460px !important;
    margin: 0 !important;
    padding: 0 !important;
}
.wpnp-form-wrap.wpnp-form--popup.wpnp-form-wrap--visible {
    display: block !important;
}
.wpnp-form--popup .wpnp-form-inner {
    background: #FFFFFF !important;
    border-radius: 16px !important;
    padding: 36px 32px !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.35), 0 4px 16px rgba(0,0,0,0.15) !important;
    position: relative !important;
    color: #111827 !important;
    opacity: 1 !important;
}

/* ── FLOATING BAR ───────────────────────────────────────────────────────── */
.wpnp-form-wrap.wpnp-form--floating_bar {
    display: none !important;
    position: fixed !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    z-index: 999999 !important;
    background: #4F46E5 !important;
    padding: 12px 20px !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.25) !important;
    margin: 0 !important;
}
.wpnp-form-wrap.wpnp-form--floating_bar.wpnp-form-wrap--visible {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}
.wpnp-form--floating_bar .wpnp-form {
    display: flex !important;
    align-items: center !important;
    flex: 1 !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}
.wpnp-form--floating_bar .wpnp-form__title {
    color: #FFFFFF !important;
    margin: 0 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}
.wpnp-form--floating_bar .wpnp-form input[type="email"],
.wpnp-form--floating_bar .wpnp-form input[type="text"] {
    background: rgba(255,255,255,0.18) !important;
    border-color: rgba(255,255,255,0.45) !important;
    color: #fff !important;
    flex: 1 !important;
    min-width: 180px !important;
}
.wpnp-form--floating_bar .wpnp-form input::placeholder { color: rgba(255,255,255,0.75) !important; }

/* ── Close button ───────────────────────────────────────────────────────── */
.wpnp-form-close {
    position: absolute !important;
    top: 10px !important; right: 14px !important;
    background: none !important;
    border: none !important;
    font-size: 22px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    color: #9CA3AF !important;
    padding: 4px 6px !important;
    z-index: 2 !important;
    border-radius: 50% !important;
    transition: background .15s, color .15s !important;
}
.wpnp-form-close:hover {
    color: #374151 !important;
    background: #F3F4F6 !important;
}

/* ── Title & Description ────────────────────────────────────────────────── */
.wpnp-form__title {
    margin: 0 0 8px 0 !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    color: #111827 !important;
}
.wpnp-form__desc {
    margin: 0 0 20px 0 !important;
    color: #6B7280 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

/* ── Inputs ─────────────────────────────────────────────────────────────── */
.wpnp-form input[type="email"],
.wpnp-form input[type="text"] {
    width: 100% !important;
    padding: 11px 14px !important;
    border: 1.5px solid #D1D5DB !important;
    border-radius: var(--wpnp-radius) !important;
    font-size: 15px !important;
    color: #111827 !important;
    background: #FFFFFF !important;
    outline: none !important;
    -webkit-appearance: none !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05) !important;
    transition: border-color .15s, box-shadow .15s !important;
}
.wpnp-form input[type="email"]:focus,
.wpnp-form input[type="text"]:focus {
    border-color: #4F46E5 !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,0.15) !important;
}

/* ── Form row (email + button side by side) ─────────────────────────────── */
.wpnp-form__row {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    align-items: stretch !important;
}
.wpnp-form__row input[type="email"] { flex: 1 !important; min-width: 0 !important; }
.wpnp-form__field { margin-bottom: 12px !important; }

/* ── GDPR checkbox ──────────────────────────────────────────────────────── */
.wpnp-form__field--gdpr { margin-top: 12px !important; }
.wpnp-form__field--gdpr label {
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
    font-size: 12px !important;
    color: #6B7280 !important;
    cursor: pointer !important;
    font-weight: 400 !important;
}
.wpnp-form__field--gdpr input[type="checkbox"] {
    margin-top: 2px !important;
    flex-shrink: 0 !important;
    accent-color: #4F46E5 !important;
    width: 14px !important; height: 14px !important;
}

/* ── Submit button ──────────────────────────────────────────────────────── */
.wpnp-form__submit {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 11px 24px !important;
    background: #4F46E5 !important;
    color: #FFFFFF !important;
    border: none !important;
    border-radius: var(--wpnp-radius) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: background .15s !important;
    box-shadow: 0 1px 3px rgba(79,70,229,0.3) !important;
}
.wpnp-form__submit:hover:not(:disabled) { background: #3730A3 !important; }
.wpnp-form__submit:active:not(:disabled) { transform: scale(0.98) !important; }
.wpnp-form__submit:disabled { opacity: 0.6 !important; cursor: default !important; }

/* ── Message ────────────────────────────────────────────────────────────── */
.wpnp-form__message {
    margin-top: 12px !important;
    padding: 10px 14px !important;
    border-radius: var(--wpnp-radius) !important;
    font-size: 13px !important;
}
.wpnp-form__message--success {
    background: #ECFDF5 !important;
    color: #065F46 !important;
    border: 1px solid #A7F3D0 !important;
}
.wpnp-form__message--error {
    background: #FEF2F2 !important;
    color: #991B1B !important;
    border: 1px solid #FECACA !important;
}

/* ── Branding ───────────────────────────────────────────────────────────── */
.wpnp-form__branding {
    display: block !important;
    text-align: center !important;
    margin-top: 14px !important;
    font-size: 11px !important;
    color: #D1D5DB !important;
}
.wpnp-form__branding a { color: #D1D5DB !important; text-decoration: none !important; }

/* ── PUSH soft-ask popup (bottom-right corner) ──────────────────────────── */
.wpnp-soft-ask {
    position: fixed !important;
    bottom: 24px !important;
    right: 24px !important;
    z-index: 9999999 !important;
    background: #FFFFFF !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.25), 0 4px 16px rgba(0,0,0,0.12) !important;
    width: 300px !important;
    border: 1px solid #E5E7EB !important;
    transform: translateY(140%) !important;
    transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
    visibility: hidden !important;
    color: #111827 !important;
}
.wpnp-soft-ask.wpnp-soft-ask--visible {
    transform: translateY(0) !important;
    visibility: visible !important;
}
.wpnp-soft-ask__inner { padding: 20px !important; }
.wpnp-soft-ask__icon { font-size: 32px !important; margin-bottom: 10px !important; line-height: 1 !important; }
.wpnp-soft-ask__title {
    display: block !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    margin-bottom: 6px !important;
    color: #111827 !important;
}
.wpnp-soft-ask__text {
    font-size: 13px !important;
    color: #6B7280 !important;
    margin: 0 0 16px !important;
    line-height: 1.5 !important;
}
.wpnp-soft-ask__actions { display: flex !important; gap: 8px !important; }
.wpnp-soft-ask__btn {
    flex: 1 !important;
    padding: 10px 0 !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    border: none !important;
    transition: background .15s !important;
}
.wpnp-soft-ask__btn--allow { background: #4F46E5 !important; color: #FFFFFF !important; }
.wpnp-soft-ask__btn--allow:hover { background: #3730A3 !important; }
.wpnp-soft-ask__btn--deny { background: #F3F4F6 !important; color: #6B7280 !important; }
.wpnp-soft-ask__btn--deny:hover { background: #E5E7EB !important; }

/* ── Push button shortcode ──────────────────────────────────────────────── */
.wpnp-push-btn {
    display: inline-block !important;
    padding: 11px 24px !important;
    border-radius: var(--wpnp-radius) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    border: none !important;
    transition: background .15s !important;
    text-decoration: none !important;
}
.wpnp-push-btn--primary { background: #4F46E5 !important; color: #FFFFFF !important; }
.wpnp-push-btn--primary:hover { background: #3730A3 !important; }
.wpnp-push-btn--outline { background: transparent !important; color: #4F46E5 !important; border: 2px solid #4F46E5 !important; }
.wpnp-push-btn--outline:hover { background: #4F46E5 !important; color: #FFFFFF !important; }

/* ── Sidebar / Widget forms — always visible, no JS needed ─────────────── */
/* .wpnp-widget-form class is added by the PHP widget directly */
.wpnp-widget-form,
.widget-wpnp-subscribe .wpnp-form-wrap,
.widget-wpnp-subscribe .wpnp-form-wrap.wpnp-form--inline {
    display: block !important;
    max-width: 100% !important;
}
.widget-wpnp-subscribe .wpnp-form--inline .wpnp-form-inner,
.wpnp-widget-form .wpnp-form-inner {
    padding: 16px !important;
    border-radius: 8px !important;
}

/* ── Mobile ─────────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
    .wpnp-form-wrap.wpnp-form--popup { width: 95% !important; }
    .wpnp-form--popup .wpnp-form-inner { padding: 24px 20px !important; }
    .wpnp-form__row { flex-direction: column !important; }
    .wpnp-soft-ask { width: calc(100vw - 32px) !important; right: 16px !important; bottom: 16px !important; }
}
