/**
 * relatorio.css
 * Estilos do módulo de relatório diário de coletas.
 * Inclua no index.php após coletas.css:
 *   <link rel="stylesheet" href="/app/css/relatorio.css">
 *
 * Usa as mesmas variáveis CSS do projeto (cor-petroleo, cor-linha, etc.)
 */

/* ===================== Cabeçalho ===================== */

.rel_cabecalho {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.rel_titulo {
    font-family: var(--fonte-display);
    font-size: 22px;
    color: var(--cor-petroleo-escuro);
    margin: 0 0 4px;
}

.rel_subtitulo {
    font-size: 13px;
    color: var(--cor-tinta-suave);
    margin: 0;
}

/* ── Controles de data ── */

.rel_controles {
    display: flex;
    align-items: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.rel_data_wrapper {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.rel_label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--cor-tinta-suave);
}

.rel_input_data {
    font-family: var(--fonte-corpo);
    font-size: 14px;
    padding: 9px 12px;
    border: 1px solid var(--cor-linha);
    border-radius: 6px;
    background: #fff;
    color: var(--cor-tinta);
    transition: border-color 0.15s;
}

.rel_input_data:focus {
    outline: none;
    border-color: var(--cor-petroleo);
}

.rel_btn_buscar {
    background: var(--cor-petroleo);
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 10px 18px;
    font-size: 14px;
    font-weight: 600;
    transition: background 0.15s;
    white-space: nowrap;
}

.rel_btn_buscar:hover { background: var(--cor-petroleo-escuro); }

/* ===================== Mensagens de estado ===================== */

.rel_aviso_inicial,
.rel_carregando,
.rel_erro,
.rel_vazio {
    text-align: center;
    padding: 40px 20px;
    font-size: 14px;
    color: var(--cor-tinta-suave);
}

.rel_erro { color: #b91c1c; }

/* ===================== Resumo ===================== */

.rel_resumo {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-cartao);
    overflow: hidden;
    margin-bottom: 16px;
    background: #fff;
}

.rel_resumo_bloco {
    padding: 16px 20px;
    border-right: 1px solid var(--cor-linha);
    text-align: center;
}

.rel_resumo_bloco:last-child { border-right: none; }

.rel_numero {
    font-size: 32px;
    font-weight: 700;
    color: var(--cor-tinta);
    line-height: 1.1;
}

.rel_rotulo {
    font-size: 12px;
    color: var(--cor-tinta-suave);
    margin-top: 4px;
}

.rel_verde  .rel_numero { color: #059669; }
.rel_amarelo .rel_numero { color: #d97706; }

/* ===================== Box de envio para a síndica ===================== */

.rel_envio_box {
    background: #fff;
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-cartao);
    padding: 16px 20px;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.rel_envio_info {
    flex: 1;
    min-width: 200px;
}

.rel_envio_info strong {
    display: block;
    font-size: 14px;
    color: var(--cor-petroleo-escuro);
    margin-bottom: 3px;
}

.rel_envio_desc {
    font-size: 12px;
    color: var(--cor-tinta-suave);
}

.rel_envio_linha {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.rel_input_tel {
    font-family: var(--fonte-corpo);
    font-size: 14px;
    padding: 9px 12px;
    border: 1px solid var(--cor-linha);
    border-radius: 6px;
    background: #fff;
    color: var(--cor-tinta);
    width: 180px;
    transition: border-color 0.15s;
}

.rel_input_tel:focus {
    outline: none;
    border-color: var(--cor-petroleo);
}

.rel_btn_enviar {
    background: #25D366;
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 10px 18px;
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
    transition: opacity 0.15s, transform 0.1s;
}

.rel_btn_enviar:hover   { opacity: 0.88; }
.rel_btn_enviar:active  { transform: scale(0.97); }
.rel_btn_enviar:disabled { opacity: 0.55; cursor: not-allowed; }

/* ===================== Seções coletadas / pendentes ===================== */

.rel_secoes {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.rel_secao {
    background: #fff;
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-cartao);
    overflow: hidden;
}

.rel_sec_titulo {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 10px 16px;
    border-bottom: 1px solid var(--cor-linha);
}

.rel_sec_verde   { background: #d1fae5; color: #065f46; }
.rel_sec_amarelo { background: #fef3c7; color: #92400e; }

/* ===================== Tabela ===================== */

.rel_tabela_wrapper {
    overflow-x: auto;
}

.rel_tabela {
    width: 100%;
    border-collapse: collapse;
}

.rel_tabela thead th {
    background: #f9fafb;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--cor-tinta-suave);
    padding: 9px 12px;
    text-align: left;
    border-bottom: 1px solid var(--cor-linha);
    white-space: nowrap;
}

.rel_tabela tbody td {
    padding: 10px 12px;
    border-bottom: 1px solid #f3f4f6;
    vertical-align: middle;
    font-size: 13px;
    color: var(--cor-tinta);
}

.rel_tabela tbody tr:last-child td { border-bottom: none; }
.rel_tabela tbody tr:nth-child(even) td { background: #f9fafb; }
.rel_tabela tbody tr:hover td { background: #f0fdf4; transition: background 0.1s; }

.rel_th_foto { width: 72px; }
.rel_td_foto { text-align: center; }

/* ── Foto miniatura ── */

.rel_foto_btn {
    background: none;
    border: none;
    padding: 0;
    cursor: zoom-in;
    border-radius: 4px;
    overflow: hidden;
    display: inline-block;
}

.rel_foto_mini {
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: 4px;
    border: 1px solid var(--cor-linha);
    display: block;
    transition: opacity 0.15s;
}

.rel_foto_btn:hover .rel_foto_mini { opacity: 0.82; }

.rel_sem_foto {
    width: 56px;
    height: 56px;
    background: var(--cor-papel-escuro);
    border: 1px solid var(--cor-linha);
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
}

/* ── Textos dentro da tabela ── */

.rel_nome {
    font-size: 13px;
    font-weight: 600;
    display: block;
}

.rel_telefone {
    font-size: 11px;
    color: var(--cor-tinta-suave);
    display: block;
    margin-top: 2px;
}

.rel_rastreio {
    font-family: var(--fonte-dados);
    font-size: 11px;
    color: var(--cor-tinta-suave);
}

.rel_hora {
    font-size: 12px;
    color: var(--cor-tinta-suave);
    white-space: nowrap;
}

.rel_sem_info {
    color: var(--cor-tinta-suave);
    font-size: 12px;
}

/* ── Tags de marketplace (reaproveitando as do coletas.css) ── */

.rel_tag {
    display: inline-block;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 2px 7px;
    border-radius: 3px;
}

.rel_tag_shopee          { background: #FF6130; color: #fff; }
.rel_tag_amazon          { background: #FF9900; color: #111; }
.rel_tag_mercado-livre   { background: #FFE600; color: #111; }
.rel_tag_shein           { background: #3A1C5C; color: #fff; }
.rel_tag_aliexpress      { background: #E43225; color: #fff; }
.rel_tag_magalu          { background: #0086FF; color: #fff; }
.rel_tag_americanas      { background: #EE1C25; color: #fff; }
.rel_tag_submarino       { background: #004B8D; color: #fff; }
.rel_tag_casas-bahia     { background: #F7A600; color: #111; }
.rel_tag_outros          { background: var(--cor-linha); color: var(--cor-tinta); }

/* ===================== Toast de feedback ===================== */

.rel_toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    padding: 14px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 8px 24px rgba(0,0,0,0.18);
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.3s, transform 0.3s;
    z-index: 9999;
    max-width: 360px;
}

.rel_toast_visivel {
    opacity: 1;
    transform: translateY(0);
}

.rel_toast_sucesso {
    background: #059669;
    color: #fff;
}

.rel_toast_erro {
    background: #b91c1c;
    color: #fff;
}

/* ===================== Responsivo ===================== */

@media (max-width: 640px) {
    .rel_cabecalho {
        flex-direction: column;
    }

    .rel_controles {
        width: 100%;
    }

    .rel_input_data { width: 100%; }
    .rel_btn_buscar { width: 100%; }

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

    .rel_resumo_bloco {
        border-right: none;
        border-bottom: 1px solid var(--cor-linha);
    }

    .rel_resumo_bloco:last-child { border-bottom: none; }

    .rel_envio_box {
        flex-direction: column;
        align-items: stretch;
    }

    .rel_envio_linha {
        flex-direction: column;
    }

    .rel_input_tel { width: 100%; }
    .rel_btn_enviar { width: 100%; text-align: center; }

    /* Esconde coluna de telefone na tabela (já aparece embaixo do nome) */
    .rel_tabela th:nth-child(3),
    .rel_tabela td:nth-child(3) {
        display: none;
    }

    .rel_toast {
        bottom: 16px;
        right: 16px;
        left: 16px;
        max-width: unset;
    }
}