/* ============================================================
   Makro Corridas — Formulário de Inscrição
   ============================================================ */

.mfi-wrap {
    width: 100%;
    margin: 2rem 0;
    font-family: var(--makro-fonte-base, 'Segoe UI', system-ui, sans-serif);
    color: var(--makro-cor-texto, #2c3e50);
}

/* ── Progresso ── */
.mfi-progress {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    position: relative;
    padding: 1.5rem 2rem 0;
    background: #fff;
    border: 1px solid #dee2e6;
    border-top: none;
    border-bottom: none;
}

.mfi-progress::after {
    content: '';
    position: absolute;
    top: 2.35rem;
    left: calc(2rem + 18px);
    right: calc(2rem + 18px);
    height: 2px;
    background: #dee2e6;
    z-index: 0;
}

.mfi-progress__line {
    position: absolute;
    top: 2.35rem;
    left: calc(2rem + 18px);
    height: 2px;
    background: var(--makro-cor-primaria, #1a5276);
    z-index: 1;
    transition: width .4s ease;
    width: 0%;
}

.mfi-step-indicator {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .4rem;
    position: relative;
    z-index: 2;
    flex: 1;
}

.mfi-step-indicator__dot {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid #dee2e6;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    font-weight: 700;
    color: #aaa;
    transition: all .3s;
}

.mfi-step-indicator__label {
    font-size: .7rem;
    font-weight: 600;
    color: #aaa;
    text-transform: uppercase;
    letter-spacing: .05em;
    text-align: center;
    transition: color .3s;
    white-space: nowrap;
}

.mfi-step-indicator.is-done .mfi-step-indicator__dot {
    background: var(--makro-cor-primaria, #1a5276);
    border-color: var(--makro-cor-primaria, #1a5276);
    color: #fff;
}

.mfi-step-indicator.is-active .mfi-step-indicator__dot {
    background: #fff;
    border-color: var(--makro-cor-primaria, #1a5276);
    color: var(--makro-cor-primaria, #1a5276);
    box-shadow: 0 0 0 4px rgba(26,82,118,.12);
}

.mfi-step-indicator.is-active .mfi-step-indicator__label,
.mfi-step-indicator.is-done .mfi-step-indicator__label {
    color: var(--makro-cor-primaria, #1a5276);
}

/* Cabeçalho do evento */
.mfi-evento-header {
    background: var(--makro-cor-primaria, #1a5276);
    color: #fff;
    border-radius: 10px 10px 0 0;
    padding: 1.5rem 2rem;
}

.mfi-evento-header__titulo {
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0 0 .5rem;
    line-height: 1.3;
}

.mfi-evento-header__meta {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    font-size: .875rem;
    opacity: .9;
    margin-bottom: 1rem;
}

.mfi-lote-badge {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 50px;
    padding: .35rem 1rem;
    width: fit-content;
}

.mfi-lote-badge__nome {
    font-size: .8rem;
    opacity: .85;
}

.mfi-lote-badge__preco {
    font-size: 1.1rem;
    font-weight: 700;
}

/* Formulário */
.mfi-form {
    background: #fff;
    border: 1px solid #dee2e6;
    border-top: none;
    border-radius: 0 0 10px 10px;
    padding: 0 0 2rem;
}

/* Fieldsets */
.mfi-fieldset {
    border: none;
    padding: 1.75rem 2rem 0;
    margin: 0;
    display: none;
}

.mfi-fieldset.is-active { display: block; }

.mfi-fieldset__legend {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--makro-cor-primaria, #1a5276);
    background: var(--makro-cor-primaria, #1a5276);
    color: #fff;
    padding: .25rem .75rem;
    border-radius: 4px;
    margin-bottom: 1.25rem;
    display: block;
}

/* Grid */
.mfi-grid {
    display: grid;
    gap: 1rem;
}

.mfi-grid--2 { grid-template-columns: 1fr 1fr; }
.mfi-grid--3 { grid-template-columns: 1fr 1fr 1fr; }

/* Campos */
.mfi-field { display: flex; flex-direction: column; gap: .35rem; }
.mfi-field--full { grid-column: 1 / -1; }

.mfi-label {
    font-size: .85rem;
    font-weight: 600;
    color: #444;
}

.mfi-obrigatorio { color: #e74c3c; }

.mfi-input,
.mfi-select {
    width: 100%;
    padding: .6rem .85rem;
    border: 1.5px solid #ced4da;
    border-radius: 6px;
    font-size: .95rem;
    font-family: inherit;
    color: #2c3e50;
    background: #fff;
    transition: border-color .2s, box-shadow .2s;
    appearance: none;
    -webkit-appearance: none;
}

.mfi-input:focus,
.mfi-select:focus {
    outline: none;
    border-color: var(--makro-cor-primaria, #1a5276);
    box-shadow: 0 0 0 3px rgba(26,82,118,.12);
}

.mfi-input::placeholder { color: #aaa; }

.mfi-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .85rem center;
    padding-right: 2.25rem;
    cursor: pointer;
}

.mfi-select:disabled {
    background-color: #f5f5f5;
    color: #999;
    cursor: not-allowed;
}

/* Termos */
.mfi-fieldset--termos { padding-bottom: .5rem; }

.mfi-check {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    margin-bottom: .85rem;
    cursor: pointer;
    font-size: .9rem;
    line-height: 1.5;
}

.mfi-check input[type="checkbox"] {
    width: 18px;
    height: 18px;
    min-width: 18px;
    margin-top: .15rem;
    accent-color: var(--makro-cor-primaria, #1a5276);
    cursor: pointer;
}

.mfi-check a { color: var(--makro-cor-primaria, #1a5276); }

/* Rodapé */
.mfi-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem 2rem 0;
    border-top: 1px solid #dee2e6;
    margin-top: 1.75rem;
}

.mfi-btn-back {
    background: transparent;
    color: var(--makro-cor-primaria, #1a5276);
    border: 2px solid var(--makro-cor-primaria, #1a5276);
    border-radius: 8px;
    padding: .85rem 1.75rem;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: background .2s, color .2s;
}

.mfi-btn-back:hover {
    background: var(--makro-cor-primaria, #1a5276);
    color: #fff;
}

.mfi-btn-next {
    background: var(--makro-cor-primaria, #1a5276);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: .85rem 2rem;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: opacity .2s;
    margin-left: auto;
}

.mfi-btn-next:hover { opacity: .88; }

.mfi-footer__resumo {
    display: flex;
    flex-direction: column;
    gap: .15rem;
}

.mfi-footer__label {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #888;
}

.mfi-footer__valor {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--makro-cor-primaria, #1a5276);
}

.mfi-btn-submit {
    background: var(--makro-cor-secundaria, #f39c12);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: .85rem 2rem;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: opacity .2s, transform .1s;
    white-space: nowrap;
}

.mfi-btn-submit:hover { opacity: .88; }
.mfi-btn-submit:active { transform: scale(.98); }

/* Avisos */
.makro-aviso {
    padding: 1rem 1.25rem;
    border-radius: 8px;
    font-size: .95rem;
}

.makro-aviso--erro   { background: #fdecea; color: #c0392b; border: 1px solid #f5c6cb; }
.makro-aviso--aviso  { background: #fff8e1; color: #856404; border: 1px solid #ffeeba; }

/* Abas cadastro/login */
.mfi-tabs {
    display: flex;
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    border-top: none;
    border-bottom: none;
}

.mfi-tab {
    flex: 1;
    padding: .9rem 1rem;
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    font-size: .95rem;
    font-weight: 600;
    color: #888;
    cursor: pointer;
    transition: color .2s, border-color .2s;
}

.mfi-tab.is-active {
    color: var(--makro-cor-primaria, #1a5276);
    border-bottom-color: var(--makro-cor-primaria, #1a5276);
    background: #fff;
}

.mfi-tab-panel { display: none; }
.mfi-tab-panel.is-active { display: block; }

/* Campo senha com toggle */
.mfi-input-senha {
    position: relative;
    display: flex;
    align-items: center;
}

.mfi-input-senha .mfi-input {
    padding-right: 2.75rem;
}

.mfi-toggle-senha {
    position: absolute;
    right: .6rem;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    padding: 0;
    line-height: 1;
    color: #888;
}

.mfi-senha-regras {
    font-size: .78rem;
    color: #888;
    margin-top: .2rem;
    display: block;
}

.mfi-grid--1 { grid-template-columns: 1fr; }

/* CEP com botão */
.mfi-cep-wrap {
    display: flex;
    gap: .5rem;
}

.mfi-cep-wrap .mfi-input {
    flex: 1;
}

.mfi-btn-cep {
    white-space: nowrap;
    background: var(--makro-cor-primaria, #1a5276);
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: .6rem 1rem;
    font-size: .875rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .2s;
}

.mfi-btn-cep:hover    { opacity: .88; }
.mfi-btn-cep:disabled { opacity: .6; cursor: not-allowed; }

/* Responsivo */
@media (max-width: 600px) {
    .mfi-wrap { margin: 1rem; }
    .mfi-evento-header { padding: 1.25rem; border-radius: 8px 8px 0 0; }
    .mfi-progress { padding: 1.25rem 1.25rem 0; overflow-x: auto; }
    .mfi-step-indicator__label { display: none; }
    .mfi-fieldset { padding: 1.25rem 1.25rem 0; }
    .mfi-grid--2,
    .mfi-grid--3 { grid-template-columns: 1fr; }
    .mfi-footer { flex-direction: column; align-items: stretch; }
    .mfi-btn-back,
    .mfi-btn-next,
    .mfi-btn-submit { text-align: center; width: 100%; }
    .mfi-btn-next { margin-left: 0; }
}
