/* ═══════════════════════════════════════════════════════════════════
   Logix Survey Form — Widget CSS  v1.0.2
   All rules scoped under .lsf-wrapper for theme override protection.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Tokens ──────────────────────────────────────────────────────── */
.lsf-wrapper {
    /* Primary — overridden by Elementor color picker via inline style */
    --lsf-primary:      #76b900;
    --lsf-primary-dk:   color-mix(in srgb, var(--lsf-primary) 80%, #000);
    --lsf-primary-lt:   color-mix(in srgb, var(--lsf-primary) 10%, #fff);
    --lsf-primary-ring: color-mix(in srgb, var(--lsf-primary) 30%, transparent);

    /* Neutrals */
    --lsf-border:    #e5e7eb;
    --lsf-border-h:  #d1d5db;
    --lsf-text:      #111827;
    --lsf-muted:     #6b7280;
    --lsf-light:     #9ca3af;
    --lsf-bg:        #ffffff;
    --lsf-bg-subtle: #f9fafb;

    /* Geometry */
    --lsf-radius:  3px;
    --lsf-shadow:  0 1px 2px rgba(0,0,0,.06);
    --lsf-t:       .15s ease;
}

/* ── Box-model reset ──────────────────────────────────────────────── */
.lsf-wrapper,
.lsf-wrapper * {
    box-sizing: border-box;
}

.lsf-wrapper .lsf-form {
    margin:  0;
    padding: 0;
}

/* ── Layout ──────────────────────────────────────────────────────── */
.lsf-wrapper .lsf-field {
    margin-bottom: 16px;
    position: relative;
}

.lsf-wrapper .lsf-field--pills {
    margin-bottom: 18px;
}

.lsf-wrapper .lsf-row {
    display: flex;
    gap: 14px;
    align-items: flex-end;  /* default: inputs share the same baseline */
}

.lsf-wrapper .lsf-row--align-start {
    align-items: stretch;  /* both columns same height so pills can fill */
}

.lsf-wrapper .lsf-row--three {
    flex-wrap: wrap;
}

@media (min-width: 768px) {
    .lsf-wrapper .lsf-row--three .lsf-field {
        flex: 1 1 30%;
    }
}

@media (max-width: 767px) {
    .lsf-wrapper .lsf-row--three .lsf-field {
        flex: 1 1 100%;
    }
}

.lsf-wrapper .lsf-row .lsf-field {
    flex: 1 1 0;
    min-width: 0;
}

/* ── Labels ──────────────────────────────────────────────────────── */
.lsf-wrapper .lsf-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #000000;
    margin-bottom: 7px;
    letter-spacing: .1px;
    line-height: 1.4;
    /* Override theme "screen-reader" or absolute tricks */
    position: static;
    clip: auto;
    clip-path: none;
    width: auto;
    height: auto;
    overflow: visible;
    white-space: normal;
}

.lsf-wrapper .lsf-req {
    color: var(--lsf-primary);
    margin-left: 2px;
    font-weight: 700;
}

.lsf-wrapper .lsf-optional {
    color: var(--lsf-light);
    font-weight: 400;
    font-size: .85em;
    margin-left: 3px;
}

/* Label row — label on the left, secondary text on the right */
.lsf-wrapper .lsf-label-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px;
    margin-bottom: 7px;
}

.lsf-wrapper .lsf-label-row .lsf-label {
    margin-bottom: 0;
}

.lsf-wrapper .lsf-label-row .lsf-optional {
    margin-left: 0;
    white-space: nowrap;
}

/* ── Intro text ──────────────────────────────────────────────────── */
.lsf-wrapper .lsf-intro-text {
    font-size: 13.5px;
    color: var(--lsf-muted);
    margin: 0 0 18px;
    line-height: 1.55;
    padding: 0;
}

/* ── Text inputs & textareas ─────────────────────────────────────── */
.lsf-wrapper input.lsf-input,
.lsf-wrapper textarea.lsf-textarea {
    display: block;
    width: 100%;
    padding: 10px 12px;
    border: 1.5px solid var(--lsf-border);
    border-radius: var(--lsf-radius);
    background: var(--lsf-bg-subtle);
    font-size: 14px;
    line-height: 1.5;
    color: var(--lsf-text);
    appearance: none;
    -webkit-appearance: none;
    transition: border-color var(--lsf-t), box-shadow var(--lsf-t);
    outline: none;
    box-shadow: none;
    font-family: inherit;
    margin: 0;
    max-width: 100%;
}

.lsf-wrapper input.lsf-input:hover,
.lsf-wrapper textarea.lsf-textarea:hover {
    border-color: var(--lsf-border-h);
}

.lsf-wrapper input.lsf-input:focus,
.lsf-wrapper textarea.lsf-textarea:focus {
    border-color: var(--lsf-primary);
    box-shadow: 0 0 0 3px var(--lsf-primary-ring);
    outline: none;
}

/* Phone field placeholder state - grey when only +1 */
.lsf-wrapper input.lsf-input.lsf-phone--empty {
    color: var(--lsf-light);
}

.lsf-wrapper input.lsf-input.lsf-phone--filled {
    color: var(--lsf-text);
}

.lsf-wrapper textarea.lsf-textarea {
    resize: vertical;
    min-height: 90px;
}

/* ── Selects ─────────────────────────────────────────────────────── */
.lsf-wrapper .lsf-select-wrap {
    position: relative;
}

.lsf-wrapper select.lsf-select {
    display: block;
    width: 100%;
    padding: 10px 34px 10px 12px;
    border: 1.5px solid var(--lsf-border);
    border-radius: var(--lsf-radius);
    background: var(--lsf-bg-subtle);
    font-size: 14px;
    line-height: 1.5;
    color: var(--lsf-text);
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: border-color var(--lsf-t), box-shadow var(--lsf-t);
    outline: none;
    font-family: inherit;
    margin: 0;
}

.lsf-wrapper select.lsf-select:hover {
    border-color: var(--lsf-border-h);
}

.lsf-wrapper select.lsf-select:focus {
    border-color: var(--lsf-primary);
    box-shadow: 0 0 0 3px var(--lsf-primary-ring);
    outline: none;
}

/* Placeholder state — same muted colour as text input ::placeholder */
.lsf-wrapper select.lsf-select.lsf-select--empty {
    color: var(--lsf-light);
}

/* Disabled state */
.lsf-wrapper .lsf-select-wrap--disabled {
    opacity: 0.5;
    pointer-events: none;
}

.lsf-wrapper .lsf-select-wrap--disabled select.lsf-select {
    cursor: not-allowed;
    background: var(--lsf-bg-subtle);
}

.lsf-wrapper .lsf-chevron {
    position: absolute;
    right: 11px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--lsf-muted);
    display: flex;
    align-items: center;
    line-height: 0;
    transition: color var(--lsf-t), transform var(--lsf-t);
}

.lsf-wrapper .lsf-select-wrap:focus-within .lsf-chevron {
    color: var(--lsf-primary);
    transform: translateY(-50%) rotate(180deg);
}

/* ── Combobox (custom searchable select) ─────────────────────────── */

/*
 * The native <select> is left in the DOM (tiny, invisible) for FormData.
 * The .lsf-select-wrap gains .lsf-combo--open when the list is visible.
 * The combo input inherits .lsf-input styles automatically.
 */

/* Combo text input — fills the wrap just like the native select did */
.lsf-wrapper .lsf-combo__input.lsf-input {
    width: 100%;
    padding-right: 34px;  /* room for chevron */
    cursor: pointer;
}

.lsf-wrapper .lsf-combo__input.lsf-input:focus {
    cursor: text;
}

/* Hide chevron when combo is open — replaced by × clear button */
.lsf-wrapper .lsf-select-wrap.lsf-combo--open .lsf-chevron {
    display: none;
}

/* Clear (×) button — only visible when the list is open */
.lsf-wrapper .lsf-combo__clear {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    display: none;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    padding: 0;
    border: none;
    background: none;
    border-radius: 50%;
    cursor: pointer;
    color: var(--lsf-muted);
    line-height: 0;
    z-index: 3;
    transition: color var(--lsf-t), background var(--lsf-t);
}

.lsf-wrapper .lsf-select-wrap.lsf-combo--open .lsf-combo__clear {
    display: flex;
}

.lsf-wrapper .lsf-combo__clear:hover {
    color: var(--lsf-text);
    background: #f3f4f6;
}

/* Dropdown list panel */
.lsf-wrapper .lsf-combo__list {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: var(--lsf-bg);
    border: none;
    border-radius: var(--lsf-radius);
    max-height: 220px;
    overflow-y: auto;
    overflow-x: hidden;
    z-index: 9999;
    padding: 4px 0;
    list-style: none;
    margin: 0;
    box-shadow: 0 6px 20px rgba(0,0,0,.12);
    animation: lsf-rise .14s ease;
}

.lsf-wrapper .lsf-select-wrap.lsf-combo--open .lsf-combo__list {
    display: block;
}

/* Individual option */
.lsf-wrapper .lsf-combo__item {
    padding: 9px 13px;
    font-size: 14px;
    color: var(--lsf-text);
    cursor: pointer;
    line-height: 1.4;
    transition: background var(--lsf-t), color var(--lsf-t);
    list-style: none;
}

.lsf-wrapper .lsf-combo__item:hover,
.lsf-wrapper .lsf-combo__item--active {
    background: #f3f4f6;
    color: var(--lsf-text);
}

.lsf-wrapper .lsf-combo__item--selected {
    font-weight: 600;
}

.lsf-wrapper .lsf-combo__item--selected::after {
    content: " \2713";
    color: var(--lsf-primary);
    font-size: .85em;
}

/* No-results row */
.lsf-wrapper .lsf-combo__empty {
    padding: 9px 13px;
    font-size: 13px;
    color: var(--lsf-light);
    font-style: italic;
    list-style: none;
    cursor: default;
}

/* Highlighted match text */
.lsf-wrapper .lsf-hl {
    background: none;
    color: var(--lsf-primary);
    font-weight: 700;
}

/* ── Pills (radio toggles) ────────────────────────────────────────── */
.lsf-wrapper .lsf-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}


/* Inline field: label and pills on one row */
.lsf-wrapper .lsf-field--inline {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.lsf-wrapper .lsf-field--inline .lsf-label {
    margin-bottom: 0;
    flex-shrink: 0;
    white-space: nowrap;
}

.lsf-wrapper .lsf-field--inline .lsf-pills {
    flex: 1;
}


/* Pill label element */
.lsf-wrapper .lsf-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 7px 16px;
    border: 1.5px solid var(--lsf-border);
    border-radius: var(--lsf-radius);
    cursor: pointer;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--lsf-muted);
    background: var(--lsf-bg);
    user-select: none;
    -webkit-user-select: none;
    transition: border-color var(--lsf-t), background var(--lsf-t), color var(--lsf-t);
    margin: 0;
    line-height: 1;
    position: relative;
}

/* Hide the native radio — zero-size absolute so it doesn't affect layout */
.lsf-wrapper .lsf-pill input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    margin: 0;
    padding: 0;
    pointer-events: none;
}

.lsf-wrapper .lsf-pill:hover {
    border-color: var(--lsf-primary);
    background: var(--lsf-primary-lt);
    color: var(--lsf-primary-dk);
}

/* Selected state — toggled by JS */
.lsf-wrapper .lsf-pill.lsf-pill--on {
    border-color: var(--lsf-primary);
    background: var(--lsf-primary);
    color: #fff;
}

.lsf-wrapper .lsf-pill.lsf-pill--on:hover {
    background: var(--lsf-primary-dk);
    border-color: var(--lsf-primary-dk);
}

.lsf-wrapper .lsf-pill:focus-within {
    box-shadow: 0 0 0 3px var(--lsf-primary-ring);
    border-color: var(--lsf-primary);
}

/* ── Contact-method pills: fill the row height ────────────────────── */
/* Pills container: exact height matching lsf-input (10+21+10+3 px), no wrap */
.lsf-wrapper [data-field="contact_method"] .lsf-pills {
    flex-wrap: nowrap;
    width: 100%;
    height: 44px;       /* rigid – container can't collapse */
    align-items: stretch;
    gap: 8px;
}

/* Each pill: block-level flex (overrides inline-flex), equal width,
   no vertical padding so the container's 44 px drives the height,
   text centred inside via align-items on the pill itself */
.lsf-wrapper [data-field="contact_method"] .lsf-pill {
    display: flex;
    flex: 1 1 0;
    min-width: 0;
    justify-content: center;
    align-items: center;
    padding-top: 0;
    padding-bottom: 0;
    align-self: stretch;    /* belt-and-suspenders: override any align-items from parent */
}

/* ── Drag-and-drop zone ───────────────────────────────────────────── */
.lsf-wrapper .lsf-dropzone {
    position: relative;
    border: 1.5px dashed var(--lsf-border);
    border-radius: var(--lsf-radius);
    background: var(--lsf-bg-subtle);
    padding: 14px 16px;
    min-height: 72px;
    display: flex;
    align-items: center;
    cursor: pointer;
    transition: border-color var(--lsf-t), background var(--lsf-t), box-shadow var(--lsf-t);
    outline: none;
    overflow: hidden;
}

.lsf-wrapper .lsf-dropzone:hover,
.lsf-wrapper .lsf-dropzone:focus-visible {
    border-color: var(--lsf-primary);
    background: var(--lsf-primary-lt);
    box-shadow: 0 0 0 3px var(--lsf-primary-ring);
}

.lsf-wrapper .lsf-dropzone.lsf-dz--over {
    border-color: var(--lsf-primary);
    background: var(--lsf-primary-lt);
    box-shadow: 0 0 0 4px var(--lsf-primary-ring);
}

/* Hidden file input - positioned off-screen, triggered via JS */
.lsf-wrapper .lsf-file-input {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    opacity: 0;
}

/* Idle state: icon + text side by side */
.lsf-wrapper .lsf-dz-idle {
    display: flex;
    align-items: center;
    gap: 14px;
    width: 100%;
    pointer-events: none;
}

.lsf-wrapper .lsf-dz-idle-text {
    flex: 1;
    min-width: 0;
    text-align: left;
}

.lsf-wrapper .lsf-dz-icon {
    color: var(--lsf-light);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    line-height: 0;
    transition: color var(--lsf-t);
}

.lsf-wrapper .lsf-dropzone:hover   .lsf-dz-icon,
.lsf-wrapper .lsf-dropzone.lsf-dz--over .lsf-dz-icon {
    color: var(--lsf-primary);
}

.lsf-wrapper .lsf-dz-title {
    margin: 0 0 2px;
    font-size: 13.5px;
    font-weight: 700;
    color: var(--lsf-text);
    line-height: 1.4;
}

.lsf-wrapper .lsf-dz-sub {
    margin: 0;
    font-size: 13px;
    color: var(--lsf-muted);
}

.lsf-wrapper .lsf-dz-browse {
    color: var(--lsf-primary-dk);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* Preview card */
.lsf-wrapper .lsf-dz-preview {
    display: none;
    align-items: center;
    gap: 12px;
    width: 100%;
    background: var(--lsf-bg);
    border: 1.5px solid var(--lsf-primary);
    border-radius: var(--lsf-radius);
    padding: 9px 12px;
    text-align: left;
    animation: lsf-rise .18s ease;
}

.lsf-wrapper .lsf-dz-preview.is-visible {
    display: flex;
}

.lsf-wrapper .lsf-dz-preview__file-icon {
    color: var(--lsf-primary-dk);
    flex-shrink: 0;
    line-height: 0;
}

.lsf-wrapper .lsf-dz-preview__info {
    flex: 1;
    min-width: 0;
}

.lsf-wrapper .lsf-dz-filename {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--lsf-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lsf-wrapper .lsf-dz-filesize {
    display: block;
    font-size: 11px;
    color: var(--lsf-muted);
    margin-top: 2px;
}

.lsf-wrapper .lsf-dz-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 26px;
    height: 26px;
    border: none;
    background: none;
    cursor: pointer;
    border-radius: 50%;
    color: var(--lsf-muted);
    transition: color var(--lsf-t), background var(--lsf-t);
    position: relative;
    z-index: 5;
    padding: 0;
    line-height: 0;
}

.lsf-wrapper .lsf-dz-remove:hover {
    color: #ef4444;
    background: #fef2f2;
}

/* ── Validation ───────────────────────────────────────────────────── */

/*
 * Errors are absolutely positioned at the top-right of their .lsf-field
 * (which is position:relative). This puts them on the same line as the
 * label and means they take up zero space — no layout/height shift.
 */
.lsf-wrapper .lsf-inline-error {
    display: none;
    position: absolute;
    top: 0;
    right: 0;
    font-size: 11.5px;
    font-weight: 500;
    color: #dc2626;
    line-height: 1.4;
    white-space: nowrap;
    animation: lsf-rise .14s ease;
}

.lsf-wrapper .lsf-inline-error::before {
    content: "\26A0\00A0";
}

.lsf-wrapper .lsf-field.is-invalid .lsf-inline-error,
.lsf-wrapper .lsf-field--pills.is-invalid .lsf-inline-error {
    display: block;
}

/* For inline pill rows the error sits on its own line below —
   override back to relative flow only for that sub-case */
.lsf-wrapper .lsf-field--inline .lsf-inline-error {
    position: static;
    display: none;
    flex-basis: 100%;
    margin-top: 2px;
}

.lsf-wrapper .lsf-field--inline.is-invalid .lsf-inline-error {
    display: block;
}

.lsf-wrapper .lsf-field.is-invalid input.lsf-input,
.lsf-wrapper .lsf-field.is-invalid select.lsf-select,
.lsf-wrapper .lsf-field.is-invalid textarea.lsf-textarea {
    border-color: #ef4444;
    box-shadow: 0 0 0 3px rgba(239,68,68,.15);
}

.lsf-wrapper .lsf-field--pills.is-invalid .lsf-pill {
    border-color: #ef4444;
}

/* ── Banner messages ──────────────────────────────────────────────── */
.lsf-wrapper .lsf-banner {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    border-radius: var(--lsf-radius);
    font-size: 13.5px;
    margin-bottom: 14px;
    line-height: 1.5;
    animation: lsf-rise .18s ease;
}

.lsf-wrapper .lsf-banner::before {
    content: "";
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    font-size: 11px;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    margin-top: 1px;
}

.lsf-wrapper .lsf-banner--error {
    background: #fef2f2;
    border: 1.5px solid #fca5a5;
    color: #991b1b;
}

.lsf-wrapper .lsf-banner--error::before {
    content: "\2715";
    background: #ef4444;
    line-height: 18px;
    text-align: center;
}

.lsf-wrapper .lsf-banner--success {
    background: #f0fdf4;
    border: 1.5px solid #86efac;
    color: #166534;
}

.lsf-wrapper .lsf-banner--success::before {
    content: "\2713";
    background: var(--lsf-primary);
    line-height: 18px;
    text-align: center;
}

/* ── Submit button ────────────────────────────────────────────────── */
.lsf-wrapper .lsf-btn-submit {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    width: 100%;
    padding: 13px 24px;
    border: none;
    border-radius: var(--lsf-radius);
    background: var(--lsf-primary);
    color: #fff;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .3px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    font-family: inherit;
    transition: background var(--lsf-t), box-shadow var(--lsf-t);
    margin: 0;
    text-decoration: none;
    line-height: 1.5;
}

.lsf-wrapper .lsf-btn-submit:hover:not(:disabled) {
    background: var(--lsf-primary-dk);
    box-shadow: 0 3px 12px var(--lsf-primary-ring);
}

.lsf-wrapper .lsf-btn-submit:active:not(:disabled) {
    box-shadow: none;
    filter: brightness(.92);
}

.lsf-wrapper .lsf-btn-submit:disabled {
    opacity: .6;
    cursor: not-allowed;
}

/* Spinner */
.lsf-wrapper .lsf-btn-submit__spinner {
    display: none;
    width: 16px;
    height: 16px;
    border: 2.5px solid rgba(255,255,255,.35);
    border-top-color: #fff;
    border-radius: 50%;
    animation: lsf-spin .6s linear infinite;
    flex-shrink: 0;
}

.lsf-wrapper .lsf-btn-submit.is-loading .lsf-btn-submit__spinner { display: block; }
.lsf-wrapper .lsf-btn-submit.is-loading .lsf-btn-submit__label   { opacity: .85; }

/* ── Privacy / disclaimer ──────────────────────────────────────────── */
.lsf-wrapper .lsf-privacy {
    display: block;
    text-align: center;
    font-size: 11.5px;
    color: var(--lsf-muted);
    line-height: 1.65;
    margin: 10px 0 0;
    padding: 0;
}

.lsf-wrapper .lsf-privacy a {
    color: var(--lsf-text);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
    text-decoration-color: transparent;
    transition: color var(--lsf-t), text-decoration-color var(--lsf-t);
}

.lsf-wrapper .lsf-privacy a:hover {
    color: var(--lsf-primary-dk);
    text-decoration-color: var(--lsf-primary-dk);
}

/* ── Animations ────────────────────────────────────────────────────── */
@keyframes lsf-spin {
    to { transform: rotate(360deg); }
}

@keyframes lsf-rise {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 560px) {
    .lsf-wrapper .lsf-row {
        flex-direction: column;
        gap: 0;
    }

    .lsf-wrapper .lsf-field--inline {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .lsf-wrapper .lsf-field--inline .lsf-label {
        white-space: normal;
    }

    .lsf-wrapper .lsf-dropzone {
        padding: 10px 12px;
    }

    /* Contact pills revert to natural layout on small screens */
    .lsf-wrapper [data-field="contact_method"] {
        display: block;
    }

    .lsf-wrapper [data-field="contact_method"] .lsf-pills {
        flex-wrap: wrap;
    }

    .lsf-wrapper [data-field="contact_method"] .lsf-pill {
        flex: none;
    }
}
