/**
 * App Eletrical - Estilos mobile-first
 * A maioria dos usuários acessa via celular. Desenvolvido pensando nisso.
 */

/* ========== Base mobile-first ========== */
:root {
    --touch-min: 44px;       /* Área mínima de toque (WCAG) */
    --spacing-mobile: 1rem;
    --font-body-mobile: 1rem;
    --font-title-mobile: 1.25rem;
    --safe-top: env(safe-area-inset-top, 0);
    --safe-bottom: env(safe-area-inset-bottom, 0);
}

/* Evitar zoom em inputs no iOS */
@media screen and (max-width: 767px) {
    input[type="text"],
    input[type="email"],
    input[type="tel"],
    input[type="number"],
    input[type="password"],
    select,
    textarea {
        font-size: 16px !important;
    }
}

/* Containers com padding seguro (notch, gestos) */
@media (max-width: 767.98px) {
    body {
        padding-left: env(safe-area-inset-left, 0);
        padding-right: env(safe-area-inset-right, 0);
        padding-bottom: var(--safe-bottom);
    }
    .container, .container-fluid {
        padding-left: var(--spacing-mobile);
        padding-right: var(--spacing-mobile);
    }
}

/* ========== Botões e áreas de toque ========== */
@media (max-width: 767.98px) {
    .btn {
        min-height: var(--touch-min);
        padding: 0.6rem 1rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
    .btn-lg {
        min-height: 48px;
        padding: 0.75rem 1.25rem;
    }
    .btn-sm {
        min-height: 36px;
        padding: 0.35rem 0.75rem;
    }
    /* Links que funcionam como botão */
    a.nav-link {
        min-height: var(--touch-min);
        display: flex;
        align-items: center;
        padding: 0.75rem 1rem;
    }
}

/* ========== Cards e listas em telas pequenas ========== */
@media (max-width: 767.98px) {
    .card {
        border-radius: 12px;
        margin-bottom: 1rem;
    }
    .card-body {
        padding: 1rem;
    }
    .card-stat .card-body {
        padding: 1rem;
    }
    .card-stat .stat-icon {
        font-size: 1.75rem;
    }
    .card-stat h3 {
        font-size: 1.5rem;
    }
}

/* ========== Cabeçalhos e títulos ========== */
@media (max-width: 767.98px) {
    .main-content-wrap h2,
    .p-4 h2 {
        font-size: var(--font-title-mobile);
        line-height: 1.3;
        word-break: break-word;
    }
    .d-flex.justify-content-between.align-items-center.mb-4 {
        flex-wrap: wrap;
        gap: 0.75rem;
    }
    .d-flex.justify-content-between.align-items-center.mb-4 .text-muted {
        width: 100%;
        order: 2;
        font-size: 0.875rem;
    }
}

/* ========== Formulários ========== */
@media (max-width: 767.98px) {
    .form-control,
    .form-select {
        min-height: var(--touch-min);
        padding: 0.65rem 1rem;
    }
    .form-label {
        margin-bottom: 0.35rem;
    }
    .input-group .form-control,
    .input-group .input-group-text {
        min-height: var(--touch-min);
    }
}

/* ========== Grid responsivo (cards de estatística) ========== */
@media (max-width: 575.98px) {
    .row .col-md-3.mb-3 {
        flex: 0 0 50%;
        max-width: 50%;
    }
}
@media (max-width: 399px) {
    .row .col-md-3.mb-3 {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

/* ========== Ações rápidas / botões em linha ========== */
@media (max-width: 767.98px) {
    .row .col-md-4.mb-3 .btn {
        width: 100%;
    }
}

/* ========== Tabelas (scroll horizontal em mobile) ========== */
@media (max-width: 767.98px) {
    .table-responsive {
        -webkit-overflow-scrolling: touch;
        margin-bottom: 1rem;
    }
    .table td, .table th {
        padding: 0.6rem 0.5rem;
        font-size: 0.875rem;
    }
}

/* ========== Alertas ========== */
@media (max-width: 767.98px) {
    .alert {
        padding: 0.75rem 1rem;
        font-size: 0.9375rem;
    }
}

/* ========== Utilitários ========== */
@media (max-width: 767.98px) {
    .p-4 {
        padding: 1rem !important;
    }
    .p-5 {
        padding: 1.25rem !important;
    }
}
