:root {
    --cor-fundo: #F4F7F9;
    --cor-texto: #172B4D;
    --cor-primaria: #0052CC;
    --cor-acento: #00B894;
    --cor-positivo: #2ECC71;
    --cor-negativo: #FF7675;
    --cor-branco: #FFFFFF;
    --cor-borda: rgba(23, 43, 77, 0.08);
    --sombra: 0 4px 6px rgba(0, 0, 0, 0.05);
    --raio: 12px;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: "Inter", "Roboto", system-ui, sans-serif;
    background: var(--cor-fundo);
    color: var(--cor-texto);
    line-height: 1.5;
}

a {
    color: var(--cor-primaria);
    text-decoration: none;
}

a:hover,
a:focus-visible {
    text-decoration: underline;
}

img {
    max-width: 100%;
    height: auto;
}

.pagina {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.cabecalho {
    padding: 1rem 1.25rem;
    background: var(--cor-branco);
    box-shadow: var(--sombra);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    position: sticky;
    top: 0;
    z-index: 10;
}

.cabecalho--painel-min {
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
}

.cabecalho--painel-min .cabecalho__sair {
    margin: 0;
    flex-shrink: 0;
}

.botao--sair-topo {
    min-height: 44px;
    min-width: 4.5rem;
}

.marca {
    display: inline-flex;
    align-items: center;
    line-height: 0;
    text-decoration: none;
}

.marca-img {
    height: 1.85rem;
    width: auto;
    max-width: 9.5rem;
    display: block;
}

.marca:hover {
    opacity: 0.92;
}

.marca:focus-visible {
    outline: 2px solid var(--cor-primaria);
    outline-offset: 4px;
    border-radius: 6px;
    opacity: 1;
}

.conteudo {
    flex: 1;
    width: 100%;
    max-width: 42rem;
    margin: 0 auto;
    padding: 1.5rem 1.25rem 2.5rem;
}

.conteudo--largo {
    max-width: 48rem;
}

.titulo-principal {
    font-size: 1.75rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    margin: 0 0 0.5rem;
    line-height: 1.2;
}

.subtitulo {
    margin: 0 0 1.75rem;
    font-size: 1rem;
    color: rgba(23, 43, 77, 0.78);
}

.hero {
    text-align: left;
    padding: 2rem 0 1rem;
}

.pilula {
    display: inline-block;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: rgba(0, 82, 204, 0.1);
    color: var(--cor-primaria);
    font-size: 0.8125rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.acoes-principais {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 2rem;
}

@media (min-width: 480px) {
    .acoes-principais {
        flex-direction: row;
        flex-wrap: wrap;
    }
}

.botao {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0.75rem 1.25rem;
    border-radius: var(--raio);
    font-family: inherit;
    font-size: 1rem;
    font-weight: 600;
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    width: 100%;
}

@media (min-width: 480px) {
    .botao--inline {
        width: auto;
        min-width: 10rem;
    }
}

.botao:active {
    transform: scale(0.98);
}

.botao--primario {
    background: var(--cor-primaria);
    color: var(--cor-branco);
    box-shadow: var(--sombra);
}

.botao--primario:hover,
.botao--primario:focus-visible {
    background: #0747A6;
    text-decoration: none;
}

.botao--secundario {
    background: var(--cor-branco);
    color: var(--cor-primaria);
    border: 2px solid var(--cor-primaria);
}

.botao--secundario:hover,
.botao--secundario:focus-visible {
    background: rgba(0, 82, 204, 0.06);
    text-decoration: none;
}

.botao--fantasma {
    background: transparent;
    color: var(--cor-texto);
    border: 1px solid var(--cor-borda);
}

.botao--fantasma:hover,
.botao--fantasma:focus-visible {
    background: rgba(23, 43, 77, 0.04);
    text-decoration: none;
}

.cartao {
    background: var(--cor-branco);
    border-radius: var(--raio);
    box-shadow: var(--sombra);
    padding: 1.25rem 1.35rem;
    margin-bottom: 1rem;
}

.cartao--destaque {
    border-left: 4px solid var(--cor-primaria);
}

.cartao--entrada {
    border-left: 4px solid var(--cor-positivo);
}

.cartao--saida {
    border-left: 4px solid var(--cor-negativo);
}

.formulario {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.rotulo {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: 0.35rem;
    color: var(--cor-texto);
}

.campo {
    width: 100%;
    min-height: 48px;
    padding: 0.65rem 0.85rem;
    border-radius: var(--raio);
    border: 1px solid var(--cor-borda);
    font-family: inherit;
    font-size: 1rem;
    color: var(--cor-texto);
    background: var(--cor-branco);
}

.campo:focus {
    outline: 2px solid var(--cor-primaria);
    outline-offset: 1px;
    border-color: transparent;
}

.alerta {
    padding: 0.85rem 1rem;
    border-radius: var(--raio);
    font-size: 0.9375rem;
    margin-bottom: 1rem;
}

.alerta--erro {
    background: rgba(255, 118, 117, 0.15);
    color: #C0392B;
    border: 1px solid rgba(255, 118, 117, 0.4);
}

.alerta--sucesso {
    background: rgba(46, 204, 113, 0.15);
    color: #1E8449;
    border: 1px solid rgba(46, 204, 113, 0.35);
}

.grade-resumo {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

@media (min-width: 560px) {
    .grade-resumo {
        grid-template-columns: repeat(3, 1fr);
    }
}

.mini-cartao {
    background: var(--cor-branco);
    border-radius: var(--raio);
    box-shadow: var(--sombra);
    padding: 1rem 1.1rem;
}

.mini-cartao__titulo {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(23, 43, 77, 0.55);
    margin: 0 0 0.35rem;
}

.mini-cartao__valor {
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin: 0;
}

.mini-cartao__valor--positivo {
    color: var(--cor-positivo);
}

.mini-cartao__valor--neutro {
    color: var(--cor-texto);
}

.mini-cartao__valor--negativo {
    color: var(--cor-negativo);
}

.secao-titulo {
    font-size: 1.125rem;
    font-weight: 700;
    margin: 0 0 0.75rem;
}

.lista-lancamentos-wrap {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.lista-lancamentos {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.65rem;
    align-items: stretch;
}

@media (min-width: 640px) {
    .lista-lancamentos {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    .lista-lancamentos {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.paginacao {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.65rem 1.25rem;
    margin-top: 1rem;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(23, 43, 77, 0.08);
}

.paginacao__info {
    font-size: 0.875rem;
    color: rgba(23, 43, 77, 0.65);
    font-weight: 600;
}

.paginacao__link {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--cor-primaria);
    text-decoration: none;
    padding: 0.35rem 0.65rem;
    border-radius: 8px;
}

.paginacao__link:hover,
.paginacao__link:focus-visible {
    background: rgba(0, 82, 204, 0.08);
    text-decoration: none;
}

.item-lancamento {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.item-lancamento__linha {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
}

.item-lancamento__descricao {
    font-weight: 600;
    margin: 0;
    font-size: 1rem;
}

.item-lancamento__valor {
    font-weight: 700;
    white-space: nowrap;
    font-size: 1.05rem;
}

.item-lancamento__valor--entrada {
    color: var(--cor-positivo);
}

.item-lancamento__valor--saida {
    color: var(--cor-negativo);
}

.item-lancamento__meta {
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.65);
    margin: 0;
}

.item-lancamento__acoes {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.35rem;
    padding-top: 0.5rem;
    border-top: 1px solid rgba(23, 43, 77, 0.08);
}

.form-excluir-inline {
    display: inline;
    margin: 0;
}

.form-acoes-editar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

.cabecalho-dashboard {
    margin-bottom: 1.25rem;
}

.cabecalho-dashboard__saudacao {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.vazio {
    text-align: center;
    padding: 2rem 1rem;
    color: rgba(23, 43, 77, 0.6);
    font-size: 0.9375rem;
}

.rodape {
    padding: 1rem 1.25rem;
    text-align: center;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.45);
}

.rodape-marca {
    display: inline-flex;
    line-height: 0;
    opacity: 0.72;
    transition: opacity 0.15s ease;
}

.rodape-marca:hover,
.rodape-marca:focus-visible {
    opacity: 1;
}

.rodape-marca:focus-visible {
    outline: 2px solid var(--cor-primaria);
    outline-offset: 4px;
    border-radius: 6px;
}

.rodape-marca__img {
    height: 1.35rem;
    width: auto;
    max-width: 7.75rem;
    display: block;
}

.barra-acoes-topo {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.barra-acoes-topo .botao {
    width: auto;
    min-height: 44px;
    padding: 0.5rem 1rem;
    font-size: 0.9375rem;
}

.botao--outline {
    background: transparent;
    color: var(--cor-primaria);
    border: 2px solid var(--cor-primaria);
    box-shadow: none;
}

.botao--outline:hover,
.botao--outline:focus-visible {
    background: rgba(0, 82, 204, 0.08);
    text-decoration: none;
}

.botao--sm {
    min-height: 36px;
    padding: 0.35rem 0.75rem;
    font-size: 0.8125rem;
}

.botao--perigo {
    color: #c0392b;
    border-color: rgba(192, 57, 43, 0.55);
}

.botao--perigo:hover,
.botao--perigo:focus-visible {
    background: rgba(192, 57, 43, 0.08);
}

.landing-body {
    padding-top: 4rem;
}

.pagina--landing {
    min-height: 100vh;
}

.cabecalho--fixo {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    max-width: none;
    padding: 1rem clamp(1.25rem, 4vw, 3rem);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--cor-borda);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
}

.cabecalho--fixo .marca {
    text-decoration: none;
}

.cabecalho--fixo .marca:hover,
.cabecalho--fixo .marca:focus-visible {
    text-decoration: none;
}

.cabecalho__entrar {
    min-height: 44px;
    padding: 0.5rem 1.15rem;
    font-size: 0.9375rem;
}

.landing-main {
    width: 100%;
    max-width: 72rem;
    margin: 0 auto;
    padding: 2rem clamp(1.25rem, 4vw, 3rem) 3rem;
}

.hero-split {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.75rem;
    align-items: center;
    padding: 0.5rem 0 3rem;
}

@media (min-width: 960px) {
    .hero-split {
        grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
        gap: 3rem;
        padding: 1rem 0 4rem;
    }
}

.hero-split__texto {
    max-width: 36rem;
}

@media (min-width: 960px) {
    .hero-split__texto {
        max-width: none;
    }
}

.hero-split__visual {
    display: flex;
    justify-content: center;
    align-items: center;
}

.titulo-principal--hero {
    font-size: clamp(1.65rem, 4vw, 2.35rem);
    line-height: 1.18;
    margin-bottom: 0.75rem;
}

.titulo-hero__destaque {
    color: var(--cor-primaria);
}

.subtitulo--hero {
    margin-bottom: 0;
    max-width: 32rem;
}

@media (min-width: 960px) {
    .subtitulo--hero {
        max-width: none;
    }
}

.acoes-principais--hero {
    margin-top: 1.75rem;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.acoes-principais--hero .botao--inline {
    flex: 1 1 auto;
    min-width: 9rem;
}

@media (min-width: 480px) {
    .acoes-principais--hero .botao--inline {
        flex: 0 1 auto;
    }
}

.mockup-celular {
    width: 100%;
    max-width: 17.5rem;
}

.mockup-celular__bezel {
    position: relative;
    isolation: isolate;
    border-radius: 30px;
    border: 12px solid #1e1e24;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
    background: #1e1e24;
    padding: 0.5rem 0.65rem 0.85rem;
}

.mockup-celular__notch {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 5rem;
    height: 1.35rem;
    background: #1e1e24;
    border-radius: 0 0 14px 14px;
    z-index: 1;
}

.mockup-celular__tela {
    margin-top: 1.25rem;
    border-radius: 22px;
    background: var(--cor-fundo);
    padding: 1rem 0.85rem;
    min-height: 15rem;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.mockup-mini-card {
    border-radius: var(--raio);
    padding: 0.55rem 0.7rem;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    box-shadow: var(--sombra);
    background: var(--cor-branco);
}

.mockup-mini-card--positivo {
    border-left: 4px solid var(--cor-positivo);
}

.mockup-mini-card--neutro {
    border-left: 4px solid var(--cor-primaria);
}

.mockup-mini-card--negativo {
    border-left: 4px solid var(--cor-negativo);
}

.mockup-mini-card__rotulo {
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgba(23, 43, 77, 0.55);
}

.mockup-mini-card__valor {
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--cor-texto);
}

.mockup-mini-card--positivo .mockup-mini-card__valor {
    color: var(--cor-positivo);
}

.mockup-mini-card--negativo .mockup-mini-card__valor {
    color: var(--cor-negativo);
}

.mockup-mini-card__valor--destaque {
    color: var(--cor-primaria);
}

.mockup-mini-lista {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    margin-top: 0.25rem;
}

.mockup-mini-lista__linha {
    height: 0.4rem;
    border-radius: 4px;
    background: rgba(23, 43, 77, 0.08);
}

.mockup-mini-lista__linha--entrada {
    width: 88%;
    background: rgba(46, 204, 113, 0.35);
}

.mockup-mini-lista__linha--saida {
    width: 62%;
    background: rgba(255, 118, 117, 0.4);
}

.features {
    padding-top: 0.5rem;
    padding-bottom: 1rem;
}

.features__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 640px) {
    .features__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 1.25rem;
    }
}

.feature-card {
    background: var(--cor-branco);
    border-radius: var(--raio);
    box-shadow: var(--sombra);
    padding: 1.35rem 1.25rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.65rem;
    border: 1px solid var(--cor-borda);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.feature-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
}

.feature-card__icone {
    width: 3rem;
    height: 3rem;
    border-radius: 12px;
    background: rgba(0, 82, 204, 0.1);
    color: var(--cor-primaria);
    display: flex;
    align-items: center;
    justify-content: center;
}

.feature-card__svg {
    width: 1.75rem;
    height: 1.75rem;
}

.feature-card__nome {
    margin: 0;
    font-size: 1.0625rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.feature-card__texto {
    margin: 0;
    font-size: 0.9375rem;
    color: rgba(23, 43, 77, 0.75);
    line-height: 1.55;
}

.rodape--landing {
    padding: 2rem 1.25rem 2.25rem;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.38);
    letter-spacing: 0.02em;
}

/* Painel: fechamento mensal e formulários */
.fechamento-mes {
    margin-bottom: 1.75rem;
    padding: 1.1rem 1rem 1.25rem;
    background: var(--cor-branco);
    border-radius: var(--raio);
    box-shadow: var(--sombra);
    border: 1px solid var(--cor-borda);
}

.fechamento-mes__topo {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    margin-bottom: 0.75rem;
}

.fechamento-mes__titulo {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 700;
}

.fechamento-mes__form-mes {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.rotulo--inline {
    margin: 0;
    font-size: 0.875rem;
}

.campo--mes {
    width: auto;
    min-width: 10.5rem;
    padding: 0.45rem 0.65rem;
    min-height: 2.5rem;
}

.fechamento-mes__nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.fechamento-mes__seta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    min-height: 2.5rem;
    border-radius: var(--raio);
    background: rgba(0, 82, 204, 0.08);
    color: var(--cor-primaria);
    font-weight: 700;
    text-decoration: none;
    font-size: 1.125rem;
}

.fechamento-mes__seta:hover,
.fechamento-mes__seta:focus-visible {
    background: rgba(0, 82, 204, 0.15);
    text-decoration: none;
}

.fechamento-mes__periodo {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    text-align: center;
    text-transform: capitalize;
    min-width: 10rem;
}

.fechamento-mes__contagem {
    margin: 0.75rem 0 0;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.55);
    text-align: center;
}

.visao-geral {
    margin-bottom: 1.75rem;
}

.visao-geral__meta {
    margin: 0.5rem 0 0;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.5);
}

.secao-titulo--menor {
    font-size: 1rem;
    font-weight: 700;
    color: rgba(23, 43, 77, 0.85);
}

.grade-resumo--compacta {
    margin-bottom: 0.35rem;
}

.grade-resumo--compacta .mini-cartao {
    padding: 0.75rem 0.9rem;
}

.mini-cartao--muted {
    background: rgba(255, 255, 255, 0.7);
    border: 1px dashed var(--cor-borda);
    box-shadow: none;
}

.mini-cartao__valor--sm {
    font-size: 1.1rem;
}

.form-dica {
    margin: 0 0 1rem;
    font-size: 0.875rem;
    color: rgba(23, 43, 77, 0.72);
    line-height: 1.45;
}

.form-fieldset {
    margin: 0 0 1.25rem;
    padding: 0;
    border: none;
}

.form-legend {
    padding: 0;
    margin: 0 0 0.75rem;
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--cor-texto);
}

.form-legend--opcional {
    font-weight: 500;
    color: rgba(23, 43, 77, 0.55);
    font-size: 0.8125rem;
}

.form-linha-dupla {
    display: grid;
    gap: 1rem;
}

@media (min-width: 520px) {
    .form-linha-dupla {
        grid-template-columns: 1fr 1fr;
    }
}

.campo-dica {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.75rem;
    color: rgba(23, 43, 77, 0.55);
    line-height: 1.35;
}

.lista-cabecalho {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem 1rem;
    margin-bottom: 0.75rem;
}

.lista-cabecalho__filtro {
    margin: 0;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.55);
    text-transform: capitalize;
}

.lista-cabecalho__filtro--solo {
    margin: 0 0 0.75rem;
}

.cabecalho--com-nav {
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem 1rem;
}

.nav-painel {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.75rem;
    flex: 1;
    justify-content: center;
    order: 3;
    width: 100%;
    padding-top: 0.5rem;
    border-top: 1px solid var(--cor-borda);
}

@media (min-width: 720px) {
    .cabecalho--com-nav {
        flex-wrap: nowrap;
    }

    .nav-painel {
        order: 0;
        width: auto;
        padding-top: 0;
        border-top: none;
        justify-content: flex-start;
        margin-left: 0.5rem;
    }
}

.nav-painel__link {
    font-size: 0.875rem;
    font-weight: 600;
    color: rgba(23, 43, 77, 0.65);
    padding: 0.35rem 0.6rem;
    border-radius: 8px;
    text-decoration: none;
}

.nav-painel__link:hover,
.nav-painel__link:focus-visible {
    color: var(--cor-primaria);
    background: rgba(0, 82, 204, 0.06);
    text-decoration: none;
}

.nav-painel__link--ativo {
    color: var(--cor-primaria);
    background: rgba(0, 82, 204, 0.1);
}

.voltar-painel {
    margin: 0 0 1rem;
    font-size: 0.9375rem;
}

.visao-geral__link-fechamento {
    margin: 0.85rem 0 0;
}

.lista-cabecalho--com-mes {
    align-items: center;
}

.lista-cabecalho__form-mes {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.lista-cabecalho__linha2 {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.lista-cabecalho__setas {
    display: flex;
    gap: 0.35rem;
}

.fechamento-mes__seta--sm {
    min-width: 2.25rem;
    min-height: 2.25rem;
    font-size: 1rem;
}

/* Painel motorista: mobile-first, hierarquia clara */
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.conteudo--painel-motorista {
    max-width: 26rem;
    padding-bottom: max(2rem, env(safe-area-inset-bottom));
}

@media (min-width: 640px) {
    .conteudo--painel-motorista {
        max-width: 40rem;
    }
}

.painel-topo {
    background: var(--cor-branco);
    border-radius: var(--raio);
    box-shadow: var(--sombra);
    padding: 1rem 1.1rem 1.1rem;
    margin-bottom: 1rem;
    border: 1px solid var(--cor-borda);
}

.painel-topo__nome {
    margin: 0 0 0.75rem;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--cor-texto);
}

.painel-topo__periodo-linha {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem 0.75rem;
    margin-bottom: 0.35rem;
}

.painel-topo__chips {
    display: flex;
    gap: 0.35rem;
}

.painel-topo__chip {
    min-height: 44px;
    min-width: 4.25rem;
    padding: 0.5rem 1rem;
    border-radius: 10px;
    font-size: 0.9375rem;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
    color: rgba(23, 43, 77, 0.75);
    background: rgba(23, 43, 77, 0.05);
    border: 1px solid transparent;
    transition: background 0.15s ease, color 0.15s ease;
}

.painel-topo__chip:hover,
.painel-topo__chip:focus-visible {
    color: var(--cor-primaria);
    background: rgba(0, 82, 204, 0.08);
    text-decoration: none;
}

.painel-topo__chip--on {
    color: var(--cor-branco);
    background: var(--cor-primaria);
}

.painel-topo__chip--on:hover,
.painel-topo__chip--on:focus-visible {
    color: var(--cor-branco);
    background: #0747a6;
}

.painel-topo__mes-nav {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.painel-topo__seta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 44px;
    border-radius: 10px;
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    color: var(--cor-primaria);
    background: rgba(0, 82, 204, 0.08);
}

.painel-topo__seta:hover,
.painel-topo__seta:focus-visible {
    background: rgba(0, 82, 204, 0.15);
    text-decoration: none;
}

.painel-topo__mes-nome {
    margin: 0;
    min-width: 7.5rem;
    text-align: center;
    font-size: 0.875rem;
    font-weight: 600;
    text-transform: capitalize;
    color: rgba(23, 43, 77, 0.7);
}

.painel-topo__sub {
    margin: 0 0 0.85rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: rgba(23, 43, 77, 0.45);
    text-transform: capitalize;
}

.painel-topo__lucro {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    margin-bottom: 0.85rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid var(--cor-borda);
}

.painel-topo__lucro-rotulo {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(23, 43, 77, 0.45);
}

.painel-topo__lucro-valor {
    font-size: clamp(1.65rem, 7vw, 2rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--cor-texto);
    line-height: 1.1;
}

.painel-topo__mini-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.65rem;
}

.painel-mini {
    padding: 0.65rem 0.75rem;
    border-radius: 10px;
    border: 1px solid var(--cor-borda);
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.painel-mini--entrada {
    border-left: 3px solid var(--cor-positivo);
}

.painel-mini--saida {
    border-left: 3px solid var(--cor-negativo);
}

.painel-mini__k {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(23, 43, 77, 0.45);
}

.painel-mini__v {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.painel-mini--entrada .painel-mini__v {
    color: var(--cor-positivo);
}

.painel-mini--saida .painel-mini__v {
    color: var(--cor-negativo);
}

.secao-painel {
    margin-bottom: 1.15rem;
}

.secao-painel__titulo {
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 0.35rem;
    letter-spacing: -0.02em;
}

.secao-painel__titulo--inline {
    margin: 0;
}

.secao-painel__ajuda {
    margin: 0 0 0.65rem;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.55);
    line-height: 1.35;
}

.secao-painel--meta {
    background: var(--cor-branco);
    border-radius: var(--raio);
    padding: 0.9rem 1rem 1rem;
    border: 1px solid var(--cor-borda);
    box-shadow: var(--sombra);
    border-left: 4px solid var(--cor-acento);
}

.secao-painel--rapidos {
    background: var(--cor-branco);
    border-radius: var(--raio);
    padding: 0.9rem 1rem 1rem;
    border: 1px solid var(--cor-borda);
    box-shadow: var(--sombra);
}

.secao-painel--extrato {
    padding-top: 0.25rem;
}

.meta-compacta {
    display: flex;
    align-items: center;
    gap: 0.85rem 1rem;
}

.meta-compacta__col {
    flex: 1;
    min-width: 0;
}

.meta-compacta__hoje {
    margin: 0 0 0.5rem;
    font-size: 0.875rem;
    color: rgba(23, 43, 77, 0.8);
}

.meta-compacta__form {
    margin: 0;
}

.meta-compacta__inputs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: stretch;
}

.campo--meta-compacta {
    flex: 1 1 7rem;
    min-width: 0;
    min-height: 48px;
}

.botao--compacto {
    min-height: 48px;
    padding-left: 1rem;
    padding-right: 1rem;
}

.meta-ring {
    --p: 0;
    width: 5.5rem;
    height: 5.5rem;
    flex-shrink: 0;
    border-radius: 50%;
    background: conic-gradient(
        var(--cor-acento) calc(var(--p) * 1%),
        rgba(23, 43, 77, 0.1) 0
    );
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--sombra);
}

.meta-ring--sm {
    width: 4.75rem;
    height: 4.75rem;
}

.meta-ring__inner {
    width: 3.55rem;
    height: 3.55rem;
    border-radius: 50%;
    background: var(--cor-branco);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1.1;
}

.meta-ring--sm .meta-ring__inner {
    width: 3.15rem;
    height: 3.15rem;
}

.meta-ring__pct {
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--cor-texto);
}

.meta-ring__pct--sm {
    font-size: 1rem;
}

.grid-rapidos {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.6rem;
}

.grid-rapidos--touch {
    gap: 0.65rem;
}

@media (min-width: 380px) {
    .grid-rapidos--touch {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Corrida rápida + Gasto rápido: mesmo padrão de cartão (entrada verde / saída vermelho) */
.secao-painel--fluxo-rapido .secao-painel__ajuda {
    margin-bottom: 0.85rem;
}

.cartao--fluxo-rapido {
    margin: 0;
    padding: 1rem 1.05rem 1.05rem;
    border-radius: 14px;
    border: 2px solid var(--cor-borda);
    box-shadow: var(--sombra);
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.cartao--fluxo-rapido--entrada {
    background: rgba(46, 204, 113, 0.1);
    border-color: rgba(46, 204, 113, 0.5);
    border-left: 4px solid var(--cor-positivo);
}

.cartao--fluxo-rapido--saida {
    background: rgba(255, 118, 117, 0.1);
    border-color: rgba(255, 118, 117, 0.48);
    border-left: 4px solid var(--cor-negativo);
}

.formulario--fluxo-rapido {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    margin: 0;
}

.formulario--fluxo-rapido .rotulo {
    font-size: 0.8125rem;
}

.botao--fluxo-rapido {
    width: 100%;
    min-height: 48px;
    font-weight: 700;
    margin-top: 0.15rem;
    border: none;
    touch-action: manipulation;
}

.botao--fluxo-rapido--entrada {
    background: var(--cor-positivo);
    color: var(--cor-branco);
    box-shadow: 0 2px 8px rgba(46, 204, 113, 0.35);
}

.botao--fluxo-rapido--entrada:hover,
.botao--fluxo-rapido--entrada:focus-visible {
    background: #27ae60;
    color: var(--cor-branco);
    text-decoration: none;
}

.botao--fluxo-rapido--saida {
    background: var(--cor-negativo);
    color: var(--cor-branco);
    box-shadow: 0 2px 8px rgba(255, 118, 117, 0.35);
}

.botao--fluxo-rapido--saida:hover,
.botao--fluxo-rapido--saida:focus-visible {
    background: #e74c3c;
    color: var(--cor-branco);
    text-decoration: none;
}

.campo--select-fluxo {
    min-height: 48px;
    font-weight: 600;
}

.extrato-cab {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.15rem;
}

.extrato-cab__n {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.75rem;
    min-height: 1.75rem;
    padding: 0 0.45rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--cor-primaria);
    background: rgba(0, 82, 204, 0.1);
}

.extrato-cab__hint {
    margin: 0 0 0.65rem;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.5);
    text-transform: capitalize;
}

.vazio--painel {
    text-align: center;
    padding: 1.25rem 1rem;
    font-size: 0.875rem;
    color: rgba(23, 43, 77, 0.55);
    background: var(--cor-branco);
    border-radius: var(--raio);
    border: 1px dashed var(--cor-borda);
}

.lista-lancamentos--painel {
    gap: 0.5rem;
}

.item-lancamento--painel {
    padding: 0.85rem 1rem;
    margin-bottom: 0;
}

.painel-detalhes {
    margin-bottom: 0.65rem;
    border-radius: var(--raio);
    border: 1px solid var(--cor-borda);
    background: rgba(255, 255, 255, 0.5);
    overflow: hidden;
}

.painel-detalhes--ultimo {
    margin-bottom: 0;
}

.painel-detalhes__sumario {
    list-style: none;
    cursor: pointer;
    position: relative;
    padding: 0.9rem 2.25rem 0.9rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
    font-weight: 600;
    color: var(--cor-texto);
    min-height: 52px;
    touch-action: manipulation;
}

.painel-detalhes__sumario::-webkit-details-marker {
    display: none;
}

.painel-detalhes__sumario::after {
    content: "";
    position: absolute;
    right: 1rem;
    top: 50%;
    width: 0.5rem;
    height: 0.5rem;
    margin-top: -0.25rem;
    border-right: 2px solid rgba(23, 43, 77, 0.35);
    border-bottom: 2px solid rgba(23, 43, 77, 0.35);
    transform: rotate(45deg);
    transition: transform 0.2s ease;
}

.painel-detalhes[open] .painel-detalhes__sumario::after {
    transform: rotate(225deg);
    margin-top: -0.1rem;
}

.painel-detalhes__titulo {
    font-size: 0.9375rem;
    font-weight: 700;
}

.painel-detalhes__sub {
    font-size: 0.75rem;
    font-weight: 500;
    color: rgba(23, 43, 77, 0.5);
}

.painel-detalhes__body {
    padding: 0 0 1rem;
    border-top: 1px solid var(--cor-borda);
    margin: 0;
}

.cartao--dentro-detalhes {
    margin: 0.75rem 0.75rem 0;
    box-shadow: none;
    border: 1px solid var(--cor-borda);
}

.cartao--manutencao {
    border-left: 4px solid #6c5ce7;
}

.formulario--manut {
    margin-bottom: 1rem;
}

.vazio--inline {
    padding: 1rem;
    text-align: left;
}

.lista-lembretes {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.lembrete-card {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.65rem;
    padding: 0.85rem 1rem;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--cor-borda);
    border-radius: var(--raio);
    border-left: 4px solid #6c5ce7;
}

.lembrete-card__corpo {
    flex: 1;
    min-width: 0;
}

.lembrete-card__titulo {
    margin: 0 0 0.25rem;
    font-weight: 700;
    font-size: 0.9375rem;
}

.lembrete-card__meta {
    margin: 0.15rem 0 0;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.65);
}

.lembrete-card__detalhes {
    margin: 0.35rem 0 0;
    font-size: 0.8125rem;
    color: rgba(23, 43, 77, 0.75);
    line-height: 1.4;
}

.lembrete-card__excluir {
    flex-shrink: 0;
    margin: 0;
}

/* Menu inferior do painel (4 abas) */
.pagina--com-menu-app {
    padding-bottom: env(safe-area-inset-bottom, 0);
}

.conteudo--com-nav-app {
    padding-bottom: 5.25rem;
}

@media (min-width: 720px) {
    .conteudo--com-nav-app {
        padding-bottom: 5.5rem;
    }
}

.nav-app {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    padding: 0.35rem 0.25rem calc(0.35rem + env(safe-area-inset-bottom, 0));
    background: rgba(255, 255, 255, 0.96);
    border-top: 1px solid var(--cor-borda);
    box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.06);
    backdrop-filter: blur(10px);
}

.nav-app__link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.1rem;
    min-height: 48px;
    padding: 0.35rem 0.2rem;
    font-size: 0.625rem;
    font-weight: 700;
    text-decoration: none;
    color: rgba(23, 43, 77, 0.5);
    border-radius: 10px;
    transition: background 0.15s ease, color 0.15s ease;
    touch-action: manipulation;
}

.nav-app__link:hover,
.nav-app__link:focus-visible {
    color: var(--cor-primaria);
    background: rgba(0, 82, 204, 0.06);
    text-decoration: none;
}

.nav-app__link--on {
    color: var(--cor-primaria);
    background: rgba(0, 82, 204, 0.1);
}

.nav-app__ico {
    font-size: 1.15rem;
    line-height: 1;
    opacity: 0.85;
}

.nav-app__txt {
    letter-spacing: 0.02em;
}

.rodape--com-nav-app {
    padding-bottom: calc(0.5rem + env(safe-area-inset-bottom, 0));
}

.painel-topo--sem-lucro {
    margin-bottom: 1rem;
}

.cartao--mais-bloco {
    margin-top: 0.5rem;
}

.painel-mais-link {
    margin: 0 0 1rem;
    text-align: center;
}

.painel-mais-link__a {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--cor-primaria);
    text-decoration: none;
}

.painel-mais-link__a:hover,
.painel-mais-link__a:focus-visible {
    text-decoration: underline;
}

.inicio-acoes {
    margin-bottom: 1.15rem;
}

.inicio-acoes__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.65rem;
}

.inicio-acoes__btn {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    min-height: 5.25rem;
    padding: 1rem 0.9rem;
    border-radius: 14px;
    text-decoration: none;
    font-weight: 700;
    border: 2px solid var(--cor-borda);
    transition: transform 0.12s ease, box-shadow 0.12s ease;
    touch-action: manipulation;
}

.inicio-acoes__btn:hover,
.inicio-acoes__btn:focus-visible {
    transform: translateY(-1px);
    box-shadow: var(--sombra);
    text-decoration: none;
}

.inicio-acoes__btn--entrada {
    background: rgba(46, 204, 113, 0.12);
    border-color: rgba(46, 204, 113, 0.55);
    color: #1e8449;
}

.inicio-acoes__btn--saida {
    background: rgba(255, 118, 117, 0.12);
    border-color: rgba(255, 118, 117, 0.5);
    color: #c0392b;
}

.inicio-acoes__btn-titulo {
    font-size: 0.9375rem;
    letter-spacing: -0.02em;
}

.inicio-acoes__btn-sub {
    margin-top: 0.25rem;
    font-size: 0.75rem;
    font-weight: 600;
    opacity: 0.85;
}

.voltar-inicio {
    margin: 0 0 0.75rem;
    font-size: 0.9375rem;
}

.voltar-inicio a {
    font-weight: 600;
    color: var(--cor-primaria);
    text-decoration: none;
}

.voltar-inicio a:hover,
.voltar-inicio a:focus-visible {
    text-decoration: underline;
}

