/* Loading */
.loading {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.7);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.loading::after {
    content: '';
    width: 50px;
    height: 50px;
    border: 5px solid #ccc;
    border-top-color: #0d6efd;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}
@keyframes spin {
    to { transform: rotate(360deg); }
}
.loading.hidden {
    display: none;
}
.loading.show {
    display: flex;
}

/* ============================ Layout mobile-first ============================ */

body {
    background-color: #f2f2f2;
}

/* Container com respiro confortável no celular e largura controlada no desktop.
   No desktop os lançamentos ficam em 2 colunas (row/col-lg-6), por isso uma
   largura maior aproveita melhor o espaço sem deixar os cards esticados. */
.container-extrato {
    max-width: 960px;
}

/* ============================ Card de lançamento ============================
   Layout "recibo": faixa de cor à esquerda codifica entrada/saída, o valor é a
   âncora visual e o histórico fica logo abaixo. O campo de identificação é
   separado por um divisor sutil. Sem altura forçada — densidade enxuta. */
.lancamento-card {
    position: relative;
    background: #fff;
    border: 1px solid #e6e6e9;
    border-left: 4px solid var(--lc-cor, #adb5bd);
    border-radius: 10px;
    padding: 0.85rem 1rem 0.9rem;
    box-shadow: 0 1px 2px rgba(16, 24, 40, 0.04);
    transition: box-shadow 0.18s ease, border-color 0.18s ease;
}
.lancamento-card.is-credito { --lc-cor: #16a34a; }
.lancamento-card.is-debito  { --lc-cor: #dc2626; }

.lancamento-card.respondido {
    border-color: #cfe8d6;
    border-left-color: #16a34a;
    background: #fbfdfb;
}

.lancamento-card.nao-respondido {
    border-color: #cfe8d6;
    border-left-color: #dcca26;
    background: #fbfdfb;
}


/* Topo: data à esquerda, tipo à direita (eyebrow discreto) */
.lc-topo {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.15rem;
}
.lc-data {
    font-size: 0.78rem;
    color: #98a2b3;
    letter-spacing: 0.01em;
}
.lc-tipo {
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--lc-cor);
}

/* Valor: protagonista do card */
.lc-valor {
    font-size: 1.35rem;
    font-weight: 700;
    line-height: 1.1;
    color: #1d2939;
    font-variant-numeric: tabular-nums;
}
.lancamento-card.is-debito .lc-valor { color: #b42318; }
.lancamento-card.is-credito .lc-valor { color: #157347; }

/* Histórico do extrato: secundário, abaixo do valor */
.lc-historico {
    font-size: 0.86rem;
    color: #667085;
    margin-top: 0.1rem;
    line-height: 1.35;
}

/* Campo de identificação, separado por um divisor fino */
.lc-campo {
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px dashed #e6e6e9;
}
.lc-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #0d6efd;
    margin-bottom: 0.35rem;
}
.lancamento-card .input-descricao-cliente {
    font-size: 1rem; /* >=16px evita zoom automático do iOS ao focar */
    border-color: #e1e1e6;
    resize: vertical;
}
.lancamento-card .input-descricao-cliente:focus {
    border-color: #0d6efd;
    box-shadow: 0 0 0 0.18rem rgba(13, 110, 253, 0.12);
}

/* Ações: selo + botão na mesma linha */
.lc-acoes {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0.6rem;
}
.btn-salvar-card { min-width: 104px; }

/* Selos de estado */
.selo-salvo {
    font-size: 0.72rem;
    font-weight: 600;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    letter-spacing: 0.02em;
}
.selo-pendente {
    color: #b54708;
    background: #fff4e5;
}
.selo-ok {
    color: #157347;
    background: #e7f6ec;
}

/* ============================ Ajustes mobile ============================ */
@media (max-width: 576px) {
    .container-extrato {
        padding-left: 10px;
        padding-right: 10px;
    }
    .card-header h6 {
        font-size: 0.95rem;
    }
    /* Faixa azul da empresa: nome longo + CNPJ sem espremer */
    .card-body > .bg-primary .fw-semibold {
        font-size: 0.95rem;
        line-height: 1.3;
        word-break: break-word;
    }
    .lc-valor {
        font-size: 1.25rem;
    }
    /* Rodapé do card: selo em cima, botão full-width embaixo */
    .lc-acoes {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
    }
    .lc-acoes .selo-salvo {
        align-self: flex-start;
    }
    .btn-salvar-card {
        width: 100%;
    }
}
