/**
 * recife_form.css — estilos mobile-first do recifemecatron_form_v2.php.
 * Carregado por grupojb/custom_forms/recifemecatron_form_v2.php.
 */

/* =========================================================================
   Tokens
   ========================================================================= */
:root {
    --cor-primaria: #ee5808;
    --cor-bg: #575757;
    --radius: .75rem;
    --tap-target: 48px;
}

/* =========================================================================
   Base (mobile-first)
   ========================================================================= */
html, body {
    max-width: 100%;
    overflow-x: hidden;
}
body {
    font-family: 'Sora', sans-serif;
    background: var(--cor-bg);
}

h1, h2, h3, h4, h5 {
    font-family: 'Exo 2', sans-serif;
}

h1 { font-size: clamp(1.5rem, 5vw, 2.5rem); }
h3 { font-size: clamp(1.15rem, 4vw, 1.5rem); }

/* Botão primário — tap-target generoso em telas pequenas */
.btn-primario {
    background: var(--cor-primaria);
    color: #fff;
    border: none;
    min-height: var(--tap-target);
}
.btn-primario:hover,
.btn-primario:focus,
.btn-primario:disabled {
    background: var(--cor-primaria);
    color: #fff;
    opacity: .92;
}
.btn-primario.btn-sm { min-height: 40px; }

.text-primario { color: var(--cor-primaria); }

/* =========================================================================
   Header (logo) e hero
   ========================================================================= */
.logo-header {
    padding: .75rem 1rem;
    text-align: center;
}
.logo-header img {
    width: 100%;
    max-width: 240px;
    height: auto;
}

.overlay {
    background: url('https://recifemecatron.com/assets/images/office.webp') center/cover no-repeat;
    /* Contém o banner dentro do viewport em telas pequenas (sem padding lateral
       herdado do .container-fluid que gerava rolagem horizontal). */
    width: 100%;
    max-width: 100vw;
    padding-left: 0;
    padding-right: 0;
    overflow: hidden;
    box-sizing: border-box;
}
.overlay-inside {
    background: rgba(0, 0, 0, .6);
    padding: 1.75rem 1rem;
    color: #fff;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
}
.overlay-inside h1 {
    overflow-wrap: anywhere;
    word-break: break-word;
    margin: 0;
}

/* =========================================================================
   Card do formulário
   ========================================================================= */
.form-card {
    background: #fff;
    border-radius: var(--radius);
    box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .08);
    padding: 1.25rem;
}

/* =========================================================================
   Indicador de passos
   ========================================================================= */
.step-indicator {
    display: flex;
    gap: .35rem;
    justify-content: center;
    margin: 0 0 .75rem;
}
.step-indicator span {
    flex: 1;
    max-width: 2.5rem;
    height: .4rem;
    background: #e0e0e0;
    border-radius: 999px;
    transition: background .2s;
}
.step-indicator span.done,
.step-indicator span.current { background: var(--cor-primaria); }

.step-numero {
    display: block;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: .06em;
    font-size: .72rem;
    font-weight: 600;
    color: var(--cor-primaria);
    margin-bottom: .15rem;
}

/* =========================================================================
   Steps (seções do formulário)
   ========================================================================= */
.step { display: none; }
.step.is-active { display: block; }

/* Inputs — tap-target em tela pequena */
.form-control,
.form-select {
    min-height: var(--tap-target);
}
label.fw-bold {
    display: block;
    margin-bottom: .25rem;
}

/* =========================================================================
   Focus — destaca campo (inputs, selects, datalist, textarea) e o <label>
   do container pai com a cor primária do tema.
   ========================================================================= */
#formInscricao .form-control:focus,
#formInscricao .form-select:focus,
#formInscricao input:focus,
#formInscricao select:focus,
#formInscricao textarea:focus {
    border-color: var(--cor-primaria);
    outline: none;
    /* color-mix mantém o ring derivado da mesma --cor-primaria, sem hardcode. */
    box-shadow: 0 0 0 .2rem color-mix(in srgb, var(--cor-primaria) 25%, transparent);
    transition: border-color .15s ease, box-shadow .15s ease;
}

/* Label do container imediato muda para a cor primária quando qualquer campo
   interno está focado. Estrutura típica do form:
     <div class="col-md-X"><label>…</label><input ou select></div>
     <div class="mb-3"><label>…</label><div class="input-group">…</div></div>
   Como <label> só aparece como filho direto desses wrappers (nunca de <section>
   ou <form>), o seletor universal abaixo é seguro — :focus-within só atinge o
   container correto. */
#formInscricao *:focus-within > label {
    color: var(--cor-primaria);
    transition: color .15s ease;
}

/* =========================================================================
   Listagem de vagas — cards no mobile, tabela no desktop
   ========================================================================= */
.vagas-table { margin-bottom: 1rem; }

@media (max-width: 767.98px) {
    .vagas-table,
    .vagas-table thead,
    .vagas-table tbody,
    .vagas-table tr,
    .vagas-table td {
        display: block;
        width: 100%;
    }
    .vagas-table thead {
        position: absolute;
        left: -9999px;
    }
    .vagas-table tr {
        border: 1px solid #dee2e6 !important;
        border-radius: var(--radius);
        padding: 1rem;
        margin-bottom: .75rem;
        background: #fff;
    }
    .vagas-table td {
        padding: .25rem 0 !important;
        border: 0 !important;
        background: transparent !important;
    }
    .vagas-table td[data-label]::before {
        content: attr(data-label);
        display: block;
        font-size: .7rem;
        font-weight: 600;
        color: #6c757d;
        text-transform: uppercase;
        letter-spacing: .03em;
    }
    .vagas-table td:last-child { margin-top: .75rem; }
    .vagas-table td:last-child::before { display: none; }
    .vagas-table td:last-child .btn {
        width: 100%;
        min-height: var(--tap-target);
    }
    /* desativa o "striped" do Bootstrap quando a tabela vira card */
    .vagas-table.table-striped > tbody > tr:nth-of-type(odd) > * {
        background-color: transparent !important;
    }
}

/* =========================================================================
   Vaga selecionada (banner no topo do step de verificação)
   ========================================================================= */
[data-vaga-selecionada] .d-flex {
    flex-wrap: wrap;
    gap: .75rem;
}

/* =========================================================================
   Itens dinâmicos (certificados, formação, experiências, cursos, idiomas)
   ========================================================================= */
.item-dinamico {
    border: 1px solid #dee2e6;
    border-radius: var(--radius);
    padding: 1rem;
    padding-right: 2.5rem;
    margin-bottom: .75rem;
    background: #fafafa;
    position: relative;
}
.item-dinamico .remover {
    position: absolute;
    top: .75rem;
    right: .75rem;
    float: none;
    width: 2rem;
    height: 2rem;
    padding: .25rem;
}
.item-dinamico .row > [class*="col"] { margin-bottom: .5rem; }

/* Botão "Adicionar ..." com área de toque maior */
.btn-add-inline {
    min-height: 40px;
}

/* =========================================================================
   Barra de navegação do step (Voltar / Continuar)
   ========================================================================= */
.form-nav {
    display: flex;
    gap: .75rem;
    margin-top: 1.5rem;
}
.form-nav .btn {
    flex: 1;
    min-height: var(--tap-target);
}

/* =========================================================================
   Alerta de feedback
   ========================================================================= */
.alerta-feedback { display: none; margin-top: 1rem; }
.alerta-feedback.visivel { display: block; }

/* =========================================================================
   Chips (habilidades de informática / idiomas)
   ========================================================================= */
.chips-container {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    min-height: 1.5rem;
}
.chip {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    background: #fff;
    border: 1px solid #dee2e6;
    border-radius: 999px;
    padding: .35rem .25rem .35rem .85rem;
    font-size: .9rem;
    line-height: 1;
    min-height: 36px;
}
.chip-label {
    white-space: nowrap;
}
.chip-close {
    width: 1.75rem;
    height: 1.75rem;
    border: 0;
    background: transparent;
    color: #6c757d;
    font-size: 1.25rem;
    line-height: 1;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}
.chip-close:hover,
.chip-close:focus {
    background: rgba(0, 0, 0, .08);
    color: #000;
    outline: none;
}

/* =========================================================================
   Star rating (habilidades)
   ========================================================================= */
.star-rating { display: inline-flex; gap: .25rem; }
.star-rating button {
    border: 0;
    background: transparent;
    padding: .25rem;
    cursor: pointer;
    font-size: 1.5rem;
    line-height: 1;
    color: #d0d0d0;
    min-width: 2.25rem;
    min-height: 2.25rem;
}
.star-rating button.selected,
.star-rating button:hover { color: var(--cor-primaria); }

/* =========================================================================
   FCM desativado — oculta markup residual (modal + toast-container) enquanto
   o JS do FCM não está ligado. O toast-container é position: fixed; bottom: 0
   e, em telas pequenas, sobrepunha os botões da .form-nav capturando os taps.
   ========================================================================= */
[data-fcm-disabled="true"] { display: none !important; }

/* =========================================================================
   No-JS fallback
   ========================================================================= */
.sem-js {
    display: block;
    padding: 2rem;
    background: #fff;
    color: #000;
    text-align: center;
}

/* =========================================================================
   Modal de detalhes da vaga — preserva as quebras de linha dos campos
   (os valores entram via textContent; sem isto o HTML colapsa \n / \r\n)
   ========================================================================= */
#modalDetalhesVaga .modal-body dd[data-campo] {
    white-space: pre-line;
}

/* =========================================================================
   Modal de detalhes da vaga — ajustes para telas pequenas
   ========================================================================= */
@media (max-width: 575.98px) {
    #modalDetalhesVaga .modal-body dt {
        font-size: .75rem;
        text-transform: uppercase;
        color: #6c757d;
        padding-top: .6rem;
        margin-bottom: .1rem;
    }
    #modalDetalhesVaga .modal-body dd { margin-bottom: .5rem; }
    #modalDetalhesVaga .modal-footer { flex-direction: column; gap: .5rem; }
    #modalDetalhesVaga .modal-footer .btn {
        width: 100%;
        margin: 0;
        min-height: var(--tap-target);
    }
}

/* =========================================================================
   Tablet / desktop — refinamentos
   ========================================================================= */
@media (min-width: 768px) {
    .logo-header { padding: 1rem; }
    .logo-header img { max-width: 360px; }

    .overlay-inside { padding: 6% 8%; }

    .form-card { padding: 2rem; }

    .step-indicator span { max-width: 3rem; }

    .form-nav { justify-content: space-between; }
    .form-nav .btn {
        flex: 0 0 auto;
        min-width: 9rem;
    }

    .item-dinamico { padding-right: 2.75rem; }
}

@media (min-width: 992px) {
    .form-card { padding: 2.5rem; }
    .overlay-inside { padding: 8% 10%; }
}
