:root {
    --idpfi-bg-color: #f2f2fd;
    --idpfi-primary-color: #524efa;
    --idpfi-primary-hover: #403ce0;
    --idpfi-danger-color: #b32d2e;
    --idpfi-danger-hover: #8f2424;
    --idpfi-text-color: #1a1a1a;
    --idpfi-border-color: #d7d9ea;
    /* Alinhado a .elementor-field-textual (formulário público) */
    --idpfi-field-border: #69727d;
    --idpfi-field-text: #1f2124;
    --idpfi-input-bg: #ffffff;
    /* Seta sólida (triângulo) nos selects — mesmo ícone em data URI */
    --idpfi-select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%231a1a1a' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
    --idpfi-success-bg: #e8f8ef;
    --idpfi-success-text: #1d6b43;
    --idpfi-error-bg: #fdeeee;
    --idpfi-error-text: #a12626;
    --idpfi-font-family: var(--e-global-typography-text-font-family, var(--e-global-typography-primary-font-family, inherit));
    /* Título → primeiro campo: gap moderado (mockup à direita = mais compacto) */
    --idpfi-title-to-fields-gap: 0.85rem;
}

.idpfi-shortcode-wrap {
    display: flex;
    justify-content: center;
    padding: 48px 24px;
    font-family: var(--idpfi-font-family);
    color: var(--idpfi-text-color);
    background-color: #ffffff;
    box-sizing: border-box;
}

.idpfi-shortcode-wrap *,
.idpfi-shortcode-wrap *::before,
.idpfi-shortcode-wrap *::after {
    box-sizing: border-box;
}

/*
 * Formulário público: apenas títulos de secção (h3/h4) são visíveis.
 * Os <label> mantêm-se no DOM para acessibilidade mas ficam sempre ocultos
 * (alguns temas/Elementor não carregam estilos para .screen-reader-text).
 */
.idpfi-shortcode-wrap .idpfi-form label.screen-reader-text {
    border: 0 !important;
    clip: rect(1px, 1px, 1px, 1px) !important;
    clip-path: inset(50%) !important;
    height: 1px !important;
    margin: -1px !important;
    overflow: hidden !important;
    padding: 0 !important;
    position: absolute !important;
    width: 1px !important;
    word-wrap: normal !important;
    white-space: nowrap !important;
}

.idpfi-form-container {
    background-color: var(--idpfi-bg-color);
    padding: 40px 100px 100px;
    border-radius: 20px;
    width: 100%;
    max-width: 1080px;
    box-sizing: border-box;
    box-shadow: 0 4px 24px rgba(31, 36, 64, 0.06);
}

.idpfi-form .form-row {
    display: flex;
    gap: 18px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

/*
 * Formulário público: campos agrupados mais próximos (mockup correcto = direita na imagem).
 * Menos row-gap / column-gap entre inputs e selects na mesma secção.
 */
.idpfi-shortcode-wrap .idpfi-form .form-row {
    row-gap: 10px;
    column-gap: 10px;
    margin-bottom: 12px;
}

/* Duas colunas (Nome + Email): gap horizontal reduzido */
.idpfi-shortcode-wrap .idpfi-form .col-50 {
    flex: 1 1 calc(50% - 5px);
}

/* Três colunas (Município / Ano / Área): pouco espaço entre caixas */
.idpfi-shortcode-wrap .idpfi-form .col-33 {
    flex: 1 1 calc((100% - 20px) / 3);
    min-width: 0;
}

.idpfi-shortcode-wrap .idpfi-form .form-row:last-of-type {
    margin-bottom: 0;
}

.idpfi-shortcode-wrap .idpfi-form h3.idpfi-section-title:not(:first-of-type) {
    margin-block-start: 1.35rem;
}

.idpfi-field {
    display: flex;
    flex-direction: column;
}

.idpfi-form .col-100 {
    flex: 1 1 100%;
}

.idpfi-form .col-50 {
    flex: 1 1 calc(50% - 7.5px);
}

.idpfi-form .col-33 {
    flex: 1 1 calc(33.333% - 10px);
}

.idpfi-section-title {
    font-weight: 700;
    letter-spacing: -0.35px;
    margin-top: 40px;
    margin-bottom: 22px;
    color: var(--idpfi-text-color);
    font-family: var(--idpfi-font-family);
    line-height: 1.2;
}

.idpfi-section-title:first-of-type {
    margin-top: 0;
}

/* Títulos de secção no formulário público — alinhado ao Elementor (h3) */
.idpfi-shortcode-wrap .idpfi-form h3.idpfi-section-title {
    margin: 0;
    color: inherit;
    font-family: inherit;
    font-weight: 500;
    line-height: 1.2;
    margin-block-end: var(--idpfi-title-to-fields-gap, 0.85rem);
    margin-block-start: 0.25rem;
    font-size: 1.75rem;
    letter-spacing: normal;
}

.idpfi-shortcode-wrap .idpfi-form h3.idpfi-section-title:first-of-type {
    margin-block-start: 0;
}

.idpfi-shortcode-wrap .idpfi-form h4.idpfi-section-title {
    margin: 0;
    color: inherit;
    font-family: inherit;
    font-weight: 500;
    line-height: 1.2;
    margin-block-end: var(--idpfi-title-to-fields-gap, 0.85rem);
    margin-block-start: 1.5rem;
    font-size: 1.35rem;
    letter-spacing: normal;
}

/* «Dados de Contacto» (3.º h3): mais espaço relativamente ao bloco anterior; gap para campos = igual aos outros h3 */
.idpfi-shortcode-wrap .idpfi-form > h3.idpfi-section-title:nth-of-type(3) {
    margin-block-start: 1.5rem;
    margin-block-end: var(--idpfi-title-to-fields-gap, 0.85rem);
}

/* Secções finais: mesmo ritmo compacto que o resto do formulário */
.idpfi-shortcode-wrap .idpfi-form > h4.idpfi-section-title + .form-row,
.idpfi-shortcode-wrap .idpfi-form > h3.idpfi-section-title:nth-of-type(3) + .form-row {
    row-gap: 10px;
    margin-bottom: 12px;
}

/* Back-office: títulos de secção mais discretos */
.idpfi-admin-form h3.idpfi-section-title {
    font-size: 16px;
    font-weight: 700;
}

.idpfi-admin-form h4.idpfi-section-title {
    font-size: 15px;
    font-weight: 700;
}

.idpfi-input {
    width: 100%;
    padding: 16px 18px;
    border: 1px solid var(--idpfi-border-color);
    border-radius: 6px;
    background-color: var(--idpfi-input-bg);
    color: #333333;
    font-size: 13px;
    line-height: 1.4;
    font-family: var(--idpfi-font-family);
    font-weight: 500;
    box-sizing: border-box;
    outline: none;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
    min-height: 50px;
}

.idpfi-input::placeholder {
    color: #555555;
    font-weight: 500;
}

.idpfi-input:focus {
    border-color: var(--idpfi-primary-color);
    box-shadow: 0 0 0 2px rgba(82, 78, 250, 0.1);
}

/*
 * Formulário público: campos alinhados a .elementor-field-textual + .elementor-size-lg
 * (border #69727d, 18px, min-height 59px, tipografia herdada do tema/Elementor)
 */
.idpfi-shortcode-wrap .idpfi-input {
    border: 1px solid var(--idpfi-field-border, #69727d);
    border-radius: 5px;
    color: var(--idpfi-field-text, #1f2124);
    font-family: inherit;
    font-size: 18px;
    font-style: inherit;
    font-weight: 600;
    letter-spacing: inherit;
    line-height: 1.35;
    min-height: 59px;
    padding: 7px 20px;
    text-transform: inherit;
    -webkit-font-smoothing: antialiased;
}

.idpfi-shortcode-wrap .idpfi-input::placeholder {
    color: #69727d;
    font-family: inherit;
    font-size: inherit;
    font-weight: 600;
    letter-spacing: inherit;
    line-height: inherit;
    opacity: 1;
}

.idpfi-shortcode-wrap .idpfi-input:focus {
    border-color: var(--idpfi-primary-color);
    box-shadow: 0 0 0 2px rgba(82, 78, 250, 0.12);
}

.idpfi-shortcode-wrap .idpfi-form textarea.idpfi-input {
    min-height: 140px;
    padding-top: 12px;
    padding-bottom: 12px;
    line-height: 1.45;
}

/* Pequeno extra só entre descrição e o bloco de selects seguinte */
.idpfi-shortcode-wrap .idpfi-field.idpfi-field-descricao {
    margin-bottom: 10px;
}

/* Stack de selects em coluna: pouca margem extra (soma com row-gap) */
.idpfi-shortcode-wrap .idpfi-form .form-row .idpfi-field.col-100:has(.idpfi-select-wrap) {
    margin-bottom: 2px;
}

.idpfi-form textarea.idpfi-input {
    resize: vertical;
    min-height: 140px;
}

/*
 * Selects no back-office: seta como background (posição válida em todos os browsers).
 * Nota: `right 18px 50%` é inválido em CSS e fazia a seta cair no canto superior esquerdo.
 */
.idpfi-admin-form select.idpfi-input {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: var(--idpfi-input-bg);
    background-image: var(--idpfi-select-arrow);
    background-repeat: no-repeat;
    background-position: calc(100% - 18px) 50%;
    background-size: 12px 8px;
    cursor: pointer;
    padding-right: 44px;
    line-height: 1.4;
}

/* Formulário público: wrapper + pseudo-elemento (à prova de resets do Elementor/tema) */
.idpfi-shortcode-wrap .idpfi-select-wrap {
    position: relative;
    display: block;
    width: 100%;
}

.idpfi-shortcode-wrap .idpfi-select-wrap::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 18px;
    width: 12px;
    height: 8px;
    margin-top: -4px;
    background-image: var(--idpfi-select-arrow);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 12px 8px;
    pointer-events: none;
    z-index: 2;
}

.idpfi-shortcode-wrap .idpfi-select-wrap select.idpfi-input {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-color: var(--idpfi-input-bg) !important;
    background-image: none !important;
    color: var(--idpfi-field-text, #1f2124) !important;
    font-family: inherit !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    letter-spacing: inherit !important;
    line-height: inherit !important;
    padding-right: 44px !important;
    width: 100%;
    cursor: pointer;
}

/*
 * Opções nativas do <select>: peso bold onde o browser permite (Chrome/Firefox/Safari variam).
 * O texto fechado do select fica alinhado com font-weight acima.
 */
.idpfi-shortcode-wrap .idpfi-select-wrap select.idpfi-input option {
    font-weight: 600 !important;
    font-size: 18px !important;
    font-family: inherit !important;
    padding: 10px 16px !important;
    color: var(--idpfi-field-text, #1f2124) !important;
}

/* =====================================================
 * Multi-select custom widget (trigger + painel com checkboxes)
 * Funciona igual em Chrome/Firefox/Edge/Safari (não usa <select multiple> visualmente).
 * ===================================================== */
.idpfi-multi-select {
    position: relative;
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

/* Native <select multiple> escondido, mas no layout para acessibilidade/submit */
.idpfi-multi-select__native {
    position: absolute !important;
    left: 0;
    top: 0;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    opacity: 0 !important;
    pointer-events: none;
    white-space: nowrap;
    z-index: -1;
}

.idpfi-multi-select__trigger {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    text-align: left;
    cursor: pointer;
    padding-right: 44px;
    position: relative;
    background-color: var(--idpfi-input-bg);
    font-family: inherit;
    -webkit-tap-highlight-color: transparent;
}

.idpfi-multi-select__summary {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #555555;
    font-weight: 500;
}

.idpfi-multi-select.has-selection .idpfi-multi-select__summary {
    color: var(--idpfi-text-color);
    font-weight: 600;
}

.idpfi-multi-select__arrow {
    position: absolute;
    top: 50%;
    right: 18px;
    width: 12px;
    height: 8px;
    margin-top: -4px;
    background-image: var(--idpfi-select-arrow);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 12px 8px;
    pointer-events: none;
    transition: transform 0.2s ease;
}

.idpfi-multi-select.is-open .idpfi-multi-select__arrow {
    transform: rotate(180deg);
}

/* Foco / aberto: contorno neutro (evita halo roxo/vermelho que alguns browsers/temas aplicam a <button>) */
.idpfi-multi-select__trigger:focus,
.idpfi-multi-select__trigger:focus-visible,
.idpfi-multi-select.is-open .idpfi-multi-select__trigger {
    border-color: var(--idpfi-field-border, #69727d);
    box-shadow: none;
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.idpfi-multi-select__trigger:focus-visible {
    outline-color: rgba(105, 114, 125, 0.45);
}

.idpfi-multi-select__panel {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    z-index: 40;
    background: #ffffff;
    border: 1px solid rgba(26, 26, 26, 0.14);
    border-radius: 8px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
    padding: 8px 0;
    max-height: 280px;
    overflow-y: auto;
}

.idpfi-multi-select__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.idpfi-multi-select__option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    cursor: pointer;
    font-size: 14px;
    color: var(--idpfi-text-color);
    font-family: inherit;
    line-height: 1.35;
    user-select: none;
}

.idpfi-multi-select__option:hover,
.idpfi-multi-select__option:focus {
    background: #eef0f4;
    outline: none;
}

.idpfi-multi-select__option.is-selected {
    background: #f4f5f8;
    font-weight: 600;
}

.idpfi-multi-select__check {
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    border: 1.5px solid #b9bfd1;
    border-radius: 4px;
    background: #ffffff;
    position: relative;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.idpfi-multi-select__option.is-selected .idpfi-multi-select__check {
    background: var(--idpfi-primary-color);
    border-color: var(--idpfi-primary-color);
}

.idpfi-multi-select__option.is-selected .idpfi-multi-select__check::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 1px;
    width: 5px;
    height: 10px;
    border: solid #ffffff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.idpfi-multi-select__option-label {
    flex: 1 1 auto;
    min-width: 0;
    overflow-wrap: break-word;
}

/* Frontend (shortcode): alinhar com o visual dos selects (font-size 18px, altura 59px, border-radius 5px) */
.idpfi-shortcode-wrap .idpfi-multi-select__trigger {
    border: 1px solid var(--idpfi-field-border, #69727d);
    border-radius: 5px;
    color: var(--idpfi-field-text, #1f2124);
    font-size: 18px;
    font-weight: 600;
    line-height: 1.35;
    min-height: 59px;
    padding: 7px 44px 7px 20px;
    transition: background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease;
}

/*
 * Hover = mesmo raciocínio do botão CTA «Enviar Inscrição»: fundo roxo da marca + texto branco.
 * Só quando fechado e sem :focus (evita sobrepor o estado aberto / foco de teclado).
 */
.idpfi-shortcode-wrap .idpfi-multi-select:not(.is-open) .idpfi-multi-select__trigger.idpfi-input:hover:not(:focus) {
    background-color: var(--idpfi-primary-color) !important;
    border-color: var(--idpfi-primary-color) !important;
    color: #ffffff !important;
    box-shadow: none !important;
}

.idpfi-shortcode-wrap .idpfi-multi-select:not(.is-open) .idpfi-multi-select__trigger.idpfi-input:hover:not(:focus) .idpfi-multi-select__summary {
    color: #ffffff !important;
}

.idpfi-shortcode-wrap .idpfi-multi-select:not(.is-open) .idpfi-multi-select__trigger.idpfi-input:hover:not(:focus) .idpfi-multi-select__arrow {
    filter: brightness(0) invert(1);
}

/* Hover mais escuro (igual ao .idpfi-submit-btn:hover) */
.idpfi-shortcode-wrap .idpfi-multi-select:not(.is-open) .idpfi-multi-select__trigger.idpfi-input:hover:not(:focus):active {
    background-color: var(--idpfi-primary-hover) !important;
    border-color: var(--idpfi-primary-hover) !important;
}

.idpfi-shortcode-wrap .idpfi-multi-select__summary {
    color: #69727d;
    font-weight: 600;
}

.idpfi-shortcode-wrap .idpfi-multi-select.has-selection .idpfi-multi-select__summary {
    color: var(--idpfi-field-text, #1f2124);
}

/* Placeholder de resumo em col-33 (caixas estreitas): truncagem boa */
.idpfi-shortcode-wrap .idpfi-form .col-33 .idpfi-multi-select__summary {
    font-size: 16px;
}

/* Linhas flex: permitir que campos encolham e o texto do resumo não alargue a página */
.idpfi-form .form-row .idpfi-field {
    min-width: 0;
}

/*
 * Multi-select trigger usa também .idpfi-input — sobrepor regras de foco do tema/Elementor
 * (halo roxo/vermelho e fundos coloridos no :focus / :active).
 */
.idpfi-shortcode-wrap .idpfi-multi-select .idpfi-multi-select__trigger.idpfi-input:focus,
.idpfi-shortcode-wrap .idpfi-multi-select .idpfi-multi-select__trigger.idpfi-input:focus-visible,
.idpfi-shortcode-wrap .idpfi-multi-select.is-open .idpfi-multi-select__trigger.idpfi-input,
.idpfi-shortcode-wrap .idpfi-multi-select .idpfi-multi-select__trigger.idpfi-input:active {
    border-color: var(--idpfi-field-border, #69727d) !important;
    box-shadow: none !important;
    background-color: var(--idpfi-input-bg, #ffffff) !important;
    color: var(--idpfi-field-text, #1f2124) !important;
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.idpfi-shortcode-wrap .idpfi-multi-select .idpfi-multi-select__trigger.idpfi-input:focus-visible {
    outline-color: rgba(105, 114, 125, 0.45);
}

.idpfi-admin-form .idpfi-multi-select .idpfi-multi-select__trigger.idpfi-input:focus,
.idpfi-admin-form .idpfi-multi-select .idpfi-multi-select__trigger.idpfi-input:focus-visible,
.idpfi-admin-form .idpfi-multi-select.is-open .idpfi-multi-select__trigger.idpfi-input,
.idpfi-admin-form .idpfi-multi-select .idpfi-multi-select__trigger.idpfi-input:active {
    border-color: var(--idpfi-border-color, #d7d9ea) !important;
    box-shadow: none !important;
    background-color: var(--idpfi-input-bg, #ffffff) !important;
    color: #333333 !important;
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.idpfi-admin-form .idpfi-multi-select .idpfi-multi-select__trigger.idpfi-input:focus-visible {
    outline-color: rgba(105, 114, 125, 0.45);
}

.idpfi-combobox {
    position: relative;
}

.idpfi-combobox-input {
    padding-right: 46px;
}

.idpfi-combobox-toggle {
    position: absolute;
    top: 1px;
    right: 1px;
    bottom: 1px;
    width: 44px;
    border: 0;
    background: transparent;
    cursor: pointer;
    border-radius: 0 6px 6px 0;
}

.idpfi-combobox-toggle:focus {
    outline: none;
}

.idpfi-combobox-toggle-icon {
    display: inline-block;
    width: 14px;
    height: 10px;
    background-image: var(--idpfi-select-arrow);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 12px 8px;
}

.idpfi-combobox.is-open .idpfi-combobox-toggle-icon {
    transform: rotate(180deg);
}

.idpfi-combobox-panel {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    z-index: 30;
    background: #ffffff;
    border: 1px solid rgba(26, 26, 26, 0.14);
    border-radius: 8px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
    padding: 10px;
}

.idpfi-combobox-message {
    font-size: 12px;
    line-height: 1.45;
    color: #5f6c7b;
    margin-bottom: 8px;
}

.idpfi-combobox-options {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 220px;
    overflow-y: auto;
}

.idpfi-combobox-option {
    display: block;
    width: 100%;
    text-align: left;
    border: 1px solid #d7dbe7;
    background: #ffffff;
    border-radius: 6px;
    padding: 10px 12px;
    cursor: pointer;
    font: inherit;
    color: #1a1a1a;
}

.idpfi-combobox-option:hover,
.idpfi-combobox-option:focus {
    border-color: var(--idpfi-primary-color);
    background: rgba(82, 78, 250, 0.06);
}

.idpfi-combobox-add {
    margin-top: 8px !important;
    width: 100%;
    justify-content: center;
}

.submit-btn,
.idpfi-submit-btn {
    background-color: var(--idpfi-primary-color);
    color: #ffffff;
    border: none;
    padding: 18px 16px;
    font-size: 14px;
    font-weight: 700;
    font-family: var(--idpfi-font-family);
    border-radius: 8px;
    cursor: pointer;
    width: 100%;
    margin-top: 12px;
    transition: background-color 0.3s ease, opacity 0.3s ease;
    min-height: 54px;
}

.idpfi-shortcode-wrap .idpfi-submit-btn {
    margin-top: 18px;
}

.submit-btn:hover,
.idpfi-submit-btn:hover {
    background-color: var(--idpfi-primary-hover);
}

.idpfi-submit-btn.is-loading,
.idpfi-approve-form button.is-loading,
.idpfi-reject-form button.is-loading,
.idpfi-deactivate-form button.is-loading,
.idpfi-delete-form button.is-loading {
    opacity: 0.75;
    pointer-events: none;
}

.idpfi-notice {
    margin-bottom: 18px;
    padding: 14px 16px;
    border-radius: 6px;
    font-weight: 600;
}

.idpfi-notice-success {
    background: var(--idpfi-success-bg);
    color: var(--idpfi-success-text);
}

.idpfi-notice-error {
    background: var(--idpfi-error-bg);
    color: var(--idpfi-error-text);
}

.idpfi-field-label {
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--idpfi-text-color);
    font-family: var(--idpfi-font-family);
}

.idpfi-admin-wrap {
    max-width: 1200px;
}

.idpfi-admin-card {
    margin-top: 18px;
    background: #ffffff;
    border: 1px solid #dcdcde;
    border-radius: 10px;
    padding: 24px;
}

.idpfi-admin-intro {
    display: grid;
    gap: 16px;
}

.idpfi-intro-text {
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
}

.idpfi-shortcode-box {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
    padding: 16px;
    border: 1px dashed #b9bfd1;
    border-radius: 8px;
    background: #f7f8fc;
}

.idpfi-shortcode-code {
    display: inline-block;
    margin-top: 8px;
    padding: 8px 12px;
    background: #1f2430;
    color: #ffffff;
    border-radius: 6px;
    font-size: 13px;
}

.idpfi-warning-text {
    margin: 0;
    color: #8a5a00;
    font-weight: 600;
}

.idpfi-edit-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-bottom: 18px;
    flex-wrap: wrap;
}

.idpfi-table th,
.idpfi-table td {
    vertical-align: top;
}

.idpfi-muted {
    color: #5f6c7b;
    margin-top: 4px;
}

.idpfi-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}

.idpfi-inline-form {
    display: inline-flex;
}

.idpfi-button-danger {
    color: var(--idpfi-danger-color) !important;
    border-color: var(--idpfi-danger-color) !important;
}

.idpfi-button-danger:hover,
.idpfi-button-danger:focus {
    color: var(--idpfi-danger-hover) !important;
    border-color: var(--idpfi-danger-hover) !important;
}

.idpfi-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
}

.idpfi-badge-pendente {
    background: #fff3cd;
    color: #856404;
}

.idpfi-badge-aprovado {
    background: #d4edda;
    color: #155724;
}

.idpfi-badge-rejeitado {
    background: #f8d7da;
    color: #721c24;
}

.idpfi-badge-publicado {
    background: #dbeafe;
    color: #1d4ed8;
}

.idpfi-badge-inativo {
    background: #eceff3;
    color: #4b5563;
}

.idpfi-admin-form .idpfi-field {
    margin-bottom: 2px;
}

.idpfi-admin-actions {
    display: flex;
    gap: 12px;
    margin-top: 24px;
    flex-wrap: wrap;
}

@media (max-width: 1200px) {
    .idpfi-form-container {
        padding: 40px 48px 72px;
    }
}

@media (max-width: 782px) {
    .idpfi-shortcode-wrap {
        padding: 32px 16px;
    }

    .idpfi-form-container {
        padding: 36px 24px 56px;
        border-radius: 16px;
    }

    .idpfi-shortcode-wrap .idpfi-form h3.idpfi-section-title {
        font-size: 1.45rem;
    }

    .idpfi-shortcode-wrap .idpfi-form h4.idpfi-section-title {
        font-size: 1.15rem;
    }

    .idpfi-form .col-50,
    .idpfi-form .col-33 {
        flex: 1 1 100%;
    }

    .idpfi-shortcode-wrap .idpfi-form .col-50,
    .idpfi-shortcode-wrap .idpfi-form .col-33 {
        flex: 1 1 100%;
    }
}
