/* ===========================================================================
   GM ERP — tema visual (sem build; só CSS sobre o Bootstrap 5.3)
   - Paleta alinhada ao logo (azuis #0F3D63 / #1C5FA8, accent #F28C28)
   - Tipografia Inter; layout sidebar + topbar; modo escuro (data-bs-theme)
   =========================================================================== */

:root {
    /* Paleta principal */
    --blue-primary:   #0F3D63;
    --blue-secondary: #1C5FA8;
    --blue-light:     #4F8FD8;
    --white:          #FFFFFF;
    --bg-light:       #F5F7FA;

    /* Tons de cinza */
    --gray-900: #2B2F36;
    --gray-800: #3B3F46;
    --gray-700: #555B65;
    --gray-500: #8C939F;
    --gray-300: #D9DEE6;
    --gray-200: #E8EBEF;
    --gray-100: #F4F6F8;

    /* Destaque (uso restrito: CTA, ativo, badges, gráficos) */
    --accent:       #F28C28;
    --accent-hover: #DD7A18;
    --accent-light: #FFD7AE;

    /* Estados do sistema */
    --success: #34A853;
    --info:    #2D9CDB;
    --warning: #F4B400;
    --error:   #D93025;

    /* Sequência sugerida para gráficos */
    --chart-1: var(--blue-primary);
    --chart-2: var(--blue-secondary);
    --chart-3: var(--blue-light);
    --chart-4: var(--accent);
    --chart-5: var(--success);
    --chart-6: var(--gray-500);

    /* Aliases legados (PDF / JS) */
    --brand:     var(--blue-primary);
    --brand-600: var(--blue-secondary);
    --brand-700: #0A2944;

    /* Bootstrap — tokens dirigidos por CSS var */
    --bs-primary:       var(--blue-primary);
    --bs-primary-rgb:   15, 61, 99;
    --bs-secondary:     var(--gray-500);
    --bs-secondary-rgb: 140, 147, 159;
    --bs-success:       var(--success);
    --bs-success-rgb:   52, 168, 83;
    --bs-info:          var(--info);
    --bs-info-rgb:      45, 156, 219;
    --bs-warning:       var(--warning);
    --bs-warning-rgb:   244, 180, 0;
    --bs-danger:        var(--error);
    --bs-danger-rgb:    217, 48, 37;

    --bs-link-color:       var(--blue-secondary);
    --bs-link-hover-color: var(--blue-light);

    --bs-body-font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --bs-body-bg:          var(--bg-light);
    --bs-body-color:       var(--gray-700);
    --bs-emphasis-color:   var(--gray-900);
    --bs-secondary-color:  #6B7280;
    --bs-border-color:     var(--gray-200);
    --bs-border-radius:    0.6rem;
    --bs-border-radius-lg: 0.8rem;

    /* Superfícies do app (dashboard) */
    --surface:        var(--white);
    --surface-border: var(--gray-200);

    /* Sidebar */
    --sidebar-bg:         var(--blue-primary);
    --sidebar-fg:         #D6E5F5;
    --sidebar-fg-muted:   rgba(214, 229, 245, .55);
    --sidebar-hover-bg:   var(--blue-secondary);
    --sidebar-active-bg:  var(--accent);

    /* Tabelas */
    --table-head-bg:     var(--gray-100);
    --table-stripe-even: #FBFCFD;
    --table-hover-bg:    #EEF5FC;
    --table-selected-bg: #DCEBFA;

    --app-sidebar-w: 250px;
}

[data-bs-theme="dark"] {
    --bs-body-bg:         #101820;
    --bs-body-color:      #F5F7FA;
    --bs-emphasis-color:  #F5F7FA;
    --bs-secondary-color: #8C939F;
    --bs-border-color:    #27384B;

    --surface:        #162433;
    --surface-border: #27384B;

    --bs-primary-rgb:      79, 143, 216;
    --bs-link-color:       var(--blue-light);
    --bs-link-hover-color: #7FB0E8;

    --sidebar-bg:       #0A2944;
    --sidebar-fg:       #D6E5F5;
    --sidebar-fg-muted: rgba(214, 229, 245, .45);

    --table-head-bg:     #1a2d42;
    --table-stripe-even: #131f2e;
    --table-hover-bg:    #1e3348;
    --table-selected-bg: #243a52;
}

body {
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    color: var(--gray-900);
    font-weight: 700;
}

[data-bs-theme="dark"] h1, [data-bs-theme="dark"] h2,
[data-bs-theme="dark"] h3, [data-bs-theme="dark"] h4,
[data-bs-theme="dark"] h5, [data-bs-theme="dark"] h6,
[data-bs-theme="dark"] .h1, [data-bs-theme="dark"] .h2,
[data-bs-theme="dark"] .h3, [data-bs-theme="dark"] .h4,
[data-bs-theme="dark"] .h5, [data-bs-theme="dark"] .h6 {
    color: var(--bs-emphasis-color);
}

/* Títulos dentro de superfícies coloridas (badges, cards sólidos legados) */
[class*="text-bg-"] .h1, [class*="text-bg-"] .h2,
[class*="text-bg-"] .h3, [class*="text-bg-"] .h4,
[class*="text-bg-"] .h5, [class*="text-bg-"] .h6,
[class*="text-bg-"] .display-1, [class*="text-bg-"] .display-2,
[class*="text-bg-"] .display-3, [class*="text-bg-"] .display-4,
[class*="text-bg-"] .display-5, [class*="text-bg-"] .display-6 {
    color: inherit;
}

/* Botões (variantes do BS são valores compilados) */
.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--blue-primary);
    --bs-btn-border-color: var(--blue-primary);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--blue-secondary);
    --bs-btn-hover-border-color: var(--blue-secondary);
    --bs-btn-active-bg: var(--brand-700);
    --bs-btn-active-border-color: var(--brand-700);
    --bs-btn-disabled-bg: var(--blue-primary);
    --bs-btn-disabled-border-color: var(--blue-primary);
}
.btn-outline-primary {
    --bs-btn-color: var(--blue-primary);
    --bs-btn-bg: var(--white);
    --bs-btn-border-color: var(--blue-primary);
    --bs-btn-hover-color: var(--blue-primary);
    --bs-btn-hover-bg: var(--white);
    --bs-btn-hover-border-color: var(--blue-primary);
    --bs-btn-active-bg: var(--white);
    --bs-btn-active-border-color: var(--blue-primary);
    --bs-btn-active-color: var(--blue-primary);
}
.btn-cta {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--accent);
    --bs-btn-border-color: var(--accent);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--accent-hover);
    --bs-btn-hover-border-color: var(--accent-hover);
    --bs-btn-active-bg: var(--accent-hover);
    --bs-btn-active-border-color: var(--accent-hover);
}

/* ---------------------------------------------------------------------------
   Layout: sidebar + main
   --------------------------------------------------------------------------- */
.app-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: var(--app-sidebar-w);
    background-color: #0F3D63;
    background: var(--sidebar-bg);
    color: var(--sidebar-fg);
    display: flex;
    flex-direction: column;
    z-index: 1045;
    overflow-y: auto;
    transition: transform .2s ease;
}
[data-bs-theme="dark"] .app-sidebar {
    background-color: #0A2944;
}

.app-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: .85rem 1rem;
    color: #fff;
    font-weight: 700;
    font-size: 1.15rem;
    text-decoration: none;
    border-bottom: 1px solid rgba(255, 255, 255, .07);
}
.app-brand:hover { color: #fff; }
.app-brand-logo-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: .45rem .65rem;
    background: var(--white);
    border-radius: var(--bs-border-radius);
    box-shadow: 0 1px 4px rgba(0, 0, 0, .14);
    transition: background .12s, box-shadow .12s;
}
.app-brand:hover .app-brand-logo-wrap {
    background: var(--bg-light);
    box-shadow: 0 2px 8px rgba(0, 0, 0, .18);
}
.app-brand-logo {
    height: 44px;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    display: block;
}
.app-brand .logo-badge {
    width: 32px; height: 32px;
    display: grid; place-items: center;
    border-radius: .5rem;
    background: linear-gradient(135deg, var(--brand) 0%, var(--accent) 130%);
    color: #fff;
    font-size: 1rem;
}

.side-nav { padding: .5rem 0 1.5rem; flex: 1 1 auto; }

.side-section {
    font-size: .67rem;
    letter-spacing: .09em;
    text-transform: uppercase;
    color: var(--sidebar-fg-muted);
    padding: 1rem 1.25rem .35rem;
    font-weight: 600;
}

.side-link {
    display: flex;
    align-items: center;
    gap: .7rem;
    padding: .5rem 1.25rem;
    color: var(--sidebar-fg);
    text-decoration: none;
    font-size: .9rem;
    border-left: 3px solid transparent;
    transition: background .12s, color .12s;
}
.side-link:hover { background: var(--sidebar-hover-bg); color: #fff; }
.side-link.active {
    background: var(--sidebar-active-bg);
    color: #fff;
    border-left-color: var(--accent);
    font-weight: 600;
}
.side-link i { font-size: 1.05rem; width: 1.25rem; text-align: center; opacity: .92; }

.app-main {
    margin-left: var(--app-sidebar-w);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.app-topbar {
    position: sticky;
    top: 0;
    z-index: 1030;
    height: 56px;
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: 0 1.25rem;
    background: color-mix(in srgb, var(--surface) 85%, transparent);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--surface-border);
}

.app-crumb { display: flex; align-items: center; gap: .4rem; font-size: .85rem; }
.app-crumb a { color: var(--bs-secondary-color); text-decoration: none; }
.app-crumb a:hover { color: var(--bs-link-color); }
.app-crumb .bi-chevron-right { font-size: .65rem; color: var(--bs-secondary-color); }
.app-crumb .crumb-current { font-weight: 600; }

.topbar-icon {
    color: var(--bs-secondary-color);
    border: 0;
    background: transparent;
    font-size: 1.15rem;
    line-height: 1;
    padding: .35rem .5rem;
    border-radius: .5rem;
}
.topbar-icon:hover { background: var(--bs-secondary-bg); color: var(--bs-body-color); }

.app-content { padding: 1.5rem; flex: 1 1 auto; }

.app-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .4);
    z-index: 1044;
}

/* Mobile: sidebar vira gaveta */
@media (max-width: 991.98px) {
    .app-sidebar { transform: translateX(-100%); }
    .app-sidebar.is-open { transform: translateX(0); box-shadow: 0 0 40px rgba(0, 0, 0, .4); }
    .app-main { margin-left: 0; }
}
@media (min-width: 992px) {
    .app-hamburger, .app-backdrop { display: none !important; }
}

/* ---------------------------------------------------------------------------
   Polimento de componentes
   --------------------------------------------------------------------------- */
.card {
    border: 1px solid var(--surface-border);
    background: var(--surface);
    box-shadow: 0 1px 2px rgba(16, 24, 40, .04);
}
.card.shadow-sm { box-shadow: 0 1px 3px rgba(16, 24, 40, .07) !important; }

.table > :not(caption) > * > * { padding-block: .6rem; }
.table thead th {
    font-size: .8rem;
    letter-spacing: .02em;
    text-transform: uppercase;
    color: var(--bs-secondary-color);
    background: var(--table-head-bg);
    border-bottom-color: var(--surface-border);
}
.table.table-striped > tbody > tr:nth-of-type(odd) > * { background-color: var(--surface); }
.table.table-striped > tbody > tr:nth-of-type(even) > * { background-color: var(--table-stripe-even); }
.table:not(.table-cards) > tbody > tr:nth-of-type(even) > * { background-color: var(--table-stripe-even); }
.table-hover > tbody > tr:hover > * { background-color: var(--table-hover-bg) !important; }
.table > tbody > tr.table-active > *,
.table > tbody > tr.table-active:hover > * { background-color: var(--table-selected-bg) !important; }

/* Barra de carregamento global do HTMX */
#top-progress {
    position: fixed;
    top: 0; left: 0;
    height: 3px;
    width: 0;
    z-index: 2000;
    background: linear-gradient(90deg, var(--brand), var(--accent));
    opacity: 0;
    transition: opacity .2s;
}
#top-progress.loading {
    opacity: 1;
    width: 100%;
    animation: gm-progress 1.4s ease-in-out infinite;
}
@keyframes gm-progress {
    0%   { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

/* HTMX indicators (mantido) */
.htmx-indicator { display: none; }
.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator { display: inline; }

[x-cloak] { display: none !important; }

/* Scrollbar discreta */
.app-sidebar::-webkit-scrollbar { width: 8px; }
.app-sidebar::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, .12); border-radius: 8px; }

/* ---------------------------------------------------------------------------
   Tabelas que viram cartões no mobile (.table-cards)
   - No desktop, tabela normal.
   - Abaixo de 768px, cada <tr> vira um cartão e cada <td> mostra o rótulo
     da coluna via atributo data-label="...".
   - Células de ação devem usar class="td-actions" para ocupar a largura toda.
   --------------------------------------------------------------------------- */
@media (max-width: 767.98px) {
    .table-cards thead { display: none; }

    .table-cards,
    .table-cards tbody,
    .table-cards tr,
    .table-cards td { display: block; width: 100%; }

    .table-cards tr {
        background: var(--surface);
        border: 1px solid var(--surface-border);
        border-radius: var(--bs-border-radius);
        box-shadow: 0 1px 2px rgba(16, 24, 40, .05);
        margin-bottom: .75rem;
        padding: .35rem .9rem;
    }
    .table-cards.table-hover > tbody > tr:hover > * { background: transparent; }

    .table-cards td {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: .45rem 0 !important;
        border: 0;
        border-bottom: 1px solid var(--surface-border);
        text-align: right;
        white-space: normal;
    }
    .table-cards tr > td:last-child { border-bottom: 0; }

    .table-cards td::before {
        content: attr(data-label);
        flex: 0 0 auto;
        text-align: left;
        font-size: .72rem;
        font-weight: 600;
        letter-spacing: .02em;
        text-transform: uppercase;
        color: var(--bs-secondary-color);
    }
    /* Células sem rótulo (ou de ação) não recebem o pseudo-rótulo */
    .table-cards td:not([data-label])::before { content: ""; }

    /* Barras de progresso ocupam o espaço restante (não espremem ao lado do rótulo) */
    .table-cards td .progress { flex: 1 1 auto; min-width: 8rem; }

    /* Linha de ações: botões ocupam a largura toda, alinhados à direita */
    .table-cards td.td-actions {
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: .4rem;
        padding-top: .6rem !important;
    }
    .table-cards td.td-actions .btn { flex: 0 0 auto; }

    /* Estado vazio (colspan) volta a ocupar a linha inteira, centralizado */
    .table-cards td[colspan] { text-align: center; }
    .table-cards td[colspan]::before { content: ""; }

    /* Célula de edição inline: empilha os campos do formulário verticalmente */
    .table-cards td.td-form {
        display: block;
        text-align: left;
        padding-top: .55rem !important;
    }
    .table-cards td.td-form::before {
        content: attr(data-label);
        display: block;
        margin-bottom: .35rem;
        text-align: left;
    }
    .table-cards td.td-form form { flex-wrap: wrap; gap: .5rem !important; }
    .table-cards td.td-form form > * { flex: 1 1 7rem; }
    .table-cards td.td-form .row { margin: 0; }
    .table-cards td.td-form .form-control,
    .table-cards td.td-form .form-select { max-width: none !important; }

    /* Rodapé de total (tfoot) vira um cartão-resumo destacado */
    .table-cards tfoot { display: block; }
    .table-cards tfoot tr {
        display: flex;
        justify-content: space-between;
        gap: 1rem;
        background: var(--bs-tertiary-bg);
    }
    .table-cards tfoot th { display: block; border: 0; padding: .2rem 0; }
    .table-cards tfoot th:empty { display: none; }
}

/* ---------------------------------------------------------------------------
   Alvos de toque mais confortáveis no mobile (>= ~40px)
   --------------------------------------------------------------------------- */
@media (max-width: 767.98px) {
    /* Botões pequenos ganham área tocável; ícones ainda cabem lado a lado */
    .btn-sm {
        --bs-btn-padding-y: .45rem;
        --bs-btn-padding-x: .7rem;
        min-height: 40px;
    }
    /* Ícones da topbar (menu, tema, perfil) */
    .topbar-icon {
        min-width: 42px;
        min-height: 42px;
        padding: .5rem .6rem;
    }
    /* Links do menu lateral com mais respiro vertical */
    .side-link { padding-block: .7rem; }
    /* Itens de dropdown (ações de ferramentas, perfil) */
    .dropdown-menu .dropdown-item { padding-block: .55rem; }
    /* Campos de formulário não encolhem abaixo do confortável */
    .form-control-sm, .form-select-sm { min-height: 38px; }
}

/* ---------------------------------------------------------------------------
   Dashboard — KPI cards
   --------------------------------------------------------------------------- */
/* Mantém o "primário subtil" alinhado à marca (tema claro e escuro) */
:root {
    --bs-primary-bg-subtle: #DCEBFA;
    --bs-primary-text-emphasis: var(--blue-primary);
    --bs-success-bg-subtle: #E6F4EA;
    --bs-success-text-emphasis: #1E7E34;
    --bs-info-bg-subtle: #E3F2FB;
    --bs-info-text-emphasis: #1A7AB8;
    --bs-warning-bg-subtle: #FEF7E0;
    --bs-warning-text-emphasis: #9A7200;
    --bs-danger-bg-subtle: #FCEAE8;
    --bs-danger-text-emphasis: #A52714;
}
[data-bs-theme="dark"] {
    --bs-primary-bg-subtle: #1a3550;
    --bs-primary-text-emphasis: var(--blue-light);
    --bs-success-bg-subtle: #1a3324;
    --bs-success-text-emphasis: #6DD58C;
    --bs-info-bg-subtle: #1a2f3f;
    --bs-info-text-emphasis: #6EC4F0;
    --bs-warning-bg-subtle: #3a3018;
    --bs-warning-text-emphasis: #F5D060;
    --bs-danger-bg-subtle: #3a1f1c;
    --bs-danger-text-emphasis: #F08078;
}

.kpi-card {
    display: flex;
    align-items: center;
    gap: .9rem;
    height: 100%;
    padding: 1rem 1.1rem;
    background: var(--surface);
    border: 1px solid var(--surface-border);
    border-radius: var(--bs-border-radius-lg);
    box-shadow: 0 1px 3px rgba(16, 24, 40, .06);
    text-decoration: none;
    color: inherit;
    transition: transform .12s, box-shadow .12s;
}
a.kpi-card:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(16, 24, 40, .12); color: inherit; }
.kpi-card.is-static { pointer-events: none; }

.kpi-icon {
    flex: 0 0 46px;
    width: 46px; height: 46px;
    display: grid; place-items: center;
    border-radius: .7rem;
    font-size: 1.3rem;
}
.kpi-value { font-size: 1.45rem; font-weight: 700; line-height: 1.1; }
.kpi-label { font-size: .82rem; color: var(--bs-secondary-color); }
.kpi-sub { font-size: .72rem; margin-top: .1rem; }

.kpi-primary   .kpi-icon { background: var(--bs-primary-bg-subtle);   color: var(--bs-primary-text-emphasis); }
.kpi-success   .kpi-icon { background: var(--bs-success-bg-subtle);   color: var(--bs-success-text-emphasis); }
.kpi-danger    .kpi-icon { background: var(--bs-danger-bg-subtle);    color: var(--bs-danger-text-emphasis); }
.kpi-info      .kpi-icon { background: var(--bs-info-bg-subtle);      color: var(--bs-info-text-emphasis); }
.kpi-warning   .kpi-icon { background: var(--bs-warning-bg-subtle);   color: var(--bs-warning-text-emphasis); }
.kpi-secondary .kpi-icon { background: var(--bs-secondary-bg-subtle); color: var(--bs-secondary-text-emphasis); }
.kpi-dark      .kpi-icon { background: var(--bs-tertiary-bg);         color: var(--bs-emphasis-color); }

/* Cards de métrica (orçamento, financeiro, RDO…) — fundo claro, legível */
.stat-card {
    border: 1px solid var(--surface-border);
    background: var(--surface);
    box-shadow: 0 1px 3px rgba(16, 24, 40, .06);
}
.stat-card-value {
    font-size: 1.45rem;
    font-weight: 700;
    line-height: 1.15;
    margin-bottom: 0;
    color: var(--bs-emphasis-color);
}
.stat-card-value-lg { font-size: clamp(1.35rem, 2.5vw, 2rem); }
.stat-card-label {
    font-size: .82rem;
    color: var(--bs-secondary-color);
    margin-top: .2rem;
}
.stat-card-primary  { border-top: 3px solid var(--blue-primary); }
.stat-card-primary  .stat-card-value { color: var(--blue-primary); }
.stat-card-success  { border-top: 3px solid var(--success); }
.stat-card-success  .stat-card-value { color: #1E7E34; }
.stat-card-info     { border-top: 3px solid var(--info); }
.stat-card-info     .stat-card-value { color: #1A7AB8; }
.stat-card-warning  { border-top: 3px solid var(--warning); }
.stat-card-warning  .stat-card-value { color: #9A7200; }
.stat-card-danger   { border-top: 3px solid var(--error); }
.stat-card-danger   .stat-card-value { color: var(--error); }
.stat-card-secondary { border-top: 3px solid var(--gray-500); }
.stat-card-secondary .stat-card-value { color: var(--gray-700); }
.stat-card-muted {
    border-top: 3px solid var(--gray-300);
    background: var(--gray-100);
}
[data-bs-theme="dark"] .stat-card-muted { background: var(--bs-tertiary-bg); }
[data-bs-theme="dark"] .stat-card-success  .stat-card-value { color: #6DD58C; }
[data-bs-theme="dark"] .stat-card-info     .stat-card-value { color: #6EC4F0; }
[data-bs-theme="dark"] .stat-card-warning  .stat-card-value { color: #F5D060; }
[data-bs-theme="dark"] .stat-card-danger   .stat-card-value { color: #F08078; }
[data-bs-theme="dark"] .stat-card-primary  .stat-card-value { color: var(--blue-light); }

/* Lista de pendências */
.pendencia-item { display: flex; align-items: center; gap: .65rem; }
.pendencia-item .bi { width: 1.3rem; text-align: center; }
.chart-box { position: relative; height: 280px; }

/* Tela inicial */
.home-hero { border: 1px solid var(--surface-border); }

/* Login (páginas públicas: entrar, 2FA etc.) */
.login-layout {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem 1rem;
    background: var(--bg-light);
}
.login-shell {
    width: 100%;
    max-width: 400px;
}
.login-card {
    border: 1px solid var(--surface-border);
    border-radius: var(--bs-border-radius-lg);
    overflow: hidden;
    background: var(--white);
}
.login-card-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.75rem 1.5rem 1.5rem;
    background: var(--blue-primary);
    border-bottom: 3px solid var(--accent);
}
.login-logo-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: .55rem .85rem;
    background: var(--white);
    border-radius: var(--bs-border-radius);
    box-shadow: 0 2px 8px rgba(0, 0, 0, .12);
}
.login-logo {
    max-height: 60px;
    max-width: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}
.login-card-body {
    padding: 1.5rem 1.5rem 1.75rem;
}
.login-card-title {
    margin: 0 0 .25rem;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--gray-900);
    text-align: center;
}
.login-card-subtitle {
    margin: 0 0 1.25rem;
    font-size: .9rem;
    color: #6B7280;
    text-align: center;
}
.login-form .form-label {
    font-weight: 600;
    color: var(--gray-900);
    font-size: .875rem;
}
.login-form .form-control {
    border-color: var(--gray-300);
    padding-block: .6rem;
}
.login-form .form-control:focus {
    border-color: var(--blue-light);
    box-shadow: 0 0 0 .2rem rgba(15, 61, 99, .12);
}
.login-block-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    background: var(--bs-warning-bg-subtle);
    color: var(--bs-warning-text-emphasis);
    font-size: 1.75rem;
}
.login-block-progress {
    height: 4px;
    background: var(--gray-200);
}
.login-block-progress .progress-bar {
    background: var(--warning);
}

[data-bs-theme="dark"] .login-layout {
    background: #101820;
}
[data-bs-theme="dark"] .login-card {
    background: #162433;
    border-color: #27384B;
}
[data-bs-theme="dark"] .login-card-brand {
    background: #0A2944;
}
[data-bs-theme="dark"] .login-card-title {
    color: #F5F7FA;
}
[data-bs-theme="dark"] .login-card-subtitle {
    color: #8C939F;
}
[data-bs-theme="dark"] .login-form .form-label {
    color: #F5F7FA;
}
[data-bs-theme="dark"] .login-form .form-control {
    background: #101820;
    border-color: #27384B;
    color: #F5F7FA;
}
[data-bs-theme="dark"] .login-form .form-control:focus {
    border-color: var(--blue-light);
    box-shadow: 0 0 0 .2rem rgba(79, 143, 216, .2);
}

.home-hero-logo {
    flex: 0 0 auto;
    max-height: 52px;
    max-width: 140px;
    width: auto;
    height: auto;
    object-fit: contain;
}
.home-hero-icon {
    flex: 0 0 42px;
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    font-size: 1.35rem;
}
.home-shortcut {
    border: 1px solid var(--surface-border);
    color: inherit;
    transition: transform .12s, box-shadow .12s;
}
.home-shortcut:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(16, 24, 40, .12);
    color: inherit;
}
.home-shortcut-icon {
    flex: 0 0 42px;
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: .65rem;
    background: var(--bs-primary-bg-subtle);
    color: var(--bs-primary-text-emphasis);
    font-size: 1.15rem;
}
.home-widget-link:hover .text-body { color: var(--bs-primary); }

/* Gantt do cronograma (renderizado no servidor) */
.gantt { --gantt-label: 16rem; font-size: .85rem; }
.gantt-head, .gantt-row { display: flex; align-items: stretch; }
.gantt-row { border-top: 1px solid var(--bs-border-color); }
.gantt-label {
    width: var(--gantt-label); flex: 0 0 var(--gantt-label);
    padding: .45rem .6rem; display: flex; flex-direction: column; justify-content: center;
}
.gantt-label .etapa-nome { font-weight: 600; line-height: 1.15; }
.gantt-label .etapa-datas { font-size: .72rem; color: var(--bs-secondary-color); }
.gantt-track { position: relative; flex: 1 1 auto; min-height: 2.6rem; }
.gantt-head .gantt-track { min-height: 1.6rem; }
.gantt-bar {
    position: absolute; top: 50%; transform: translateY(-50%);
    height: 1.3rem; border-radius: .35rem; overflow: hidden;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.12);
}
.gantt-bar-fill { position: absolute; inset: 0 auto 0 0; background: rgba(0,0,0,.30); }
.gantt-bar-label {
    position: relative; z-index: 1; font-size: .72rem; line-height: 1.3rem;
    padding: 0 .4rem; white-space: nowrap; color: #fff; font-weight: 600;
    text-shadow: 0 1px 1px rgba(0,0,0,.35);
}
.gantt-today { position: absolute; top: 0; bottom: 0; width: 2px; background: var(--bs-danger); z-index: 3; }
.gantt-month { position: absolute; top: 0; bottom: 0; border-left: 1px dashed var(--bs-border-color);
    padding-left: .2rem; font-size: .7rem; color: var(--bs-secondary-color); white-space: nowrap; }

/* Mobile: o Gantt rola na horizontal; a coluna "Etapa" fica fixa (sticky) */
@media (max-width: 767.98px) {
    .gantt {
        --gantt-label: 8.5rem;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    /* Cada linha cresce com o conteúdo (mín. = largura visível), gerando o scroll */
    .gantt-head, .gantt-row { width: max-content; min-width: 100%; }
    /* Trilha do tempo ganha largura mínima para as barras serem legíveis */
    .gantt-track { min-width: 30rem; }
    /* Rótulo da etapa acompanha o scroll grudado na esquerda */
    .gantt-label {
        position: sticky;
        left: 0;
        z-index: 4;
        background: var(--surface);
        box-shadow: 1px 0 0 var(--surface-border);
    }
}

/* ---------------------------------------------------------------------------
   Diário de Obra (RDO) — layout otimizado para canteiro / mobile
   --------------------------------------------------------------------------- */
.rdo-campo .rdo-anexo-thumb {
    object-fit: cover;
    height: 140px;
    width: 100%;
    background: var(--bs-tertiary-bg);
}

.rdo-campo .form-control[type="file"] {
    min-height: 42px;
    padding-top: .55rem;
}

@media (max-width: 767.98px) {
    .rdo-campo .list-group {
        max-height: 12rem !important;
    }
    .rdo-campo .card-body .row.g-2 > [class*="col-"] {
        flex: 0 0 100%;
        max-width: 100%;
    }
    .rdo-campo .rdo-workflow-sticky {
        position: sticky;
        bottom: .5rem;
        z-index: 10;
        box-shadow: 0 -4px 16px rgba(16, 24, 40, .15);
    }
    .rdo-campo .rdo-workflow-sticky .btn {
        min-height: 44px;
        flex: 1 1 auto;
    }
    .rdo-campo .rdo-anexo-thumb {
        height: 120px;
    }
}

/* ---------------------------------------------------------------------------
   Modal HTMX: formulários carregados dentro de #modal-content
   O <form> envolve header/body/footer; sem flex no form o .modal-body não rola
   e o conteúdo inferior fica cortado (ex.: edição de fornecedor).
   --------------------------------------------------------------------------- */
.modal-dialog-scrollable .modal-content > form {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    max-height: 100%;
    overflow: hidden;
}

.modal-dialog-scrollable .modal-content > form .modal-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
}

/* ---------------------------------------------------------------------------
   Botão flutuante de feedback (reportar bug / sugerir melhoria)
   Pequeno e translúcido; fica opaco no hover/foco. Abaixo do modal (z 1055).
   Canto inferior DIREITO (fora da sidebar); os toasts sobem acima dele.
   --------------------------------------------------------------------------- */
.fab-feedback {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 1045;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border-radius: 50%;
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    color: var(--bs-secondary-color);
    opacity: .45;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 .25rem .75rem rgba(0, 0, 0, .15);
    transition: opacity .15s ease, transform .15s ease;
}

.fab-feedback:hover,
.fab-feedback:focus-visible {
    opacity: 1;
    transform: translateY(-1px);
}
