﻿.pb-form {
    color: var(--l-text);
}

    .pb-form *,
    .pb-form *::before,
    .pb-form *::after {
        box-sizing: border-box;
        min-width: 0;
    }

    .pb-form button,
    .pb-form input,
    .pb-form select,
    .pb-form textarea {
        font: inherit;
    }

    .pb-form button {
        cursor: pointer;
    }

    .pb-form .form-shell {
        width: min(100%, 1040px);
    }

    /* Layout */

    .pb-form .wizard {
        display: grid;
        align-items: stretch;
        overflow: hidden;
        min-height: 620px;
        border: 1px solid var(--l-border);
        border-radius: var(--r-lg);
        background: var(--l-bg);
        box-shadow: 0 18px 60px rgba(11, 11, 11, .06);
    }

    .pb-form .wizard-aside {
        display: flex;
        flex-direction: column;
        gap: var(--s-5);
        padding: var(--s-5) var(--s-4);
        border-right: 1px solid var(--l-border);
        background: var(--l-surface-2);
    }

    .pb-form .wizard-main,
    .pb-form .wz-main {
        display: flex;
        min-width: 0;
        flex-direction: column;
    }

    .pb-form .wizard-content,
    .pb-form .card {
        flex: 1;
        padding: var(--s-3) var(--s-6);
    }

    .pb-form .card h2 {
        margin-bottom : var(--s-4) !important;
        margin : 0px
    }

    .pb-form .lead {
        margin:0px
    }

    .pb-form .wizard-content {
        position: relative;
    }

    .pb-form .card {
        display: flex;
        min-height: 0;
        flex-direction: column;
        background: transparent;
    }

    /* Marca */

    .pb-form .aside-title,
    .pb-form .wz-mini-brand {
        display: flex;
        align-items: center;
        gap: var(--s-2);
        margin-bottom: var(--s-3);
        font-weight: 800;
        letter-spacing: -.04em;
    }

        .pb-form .aside-title img {
            width: 65%;
            object-fit: contain;
        }

    .pb-form .mark {
        position: relative;
        flex: 0 0 auto;
        width: 24px;
        height: 24px;
        border-radius: var(--r-sm);
        background: var(--pb-red);
    }

    .pb-form .mark--sm,
    .pb-form .aside-title .mark {
        width: 18px;
        height: 18px;
        border-radius: 3px;
    }

    .pb-form .mark::after {
        content: "";
        position: absolute;
        inset: 7px 5px 5px 7px;
        border-radius: 1px;
        background: var(--d-text);
        clip-path: polygon(0 100%, 100% 0, 100% 100%);
    }

    .pb-form .mark--sm::after,
    .pb-form .aside-title .mark::after {
        inset: 5px 4px 4px 5px;
    }

    .pb-form .brand-dot {
        color: var(--pb-red);
    }

    /* Sidebar / Etapas */

    .pb-form .steps,
    .pb-form .wz-steps {
        display: flex;
        flex: 1;
        flex-direction: column;
        gap: var(--s-2);
        border: 0;
    }

    .pb-form .step,
    .pb-form .wz-step {
        position: relative;
        display: grid;
        grid-template-columns: 30px 1fr;
        align-items: center;
        gap: var(--s-3);
        min-height: 40px;
        padding: var(--s-2) var(--s-2);
        border-radius: var(--r-sm);
        transition: background var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease);
    }

        .pb-form .step-num,
        .pb-form .wz-step .num {
            font-size : 10px;
            padding : 0;
            line-height : 1;
            display: flex;
            align-items: center;
            justify-content: center;
            width: 20px;
            height: 20px;
            margin-left : var(--s-2);
            margin-bottom: 0;
            border: 1px solid var(--l-border-2);
            border-radius: 999px;
            background: var(--l-bg);
            color: var(--l-text-3);
            font-family: var(--font-mono);
            font-weight: 600;
            text-align: center;
        }

        .pb-form .step-label,
        .pb-form .wz-step .lbl {
            font-size : 11px;
            display: flex;
            flex-direction: column;
            gap: 2px;
            color: var(--l-text-2);
            font-weight: 600;
            text-transform: none !important;
        }

            .pb-form .step-label small,
            .pb-form .wz-step .lbl small,
            .pb-form .wz-step .lbl em {
                color: var(--l-text-3);
                font-family: var(--font-mono);
                font-style: normal;
                font-weight: 500;
                letter-spacing: .1em;
                text-transform: uppercase;
            }

        .pb-form .step.is-active,
        .pb-form .wz-step.is-active {
            background: var(--l-bg);
            box-shadow: inset 3px 0 0 var(--pb-red);
        }

            .pb-form .step.is-active .step-num,
            .pb-form .wz-step.is-active .num {
                border-color: var(--l-text);
                background: var(--l-bg);
                color: var(--l-text);
            }

            .pb-form .step.is-active .step-label,
            .pb-form .wz-step.is-active .lbl {
                color: var(--l-text);
            }

        .pb-form .step.is-done .step-num,
        .pb-form .wz-step.is-done .num {
            border-color: var(--l-text);
            background: var(--l-text);
            color: var(--d-text);
            font-size: 0;
        }

            .pb-form .step.is-done .step-num::after,
            .pb-form .wz-step.is-done .num::after {
                content: "✓";
                font-size: 13px;
            }

            .pb-form .wz-step.is-done .num span {
                display: none;
            }

    /* Footer da sidebar */

    .pb-form .aside-box,
    .pb-form .wz-time {
        display: grid;
        gap: var(--s-2);
        margin-top: auto;
        padding-top: var(--s-4);
        border-top: 1px solid var(--l-border);
        color: var(--l-text-3);
        font-family: var(--font-mono);
        letter-spacing: .06em;
        text-transform: uppercase;
        white-space : nowrap
    }

        .pb-form .aside-box .row,
        .pb-form .wz-time {
            display: flex;
            width: 100%;
            margin-right: auto;
            margin-left: auto;
            gap: var(--s-8);
            font-size: 11px;
        }

            .pb-form .aside-box strong,
            .pb-form .wz-time strong {
                color: var(--l-text);
                font-weight: 600;
            }

    /* Progresso */

    .pb-form .progress {
        height: 4px;
        overflow: hidden;
        background: var(--l-surface-2);
    }

.pb-form--accounting .progress {
    display: block;
    height: 4px;
}

.pb-form .progress-bar,
.pb-form .bar.is-filled {
    height: 100%;
    background: var(--pb-red);
    transition: width var(--d-base) var(--ease);
}

.pb-form .bar {
    height: 3px;
    background: transparent;
}

/* Cabeçalho do conteúdo */

.pb-form .topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-3);
    padding: var(--s-5) var(--s-6) 0;
}

.pb-form .panel-kicker,
.pb-form .step-count,
.pb-form .mobile-progress-label,
.pb-form .step-label,
.pb-form .top-meta {
    color: var(--l-text-3);
    letter-spacing: .12em;
    text-transform: uppercase;
}

.pb-form .panel-kicker,
.pb-form .step-count,
.pb-form .mobile-progress-label {
    font-size: 11px;
}

.pb-form .mobile-progress-label {
    margin-bottom: var(--s-2);
}

.pb-form .step-count strong {
    color: var(--l-text);
}

/* Painéis */

.pb-form .panel {
    display: none;
    padding: 0;
    border: 0;
    animation: pb-form-enter var(--d-base) var(--ease);
}

    .pb-form .panel.is-active {
        display: block;
    }

    .pb-form .panel h2 {
        padding-bottom: var(--s-2);
    }

@keyframes pb-form-enter {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.pb-form .fast-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-3);
    margin-bottom: var(--s-4);
}

.pb-form .question-title {
    max-width: 720px;
    margin: 0;
}

.pb-form .lead {
    margin: 0px 0 var(--s-4);
    color: var(--l-text-2);
}

/* Grids */

.pb-form .options-grid,
.pb-form .option-grid,
.pb-form .field-grid,
.pb-form .fields,
.pb-form .remote-grid {
    display: grid;
    width: 100%;
    gap: var(--s-3);
}

    .pb-form .options-grid,
    .pb-form .option-grid,
    .pb-form .remote-grid,
    .pb-form .field-grid.two,
    .pb-form .fields {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

        .pb-form .options-grid.services.chip-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
            row-gap: var(--s-1);
        }

        .pb-form .chip-grid,
        .pb-form .option-grid.chips {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            width: 100%;
            max-width: 900px;
            row-gap: var(--s-2);
            column-gap: 0;
        }

/* Opções */

.pb-form .option-card,
.pb-form .choice,
.pb-form .radio-choice,
.pb-form .remote-choice,
.pb-form .pill-choice {
    border-radius : var(--r-lg);
    position: relative;
    display: flex;
    align-items: center;
    border: 1px solid var(--l-border-2);
    border-radius: var(--r-sm);
    background: var(--l-bg);
    color: var(--l-text);
    font-weight: 600;
    transition: border-color var(--d-fast) var(--ease), background var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease), transform var(--d-fast) var(--ease);
}

.pb-form .option-card,
.pb-form .choice,
.pb-form .radio-choice,
.pb-form .remote-choice {
    width: 100%;
    min-height: 54px;
    gap: var(--s-3);
    padding: var(--s-2) var(--s-3);
    text-align: left;
}

.pb-form .choice {
    justify-content: space-between;
    min-height: 74px;
    padding: var(--s-4);
}

.pb-form .remote-choice {
    align-items: flex-start;
    flex-direction: column;
    min-height: 112px;
    padding: var(--s-4);
}

.pb-form .pill-choice {
    min-height: 36px;
    padding: var(--s-2) var(--s-3);
    appearance: none;
}

.pb-form .option-card.chip,
.pb-form .pill-choice {
    flex: 0 1 220px;
    min-width: 220px;
    max-width: 320px;
    justify-content: flex-start;
}

    .pb-form .option-card:hover,
    .pb-form .choice:hover,
    .pb-form .radio-choice:hover,
    .pb-form .remote-choice:hover,
    .pb-form .pill-choice:hover {
        border-color: var(--l-text);
        background: var(--l-surface);
        transform: translateY(-1px);
    }

.pb-form .option-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.pb-form .choice .left {
    display: flex;
    flex-direction: column;
    gap: var(--s-3);
}

/* Controles de seleção */

.pb-form .option-control,
.pb-form .box {
    position: relative;
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border: 1.5px solid var(--l-border-2);
    background: var(--l-bg);
}

.pb-form .option-card.is-checkbox .option-control,
.pb-form .box {
    border-radius: var(--r-sm);
}

.pb-form .option-card.is-radio .option-control {
    border-radius: 999px;
}

.pb-form .option-control::after,
.pb-form .box::after {
    content: "";
    opacity: 0;
    transition: opacity var(--d-fast) var(--ease), transform var(--d-fast) var(--ease);
}

.pb-form .option-card.is-checkbox .option-control::after,
.pb-form .box::after {
    width: 10px;
    height: 7px;
    border-bottom: 2px solid var(--d-text);
    border-left: 2px solid var(--d-text);
    transform: rotate(-45deg) scale(.7) translate(1px, -1px);
}

.pb-form .option-card.is-radio .option-control::after {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--d-text);
}

.pb-form .option-card:has(input:checked),
.pb-form .choice.is-selected,
.pb-form .pill-choice.is-selected,
.pb-form .radio-choice.is-selected,
.pb-form .remote-choice.is-selected {
    border-color: var(--pb-red);
    background: var(--pb-red-soft);
    box-shadow: inset 0 0 0 1px var(--pb-red);
}

.pb-form .option-card:has(input:checked) .option-control,
.pb-form .choice.is-selected .box {
    border-color: var(--pb-red);
    background: var(--pb-red);
}

    .pb-form .option-card:has(input:checked) .option-control::after,
    .pb-form .choice.is-selected .box::after {
        opacity: 1;
    }

    .pb-form .option-card.is-checkbox:has(input:checked) .option-control::after,
    .pb-form .choice.is-selected .box::after {
        transform: rotate(-45deg) scale(1) translate(1px, -1px);
    }

.pb-form .option-card.chip .option-control {
    display: none;
}

.pb-form .options-grid.services .option-card.chip .option-control {
    display: inline-flex;
}

.pb-form .options-grid.services.chip-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: var(--s-1);
}

.pb-form .options-grid.services .option-card {
    border: none;
    background: transparent;
    padding: 4px 8px 4px 0;
    min-height: auto;
    box-shadow: none;
}

    .pb-form .options-grid.services .option-card:hover {
        background: transparent;
        transform: none;
    }

    .pb-form .options-grid.services .option-card:has(input:checked) {
        background: transparent;
        box-shadow: none;
        color: var(--pb-red);
    }

/* Ícones e badges */

.pb-form .icon-bubble {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--s-6);
    height: var(--s-6);
    border: 1px solid var(--l-border);
    border-radius: var(--r-sm);
    background: var(--l-surface-2);
    color: var(--l-text);
}

    .pb-form .icon-bubble svg {
        width: 21px;
        height: 21px;
    }

.pb-form .choice.is-selected .icon-bubble,
.pb-form .remote-choice.is-selected .icon-bubble {
    border-color: var(--pb-red);
    background: var(--pb-red);
    color: var(--d-text);
}

.pb-form .eyebrow {
    position: absolute;
    top: var(--s-3);
    right: var(--s-3);
    padding: var(--s-1) var(--s-2);
    border-radius: var(--r-md)
}

/* Campos */

.pb-form .field.full-width {
    grid-column: 1 / -1;
}

.pb-form .field,
.pb-form .system-input-wrap {
    margin-top : var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
}

    .pb-form .field label {
        color: var(--l-text-2);
        font-family: var(--font-mono);
        font-weight: 600;
        letter-spacing: .1em;
        text-transform: uppercase;
    }

.pb-form .input {
    width: 100%;
    min-height: 54px;
    padding: 14px var(--s-3);
    border: 1px solid var(--l-border-2);
    border-radius: var(--r-md);
    outline: none;
    background: var(--l-bg);
    color: var(--l-text);
    transition: border-color var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease), background var(--d-fast) var(--ease);
}

    .pb-form .input:hover,
    .pb-form .input:focus {
        border-color: var(--l-text);
    }

    .pb-form .input:focus {
        box-shadow: 0 0 0 3px rgba(11, 11, 11, .08);
    }

    .pb-form .input::placeholder {
        color: var(--l-text-3);
    }

.pb-form textarea.input {
    min-height: 150px;
    resize: vertical;
    line-height: 1.5;
}

.pb-form select.input {
    padding-right: 42px;
}

/* Rodapé / ações */

.pb-form .wizard-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-3);
    padding: var(--s-3) var(--s-6);
    border-top: 1px solid var(--l-border);
    background: rgba(255, 255, 255, .88);
}

.pb-form .actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-2);
}

.pb-form .btn-primary,
.pb-form .btn-cta {
    background: var(--pb-green);
    color: var(--d-text);
}

    .pb-form .btn-primary:hover,
    .pb-form .btn-cta:hover {
        background: var(--pb-green-hover);
    }

.pb-form .btn-secondary,
.pb-form .btn-outline {
    border-color: var(--l-border-2);
    background: transparent;
    color: var(--l-text);
}

    .pb-form .btn-secondary:hover,
    .pb-form .btn-outline:hover {
        border-color: var(--l-text);
        background: var(--l-surface-2);
    }

.pb-form .btn:disabled {
    opacity: .38;
    cursor: not-allowed;
    transform: none;
}

.pb-form .divider {
    height: 1px;
    margin: var(--s-6) 0 var(--s-3);
    background: var(--l-border);
}

.pb-form .card > .divider {
    margin-top: auto;
}

/* Links internos */

.pb-form .back-top,
.pb-form .inline-back,
.pb-form .cep-link {
    border: 0;
    background: transparent;
    color: var(--l-text-3);
    font-family: var(--font-mono);
    outline : none;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    appearance: none;
}

    .pb-form .inline-back:focus {
        outline: none;
    }

.pb-form .back-top {
    font-size : 11px;
    display: inline-flex;
    align-items: center;
    gap: var(--s-2);
    opacity: 0;
    outline : none;
    pointer-events: none;
}

    .pb-form .back-top.is-visible {
        opacity: 1;
        pointer-events: auto;
    }

    .pb-form .back-top:hover,
    .pb-form .inline-back:hover,
    .pb-form .cep-link:hover {
        color: var(--l-text);
    }

/* Segurança / sucesso */

.pb-form .secure {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-2);
    padding: 0 var(--s-6) var(--s-4);
    color: var(--l-text-3);
    font-family: var(--font-mono);
    letter-spacing: .06em;
    text-transform: uppercase;
}

    .pb-form .secure svg {
        width: 18px;
        height: 18px;
        color: var(--pb-green);
    }

.pb-form .success-card {
    align-items: center;
    justify-content: center;
    text-align: center;
}

.pb-form .success-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    margin-bottom: var(--s-4);
    border: 1px solid rgba(22,179,100,.3);
    border-radius: var(--r-md);
    background: var(--pb-green-soft);
    color: var(--pb-green-hover);
}

    .pb-form .success-icon svg {
        width: 28px;
        height: 28px;
    }

.pb-form .dark-btn {
    background: var(--l-text);
    color: var(--d-text);
}

.pb-form .shake {
    animation: pb-form-shake .24s linear;
}


@keyframes pb-form-shake {
    25% {
        transform: translateX(-5px);
    }

    50% {
        transform: translateX(5px);
    }

    75% {
        transform: translateX(-3px);
    }
}

.pb-form .vertical-field-grid {
    display: grid;
    grid-template-columns: 1fr !important;
    gap: var(--s-2);
    width: 100%;
}

/* Desktop */

@media (min-width: 761px) {
    .pb-form .wizard {
        grid-template-columns: 300px minmax(0, 1fr);
    }

    .pb-form--accounting .wizard {
        grid-template-columns: 280px minmax(0, 1fr);
    }
}

/* Mobile */

@media (max-width: 760px) {

    .pb-form .options-grid.services.chip-grid {
        grid-template-columns: repeat(1, minmax(0, 1fr));
        row-gap: 0px;
    }

    .pb-form .options-grid.services .option-card {
        font-size : 18px;
        padding-bottom: 0px
    }
    .pb-form .wizard {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .pb-form .wizard-aside {
        display: none;
    }

    .pb-form .topline {
        padding: var(--s-4) var(--s-4) 0;
    }

    .pb-form .wizard-content,
    .pb-form .card {
        padding: var(--s-4);
    }

    .pb-form .options-grid,
    .pb-form .option-grid,
    .pb-form .field-grid,
    .pb-form .fields,
    .pb-form .remote-grid,
    .pb-form .options-grid.services {
        grid-template-columns: 1fr;
    }

    .pb-form .wizard-footer {
        align-items: stretch;
        flex-direction: column;
        padding: var(--s-3) var(--s-4);
    }

    .pb-form .actions {
        width: 100%;
    }

        .pb-form .actions .btn {
            flex: 1;
        }

    .pb-form .secure {
        align-items: flex-start;
        justify-content: flex-start;
        padding: 0 var(--s-4) var(--s-4);
    }

    .pb-form .divider,
    .pb-form .card > .divider {
        margin: var(--s-5) 0 var(--s-3);
    }

    
}
