/* =====================================================================
 *  STRYV CONTACT FORMS — STYLES
 *  Minimal, theme-friendly. Override via the --scf-form-* custom
 *  properties on .stryv-form (or any ancestor) to restyle.
 * ===================================================================== */

/* ===== ROOT & VARIABLES ===== */

/* CodeNumber 1.1 */
.stryv-form {
    --scf-bg:               var(--scf-form-bg, transparent);
    --scf-fg:               var(--scf-form-fg, inherit);
    --scf-border:           var(--scf-form-border, #ccc);
    --scf-border-focus:     var(--scf-form-border-focus, #2271b1);
    --scf-error:            var(--scf-form-error, #b00020);
    --scf-success-bg:       var(--scf-form-success-bg, #e7f6ee);
    --scf-success-fg:       var(--scf-form-success-fg, #0a5d33);
    --scf-radius:           var(--scf-form-radius, 4px);
    --scf-spacing:          var(--scf-form-spacing, 16px);
    --scf-button-bg:        var(--scf-form-button-bg, #1a1a1a);
    --scf-button-fg:        var(--scf-form-button-fg, #fff);
    --scf-button-bg-hover:  var(--scf-form-button-bg-hover, #333);
    color: var(--scf-fg);
    background: var(--scf-bg);
    max-width: 640px;
    position: relative;
}

/* ===== ROWS & LABELS ===== */

/* CodeNumber 2.1 */
.stryv-form__row {
    margin-bottom: var(--scf-spacing);
}
.stryv-form__row--submit {
    margin-top: calc(var(--scf-spacing) * 1.5);
}

/* CodeNumber 2.2 */
.stryv-form__label {
    display: block;
    margin-bottom: 6px;
    font-weight: 600;
    font-size: 14px;
    line-height: 1.4;
}
.stryv-form__req {
    color: var(--scf-error);
    margin-left: 2px;
}
.stryv-form__help {
    margin: 4px 0 0;
    font-size: 12px;
    color: #666;
    line-height: 1.4;
}

/* ===== INPUTS ===== */

/* CodeNumber 3.1 */
.stryv-form input[type="text"],
.stryv-form input[type="email"],
.stryv-form input[type="tel"],
.stryv-form input[type="url"],
.stryv-form textarea,
.stryv-form select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--scf-border);
    border-radius: var(--scf-radius);
    background: #fff;
    color: inherit;
    font: inherit;
    line-height: 1.4;
    box-sizing: border-box;
}
.stryv-form input:focus,
.stryv-form textarea:focus,
.stryv-form select:focus {
    border-color: var(--scf-border-focus);
    outline: 2px solid color-mix(in srgb, var(--scf-border-focus) 25%, transparent);
    outline-offset: 0;
}
.stryv-form textarea {
    resize: vertical;
    min-height: 120px;
}

/* ===== RADIO & CHECKBOX ===== */

/* CodeNumber 4.1 */
.stryv-form__radios,
.stryv-form__checks {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.stryv-form__radio,
.stryv-form__check,
.stryv-form__checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 14px;
    line-height: 1.4;
}
.stryv-form__radio input,
.stryv-form__check input,
.stryv-form__checkbox input {
    margin: 0;
    flex-shrink: 0;
}

/* ===== ERRORS ===== */

/* CodeNumber 5.1 */
.stryv-form__row--error input[type="text"],
.stryv-form__row--error input[type="email"],
.stryv-form__row--error input[type="tel"],
.stryv-form__row--error input[type="url"],
.stryv-form__row--error textarea,
.stryv-form__row--error select {
    border-color: var(--scf-error);
}
.stryv-form__error {
    margin: 6px 0 0;
    font-size: 13px;
    color: var(--scf-error);
    line-height: 1.4;
}

/* ===== SUBMIT BUTTON ===== */

/* CodeNumber 6.1 */
.stryv-form__submit {
    background: var(--scf-button-bg);
    color: var(--scf-button-fg);
    border: 0;
    padding: 12px 24px;
    border-radius: var(--scf-radius);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    line-height: 1.2;
    transition: background-color .15s ease;
}
.stryv-form__submit:hover {
    background: var(--scf-button-bg-hover);
}
.stryv-form--busy .stryv-form__submit {
    opacity: .7;
    cursor: wait;
}
.stryv-form__submit:disabled {
    cursor: not-allowed;
}

/* ===== STATUS & SUCCESS ===== */

/* CodeNumber 7.1 */
.stryv-form__status {
    margin-top: 12px;
    font-size: 14px;
    line-height: 1.4;
    min-height: 1.4em;
}
.stryv-form__status--error {
    color: var(--scf-error);
}

/* CodeNumber 7.2 */
.stryv-form__success {
    padding: 16px 20px;
    background: var(--scf-success-bg);
    color: var(--scf-success-fg);
    border-radius: var(--scf-radius);
    font-size: 15px;
    line-height: 1.5;
    max-width: 640px;
}

/* ===== HONEYPOT (visually hidden) ===== */

/* CodeNumber 8.1 */
.stryv-form__hp {
    position: absolute !important;
    left: -9999px !important;
    top: auto !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}
