@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&display=swap');

:root { --brand:#ff7f00; --brand-dark:#c96200; }

* { box-sizing: border-box; }

body {
    font-family: 'Poppins', sans-serif;
    font-size: 15px;
    background: #f5f6f8;
    padding-bottom: 50px;
    color: #34495e;
}

/* ---- Cabeçalho ---- */
.ooseg-header {
    background: var(--brand);
    padding: 12px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
}
.ooseg-header img { height: 42px; }
.ooseg-header span { color:#fff; font-size:15px; font-weight:600; letter-spacing:.3px; }

/* ---- Progress ---- */
.step-bar {
    background: #fff;
    padding: 8px 16px 10px;
    border-bottom: 1px solid #e5e5e5;
    font-size: 12px;
    color: #888;
}
.step-bar .progress { height: 5px; border-radius: 3px; background: #e9ecef; margin-top: 6px; }
.step-bar .progress-bar { background: var(--brand); border-radius: 3px; }

/* ---- Card ---- */
.step-card {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
    padding: 20px 16px;
    margin: 16px 12px;
}
.step-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--brand);
    margin-bottom: 18px;
    padding-bottom: 10px;
    border-bottom: 2px solid #f0f0f0;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* ---- Formulários — 16px evita zoom iOS ---- */
.form-control,
.form-select,
input[type=text],
input[type=email],
input[type=tel],
input[type=date],
input[type=number],
select, textarea {
    font-size: 16px !important;
    min-height: 48px;
    border: 2px solid #e5e5e5;
    border-radius: 6px;
    padding: 10px 14px;
    transition: border-color .2s;
    width: 100%;
}
.form-control:focus, .form-select:focus,
input:focus, select:focus, textarea:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 3px rgba(255,127,0,.15);
    outline: 0;
}
label.form-label { font-weight: 500; margin-bottom: 5px; font-size: 14px; }
.form-text { font-size: 12px; color: #888; }

/* ---- Grupos de Radio ---- */
.radio-group { display: flex; flex-direction: column; gap: 8px; margin-bottom: 4px; }
.radio-opt {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #f8f9fa;
    border: 2px solid #e5e5e5;
    border-radius: 8px;
    padding: 13px 14px;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    font-size: 15px;
}
.radio-opt input[type=radio] {
    width: 20px; height: 20px; min-height: 20px;
    accent-color: var(--brand);
    flex-shrink: 0;
}
.radio-opt:has(input:checked) {
    border-color: var(--brand);
    background: #fff8f2;
    color: var(--brand);
    font-weight: 600;
}

/* ---- Botões ---- */
.btn-avan {
    display: block;
    width: 100%;
    min-height: 52px;
    font-size: 16px;
    font-weight: 600;
    background: var(--brand);
    color: #fff;
    border: 0;
    border-radius: 8px;
    letter-spacing: .3px;
    margin-top: 22px;
    transition: background .2s;
}
.btn-avan:hover, .btn-avan:focus { background: var(--brand-dark); color: #fff; }
.btn-avan i { margin-right: 8px; }

.btn-voltar {
    display: block;
    width: 100%;
    min-height: 44px;
    font-size: 14px;
    color: #888;
    background: transparent;
    border: 1px solid #ddd;
    border-radius: 8px;
    margin-top: 10px;
    transition: background .2s;
}
.btn-voltar:hover { background: #f5f5f5; }

/* ---- CEP ---- */
.cep-result {
    background: #e8f5e9;
    border-radius: 6px;
    padding: 10px 14px;
    font-size: 13px;
    color: #2e7d32;
    margin-top: 6px;
    display: none;
}
.cep-loading { color: #888; font-size: 13px; margin-top: 6px; display: none; }

/* ---- Legenda de campo ---- */
.field-block { margin-bottom: 18px; }

/* ---- FIPE selects ---- */
.fipe-select {
    margin-bottom: 12px;
    position: relative;
}
.fipe-select::after {
    content: '';
    position: absolute;
    right: 14px; top: 50%;
    transform: translateY(-50%);
    border: 5px solid transparent;
    border-top-color: #888;
    pointer-events: none;
}

/* ---- Alerta flash ---- */
.flash-msg {
    margin: 12px;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
}
.flash-msg.erro { background:#fde8e8; color:#c0392b; border-left:4px solid #c0392b; }
.flash-msg.ok   { background:#e8f5e9; color:#27ae60; border-left:4px solid #27ae60; }

/* ---- Obrigado ---- */
.obrigado-card { text-align:center; padding: 40px 20px; }
.obrigado-card i { font-size:64px; color: var(--brand); margin-bottom: 20px; }
.obrigado-card h2 { font-size: 22px; font-weight: 600; }
.obrigado-card p { color: #888; }
