/* ==========================================================================
   DPS Carriere — Form candidatura frontend
   Design pulito, moderno, responsive.
   ========================================================================== */

/* Accessibilità: testo visibile solo agli screen reader (clip pattern WP-standard).
   Definito qui perché non tutti i temi forniscono `.screen-reader-text`. */
.dpscar-form-wrap .screen-reader-text,
.dpscar-manage .screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    width: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute !important;
    word-wrap: normal !important;
}

.dpscar-form-wrap {
    --dps-primary: #2271b1;
    --dps-primary-hover: #135e96;
    --dps-text: #1d2327;
    --dps-muted: #646970;
    --dps-border: #dcdfe4;
    --dps-border-focus: #2271b1;
    --dps-bg: #fff;
    --dps-bg-soft: #f7f9fc;
    --dps-required: #d63638;
    --dps-success-bg: #edfaef;
    --dps-success-border: #0a7d2c;
    --dps-radius: 6px;
    --dps-gap: 24px;
    --dps-pad-input: 11px 14px;

    max-width: 980px;
    margin: 0 auto;
    padding: 8px 0;
    color: var(--dps-text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: 15px;
    line-height: 1.5;
    font-weight: 400;
}

/* Forza weight 400 sui testi che potrebbero ereditare bold dal body del tema. */
.dpscar-form-wrap p,
.dpscar-form-wrap span,
.dpscar-form-wrap li,
.dpscar-form-wrap a,
.dpscar-form-wrap input,
.dpscar-form-wrap select,
.dpscar-form-wrap textarea,
.dpscar-form-wrap button,
.dpscar-form-wrap .acf-input,
.dpscar-form-wrap .acf-input * {
    font-weight: 400;
}

/* ===== Badge posizione fissa (form lanciato da elenco) ===== */
.dpscar-form-wrap .dpscar-pos-badge {
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 100%;
    box-sizing: border-box;
    padding: 18px 24px;
    margin: 0 0 24px;
    background: linear-gradient(135deg, #2271b1 0%, #135e96 100%);
    color: #fff;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(34, 113, 177, 0.25);
    /* Se ACF lo inietta come grid item, span su tutte le colonne. */
    grid-column: 1 / -1;
    flex-basis: 100%;
}

/* Quando il badge / sezione / turnstile sono dentro .acf-fields (alcune versioni ACF)
   forziamo lo span su tutte le colonne del grid. */
.dpscar-form-wrap .acf-fields > .dpscar-pos-badge,
.dpscar-form-wrap .acf-fields > .dpscar-section,
.dpscar-form-wrap .acf-fields > .dpscar-section-posizione,
.dpscar-form-wrap .acf-fields > .dpscar-turnstile-wrap {
    grid-column: 1 / -1;
    width: 100%;
}

/* Turnstile sotto i field, allineato a sinistra (NON center). */
.dpscar-form-wrap .dpscar-turnstile-wrap {
    margin: 18px 0 6px;
    text-align: left;
}

.dpscar-form-wrap .dpscar-turnstile-wrap .cf-turnstile {
    display: inline-block;
}

.dpscar-form-wrap .dpscar-pos-badge-label {
    font-size: 13px;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: .06em;
    opacity: .85;
    color: #fff;
}

.dpscar-form-wrap .dpscar-pos-badge-title,
.dpscar-form-wrap a.dpscar-pos-badge-title {
    font-size: 22px;
    font-weight: 600;
    line-height: 1.3;
    color: #fff !important;
    text-decoration: none !important;
    border-bottom: none !important;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: opacity .15s;
}

.dpscar-form-wrap a.dpscar-pos-badge-title:hover {
    color: #fff !important;
    opacity: .85;
    text-decoration: none !important;
}

.dpscar-form-wrap .dpscar-pos-badge-ext {
    font-size: 0.85em;
    color: inherit !important;
    opacity: 1;
    margin-left: 4px;
    vertical-align: -0.05em;
}

/* ===== Sezioni custom (Candidatura per) ===== */
.dpscar-form-wrap .dpscar-section {
    margin-bottom: var(--dps-gap);
    padding-bottom: 20px;
    border-bottom: 1px solid var(--dps-border);
}

.dpscar-form-wrap .dpscar-section-title {
    margin: 0 0 6px;
    font-size: 17px;
    font-weight: 600;
    color: var(--dps-muted);
}

.dpscar-form-wrap .dpscar-section-hint {
    margin: 0 0 14px;
    color: var(--dps-primary);
    font-size: 14px;
}

/* ===== Sezioni ACF (Message field con classe dpscar-section-divider) ===== */
.dpscar-form-wrap .acf-field.dpscar-section-divider {
    margin-top: 28px;
    margin-bottom: 4px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--dps-border);
    background: transparent;
}

.dpscar-form-wrap .acf-field.dpscar-section-divider .acf-label label {
    margin: 0;
    font-size: 17px;
    font-weight: 600;
    color: var(--dps-muted);
    text-transform: none;
}

.dpscar-form-wrap .acf-field.dpscar-section-divider .acf-input {
    display: none; /* Message field vuoto: nascondi area input */
}

/* ===== Reset wrapper ACF + layout CSS Grid =====
   ACF di default usa inline-block + width inline. Lo overridiamo con CSS Grid 2 colonne:
   spacing uniforme, allineamento pixel-perfect, niente padding di compensazione. */
.dpscar-form-wrap .acf-form,
.dpscar-form-wrap .acf-fields {
    background: transparent;
    border: none;
}

.dpscar-form-wrap .acf-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px 24px;
    align-items: start;
}

/* Reset dei field ACF: niente border/bg/padding/width inline. Grid gestisce tutto. */
.dpscar-form-wrap .acf-fields > .acf-field,
.dpscar-form-wrap .acf-fields > .acf-field[data-width] {
    width: auto !important;
    min-width: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
    float: none !important;
    box-sizing: border-box;
}

/* Field a tutta larghezza (data-width=100): occupa entrambe le colonne. */
.dpscar-form-wrap .acf-fields > .acf-field[data-width="100"],
.dpscar-form-wrap .acf-fields > .acf-field-message,
.dpscar-form-wrap .acf-fields > .acf-field-repeater,
.dpscar-form-wrap .acf-fields > .acf-field-file,
.dpscar-form-wrap .acf-fields > .acf-field-textarea,
.dpscar-form-wrap .acf-fields > .acf-field-true_false:not([data-width="50"]) {
    grid-column: 1 / -1;
}

/* Field 50%: una sola colonna del grid. */
.dpscar-form-wrap .acf-fields > .acf-field[data-width="50"] {
    grid-column: span 1;
}

/* Rimuove separatori verticali ACF (non servono più con grid). */
.dpscar-form-wrap .acf-fields > .acf-field:before,
.dpscar-form-wrap .acf-fields > .acf-field:after {
    display: none !important;
    content: none !important;
}

/* ===== Label ===== */
.dpscar-form-wrap .acf-label {
    margin: 0 0 6px;
    padding: 0;
}

.dpscar-form-wrap .acf-label label,
.dpscar-form-wrap .dpscar-field label {
    display: block;
    font-size: 14px;
    font-weight: 400;
    color: var(--dps-muted);
    margin: 0 0 6px;
}

.dpscar-form-wrap .acf-label .acf-required,
.dpscar-form-wrap .required {
    color: var(--dps-required);
    font-weight: 600;
}

.dpscar-form-wrap .acf-label .description,
.dpscar-form-wrap .acf-input p.description {
    margin: 6px 0 0;
    font-size: 13px;
    color: var(--dps-muted);
    font-style: normal;
}

/* ===== Input / Select / Textarea ===== */
.dpscar-form-wrap input[type="text"],
.dpscar-form-wrap input[type="email"],
.dpscar-form-wrap input[type="tel"],
.dpscar-form-wrap input[type="url"],
.dpscar-form-wrap input[type="number"],
.dpscar-form-wrap input[type="date"],
.dpscar-form-wrap input[type="search"],
.dpscar-form-wrap select,
.dpscar-form-wrap textarea,
.dpscar-form-wrap .acf-input input[type="text"],
.dpscar-form-wrap .acf-input input[type="email"],
.dpscar-form-wrap .acf-input input[type="url"],
.dpscar-form-wrap .acf-input select,
.dpscar-form-wrap .acf-input textarea {
    width: 100%;
    box-sizing: border-box;
    padding: var(--dps-pad-input);
    background: var(--dps-bg);
    border: 1px solid var(--dps-border);
    border-radius: var(--dps-radius);
    font-size: 15px;
    line-height: 1.4;
    color: var(--dps-text);
    transition: border-color .15s, box-shadow .15s;
    box-shadow: none;
    outline: none;
    appearance: none;
    -webkit-appearance: none;
}

.dpscar-form-wrap select {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23646970' d='M6 8L0 0h12z'/></svg>");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 38px;
}

.dpscar-form-wrap input:focus,
.dpscar-form-wrap select:focus,
.dpscar-form-wrap textarea:focus,
.dpscar-form-wrap .acf-input input:focus,
.dpscar-form-wrap .acf-input select:focus,
.dpscar-form-wrap .acf-input textarea:focus {
    border-color: var(--dps-border-focus);
    box-shadow: 0 0 0 3px rgba(34, 113, 177, 0.12);
}

.dpscar-form-wrap input::placeholder,
.dpscar-form-wrap textarea::placeholder {
    color: #a7aaad !important;
    opacity: 1 !important;
}

/* Cursore corretto: I-beam sui campi testuali (alcuni temi forzano cursor:pointer). */
.dpscar-form-wrap input[type="text"],
.dpscar-form-wrap input[type="email"],
.dpscar-form-wrap input[type="url"],
.dpscar-form-wrap input[type="tel"],
.dpscar-form-wrap input[type="number"],
.dpscar-form-wrap input[type="password"],
.dpscar-form-wrap input[type="search"],
.dpscar-form-wrap input[type="date"],
.dpscar-form-wrap textarea,
.dpscar-form-wrap .acf-input input[type="text"],
.dpscar-form-wrap .acf-input input[type="email"],
.dpscar-form-wrap .acf-input input[type="url"],
.dpscar-form-wrap .acf-input input[type="tel"],
.dpscar-form-wrap .acf-input input[type="number"],
.dpscar-form-wrap .acf-input input[type="password"],
.dpscar-form-wrap .acf-input input[type="search"],
.dpscar-form-wrap .acf-input input[type="date"],
.dpscar-form-wrap .acf-input textarea {
    cursor: text !important;
}
.dpscar-form-wrap input::-webkit-input-placeholder,
.dpscar-form-wrap textarea::-webkit-input-placeholder {
    color: #a7aaad !important;
}
.dpscar-form-wrap input::-moz-placeholder,
.dpscar-form-wrap textarea::-moz-placeholder {
    color: #a7aaad !important;
    opacity: 1 !important;
}
.dpscar-form-wrap input:-ms-input-placeholder,
.dpscar-form-wrap textarea:-ms-input-placeholder {
    color: #a7aaad !important;
}

/* ===== Select2 (ACF UI select) override =====
   `!important` su background/color: alcuni temi usano selettori con `body` +
   `!important` che vincono sulla nostra specificità. Forziamo qui per sicurezza. */
.dpscar-form-wrap .select2-container--default .select2-selection--single {
    height: auto;
    padding: 6px 14px;
    background: var(--dps-bg) !important;
    border: 1px solid var(--dps-border) !important;
    border-radius: var(--dps-radius) !important;
    transition: border-color .15s, box-shadow .15s;
}

.dpscar-form-wrap .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding: 0;
    line-height: 28px;
    color: var(--dps-text) !important;
    background: transparent !important;
}

.dpscar-form-wrap .select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #a7aaad !important;
}

.dpscar-form-wrap .select2-container--default .select2-selection--single .select2-selection__arrow {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 8px;
    height: auto;
    width: 20px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    pointer-events: none;
}
.dpscar-form-wrap .select2-container--default .select2-selection--single .select2-selection__arrow b {
    position: static;
    margin: 0;
    border-color: var(--dps-muted) transparent transparent transparent;
}

.dpscar-form-wrap .select2-container--default.select2-container--focus .select2-selection--single,
.dpscar-form-wrap .select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--dps-border-focus);
    box-shadow: 0 0 0 3px rgba(34, 113, 177, 0.12);
}

/* Pulsante "×" (clear) Select2: spostato a sinistra della freccia ↓ per non sovrapporsi.
   Padding-right sul testo per non far passare il valore sotto i due controlli. */
.dpscar-form-wrap .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-right: 48px;
}

.dpscar-form-wrap .select2-container--default .select2-selection--single .select2-selection__clear {
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    margin: 0;
    padding: 0 6px;
    font-size: 18px;
    line-height: 1;
    color: var(--dps-muted);
    cursor: pointer;
    transition: color .15s;
    z-index: 2;
}

/* Quando un valore è selezionato (clear presente) → nascondi la freccia ↓ del select2.
   Mostra solo la "×". `:has()` supportato Chrome 105+, Safari 15.4+, Firefox 121+. */
.dpscar-form-wrap .select2-container--default .select2-selection--single:has(.select2-selection__clear) .select2-selection__arrow {
    display: none !important;
}
/* Riallinea padding-right del testo quando la freccia è nascosta. */
.dpscar-form-wrap .select2-container--default .select2-selection--single:has(.select2-selection__clear) .select2-selection__rendered {
    padding-right: 28px !important;
}

.dpscar-form-wrap .select2-container--default .select2-selection--single .select2-selection__clear:hover {
    color: var(--dps-required);
}

.dpscar-form-wrap .select2-container--default .select2-selection--multiple {
    background: var(--dps-bg);
    border: 1px solid var(--dps-border);
    border-radius: var(--dps-radius);
    min-height: 42px;
    padding: 4px 8px;
}

/* ===== URL field con icona globo ACF ===== */
.dpscar-form-wrap .acf-input-wrap.acf-url {
    position: relative;
    display: flex;
    align-items: center;
}

.dpscar-form-wrap .acf-input-wrap.acf-url .acf-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    margin: 0;
    color: var(--dps-muted);
    pointer-events: none;
    z-index: 2;
}

.dpscar-form-wrap .acf-input-wrap.acf-url input[type="url"] {
    padding-left: 38px;
}

/* ===== Neutralizza clearfix ACF (.acf-hl / .acf-bl / .acf-cf) che creano gap fantasma
   nei checkbox horizontal-list (Software / Esperienza). Usiamo grid → niente float da clearare. */
.dpscar-form-wrap .acf-checkbox-list.acf-hl:before,
.dpscar-form-wrap .acf-checkbox-list.acf-hl:after,
.dpscar-form-wrap .acf-checkbox-list.acf-bl:before,
.dpscar-form-wrap .acf-checkbox-list.acf-bl:after,
.dpscar-form-wrap .acf-checkbox-list.acf-cf:before,
.dpscar-form-wrap .acf-checkbox-list.acf-cf:after,
.dpscar-form-wrap .dpscar-checkbox-grid .acf-hl:before,
.dpscar-form-wrap .dpscar-checkbox-grid .acf-hl:after,
.dpscar-form-wrap .dpscar-checkbox-grid .acf-bl:before,
.dpscar-form-wrap .dpscar-checkbox-grid .acf-bl:after,
.dpscar-form-wrap .dpscar-checkbox-grid .acf-cf:before,
.dpscar-form-wrap .dpscar-checkbox-grid .acf-cf:after {
    display: none !important;
    content: none !important;
}

/* Forza i li ACF (di default float left con .acf-hl) a comportarsi da grid item normale. */
.dpscar-form-wrap .dpscar-checkbox-grid .acf-checkbox-list li,
.dpscar-form-wrap .dpscar-checkbox-grid .acf-checkbox-list.acf-hl li {
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
}

/* ===== Select2 dropdown (appeso a body, fuori .dpscar-form-wrap) =====
   Override del tema "default" di Select2 usato da ACF. */
.select2-container--default .select2-dropdown {
    border: 1px solid #dcdfe4;
    border-radius: 6px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    background: #fff;
}

.select2-container--default .select2-search--dropdown {
    padding: 8px 10px;
    background: #f7f9fc;
    border-bottom: 1px solid #e6e8ec;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    border: 1px solid #dcdfe4;
    border-radius: 4px;
    padding: 7px 10px;
    font-size: 14px;
    line-height: 1.4;
    background: #fff;
    color: #1d2327;
    box-shadow: none;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
}

.select2-container--default .select2-search--dropdown .select2-search__field:focus {
    border-color: #2271b1;
    box-shadow: 0 0 0 3px rgba(34, 113, 177, 0.12);
}

.select2-container--default .select2-results__options {
    padding: 4px 0;
    max-height: 280px;
}

.select2-container--default .select2-results__option {
    padding: 9px 14px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.4;
    color: #1d2327;
    transition: background .12s, color .12s;
    border-radius: 0;
}

.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
    background: #2271b1;
    color: #fff;
}

.select2-container--default .select2-results__option[aria-selected="true"] {
    background: #f0f6fc;
    color: #1d2327;
    font-weight: 600;
}

.select2-container--default .select2-results__option--disabled {
    color: #a7aaad;
}

.select2-container--default .select2-results__group {
    padding: 8px 14px;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #646970;
    background: #f7f9fc;
}

/* Scrollbar custom (WebKit) */
.select2-container--default .select2-results__options::-webkit-scrollbar {
    width: 8px;
}
.select2-container--default .select2-results__options::-webkit-scrollbar-thumb {
    background: #c3c4c7;
    border-radius: 4px;
}
.select2-container--default .select2-results__options::-webkit-scrollbar-thumb:hover {
    background: #8c8f94;
}
.select2-container--default .select2-results__options::-webkit-scrollbar-track {
    background: transparent;
}

/* Multi-select tag (chip) */
.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background: #2271b1;
    color: #fff;
    border: none;
    border-radius: 12px;
    padding: 2px 10px 2px 8px;
    margin: 3px 4px 3px 0;
    font-size: 13px;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: #fff;
    margin-right: 6px;
    font-weight: 400;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
    color: #ffd1d1;
}

/* ===== Date picker ===== */
.dpscar-form-wrap .acf-date-picker .input,
.dpscar-form-wrap .acf-date-time-picker .input {
    background: var(--dps-bg);
}

/* ===== Checkbox / radio (true_false + tax checkbox) ===== */
.dpscar-form-wrap .acf-true-false .acf-switch {
    border-color: var(--dps-border);
}

.dpscar-form-wrap .acf-true-false .acf-switch.-on {
    background: var(--dps-primary);
    border-color: var(--dps-primary);
}

.dpscar-form-wrap .acf-checkbox-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.dpscar-form-wrap .dpscar-checkbox-grid .acf-checkbox-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 6px 14px;
}

.dpscar-form-wrap .acf-checkbox-list li {
    margin: 0;
    padding: 0;
}

.dpscar-form-wrap .acf-checkbox-list li label {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border-radius: 4px;
    cursor: pointer;
    font-weight: normal;
    color: var(--dps-text);
    transition: background .15s;
}

.dpscar-form-wrap .acf-checkbox-list li label:hover {
    background: var(--dps-bg-soft);
}

.dpscar-form-wrap .acf-checkbox-list input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin: 0;
    accent-color: var(--dps-primary);
}

/* ===== File upload ===== */
.dpscar-form-wrap .acf-file-uploader {
    background: var(--dps-bg-soft);
    border: 2px dashed var(--dps-border);
    border-radius: var(--dps-radius);
    padding: 18px;
    text-align: center;
    transition: border-color .15s, background .15s;
}

.dpscar-form-wrap .acf-file-uploader:hover {
    border-color: var(--dps-primary);
    background: #f0f6fc;
}

/* ===== Repeater (lingue) ===== */
.dpscar-form-wrap .acf-repeater table.acf-table {
    border-radius: var(--dps-radius);
    overflow: hidden;
    border-color: var(--dps-border);
}

.dpscar-form-wrap .acf-repeater table.acf-table > thead > tr > th,
.dpscar-form-wrap .acf-repeater table.acf-table > tbody > tr > td {
    border-color: var(--dps-border);
    padding: 8px;
}

.dpscar-form-wrap .acf-repeater .acf-actions .acf-button,
.dpscar-form-wrap a.acf-button,
.dpscar-form-wrap a.acf-repeater-add-row,
.dpscar-form-wrap .acf-repeater a.acf-repeater-add-row,
.dpscar-form-wrap .acf-repeater a.acf-button.acf-repeater-add-row,
.dpscar-form-wrap a.acf-button:link,
.dpscar-form-wrap a.acf-button:visited,
.dpscar-form-wrap a.acf-button:hover,
.dpscar-form-wrap a.acf-button:focus,
.dpscar-form-wrap a.acf-button:active,
.dpscar-form-wrap a.acf-repeater-add-row:link,
.dpscar-form-wrap a.acf-repeater-add-row:visited,
.dpscar-form-wrap a.acf-repeater-add-row:hover,
.dpscar-form-wrap a.acf-repeater-add-row:focus,
.dpscar-form-wrap a.acf-repeater-add-row:active {
    background: var(--dps-primary);
    color: #fff !important;
    border: none;
    padding: 8px 16px;
    border-radius: var(--dps-radius);
    font-weight: 500;
    cursor: pointer;
    text-decoration: none !important;
    text-decoration-line: none !important;
    text-decoration-style: solid !important;
    box-shadow: none;
    border-bottom: none !important;
    background-image: none !important;
    transition: background .15s;
}

.dpscar-form-wrap a.acf-button::after,
.dpscar-form-wrap a.acf-button::before,
.dpscar-form-wrap a.acf-repeater-add-row::after,
.dpscar-form-wrap a.acf-repeater-add-row::before {
    display: none !important;
    content: none !important;
    border: none !important;
    background: none !important;
}

.dpscar-form-wrap .acf-repeater .acf-actions .acf-button:hover,
.dpscar-form-wrap a.acf-button:hover,
.dpscar-form-wrap a.acf-repeater-add-row:hover {
    background: var(--dps-primary-hover) !important;
    color: #fff !important;
    text-decoration: none !important;
}

/* ===== Submit ===== */
.dpscar-form-wrap .acf-form-submit,
.dpscar-form-wrap .acf-form-submit p {
    margin: var(--dps-gap) 0 0 !important;
    padding: 0 !important;
    text-align: center !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

.dpscar-form-wrap .acf-form-submit input[type="submit"],
.dpscar-form-wrap input[type="submit"].acf-button {
    background: var(--dps-primary);
    color: #fff;
    border: none;
    padding: 12px 28px;
    border-radius: var(--dps-radius);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, transform .05s;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.dpscar-form-wrap .acf-form-submit input[type="submit"]:hover,
.dpscar-form-wrap input[type="submit"].acf-button:hover {
    background: var(--dps-primary-hover);
}

.dpscar-form-wrap .acf-form-submit input[type="submit"]:active {
    transform: translateY(1px);
}

/* ===== Errori validazione ===== */
.dpscar-form-wrap .acf-error {
    color: var(--dps-required);
}

.dpscar-form-wrap .acf-error-message,
.dpscar-form-wrap .acf-notice.-error {
    background: #fce8e8;
    color: var(--dps-required);
    border: 1px solid #f5c6c6;
    border-left: 4px solid var(--dps-required);
    padding: 10px 14px;
    border-radius: var(--dps-radius);
    margin-bottom: 16px;
    font-size: 14px;
}

.dpscar-form-wrap .acf-field.acf-error input,
.dpscar-form-wrap .acf-field.acf-error select,
.dpscar-form-wrap .acf-field.acf-error textarea {
    border-color: var(--dps-required);
    box-shadow: 0 0 0 3px rgba(214, 54, 56, 0.1);
}

/* ===== Successo post-submit ===== */
.dpscar-success {
    padding: 18px 22px;
    background: var(--dps-success-bg);
    border-left: 4px solid var(--dps-success-border);
    color: #0a4d1c;
    border-radius: var(--dps-radius);
    font-size: 15px;
    margin: 16px 0;
}

/* ===== Meta block in alto su singola posizione ===== */
.dpscar-pos-meta-block {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 6px 16px;
    margin: 0 0 24px;
    padding: 14px 18px;
    background: #f7f9fc;
    border: 1px solid #dcdfe4;
    border-left: 4px solid #2271b1;
    font-size: 15px;
}

.dpscar-pos-meta-block dt {
    font-weight: 600;
    color: #50575e;
    margin: 0;
}

.dpscar-pos-meta-block dd {
    margin: 0;
    color: #1d2327;
}

/* ===== Privacy field (cv_privacy) =====
   ACF usa trattini nelle classi (`acf-field-field-cv-privacy`), non underscore.
   Usiamo `[data-key]` per match esatto e cross-versione ACF. */
.dpscar-form-wrap [data-key="field_cv_privacy"] .acf-label label {
    font-weight: 600 !important;
}
/* Link "Informativa sulla Privacy": colore primario (blu), peso/dimensione ereditati
   dalla label bold. !important per battere `.dpscar-form-wrap a { font-weight:400 }`. */
.dpscar-form-wrap [data-key="field_cv_privacy"] .acf-label label a {
    color: var(--dps-primary) !important;
    text-decoration: none !important;
    font-weight: inherit !important;
    font-size: inherit !important;
    cursor: pointer;
}
.dpscar-form-wrap [data-key="field_cv_privacy"] .acf-label label a:hover {
    color: var(--dps-primary-hover) !important;
    text-decoration: underline !important;
}
/* Link descrittivo sotto checkbox: stile discreto. */
.dpscar-form-wrap .dpscar-privacy-link a {
    color: var(--dps-muted);
    text-decoration: underline;
}
.dpscar-form-wrap .dpscar-privacy-link a:hover {
    color: var(--dps-primary);
}

/* ===== CTA "Candidati" su singola posizione ===== */
.dpscar-pos-cta {
    margin: 32px 0 8px !important;
    text-align: center !important;
    display: flex !important;
    justify-content: center !important;
}

.dpscar-pos-cta-btn {
    display: inline-block;
    background: #2271b1;
    color: #fff !important;
    padding: 12px 28px;
    border-radius: 6px;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none !important;
    border: none;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
    transition: background .15s, transform .05s;
}

.dpscar-pos-cta-btn:hover {
    background: #135e96;
    color: #fff !important;
    text-decoration: none !important;
}

.dpscar-pos-cta-btn:active {
    transform: translateY(1px);
}

/* ===== Elenco posizioni aperte ([dps_posizioni_aperte]) ===== */
.dpscar-pos-list {
    display: grid;
    gap: 16px;
    margin: 24px 0;
    grid-template-columns: 1fr; /* default 1 colonna; override dai modifier */
}
/* Layout 2 colonne (opzione Impostazioni → Aspetto frontend). */
.dpscar-pos-list.dpscar-pos-list--cols-2 {
    grid-template-columns: 1fr 1fr;
}
.dpscar-pos-list.dpscar-pos-list--cols-1 {
    grid-template-columns: 1fr;
}
/* Responsive: sotto i 768px sempre 1 colonna, anche in modalità 2 colonne. */
@media (max-width: 768px) {
    .dpscar-pos-list.dpscar-pos-list--cols-2 {
        grid-template-columns: 1fr;
    }
}

.dpscar-pos-item {
    padding: 18px 22px;
    background: #fff;
    border: 1px solid #dcdfe4;
    border-left: 4px solid #2271b1;
    transition: box-shadow .15s, border-color .15s;
}

.dpscar-pos-item:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    border-left-color: #135e96;
}

.dpscar-pos-title {
    margin: 0 0 6px;
    font-size: 18px;
    font-weight: 600;
}

.dpscar-pos-title a {
    color: #1d2327;
    text-decoration: none;
}

.dpscar-pos-title a:hover {
    color: #2271b1;
}

/* Icona "apri" dopo il titolo posizione (FontAwesome). Eredita colore dal link. */
.dpscar-pos-title-ext {
    font-size: 0.75em !important;
    color: inherit !important;
    margin-left: 6px;
    vertical-align: -0.05em;
}

.dpscar-pos-meta {
    margin: 0 0 10px;
    color: #646970;
    font-size: 13px;
}

.dpscar-pos-excerpt {
    margin: 0 0 14px;
    color: #1d2327;
    font-size: 14px;
    line-height: 1.5;
}

.dpscar-pos-actions {
    margin: 0;
    display: flex;
    gap: 10px;
    align-items: center;
}

.dpscar-pos-btn {
    display: inline-block;
    background: #2271b1;
    color: #fff !important;
    padding: 8px 18px;
    border-radius: 4px;
    text-decoration: none !important;
    font-weight: 600;
    font-size: 14px;
    transition: background .15s;
}

.dpscar-pos-btn:hover {
    background: #135e96;
}

.dpscar-pos-link {
    color: #2271b1 !important;
    font-size: 13px;
    text-decoration: none !important;
}

.dpscar-pos-link:hover {
    text-decoration: underline !important;
}

.dpscar-pos-empty {
    padding: 18px;
    background: #f7f9fc;
    border: 1px dashed #c3c4c7;
    border-radius: 6px;
    text-align: center;
    color: #646970;
}

/* ===== GDPR forms (cancellazione + export) ===== */
.dpscar-gdpr-wrap {
    max-width: 600px;
}

.dpscar-gdpr-wrap .dpscar-section {
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--dps-border);
}

.dpscar-gdpr-wrap .dpscar-section-title {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: 600;
    color: var(--dps-muted);
}

.dpscar-gdpr-wrap .dpscar-section-hint {
    margin: 0;
    color: var(--dps-text);
    font-size: 14px;
    line-height: 1.5;
}

.dpscar-gdpr-form {
    margin-top: 8px;
}

.dpscar-gdpr-field {
    margin-bottom: 18px;
}

.dpscar-gdpr-field label {
    display: block;
    font-size: 14px;
    font-weight: 400;
    color: var(--dps-muted);
    margin-bottom: 6px;
}

.dpscar-gdpr-field .acf-required {
    color: var(--dps-required);
    font-weight: 600;
}

.dpscar-gdpr-field input[type="email"] {
    width: 100%;
    box-sizing: border-box;
    padding: var(--dps-pad-input);
    background: var(--dps-bg);
    border: 1px solid var(--dps-border);
    border-radius: var(--dps-radius);
    font-size: 15px;
    line-height: 1.4;
    color: var(--dps-text);
    transition: border-color .15s, box-shadow .15s;
    outline: none;
}

.dpscar-gdpr-field input[type="email"]:focus {
    border-color: var(--dps-border-focus);
    box-shadow: 0 0 0 3px rgba(34, 113, 177, 0.12);
}

.dpscar-gdpr-actions {
    text-align: center;
}

.dpscar-gdpr-form button[type="submit"] {
    background: var(--dps-primary);
    color: #fff;
    border: none;
    padding: 12px 28px;
    border-radius: var(--dps-radius);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, transform .05s;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.dpscar-gdpr-form button[type="submit"]:hover {
    background: var(--dps-primary-hover);
}

.dpscar-gdpr-form button[type="submit"]:active {
    transform: translateY(1px);
}

@media (max-width: 600px) {
    .dpscar-gdpr-actions {
        text-align: stretch;
    }
    .dpscar-gdpr-form button[type="submit"] {
        width: 100%;
    }
}

/* ===== Manage candidatura (riuso) ===== */
.dpscar-manage dl,
.dpscar-manage dl.dpscar-manage-data {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 8px 18px;
    margin: 18px 0;
}
.dpscar-manage dt { font-weight: 600; color: var(--dps-muted); }
.dpscar-manage dd { margin: 0; word-break: break-word; }
.dpscar-manage .dpscar-manage-intro {
    color: var(--dps-muted);
    font-size: 14px;
    margin: 0 0 8px;
}
/* Header di sezione dentro la dl. */
.dpscar-manage dt.dpscar-manage-section {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--dps-border);
    color: var(--dps-text);
    font-size: 15px;
}
.dpscar-manage dt.dpscar-manage-section:first-child {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}
.dpscar-manage-actions {
    margin: 22px 0 0;
}
/* Pulsante "Ritira candidatura": vero bottone, stile distruttivo. */
.dpscar-withdraw-btn {
    display: inline-block;
    background: var(--dps-required, #d63638);
    color: #fff;
    border: none;
    padding: 12px 28px;
    border-radius: var(--dps-radius, 6px);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, transform .05s;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}
.dpscar-withdraw-btn:hover {
    background: #b32d2e;
}
.dpscar-withdraw-btn:active {
    transform: translateY(1px);
}

/* ===== Responsive ===== */
@media (max-width: 768px) {
    .dpscar-form-wrap {
        font-size: 14px;
    }
    /* Mobile: grid 1 colonna, ogni field span totale. */
    .dpscar-form-wrap .acf-fields {
        grid-template-columns: 1fr;
        gap: 18px;
    }
    .dpscar-form-wrap .acf-fields > .acf-field[data-width="50"] {
        grid-column: 1 / -1;
    }
    .dpscar-form-wrap .acf-form-submit {
        text-align: center;
    }
    .dpscar-form-wrap .acf-form-submit input[type="submit"] {
        width: 100%;
    }
    .dpscar-form-wrap .dpscar-checkbox-grid .acf-checkbox-list {
        grid-template-columns: 1fr;
    }
}

/* ===== jQuery UI Datepicker (ACF date field) =====
   Il datepicker è iniettato in #ui-datepicker-div (fuori da .dpscar-form-wrap),
   quindi i selettori sono globali. Override per: select mese/anno troppo larghe,
   frecce prev/next invisibili (sprite UI mancante col tema). */
#ui-datepicker-div.ui-datepicker {
    width: auto;
    min-width: 19em;
    padding: 10px;
    background: #fff;
    border: 1px solid #c3c4c7;
    border-radius: 6px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    font-size: 13px;
    z-index: 100000;
}
#ui-datepicker-div .ui-datepicker-header {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 2.2em;
    padding: 4px 0 8px;
    border: none;
    background: transparent;
}
#ui-datepicker-div .ui-datepicker-title {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin: 0 2.4em;
}
#ui-datepicker-div select.ui-datepicker-month,
#ui-datepicker-div select.ui-datepicker-year {
    width: auto !important;
    max-width: 6.5em;
    display: inline-block !important;
    margin: 0;
    padding: 2px 4px;
    font-size: 13px;
    line-height: 1.4;
    height: auto;
    cursor: pointer !important;
}
/* Frecce prev/next: nascondo lo <span> sprite rotto, uso glifo via ::before. */
#ui-datepicker-div .ui-datepicker-prev,
#ui-datepicker-div .ui-datepicker-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 1.9em;
    height: 1.9em;
    cursor: pointer;
    border: 1px solid #dcdfe4;
    border-radius: 4px;
    background: #f6f7f7;
    overflow: hidden;
}
#ui-datepicker-div .ui-datepicker-prev { left: 0; }
#ui-datepicker-div .ui-datepicker-next { right: 0; }
#ui-datepicker-div .ui-datepicker-prev:hover,
#ui-datepicker-div .ui-datepicker-next:hover {
    background: #e8eaed;
    border-color: #c3c4c7;
}
#ui-datepicker-div .ui-datepicker-prev span,
#ui-datepicker-div .ui-datepicker-next span {
    display: none !important;
}
#ui-datepicker-div .ui-datepicker-prev::before,
#ui-datepicker-div .ui-datepicker-next::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 16px;
    line-height: 1;
    color: #1d2327;
}
#ui-datepicker-div .ui-datepicker-prev::before { content: "\2039"; } /* ‹ */
#ui-datepicker-div .ui-datepicker-next::before { content: "\203A"; } /* › */
#ui-datepicker-div table.ui-datepicker-calendar {
    margin: 4px 0 0;
    border-collapse: collapse;
    width: 100%;
}
#ui-datepicker-div .ui-datepicker-calendar th {
    padding: 6px 4px;
    font-size: 12px;
    color: #646970;
    font-weight: 600;
}
#ui-datepicker-div .ui-datepicker-calendar td {
    padding: 2px;
}
#ui-datepicker-div .ui-datepicker-calendar td a,
#ui-datepicker-div .ui-datepicker-calendar td span {
    display: block;
    padding: 6px 6px;
    text-align: center;
    text-decoration: none;
    border-radius: 4px;
    color: #1d2327;
}
#ui-datepicker-div .ui-datepicker-calendar td a:hover {
    background: #e8f0fb;
}
#ui-datepicker-div .ui-datepicker-calendar td a.ui-state-active,
#ui-datepicker-div .ui-datepicker-calendar td a.ui-state-highlight {
    background: #2271b1;
    color: #fff;
}
#ui-datepicker-div .ui-datepicker-buttonpane {
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px solid #e6e8ec;
}
#ui-datepicker-div .ui-datepicker-buttonpane button {
    cursor: pointer;
    padding: 4px 10px;
    font-size: 12px;
}
