/**
 * Formularz zapisu na webinar – styl minimalistyczny, neutralny pod WordPress.
 * Można nadpisać zmienne CSS w motywie (--webinar-*) dla dopasowania do strony.
 */

.webinar-form-body {
    margin: 0;
    font-family: var(--webinar-font, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, "Helvetica Neue", sans-serif);
    font-size: var(--webinar-font-size, 1rem);
    line-height: 1.5;
    color: var(--webinar-text, #1a1a1a);
    background: var(--webinar-bg, #fff);
}

.webinar-form-wrapper {
    max-width: 420px;
    margin: 0 auto;
    padding: var(--webinar-wrapper-padding, 1.5rem);
}

.webinar-form-success {
    padding: 1.25rem 1rem;
    background: var(--webinar-success-bg, #e8f5e9);
    color: var(--webinar-success-text, #2e7d32);
    border-radius: 6px;
    text-align: center;
}

.webinar-form-success p {
    margin: 0;
}

.webinar-form-error {
    margin: 0 0 1rem;
    padding: 0.75rem 1rem;
    background: var(--webinar-error-bg, #ffebee);
    color: var(--webinar-error-text, #c62828);
    border-radius: 6px;
    font-size: 0.9375rem;
}

.webinar-form {
    display: flex;
    flex-direction: column;
    gap: 1.125rem;
}

.webinar-form-row {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.webinar-form-label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--webinar-label, #374151);
}

.webinar-form-label .required {
    color: var(--webinar-required, #b91c1c);
}

.webinar-form-input,
.webinar-form-select {
    width: 100%;
    min-height: 2.75rem;
    padding: 0.6rem 0.75rem;
    font: inherit;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--webinar-input-text, #111);
    background: var(--webinar-input-bg, #fff);
    border: 1px solid var(--webinar-input-border, #d1d5db);
    border-radius: 6px;
    box-sizing: border-box;
    transition: border-color 0.15s ease;
}

.webinar-form-input:focus,
.webinar-form-select:focus {
    outline: none;
    border-color: var(--webinar-input-focus, #2563eb);
}

.webinar-form-input::placeholder {
    color: var(--webinar-placeholder, #9ca3af);
}

.webinar-form-select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23374151' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    padding-right: 2.25rem;
}

.webinar-form-row-checkbox {
    gap: 0.5rem;
}

.webinar-form-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    cursor: pointer;
    font-size: 0.9375rem;
    color: var(--webinar-label, #374151);
}

.webinar-form-checkbox-label input[type="checkbox"] {
    margin: 0.25rem 0 0;
    width: 1.125rem;
    height: 1.125rem;
    flex-shrink: 0;
    accent-color: var(--webinar-accent, #2563eb);
}

.webinar-form-checkbox-label .required {
    color: var(--webinar-required, #b91c1c);
}

.webinar-form-submit {
    margin-top: 0.25rem;
}

.webinar-form-submit-btn {
    width: 100%;
    padding: 0.75rem 1.25rem;
    font: inherit;
    font-size: 1rem;
    font-weight: 500;
    color: var(--webinar-btn-text, #fff);
    background: var(--webinar-btn-bg, #2563eb);
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: background-color 0.15s ease, opacity 0.15s ease;
}

.webinar-form-submit-btn:hover {
    background: var(--webinar-btn-hover, #1d4ed8);
}

.webinar-form-submit-btn:focus {
    outline: none;
    box-shadow: 0 0 0 2px var(--webinar-input-bg, #fff), 0 0 0 4px var(--webinar-btn-bg, #2563eb);
}

.webinar-form-submit-btn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

/* W kontekście WordPress (np. w treści strony) – brak full-page body */
#webinar-form-wrapper .webinar-form-success,
#webinar-form-wrapper .webinar-form-error,
#webinar-form-wrapper .webinar-form {
    margin-top: 0;
}
