* {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        }
        
        body {
            background: #f5f7fa;
            color: #333;
            font-size: 14px;
            line-height: 1.25;
        }
        
        /* CONTAINER PRINCIPAL - TELA CHEIA */
        .admin-container {
            min-height: 100vh;
            display: flex;
            width: 100%;
            overflow: hidden;
        }
        
        /* SIDEBAR */
        .admin-sidebar {
            width: 220px;
            /* Novo visual (mais clean): azul sólido */
            background: #00279c;
            color: white;
            padding: 20px 0;
            position: fixed;
            height: 100vh;
            box-shadow: 2px 0 10px rgba(0,0,0,0.1);
            overflow: hidden;
            z-index: 100;
            display: flex;
            flex-direction: column;
        }
        
        .logo {
            padding: 0 20px 30px 20px;
            border-bottom: 1px solid rgba(255,255,255,0.18);
            margin-bottom: 20px;
        }
        
        .logo h1 {
            font-size: 1.35rem;
            color: #09e2fd;
        }
        
        .logo span {
            color: #0043c7;
        }
        
        .admin-nav {
            padding: 0 15px;
            flex: 1 1 auto;
            min-height: 0;
            overflow-y: auto;
            overflow-x: hidden;
            padding-bottom: 12px;
            scrollbar-width: thin;
            scrollbar-color: transparent transparent;
            scrollbar-gutter: stable;
        }

        .admin-nav:hover,
        .admin-nav:focus-within {
            scrollbar-color: rgba(255,255,255,0.30) transparent;
        }

        .admin-nav::-webkit-scrollbar {
            width: 8px;
        }

        .admin-nav::-webkit-scrollbar-track {
            background: transparent;
        }

        .admin-nav::-webkit-scrollbar-thumb {
            background: rgba(255,255,255,0);
            border-radius: 999px;
            border: 2px solid transparent;
            background-clip: content-box;
        }

        .admin-nav:hover::-webkit-scrollbar-thumb,
        .admin-nav:focus-within::-webkit-scrollbar-thumb {
            background: rgba(255,255,255,0.30);
        }

        .admin-nav::-webkit-scrollbar-thumb:hover {
            background: rgba(255,255,255,0.42);
        }
        
        .nav-item {
            display: flex;
            align-items: center;
            padding: 10px 12px;
            margin: 5px 0;
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.3s;
            text-decoration: none;
            color: rgba(255,255,255,0.78);
            /* -2px em relação ao padrão anterior */
            font-size: 12px;
}
        
        .nav-item:hover {
            background: rgba(255,255,255,0.12);
            color: #fff;
        }
        
        .nav-item.active {
            background: rgba(255,255,255,0.18);
            color: #fff;
            font-weight: 600;
        }
        
        .nav-icon {
            margin-right: 10px;
            /* -2px em relação ao padrão anterior */
            font-size: 14px;
            width: 24px;
            text-align: center;
        }

        /* Ações no rodapé da sidebar (Alterar senha / Sair) */
        .sidebar-actions{
            flex: 0 0 auto;
            padding: 12px 20px 20px;
            border-top: 1px solid rgba(255,255,255,0.18);
            background: linear-gradient(180deg, rgba(0,39,156,0) 0%, rgba(0,39,156,0.98) 28%);
        }
        .sidebar-actions .sidebar-user{color: rgba(255,255,255,0.75); font-size: 12px;}
        .sidebar-actions .btn{
            width: 100%;
            margin-top: 6px;
            padding: 5px 9px;
            font-size: 10px;
            border-radius: 8px;
            min-height: 28px;
            line-height: 1.1;
            font-weight: 600;
            white-space: nowrap;
        }
        .sidebar-actions .btn:not(.btn-theme-toggle){
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 9px;
        }
        .sidebar-actions .btn:not(.btn-theme-toggle) .btn-ico{
            width: 12px;
            height: 12px;
        }
        
        /* CONTEÚDO PRINCIPAL */
        .admin-content {
            flex: 1;
            margin-left: 220px;
            padding: 24px;
            width: calc(100% - 220px);
            min-height: 100vh;
            background: #f5f7fa;
            overflow-y: auto;
        }
        
        .page-header {
            background: white;
            padding: 20px;
            border-radius: 10px;
            margin-bottom: 24px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.1);
            border-left: 5px solid #0043c7;
        }
        
        .page-header h2 {
            color: #2c3e50;
            font-size: 1.6rem;
            margin-bottom: 10px;
        }
        
        /* BOTÕES */
        .btn {
            padding: 8px 16px;
            border: none;
            border-radius: 5px;
            cursor: pointer;
            font-weight: 600;
            transition: all 0.3s;
            font-size: 0.95rem;
            text-decoration: none;
}
        .btn:hover { text-decoration: none; }
        
        .btn-primary {
            background: #0043c7;
            color: white;
        }
        /* Botão secundário (cinza) */
        .btn-secondary {
            background: #e5e7eb;
            color: #111827;
            border: 1px solid #e5e7eb;
        }
        .btn-secondary:hover {
            background: #d1d5db;
            border-color: #d1d5db;
        }

        /* Variante mais escura (para diferenciar Sair sem usar vermelho) */
        .btn-secondary-alt {
            background: #cbd5e1;
            color: #0f172a;
            border: 1px solid #cbd5e1;
        }
        .btn-secondary-alt:hover {
            background: #b6c2d2;
            border-color: #b6c2d2;
        }
        
        .btn-primary:hover {
            background: #0035a0;
        }

        .btn-success {
            background: #2ecc71;
            color: white;
        }
        
        .btn-success:hover {
            background: #27ae60;
        }
        
        .btn-danger {
            background: #e74c3c;
            color: white;
        }
        
        .btn-danger:hover {
            background: #c0392b;
        }
        
        .btn-warning {
            background: #f39c12;
            color: white;
        }
        
        .btn-warning:hover {
            background: #e67e22;
        }
        
        /* GRID DE EMPREENDIMENTOS */
        .empreendimentos-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
            gap: 20px;
            margin-top: 20px;
        }

        .empreendimentos-filtros {
            display: grid;
            grid-template-columns: repeat(4, minmax(180px, 1fr));
            gap: 12px;
            margin: 0 0 14px 0;
            padding: 12px;
            border: 1px solid #e1e5eb;
            border-radius: 12px;
            background: #fff;
        }

        .empreendimentos-filtros .filtro-item {
            display: flex;
            flex-direction: column;
            gap: 6px;
        }

        .empreendimentos-filtros .filtro-item label {
            font-size: 12px;
            font-weight: 700;
            color: #374151;
        }

        .empreendimentos-filtros .filtro-item select {
            min-height: 38px;
            border: 1px solid #d1d5db;
            border-radius: 8px;
            padding: 6px 10px;
            background: #fff;
            color: #111827;
        }

        .empreendimentos-filtros .filtro-item--acoes {
            justify-content: flex-end;
        }

        .empreendimentos-lista {
            display: flex;
            flex-direction: column;
            gap: 10px;
            margin-top: 12px;
        }

        .empreendimento-row-card {
            display: grid;
            grid-template-columns: 104px minmax(220px, 1.4fr) minmax(130px, .8fr) minmax(140px, .9fr) minmax(150px, .9fr) minmax(220px, 1.5fr) auto;
            gap: 12px;
            align-items: center;
            background: #fff;
            border: 1px solid #e1e5eb;
            border-radius: 12px;
            padding: 10px;
            box-shadow: 0 2px 8px rgba(0,0,0,0.06);
        }

        .empreendimento-row-imagem {
            width: 100%;
            height: 64px;
            border-radius: 8px;
            background: #eef2f7 center / cover no-repeat;
            border: 1px solid #e5e7eb;
        }

        .empreendimento-row-col {
            min-width: 0;
            display: flex;
            flex-direction: column;
            gap: 4px;
        }

        .col-label {
            font-size: 11px;
            color: #6b7280;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: .02em;
        }

        .col-value {
            color: #1f2937;
            font-size: 14px;
            font-weight: 600;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        .col-value--strong {
            font-size: 14px;
            font-weight: 700;
            color: #1f2937;
        }

        .col-sub {
            font-size: 12px;
            color: #6b7280;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        .empreendimento-row-actions {
            display: flex;
            gap: 8px;
            justify-content: flex-end;
            flex-wrap: wrap;
        }

        .empreendimento-row-actions .btn {
            margin: 0;
            white-space: nowrap;
        }

        @media (max-width: 1280px) {
            .empreendimentos-filtros {
                grid-template-columns: repeat(2, minmax(180px, 1fr));
            }
            .empreendimento-row-card {
                grid-template-columns: 90px minmax(200px, 1.4fr) minmax(120px, .8fr) minmax(130px, .9fr) minmax(130px, .9fr) minmax(170px, 1.2fr) auto;
            }
        }

        @media (max-width: 980px) {
            .empreendimentos-filtros {
                grid-template-columns: 1fr;
            }
            .empreendimento-row-card {
                grid-template-columns: 84px 1fr;
                gap: 10px;
            }
            .empreendimento-row-col,
            .empreendimento-row-actions {
                grid-column: 2 / -1;
            }
            .empreendimento-row-actions {
                justify-content: flex-start;
                padding-top: 6px;
            }
            .col-value,
            .col-sub {
                white-space: normal;
            }
        }
        
        .empreendimento-card {
            background: white;
            border-radius: 10px;
            overflow: hidden;
            box-shadow: 0 3px 15px rgba(0,0,0,0.1);
            transition: transform 0.3s;
            border: 1px solid #e1e5eb;
        }
        
        .empreendimento-card:hover {
            transform: translateY(-5px);
        }
        
        .empreendimento-imagem {
            height: 135px;
            background-size: cover;
            background-position: center;
        }
        
        .empreendimento-info {
            padding: 20px;
        }
        
        .empreendimento-info h3 {
            color: #0043c7;
            margin-bottom: 10px;
        }
        
        .empreendimento-status {
            display: inline-block;
            padding: 4px 12px;
            border-radius: 20px;
            font-size: 0.8rem;
            font-weight: 600;
            margin-bottom: 15px;
        }
        
        .status-ativo {
            background: #d4edda;
            color: #155724;
        }
        
        .status-inativo {
            background: #f8d7da;
            color: #721c24;
        }
        
        .empreendimento-detalhes {
            margin: 15px 0;
        }
        
        .detalhe-item {
            display: flex;
            margin-bottom: 8px;
            color: #666;
        }
        
        .detalhe-label {
            font-weight: 600;
            width: 120px;
            color: #444;
        }
        
        .empreendimento-acoes {
            display: flex;
            gap: 10px;
            margin-top: 15px;
        }
        
        /* MODAL */
        .modal {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0,0,0,0.7);
            align-items: center;
            justify-content: center;
            z-index: 1000;
        }
        
        .modal-content {
            background: white;
            border-radius: 10px;
            width: 90%;
            max-width: 600px;
            padding: 24px;
            max-height: 90vh;
            overflow-y: auto;
        }
        
        .modal-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 25px;
            padding-bottom: 15px;
            border-bottom: 1px solid #e1e5eb;
        }
        
        .modal-header h3 {
            color: #0043c7;
        }
        
        .close-modal {
            background: none;
            border: none;
            font-size: 1.35rem;
            cursor: pointer;
            color: #666;
        }
        
        /* FORMULÁRIOS */
        .form-group {
            margin-bottom: 20px;
        }
        
        .form-group label {
            display: block;
            margin-bottom: 8px;
            font-weight: 600;
            color: #333;
        }
        
        .form-group input,
        .form-group select,
        .form-group textarea {
            width: 100%;
            padding: 10px 12px;
            border: 1px solid #ddd;
            border-radius: 5px;
            font-size: 1rem;
            transition: border 0.3s;
        }
        
        .form-group input:focus,
        .form-group select:focus,
        .form-group textarea:focus {
            border-color: #0043c7;
            outline: none;
        }
        
        .form-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 20px;
        }
        
        .form-grid .full-width {
            grid-column: 1 / -1;
        }

        .usuario-temp-password-card {
            border: 1px solid #d9e2f2;
            border-radius: 12px;
            padding: 14px;
            background: linear-gradient(180deg, #fcfdff 0%, #f2f7ff 100%);
        }

        .usuario-temp-password-meta {
            color: #4a5a70;
            font-size: 0.92rem;
            margin-bottom: 10px;
        }

        .usuario-temp-password-row {
            display: flex;
            gap: 10px;
            align-items: center;
        }

        .usuario-temp-password-row input[readonly] {
            font-family: Consolas, "Courier New", monospace;
            font-size: 0.98rem;
            letter-spacing: 0.02em;
            background: #fff;
        }

        .usuario-temp-password-row .btn {
            flex-shrink: 0;
        }

        .usuario-assistidos-tree {
            border: 1px solid #d9e2f2;
            border-radius: 12px;
            max-height: 320px;
            overflow: auto;
            padding: 12px;
            background: linear-gradient(180deg, #fcfdff 0%, #f7faff 100%);
        }

        .usuario-assistidos-empty {
            color: #6a7381;
            font-size: 0.92rem;
            font-style: italic;
            padding: 8px 2px;
        }

        .usuario-assistidos-node {
            border: 1px solid #e2e9f5;
            border-radius: 10px;
            padding: 10px 12px;
            margin-bottom: 10px;
            background: #fff;
            box-shadow: 0 1px 2px rgba(0, 24, 72, 0.06);
        }

        .usuario-assistidos-node:last-child {
            margin-bottom: 0;
        }

        .usuario-assistidos-node label {
            margin: 0;
            font-weight: 600;
            display: flex;
            align-items: center;
            gap: 10px;
            color: #233041;
            cursor: pointer;
            line-height: 1.35;
        }

        .usuario-assistidos-node input[type="checkbox"] {
            width: 16px;
            height: 16px;
            margin: 0;
            accent-color: #0043c7;
            cursor: pointer;
            flex: 0 0 16px;
        }

        .usuario-assistidos-node ul {
            margin: 10px 0 0 24px;
            padding: 0 0 0 12px;
            border-left: 2px solid #e8eef9;
        }

        .usuario-assistidos-node li {
            margin: 6px 0;
            color: #4a5a73;
            font-size: 0.9rem;
            list-style: none;
            position: relative;
            padding-left: 12px;
        }

        .usuario-assistidos-node li::before {
            content: "";
            width: 5px;
            height: 5px;
            border-radius: 50%;
            background: #7f93b4;
            position: absolute;
            left: 0;
            top: 0.58rem;
        }
        
        .modal-footer {
            display: flex;
            justify-content: flex-end;
            gap: 15px;
            margin-top: 30px;
            padding-top: 20px;
            border-top: 1px solid #e1e5eb;
        }
        
        /* TABS DE PREMISSAS */
        .tabs-premissas {
            display: flex;
            gap: 5px;
            margin-bottom: 25px;
            background: #f8f9fa;
            padding: 10px;
            border-radius: 8px;
        }
        
        .tab-premissa {
            flex: 1;
            padding: 12px;
            border: none;
            background: white;
            border-radius: 6px;
            cursor: pointer;
            font-weight: 600;
            color: #5d6d7e;
            transition: all 0.3s;
        }
        
        .tab-premissa:hover {
            background: #e8f4fc;
            color: #0043c7;
        }
        
        .tab-premissa.active {
            background: #0043c7;
            color: white;
        }
        
        /* PREMISSAS CONTAINER */
        .premissas-container {
            background: white;
            padding: 20px;
            border-radius: 10px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.1);
        }
        
        .premissa-item {
            margin-bottom: 25px;
            padding-bottom: 25px;
            border-bottom: 1px solid #e1e5eb;
        }
        
        .premissa-item:last-child {
            border-bottom: none;
            margin-bottom: 0;
            padding-bottom: 0;
        }
        
        .premissa-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 15px;
        }
        
        .premissa-title {
            font-weight: 600;
            color: #2c3e50;
        }
        
        .premissa-description {
            color: #666;
            font-size: 0.9rem;
            margin-top: 5px;
        }
        
        /* CONTROLE DE RANGE COM INPUT NUMÉRICO */
        .range-control {
            margin-top: 10px;
        }
        
        .range-with-input {
            display: flex;
            align-items: center;
            gap: 15px;
            margin-top: 10px;
        }
        
        .range-container {
            flex: 1;
        }
        
        .range-container input[type="range"] {
            width: 100%;
            height: 6px;
            border-radius: 3px;
            background: #e1e5eb;
            outline: none;
            -webkit-appearance: none;
        }
        
        .range-container input[type="range"]::-webkit-slider-thumb {
            -webkit-appearance: none;
            width: 20px;
            height: 20px;
            border-radius: 50%;
            background: #0043c7;
            cursor: pointer;
        }
        
        .range-container input[type="range"]::-moz-range-thumb {
            width: 20px;
            height: 20px;
            border-radius: 50%;
            background: #0043c7;
            cursor: pointer;
            border: none;
        }
        
        .numeric-input-container {
            width: 100px;
        }
        
        .numeric-input {
            width: 100%;
            padding: 8px 12px;
            border: 2px solid #0043c7;
            border-radius: 5px;
            text-align: center;
            font-weight: 600;
            color: #0043c7;
            font-size: 0.9rem;
        }
        
        .numeric-input:focus {
            outline: none;
            box-shadow: 0 0 0 3px rgba(0, 67, 199, 0.1);
        }
        
        .range-labels {
            display: flex;
            justify-content: space-between;
            margin-top: 5px;
            font-size: 0.8rem;
            color: #666;
        }
        
        /* TABELA GESTORES */
        .tabela-gestores {
            width: 100%;
            border-collapse: collapse;
            background: white;
            border-radius: 10px;
            overflow: hidden;
            box-shadow: 0 2px 10px rgba(0,0,0,0.1);
            font-size: 0.95rem;
        }
        
        .tabela-gestores th {
            background: #f8f9fa;
            padding: 12px;
            text-align: left;
            font-weight: 600;
            color: #2c3e50;
        }
        
        .tabela-gestores td {
            padding: 10px 12px;
            border-bottom: 1px solid #e1e5eb;
        }
        
        .tabela-gestores tr:hover {
            background: #f8f9fa;
        }
        
        /* ================================
   MODAL DETALHES - Ajuste layout
================================= */

/* Modal container */
#modal-detalhes .modal-content {
  max-width: 900px !important;
  width: 95% !important;
  box-sizing: border-box;
}

/* Grid interno (onde estão as 2 colunas) */
#modal-detalhes .modal-content > div[style*="grid-template-columns"] {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
  align-items: start !important;
}

/* Itens de detalhe: permitir quebra e evitar sobreposição */
#modal-detalhes .detalhe-item {
  display: grid;
  grid-template-columns: 220px 1fr; /* label / valor */
  gap: 10px;
  margin: 6px 0;
  align-items: start;
}

#modal-detalhes .detalhe-label {
  font-weight: 600;
  color: #333;
  white-space: nowrap;
}

#modal-detalhes .detalhe-item span {
  font-size: 0.95rem;
  line-height: 1.25rem;
  overflow-wrap: anywhere;   /* quebra palavras longas */
  word-break: break-word;
}

/* v3.4: Premissas (Simulador) — evitar sobreposição de título/valor */
#modal-detalhes .premissas-simulador .detalhe-item {
  grid-template-columns: 1fr !important;
  gap: 8px !important;
}

#modal-detalhes .premissas-simulador .detalhe-label {
  font-size: 0.85rem;
  white-space: normal;
}

#modal-detalhes .premissas-simulador .detalhe-item > span:last-child {
  font-size: 1rem;
  line-height: 1.35rem;
}

/* Premissas: deixa um pouco menor */
#modal-detalhes h4 {
  margin-bottom: 8px;
}

#modal-detalhes .modal-content {
  font-size: 0.95rem;
}

/* Responsivo: 1 coluna para não atropelar */
@media (max-width: 820px) {
  #modal-detalhes .modal-content > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }

  #modal-detalhes .detalhe-item {
    grid-template-columns: 120px 1fr;
  }
}

        
        /* RESPONSIVO */
        @media (max-width: 768px) {
            .admin-container {
                flex-direction: column;
                overflow: visible;
            }
        
            .admin-sidebar {
                width: 100%;
                height: auto;
                position: relative;
                max-height: none;
                overflow: visible;
            }

            .admin-nav {
                overflow: visible;
                min-height: auto;
            }
        
            .admin-content {
                margin-left: 0;
                padding: 20px;
                width: 100%;
                min-height: auto;
            }
        
            .form-grid {
                grid-template-columns: 1fr;
            }
        
            .empreendimentos-grid {
                grid-template-columns: 1fr;
            }
        
            .range-with-input {
                flex-direction: column;
                gap: 10px;
            }
        
            .numeric-input-container {
                width: 100%;
            }
        
            .page-header {
                padding: 20px;
                margin-bottom: 20px;
            }
        
            .modal-content {
                width: 95%;
                padding: 20px;
                margin: 10px;
            }
        }
        
        @media (max-width: 480px) {
            .admin-content {
                padding: 12px;
            }
            
            .page-header {
                padding: 12px;
            }
            
            .empreendimento-card {
                margin-bottom: 15px;
            }
            
            .tabela-gestores {
                font-size: 0.9rem;
            font-size: 0.95rem;
            }
            
            .tabela-gestores th,
            .tabela-gestores td {
                padding: 8px 10px;
            }
        }



/* ==========================
   PAINEL (DASHBOARD) - UI DEMO
   ========================== */
.logo.logo-only {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 22px 18px 16px;
}

.sidebar-logo {
  width: 182px;
  max-width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,0.15));
}

.modal-resumo-topo {
  margin-bottom: 8px;
  color: #4b5563;
  font-size: 0.9rem;
  line-height: 1.4;
}

.modal-resumo-grupo {
  margin-top: 10px;
}

.modal-resumo-titulo {
  display: block;
  margin-bottom: 6px;
  color: #374151;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.modal-resumo-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.modal-resumo-tag,
.modal-resumo-vazio {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  line-height: 1;
}

.modal-resumo-tag {
  background: #e7eefc;
  border: 1px solid #c6d7fb;
  color: #103f99;
}

.modal-resumo-vazio {
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  color: #6b7280;
}

.emp-unidades-actions {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.emp-unidades-actions .btn {
  min-height: 34px;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 0.84rem;
  line-height: 1.05;
  white-space: nowrap;
}

.emp-unidades-actions .btn .btn-ico {
  width: 12px;
  height: 12px;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-bottom: 18px;
}

.kpi-card {
  background: #fff;
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  border: 1px solid rgba(0,0,0,0.05);
}

.kpi-title {
  color: #666;
  font-size: 0.9rem;
  margin-bottom: 8px;
  font-weight: 600;
}

.kpi-value {
  font-size: 2rem;
  font-weight: 800;
  color: #0b1b3a;
  line-height: 1.1;
  margin-bottom: 6px;
}

.kpi-sub {
  color: #888;
  font-size: 0.85rem;
}

.widget-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.widget-card {
  background: #fff;
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  border: 1px solid rgba(0,0,0,0.05);
}

.widget-span-2 { grid-column: 1 / -1; }

.widget-title {
  font-weight: 800;
  color: #0b1b3a;
  margin-bottom: 12px;
}

.widget-footnote {
  margin-top: 10px;
  color: #888;
  font-size: 0.85rem;
}

.mini-chart {
  height: 140px;
  width: 100%;
  display: flex;
  align-items: flex-end;
  gap: 10px;
  padding: 10px 10px 4px;
  background: #f7f9fc;
  border-radius: 12px;
  border: 1px dashed rgba(0,0,0,0.12);
}

.mini-chart .bar {
  flex: 1;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(0,67,199,0.85), rgba(0,67,199,0.25));
}

.quick-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.activity-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.activity-item {
  display: grid;
  grid-template-columns: 10px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 12px;
  background: #f7f9fc;
  border: 1px solid rgba(0,0,0,0.06);
}

.activity-item .dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #0043c7;
}

.activity-text { color: #1b1b1b; }
.activity-time { color: #777; font-size: 0.85rem; }

@media (max-width: 920px) {
  .widget-grid { grid-template-columns: 1fr; }
  .widget-span-2 { grid-column: auto; }
}

/* =====================
   DASHBOARD (PAINEL)
   ===================== */
.dash-filters{
  background:#fff;
  border-radius:14px;
  padding:14px 16px;
  box-shadow:0 2px 10px rgba(0,0,0,0.06);
  border:1px solid rgba(0,0,0,0.05);
  margin-bottom:16px;
}
.dash-filters-row{
  display:flex;
  gap:12px;
  align-items:flex-end;
  flex-wrap:wrap;
}
.dash-filters-row + .dash-filters-row{ margin-top:10px; }
.dash-filter{ display:flex; flex-direction:column; gap:6px; }
.dash-filter label{ font-size:.85rem; color:#666; font-weight:700; }
.dash-filter input[type="date"]{
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,0.15);
  background:#fff;
}
.dash-check{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  color:#444;
  padding:8px 10px;
  border-radius:10px;
  background:#f7f9fc;
  border:1px solid rgba(0,0,0,0.06);
}
.dash-quick .btn{ padding:10px 12px; }
.dash-range-label{
  margin-left:auto;
  font-weight:800;
  color:#0b1b3a;
  padding:8px 10px;
  border-radius:10px;
  background:#f7f9fc;
  border:1px solid rgba(0,0,0,0.06);
}

/* Mini-chart com tooltips */
#chartEnviosDia .bar{ cursor:default; }

/* Bar list (ranking) */
.barlist{ display:flex; flex-direction:column; gap:10px; }
.barlist-item{ display:grid; grid-template-columns: 1fr 70px; gap:10px; align-items:center; }
.barlist-label{ font-weight:800; color:#0b1b3a; font-size:.92rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.barlist-value{ text-align:right; color:#444; font-weight:800; font-variant-numeric: tabular-nums; }
.barlist-barwrap{ grid-column: 1 / -1; height:10px; border-radius:999px; background:#eef3fb; border:1px solid rgba(0,0,0,0.06); overflow:hidden; }
.barlist-bar{ height:100%; border-radius:999px; background: linear-gradient(180deg, rgba(0,67,199,0.85), rgba(0,67,199,0.25)); width:0%; }
.barlist-empty{ color:#777; font-size:.9rem; padding:8px 0; }

/* =========================================================
   PATCH (CSS) — 2026-02-10
   1) Sidebar: ícones monocromáticos (substitui emojis via CSS)
   2) Conteúdo do site um pouco menor (mais leve)
   3) Modos claro/escuro (automático pelo sistema) + suporte opcional via html[data-theme]
   ========================================================= */

/* 2) Escala geral (reduz um pouco tudo que usa rem/em) */
html{font-size:15px;}

/* 2) Reduz levemente espaçamentos grandes */
.admin-content{padding:20px;}
.page-header{padding:16px;}
.empreendimento-info{padding:16px;}

/* 1) Ícones monocromáticos: escondemos o emoji e desenhamos o ícone via mask SVG */
.admin-sidebar .nav-icon{
  font-size:0 !important;           /* esconde o emoji */
  width:24px;
  height:24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-right:10px;
}

.admin-sidebar .nav-icon::before{
  content:"";
  width:18px;
  height:18px;
  background: currentColor;
  opacity:.96;
  -webkit-mask-repeat:no-repeat;
  -webkit-mask-position:center;
  -webkit-mask-size:contain;
  mask-repeat:no-repeat;
  mask-position:center;
  mask-size:contain;
}

/* define a cor do ícone igual ao texto (branco/rgba branco) */
.admin-sidebar .nav-item{color: rgba(255,255,255,0.82);} 
.admin-sidebar .nav-item:hover,
.admin-sidebar .nav-item.active{color:#fff;}

/* Painel */
.admin-sidebar .nav-item[href="#painel"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='18'%20y1='20'%20x2='18'%20y2='10'/%3E%3Cline%20x1='12'%20y1='20'%20x2='12'%20y2='4'/%3E%3Cline%20x1='6'%20y1='20'%20x2='6'%20y2='14'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='18'%20y1='20'%20x2='18'%20y2='10'/%3E%3Cline%20x1='12'%20y1='20'%20x2='12'%20y2='4'/%3E%3Cline%20x1='6'%20y1='20'%20x2='6'%20y2='14'/%3E%3C/svg%3E");
}

/* Empreendimentos */
.admin-sidebar .nav-item[href="#empreendimentos"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M3%2021h18'/%3E%3Cpath%20d='M6%2021V7l6-3%206%203v14'/%3E%3Cpath%20d='M9%2011h6'/%3E%3Cpath%20d='M9%2014h6'/%3E%3Cpath%20d='M9%2017h6'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M3%2021h18'/%3E%3Cpath%20d='M6%2021V7l6-3%206%203v14'/%3E%3Cpath%20d='M9%2011h6'/%3E%3Cpath%20d='M9%2014h6'/%3E%3Cpath%20d='M9%2017h6'/%3E%3C/svg%3E");
}

/* Cidades */
.admin-sidebar .nav-item[href="#cidades"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M1%206l7-2%208%202%207-2v14l-7%202-8-2-7%202V6z'/%3E%3Cpath%20d='M8%204v16'/%3E%3Cpath%20d='M16%206v16'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M1%206l7-2%208%202%207-2v14l-7%202-8-2-7%202V6z'/%3E%3Cpath%20d='M8%204v16'/%3E%3Cpath%20d='M16%206v16'/%3E%3C/svg%3E");
}

/* Bairros */
.admin-sidebar .nav-item[href="#bairros"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2010c0%206-9%2013-9%2013S3%2016%203%2010a9%209%200%200%201%2018%200z'/%3E%3Ccircle%20cx='12'%20cy='10'%20r='3'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2010c0%206-9%2013-9%2013S3%2016%203%2010a9%209%200%200%201%2018%200z'/%3E%3Ccircle%20cx='12'%20cy='10'%20r='3'/%3E%3C/svg%3E");
}

/* Usuários */
.admin-sidebar .nav-item[href="#usuarios"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M20%2021v-2a4%204%200%200%200-4-4H8a4%204%200%200%200-4%204v2'/%3E%3Ccircle%20cx='12'%20cy='7'%20r='4'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M20%2021v-2a4%204%200%200%200-4-4H8a4%204%200%200%200-4%204v2'/%3E%3Ccircle%20cx='12'%20cy='7'%20r='4'/%3E%3C/svg%3E");
}

/* Equipes */
.admin-sidebar .nav-item[href="#equipes"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M17%2021v-2a4%204%200%200%200-3-3.87'/%3E%3Cpath%20d='M7%2021v-2a4%204%200%200%201%203-3.87'/%3E%3Cpath%20d='M16%203.13a4%204%200%200%201%200%207.75'/%3E%3Cpath%20d='M8%203.13a4%204%200%200%200%200%207.75'/%3E%3Ccircle%20cx='12'%20cy='7'%20r='4'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M17%2021v-2a4%204%200%200%200-3-3.87'/%3E%3Cpath%20d='M7%2021v-2a4%204%200%200%201%203-3.87'/%3E%3Cpath%20d='M16%203.13a4%204%200%200%201%200%207.75'/%3E%3Cpath%20d='M8%203.13a4%204%200%200%200%200%207.75'/%3E%3Ccircle%20cx='12'%20cy='7'%20r='4'/%3E%3C/svg%3E");
}

/* Imobiliárias */
.admin-sidebar .nav-item[href="#imobiliarias"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='2'%20y='7'%20width='20'%20height='14'%20rx='2'%20ry='2'/%3E%3Cpath%20d='M16%207V5a2%202%200%200%200-2-2h-4a2%202%200%200%200-2%202v2'/%3E%3Cpath%20d='M2%2013h20'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='2'%20y='7'%20width='20'%20height='14'%20rx='2'%20ry='2'/%3E%3Cpath%20d='M16%207V5a2%202%200%200%200-2-2h-4a2%202%200%200%200-2%202v2'/%3E%3Cpath%20d='M2%2013h20'/%3E%3C/svg%3E");
}

/* Propostas */
.admin-sidebar .nav-item[href="#historico"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='23%206%2013.5%2015.5%208.5%2010.5%201%2018'/%3E%3Cpolyline%20points='17%206%2023%206%2023%2012'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='23%206%2013.5%2015.5%208.5%2010.5%201%2018'/%3E%3Cpolyline%20points='17%206%2023%206%2023%2012'/%3E%3C/svg%3E");
}

.admin-sidebar .nav-item[href="#popups"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015a2%202%200%200%201-2%202H7l-4%204V5a2%202%200%200%201%202-2h14a2%202%200%200%201%202%202z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015a2%202%200%200%201-2%202H7l-4%204V5a2%202%200%200%201%202-2h14a2%202%200%200%201%202%202z'/%3E%3C/svg%3E");
}
.admin-sidebar .nav-item[href="#access-config"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='4'%20y1='21'%20x2='4'%20y2='14'/%3E%3Cline%20x1='4'%20y1='10'%20x2='4'%20y2='3'/%3E%3Cline%20x1='12'%20y1='21'%20x2='12'%20y2='12'/%3E%3Cline%20x1='12'%20y1='8'%20x2='12'%20y2='3'/%3E%3Cline%20x1='20'%20y1='21'%20x2='20'%20y2='16'/%3E%3Cline%20x1='20'%20y1='12'%20x2='20'%20y2='3'/%3E%3Cline%20x1='1'%20y1='14'%20x2='7'%20y2='14'/%3E%3Cline%20x1='9'%20y1='8'%20x2='15'%20y2='8'/%3E%3Cline%20x1='17'%20y1='16'%20x2='23'%20y2='16'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='4'%20y1='21'%20x2='4'%20y2='14'/%3E%3Cline%20x1='4'%20y1='10'%20x2='4'%20y2='3'/%3E%3Cline%20x1='12'%20y1='21'%20x2='12'%20y2='12'/%3E%3Cline%20x1='12'%20y1='8'%20x2='12'%20y2='3'/%3E%3Cline%20x1='20'%20y1='21'%20x2='20'%20y2='16'/%3E%3Cline%20x1='20'%20y1='12'%20x2='20'%20y2='3'/%3E%3Cline%20x1='1'%20y1='14'%20x2='7'%20y2='14'/%3E%3Cline%20x1='9'%20y1='8'%20x2='15'%20y2='8'/%3E%3Cline%20x1='17'%20y1='16'%20x2='23'%20y2='16'/%3E%3C/svg%3E");
}
.admin-sidebar .nav-item[href="#approval-config"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='3'%20y='4'%20width='18'%20height='16'%20rx='2'/%3E%3Cline%20x1='7'%20y1='9'%20x2='17'%20y2='9'/%3E%3Cline%20x1='7'%20y1='13'%20x2='17'%20y2='13'/%3E%3Cline%20x1='7'%20y1='17'%20x2='13'%20y2='17'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='3'%20y='4'%20width='18'%20height='16'%20rx='2'/%3E%3Cline%20x1='7'%20y1='9'%20x2='17'%20y2='9'/%3E%3Cline%20x1='7'%20y1='13'%20x2='17'%20y2='13'/%3E%3Cline%20x1='7'%20y1='17'%20x2='13'%20y2='17'/%3E%3C/svg%3E");
}
.admin-sidebar .nav-item[href="#settings"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='12'%20cy='12'%20r='3'/%3E%3Cpath%20d='M19.4%2015a1.65%201.65%200%200%200%20.33%201.82l.06.06a2%202%200%201%201-2.83%202.83l-.06-.06a1.65%201.65%200%200%200-1.82-.33%201.65%201.65%200%200%200-1%201.51V21a2%202%200%201%201-4%200v-.09a1.65%201.65%200%200%200-1-1.51%201.65%201.65%200%200%200-1.82.33l-.06.06a2%202%200%201%201-2.83-2.83l.06-.06a1.65%201.65%200%200%200%20.33-1.82%201.65%201.65%200%200%200-1.51-1H3a2%202%200%201%201%200-4h.09a1.65%201.65%200%200%200%201.51-1%201.65%201.65%200%200%200-.33-1.82l-.06-.06a2%202%200%201%201%202.83-2.83l.06.06a1.65%201.65%200%200%200%201.82.33h0A1.65%201.65%200%200%200%209%203.09V3a2%202%200%201%201%204%200v.09a1.65%201.65%200%200%200%201%201.51h0a1.65%201.65%200%200%200%201.82-.33l.06-.06a2%202%200%201%201%202.83%202.83l-.06.06a1.65%201.65%200%200%200-.33%201.82v0a1.65%201.65%200%200%200%201.51%201H21a2%202%200%201%201%200%204h-.09a1.65%201.65%200%200%200-1.51%201z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='12'%20cy='12'%20r='3'/%3E%3Cpath%20d='M19.4%2015a1.65%201.65%200%200%200%20.33%201.82l.06.06a2%202%200%201%201-2.83%202.83l-.06-.06a1.65%201.65%200%200%200-1.82-.33%201.65%201.65%200%200%200-1%201.51V21a2%202%200%201%201-4%200v-.09a1.65%201.65%200%200%200-1-1.51%201.65%201.65%200%200%200-1.82.33l-.06.06a2%202%200%201%201-2.83-2.83l.06-.06a1.65%201.65%200%200%200%20.33-1.82%201.65%201.65%200%200%200-1.51-1H3a2%202%200%201%201%200-4h.09a1.65%201.65%200%200%200%201.51-1%201.65%201.65%200%200%200-.33-1.82l-.06-.06a2%202%200%201%201%202.83-2.83l.06.06a1.65%201.65%200%200%200%201.82.33h0A1.65%201.65%200%200%200%209%203.09V3a2%202%200%201%201%204%200v.09a1.65%201.65%200%200%200%201%201.51h0a1.65%201.65%200%200%200%201.82-.33l.06-.06a2%202%200%201%201%202.83%202.83l-.06.06a1.65%201.65%200%200%200-.33%201.82v0a1.65%201.65%200%200%200%201.51%201H21a2%202%200%201%201%200%204h-.09a1.65%201.65%200%200%200-1.51%201z'/%3E%3C/svg%3E");
}
.admin-sidebar .nav-item[href="#logs"] .nav-icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M9%202H5a2%202%200%200%200-2%202v16a2%202%200%200%200%202%202h14a2%202%200%200%200%202-2V7l-5-5z'/%3E%3Cpath%20d='M14%202v6h6'/%3E%3Cline%20x1='8'%20y1='13'%20x2='16'%20y2='13'/%3E%3Cline%20x1='8'%20y1='17'%20x2='16'%20y2='17'/%3E%3Cline%20x1='8'%20y1='9'%20x2='10'%20y2='9'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M9%202H5a2%202%200%200%200-2%202v16a2%202%200%200%200%202%202h14a2%202%200%200%200%202-2V7l-5-5z'/%3E%3Cpath%20d='M14%202v6h6'/%3E%3Cline%20x1='8'%20y1='13'%20x2='16'%20y2='13'/%3E%3Cline%20x1='8'%20y1='17'%20x2='16'%20y2='17'/%3E%3Cline%20x1='8'%20y1='9'%20x2='10'%20y2='9'/%3E%3C/svg%3E");
}
.admin-sidebar .nav-item.nav-item-sub{
  margin-left: 14px;
  padding-left: 8px;
  font-size: 11px;
  opacity: .96;
}

/* 3) Modos claro/escuro: tokens + sobrescritas (sem JS) */
:root{
  --ui-bg:#f5f7fa;
  --ui-surface:#ffffff;
  --ui-surface-2:#eef2f7;
  --ui-text:#111827;
  --ui-muted:#6b7280;
  --ui-border:rgba(17,24,39,.12);
}

body{background:var(--ui-bg) !important; color:var(--ui-text) !important;}
.admin-content{background:var(--ui-bg) !important;}

/* cards/superfícies */
.page-header,
.empreendimento-card,
.modal-content,
.dash-card,
.grid-stack-item-content{
  background:var(--ui-surface) !important;
  color:var(--ui-text) !important;
  border-color:var(--ui-border) !important;
}

/* inputs / selects */
input,select,textarea{
  background:var(--ui-surface) !important;
  color:var(--ui-text) !important;
  border-color:var(--ui-border) !important;
}

/* tabelas */
.table, table{color:var(--ui-text) !important;}
.table th,.table td,table th,table td{border-color:var(--ui-border) !important;}

/* textos secundários */
.dash-sub, .sidebar-user{opacity:.85;}

/* Dark automático pelo sistema */
@media (prefers-color-scheme: dark){
  :root{
    color-scheme: dark;
    --ui-bg:#0b1220;
    --ui-surface:#0f1a2e;
    --ui-surface-2:#101f3a;
    --ui-text:#e5e7eb;
    --ui-muted:#9ca3af;
    --ui-border:rgba(229,231,235,.14);
  }

  /* Sidebar um pouco mais profunda no dark */
  .admin-sidebar{background:#001f7a !important;}

  /* Pequenos ajustes para contraste */
  .page-header h2{color:var(--ui-text) !important;}
  .dash-filter input[type="date"],
  .dash-filter select,
  .dash-filter input[type="number"],
  .dash-filter input[type="text"]{
    background:var(--ui-surface) !important;
    border-color:var(--ui-border) !important;
    color:var(--ui-text) !important;
  }
}

/* (Opcional futuro) Dark manual via <html data-theme="dark"> — sem JS aqui */
html[data-theme="dark"]{
  color-scheme: dark;
  --ui-bg:#0b1220;
  --ui-surface:#0f1a2e;
  --ui-surface-2:#101f3a;
  --ui-text:#e5e7eb;
  --ui-muted:#9ca3af;
  --ui-border:rgba(229,231,235,.14);
}
html[data-theme="dark"] .admin-sidebar{background:#001f7a !important;}


/* =========================================================
   PATCH — Toggle Claro/Escuro (botão na sidebar)
   ========================================================= */

.btn-theme-toggle{
  background: rgba(255,255,255,0.12) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.btn-theme-toggle:hover{
  background: rgba(255,255,255,0.18) !important;
  border-color: rgba(255,255,255,0.24) !important;
}

.btn-theme-toggle .theme-toggle-text{
  font-weight: 700;
  letter-spacing: .2px;
}

/* Ícone monocromático (moon/sun) via mask */
.btn-theme-toggle .theme-toggle-icon{
  width: 16px;
  height: 16px;
  display: inline-block;
  background: currentColor;
  opacity: .96;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

/* Moon (padrão) */
.btn-theme-toggle .theme-toggle-icon{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012.79A9%209%200%201%201%2011.21%203%207%207%200%200%200%2021%2012.79z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012.79A9%209%200%201%201%2011.21%203%207%207%200%200%200%2021%2012.79z'/%3E%3C/svg%3E");
}

/* Se o sistema estiver em dark e não houver escolha manual, mostra "sun" */
@media (prefers-color-scheme: dark){
  html:not([data-theme="light"]) .btn-theme-toggle .theme-toggle-icon{
    -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='12'%20cy='12'%20r='4'/%3E%3Cpath%20d='M12%202v2'/%3E%3Cpath%20d='M12%2020v2'/%3E%3Cpath%20d='M4.93%204.93l1.41%201.41'/%3E%3Cpath%20d='M17.66%2017.66l1.41%201.41'/%3E%3Cpath%20d='M2%2012h2'/%3E%3Cpath%20d='M20%2012h2'/%3E%3Cpath%20d='M6.34%2017.66l-1.41%201.41'/%3E%3Cpath%20d='M19.07%204.93l-1.41%201.41'/%3E%3C/svg%3E");
    mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='12'%20cy='12'%20r='4'/%3E%3Cpath%20d='M12%202v2'/%3E%3Cpath%20d='M12%2020v2'/%3E%3Cpath%20d='M4.93%204.93l1.41%201.41'/%3E%3Cpath%20d='M17.66%2017.66l1.41%201.41'/%3E%3Cpath%20d='M2%2012h2'/%3E%3Cpath%20d='M20%2012h2'/%3E%3Cpath%20d='M6.34%2017.66l-1.41%201.41'/%3E%3Cpath%20d='M19.07%204.93l-1.41%201.41'/%3E%3C/svg%3E");
  }
}

/* Escolha manual (JS) */
html[data-theme="dark"] .btn-theme-toggle .theme-toggle-icon{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='12'%20cy='12'%20r='4'/%3E%3Cpath%20d='M12%202v2'/%3E%3Cpath%20d='M12%2020v2'/%3E%3Cpath%20d='M4.93%204.93l1.41%201.41'/%3E%3Cpath%20d='M17.66%2017.66l1.41%201.41'/%3E%3Cpath%20d='M2%2012h2'/%3E%3Cpath%20d='M20%2012h2'/%3E%3Cpath%20d='M6.34%2017.66l-1.41%201.41'/%3E%3Cpath%20d='M19.07%204.93l-1.41%201.41'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='12'%20cy='12'%20r='4'/%3E%3Cpath%20d='M12%202v2'/%3E%3Cpath%20d='M12%2020v2'/%3E%3Cpath%20d='M4.93%204.93l1.41%201.41'/%3E%3Cpath%20d='M17.66%2017.66l1.41%201.41'/%3E%3Cpath%20d='M2%2012h2'/%3E%3Cpath%20d='M20%2012h2'/%3E%3Cpath%20d='M6.34%2017.66l-1.41%201.41'/%3E%3Cpath%20d='M19.07%204.93l-1.41%201.41'/%3E%3C/svg%3E");
}

html[data-theme="light"] .btn-theme-toggle .theme-toggle-icon{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012.79A9%209%200%201%201%2011.21%203%207%207%200%200%200%2021%2012.79z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012.79A9%209%200%201%201%2011.21%203%207%207%200%200%200%2021%2012.79z'/%3E%3C/svg%3E");
}

/* Espaçamento discreto entre usuário e botões */
.sidebar-actions .btn-theme-toggle{ margin-top: 12px; }

/* =========================================================
   PATCH (CSS) — 2026-02-10 (v2)
   - Dark mode completo: tabelas/estados/empty-states
   - Cabeçalhos sem caixa/sombra + ícones no padrão do menu
   - Botões de ação mais clean (tabelas/cards)
   ========================================================= */

:root{
  --ui-accent:#0043c7;
  --ui-accent-2:#0035a0;
  --ui-row-hover: rgba(17,24,39,.04);
  --ui-btn-hover: rgba(17,24,39,.06);
  --ui-danger:#b91c1c;
  --ui-warning:#b45309;
  --ui-success:#15803d;
}

@media (prefers-color-scheme: dark){
  :root{
    --ui-row-hover: rgba(255,255,255,.04);
    --ui-btn-hover: rgba(255,255,255,.06);
    --ui-danger:#f87171;
    --ui-warning:#fbbf24;
    --ui-success:#4ade80;
  }
}

html[data-theme="dark"]{
  --ui-row-hover: rgba(255,255,255,.04);
  --ui-btn-hover: rgba(255,255,255,.06);
  --ui-danger:#f87171;
  --ui-warning:#fbbf24;
  --ui-success:#4ade80;
}

/* ---------------- Cabeçalhos (sem caixa/sombra) ---------------- */
.page-header{
  background: transparent !important;
  box-shadow: none !important;
  border-left: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin-bottom: 16px !important;
  border-bottom: 1px solid var(--ui-border);
  padding-bottom: 12px !important;
}

.page-header h2{
  color: var(--ui-text) !important;
  font-size: 1.35rem;
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  letter-spacing: -0.01em;
}

.page-header p{
  color: var(--ui-muted) !important;
  margin-top: 6px !important;
}

.page-hint,
.modal-hint{
  color: var(--ui-muted) !important;
  font-size: 0.9rem;
}

.modal-hint{padding: 0 20px 20px;}

@media (max-width: 700px){
  .usuario-temp-password-row{
    flex-direction: column;
    align-items: stretch;
  }
}

/* Ícone do título (monocromático, padrão do menu) */
.page-hicon{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--ui-surface-2);
  border: 1px solid var(--ui-border);
  color: var(--ui-muted);
  flex: 0 0 auto;
}
.page-hicon::before{
  content: "";
  width: 18px;
  height: 18px;
  background: currentColor;
  opacity: .96;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

/* Reaproveita os mesmos SVGs do menu */
.page-hicon[data-icon="painel"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='18'%20y1='20'%20x2='18'%20y2='10'/%3E%3Cline%20x1='12'%20y1='20'%20x2='12'%20y2='4'/%3E%3Cline%20x1='6'%20y1='20'%20x2='6'%20y2='14'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='18'%20y1='20'%20x2='18'%20y2='10'/%3E%3Cline%20x1='12'%20y1='20'%20x2='12'%20y2='4'/%3E%3Cline%20x1='6'%20y1='20'%20x2='6'%20y2='14'/%3E%3C/svg%3E");
}
.page-hicon[data-icon="empreendimentos"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M3%2021h18'/%3E%3Cpath%20d='M6%2021V7l6-3%206%203v14'/%3E%3Cpath%20d='M9%2011h6'/%3E%3Cpath%20d='M9%2014h6'/%3E%3Cpath%20d='M9%2017h6'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M3%2021h18'/%3E%3Cpath%20d='M6%2021V7l6-3%206%203v14'/%3E%3Cpath%20d='M9%2011h6'/%3E%3Cpath%20d='M9%2014h6'/%3E%3Cpath%20d='M9%2017h6'/%3E%3C/svg%3E");
}
.page-hicon[data-icon="cidades"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M1%206l7-2%208%202%207-2v14l-7%202-8-2-7%202V6z'/%3E%3Cpath%20d='M8%204v16'/%3E%3Cpath%20d='M16%206v16'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M1%206l7-2%208%202%207-2v14l-7%202-8-2-7%202V6z'/%3E%3Cpath%20d='M8%204v16'/%3E%3Cpath%20d='M16%206v16'/%3E%3C/svg%3E");
}
.page-hicon[data-icon="bairros"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2010c0%206-9%2013-9%2013S3%2016%203%2010a9%209%200%200%201%2018%200z'/%3E%3Ccircle%20cx='12'%20cy='10'%20r='3'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2010c0%206-9%2013-9%2013S3%2016%203%2010a9%209%200%200%201%2018%200z'/%3E%3Ccircle%20cx='12'%20cy='10'%20r='3'/%3E%3C/svg%3E");
}
.page-hicon[data-icon="usuarios"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M20%2021v-2a4%204%200%200%200-4-4H8a4%204%200%200%200-4%204v2'/%3E%3Ccircle%20cx='12'%20cy='7'%20r='4'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M20%2021v-2a4%204%200%200%200-4-4H8a4%204%200%200%200-4%204v2'/%3E%3Ccircle%20cx='12'%20cy='7'%20r='4'/%3E%3C/svg%3E");
}
.page-hicon[data-icon="equipes"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M17%2021v-2a4%204%200%200%200-3-3.87'/%3E%3Cpath%20d='M7%2021v-2a4%204%200%200%201%203-3.87'/%3E%3Cpath%20d='M16%203.13a4%204%200%200%201%200%207.75'/%3E%3Cpath%20d='M8%203.13a4%204%200%200%200%200%207.75'/%3E%3Ccircle%20cx='12'%20cy='7'%20r='4'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M17%2021v-2a4%204%200%200%200-3-3.87'/%3E%3Cpath%20d='M7%2021v-2a4%204%200%200%201%203-3.87'/%3E%3Cpath%20d='M16%203.13a4%204%200%200%201%200%207.75'/%3E%3Cpath%20d='M8%203.13a4%204%200%200%200%200%207.75'/%3E%3Ccircle%20cx='12'%20cy='7'%20r='4'/%3E%3C/svg%3E");
}
.page-hicon[data-icon="imobiliarias"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='2'%20y='7'%20width='20'%20height='14'%20rx='2'%20ry='2'/%3E%3Cpath%20d='M16%207V5a2%202%200%200%200-2-2h-4a2%202%200%200%200-2%202v2'/%3E%3Cpath%20d='M2%2013h20'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='2'%20y='7'%20width='20'%20height='14'%20rx='2'%20ry='2'/%3E%3Cpath%20d='M16%207V5a2%202%200%200%200-2-2h-4a2%202%200%200%200-2%202v2'/%3E%3Cpath%20d='M2%2013h20'/%3E%3C/svg%3E");
}
.page-hicon[data-icon="propostas"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='23%206%2013.5%2015.5%208.5%2010.5%201%2018'/%3E%3Cpolyline%20points='17%206%2023%206%2023%2012'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='23%206%2013.5%2015.5%208.5%2010.5%201%2018'/%3E%3Cpolyline%20points='17%206%2023%206%2023%2012'/%3E%3C/svg%3E");
}

/* ---------------- Tabelas (legível em dark) ---------------- */
.gestores-container{background: transparent !important;}

.tabela-gestores{
  background: var(--ui-surface) !important;
  border: 1px solid var(--ui-border) !important;
  box-shadow: none !important;
  border-radius: 14px !important;
}

.tabela-gestores th{
  background: var(--ui-surface-2) !important;
  color: var(--ui-muted) !important;
  border-bottom: 1px solid var(--ui-border) !important;
}

.tabela-gestores td{
  color: var(--ui-text) !important;
  border-bottom: 1px solid var(--ui-border) !important;
}

.tabela-gestores tr:hover{ background: var(--ui-row-hover) !important; }

/* Status pills (mais neutro e consistente no dark) */
.status-ativo{
  background: rgba(34,197,94,.14) !important;
  color: var(--ui-success) !important;
}
.status-inativo{
  background: rgba(239,68,68,.14) !important;
  color: var(--ui-danger) !important;
}

/* ---------------- Botões de ação (clean) ---------------- */

/* Ícones monocromáticos nos botões */
.btn-ico{
  width: 14px;
  height: 14px;
  display: inline-block;
  background: currentColor;
  opacity: .96;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  flex: 0 0 auto;
}

.btn-ico.btn-ico-edit{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M12%2020h9'/%3E%3Cpath%20d='M16.5%203.5a2.121%202.121%200%200%201%203%203L7%2019l-4%201%201-4%2012.5-12.5z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M12%2020h9'/%3E%3Cpath%20d='M16.5%203.5a2.121%202.121%200%200%201%203%203L7%2019l-4%201%201-4%2012.5-12.5z'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-trash{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='3%206%205%206%2021%206'/%3E%3Cpath%20d='M19%206l-1%2014a2%202%200%200%201-2%202H8a2%202%200%200%201-2-2L5%206'/%3E%3Cpath%20d='M10%2011v6'/%3E%3Cpath%20d='M14%2011v6'/%3E%3Cpath%20d='M9%206V4a1%201%200%200%201%201-1h4a1%201%200%200%201%201%201v2'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='3%206%205%206%2021%206'/%3E%3Cpath%20d='M19%206l-1%2014a2%202%200%200%201-2%202H8a2%202%200%200%201-2-2L5%206'/%3E%3Cpath%20d='M10%2011v6'/%3E%3Cpath%20d='M14%2011v6'/%3E%3Cpath%20d='M9%206V4a1%201%200%200%201%201-1h4a1%201%200%200%201%201%201v2'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-reset{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012a9%209%200%201%201-2.64-6.36'/%3E%3Cpolyline%20points='21%203%2021%209%2015%209'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012a9%209%200%201%201-2.64-6.36'/%3E%3Cpolyline%20points='21%203%2021%209%2015%209'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-export{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015v4a2%202%200%200%201-2%202H5a2%202%200%200%201-2-2v-4'/%3E%3Cpolyline%20points='7%2010%2012%2015%2017%2010'/%3E%3Cline%20x1='12'%20y1='15'%20x2='12'%20y2='3'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015v4a2%202%200%200%201-2%202H5a2%202%200%200%201-2-2v-4'/%3E%3Cpolyline%20points='7%2010%2012%2015%2017%2010'/%3E%3Cline%20x1='12'%20y1='15'%20x2='12'%20y2='3'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-key{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='7.5'%20cy='15.5'%20r='5.5'/%3E%3Cpath%20d='M13%2015l8%200'/%3E%3Cpath%20d='M21%2015v4'/%3E%3Cpath%20d='M18%2015v3'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='7.5'%20cy='15.5'%20r='5.5'/%3E%3Cpath%20d='M13%2015l8%200'/%3E%3Cpath%20d='M21%2015v4'/%3E%3Cpath%20d='M18%2015v3'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-exit{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M9%2021H5a2%202%200%200%201-2-2V5a2%202%200%200%201%202-2h4'/%3E%3Cpolyline%20points='16%2017%2021%2012%2016%207'/%3E%3Cline%20x1='21'%20y1='12'%20x2='9'%20y2='12'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M9%2021H5a2%202%200%200%201-2-2V5a2%202%200%200%201%202-2h4'/%3E%3Cpolyline%20points='16%2017%2021%2012%2016%207'/%3E%3Cline%20x1='21'%20y1='12'%20x2='9'%20y2='12'/%3E%3C/svg%3E");
}

/* Botões dentro de tabelas/cards ficam "outline" e discretos */
.tabela-gestores td .btn,
.empreendimento-acoes .btn{
  background: transparent !important;
  border: 1px solid var(--ui-border) !important;
  color: var(--ui-text) !important;
  border-radius: 10px !important;
  padding: 7px 12px !important;
  font-size: .86rem !important;
  font-weight: 700 !important;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.tabela-gestores td .btn:hover,
.empreendimento-acoes .btn:hover{
  background: var(--ui-btn-hover) !important;
}

.tabela-gestores td .btn.btn-primary,
.empreendimento-acoes .btn.btn-primary{
  color: var(--ui-accent) !important;
  border-color: rgba(0,67,199,.35) !important;
}


/* Pop-ups: ações compactas e sóbrias (ícones visíveis) */
.popups-actions{
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.popups-actions .popups-btn{
  padding: 6px 8px !important;
  min-width: 34px;
  justify-content: center;
  background: transparent !important;
  border: 1px solid var(--ui-border) !important;
  color: var(--ui-text) !important;
  border-radius: 10px !important;
  display: inline-flex;
  align-items: center;
}

.popups-actions .popups-btn:hover{
  background: var(--ui-btn-hover) !important;
}

.popups-actions .popups-btn.popups-btn-danger:hover{
  color: var(--ui-danger) !important;
  border-color: rgba(239,68,68,.35) !important;
}

.tabela-gestores td .btn.btn-danger,
.empreendimento-acoes .btn.btn-danger{
  color: var(--ui-danger) !important;
  border-color: rgba(185,28,28,.35) !important;
}

.tabela-gestores td .btn.btn-warning,
.empreendimento-acoes .btn.btn-warning{
  color: var(--ui-warning) !important;
  border-color: rgba(180,83,9,.35) !important;
}

/* ---------------- Empty state (Propostas placeholder) ---------------- */
.empty-state{
  padding: 28px;
  border-radius: 14px;
  border: 1px dashed var(--ui-border);
  background: var(--ui-surface);
  text-align: center;
}

.empty-state-icon{
  width: 44px;
  height: 44px;
  margin: 0 auto 12px;
  border-radius: 14px;
  background: var(--ui-surface-2);
  border: 1px solid var(--ui-border);
  position: relative;
}

.empty-state-icon::before{
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 22px;
  height: 22px;
  background: var(--ui-accent);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='18'%20y1='20'%20x2='18'%20y2='10'/%3E%3Cline%20x1='12'%20y1='20'%20x2='12'%20y2='4'/%3E%3Cline%20x1='6'%20y1='20'%20x2='6'%20y2='14'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='18'%20y1='20'%20x2='18'%20y2='10'/%3E%3Cline%20x1='12'%20y1='20'%20x2='12'%20y2='4'/%3E%3Cline%20x1='6'%20y1='20'%20x2='6'%20y2='14'/%3E%3C/svg%3E");
}

/* Força modo CLARO quando usuário escolhe manualmente (mesmo se o sistema estiver em dark) */
html[data-theme="light"]{
  color-scheme: light;
  --ui-bg:#f5f7fa;
  --ui-surface:#ffffff;
  --ui-surface-2:#eef2f7;
  --ui-text:#111827;
  --ui-muted:#6b7280;
  --ui-border:rgba(17,24,39,.12);
  --ui-row-hover: rgba(17,24,39,.04);
  --ui-btn-hover: rgba(17,24,39,.06);
  --ui-danger:#b91c1c;
  --ui-warning:#b45309;
  --ui-success:#15803d;
}

html[data-theme="light"] .admin-sidebar{background:#00279c !important;}


/* =========================================================
   PATCH (CSS) — 2026-02-10 (v3)
   - Mais contraste no modo escuro (Painel + Empreendimentos)
   - Ações com botões somente ícone (mais compacto)
   ========================================================= */

/* Mais contraste no dark (fundo um pouco mais escuro, cards um pouco mais claros) */
@media (prefers-color-scheme: dark){
  :root{
    --ui-bg:#070d18;
    --ui-surface:#0f1b33;
    --ui-surface-2:#132244;
    --ui-text:#e8ecf3;
    --ui-muted:#a6b0c3;
    --ui-border:rgba(232,236,243,.14);
  }
}
html[data-theme="dark"]{
  --ui-bg:#070d18;
  --ui-surface:#0f1b33;
  --ui-surface-2:#132244;
  --ui-text:#e8ecf3;
  --ui-muted:#a6b0c3;
  --ui-border:rgba(232,236,243,.14);
}

/* v3.5.4 — Modais no tema escuro: labels e títulos com alto contraste */
html[data-theme="dark"] .modal .modal-header h3{
  color: var(--ui-text) !important;
}

html[data-theme="dark"] .modal .form-group label{
  color: var(--ui-text) !important;
}

/* fallback: algumas telas usam label fora de .form-group */
html[data-theme="dark"] .modal label{
  color: var(--ui-text) !important;
}

/* Painel: caixa dos filtros acompanha o tema */
#painel .dash-filters{
  background: var(--ui-surface) !important;
  border: 1px solid var(--ui-border) !important;
  box-shadow: none !important;
}
#painel .dash-filter label{ color: var(--ui-muted) !important; }
#painel .dash-check{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: var(--ui-text) !important;
}
#painel .dash-range-label{
  background: var(--ui-surface-2) !important;
  border: 1px solid var(--ui-border) !important;
  color: var(--ui-text) !important;
}

/* KPI antigo: garante contraste */
#painel .kpi-title{ color: var(--ui-muted) !important; }
#painel .kpi-sub{ color: var(--ui-muted) !important; }
#painel .kpi-value{ color: var(--ui-text) !important; }

/* Empreendimentos: textos mais claros e legíveis */
.empreendimento-info h3{ color: var(--ui-text) !important; }
.empreendimento-detalhes .detalhe-item > span{ color: var(--ui-text) !important; }
.empreendimento-detalhes .detalhe-label{ color: var(--ui-muted) !important; }

/* Botões de ações: somente ícone (compacto) */
:root{
  --ui-action-size: 32px;
  --ui-action-radius: 10px;
}

.tabela-gestores td .btn,
.empreendimento-acoes .btn,
.historico-actions .btn,
.historico-mass-actions .btn{
  width: var(--ui-action-size) !important;
  height: var(--ui-action-size) !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: var(--ui-action-radius) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  font-size: 0 !important;  /* esconde o texto e deixa só o ícone */
  line-height: 0 !important;
}

/* Base neutra */
.tabela-gestores td .btn,
.empreendimento-acoes .btn,
.historico-actions .btn,
.historico-mass-actions .btn{
  background: rgba(148,163,184,.14) !important;
  color: var(--ui-muted) !important;
}

/* Cores por intenção */
.tabela-gestores td .btn.btn-primary,
.empreendimento-acoes .btn.btn-primary,
.historico-actions .btn.btn-primary,
.historico-mass-actions .btn.btn-primary{
  background: rgba(0,67,199,.14) !important;
  color: var(--ui-accent) !important;
}

.tabela-gestores td .btn.btn-danger,
.empreendimento-acoes .btn.btn-danger,
.historico-actions .btn.btn-danger,
.historico-mass-actions .btn.btn-danger{
  background: rgba(239,68,68,.14) !important;
  color: var(--ui-danger) !important;
}

.tabela-gestores td .btn.btn-warning,
.empreendimento-acoes .btn.btn-warning,
.historico-actions .btn.btn-warning,
.historico-mass-actions .btn.btn-warning{
  background: rgba(245,158,11,.14) !important;
  color: var(--ui-warning) !important;
}

.tabela-gestores td .btn.btn-success,
.empreendimento-acoes .btn.btn-success,
.historico-actions .btn.btn-success,
.historico-mass-actions .btn.btn-success{
  background: rgba(34,197,94,.14) !important;
  color: var(--ui-success) !important;
}

/* Hover */
.tabela-gestores td .btn:hover,
.empreendimento-acoes .btn:hover,
.historico-actions .btn:hover,
.historico-mass-actions .btn:hover{
  filter: brightness(1.08);
}

/* Ícone um pouco maior nos botões compactos */
.tabela-gestores td .btn .btn-ico,
.empreendimento-acoes .btn .btn-ico,
.historico-actions .btn .btn-ico,
.historico-mass-actions .btn .btn-ico{
  width: 16px;
  height: 16px;
}

/* Historico: a barra de acoes em massa precisa mostrar texto sem sobreposicao */
#historico .historico-mass-actions{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  flex-wrap:wrap !important;
}

#historico .historico-mass-actions .btn{
  width:auto !important;
  min-width:0 !important;
  height:34px !important;
  padding:0 12px !important;
  border-radius:9px !important;
  gap:6px !important;
  font-size:.82rem !important;
  line-height:1 !important;
  white-space:nowrap !important;
  flex:0 0 auto !important;
}

#historico .historico-mass-actions .btn .btn-ico{
  width:12px !important;
  height:12px !important;
  flex:0 0 auto !important;
}

/* Ícones adicionais (archive/refresh/plus) */
.btn-ico.btn-ico-archive{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='3'%20y='4'%20width='18'%20height='7'%20rx='2'/%3E%3Cpath%20d='M5%2011v9a2%202%200%200%200%202%202h10a2%202%200%200%200%202-2v-9'/%3E%3Cpath%20d='M10%2015h4'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='3'%20y='4'%20width='18'%20height='7'%20rx='2'/%3E%3Cpath%20d='M5%2011v9a2%202%200%200%200%202%202h10a2%202%200%200%200%202-2v-9'/%3E%3Cpath%20d='M10%2015h4'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-refresh{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012a9%209%200%201%201-2.64-6.36'/%3E%3Cpolyline%20points='21%203%2021%209%2015%209'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012a9%209%200%201%201-2.64-6.36'/%3E%3Cpolyline%20points='21%203%2021%209%2015%209'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-plus{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='12'%20y1='5'%20x2='12'%20y2='19'/%3E%3Cline%20x1='5'%20y1='12'%20x2='19'%20y2='12'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='12'%20y1='5'%20x2='12'%20y2='19'/%3E%3Cline%20x1='5'%20y1='12'%20x2='19'%20y2='12'/%3E%3C/svg%3E");
}


.btn-ico.btn-ico-eye{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M1%2012s4-8%2011-8%2011%208%2011%208-4%208-11%208-11-8-11-8z'/%3E%3Ccircle%20cx='12'%20cy='12'%20r='3'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M1%2012s4-8%2011-8%2011%208%2011%208-4%208-11%208-11-8-11-8z'/%3E%3Ccircle%20cx='12'%20cy='12'%20r='3'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-unarchive{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012a9%209%200%201%201-2.64-6.36'/%3E%3Cpolyline%20points='21%203%2021%209%2015%209'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2012a9%209%200%201%201-2.64-6.36'/%3E%3Cpolyline%20points='21%203%2021%209%2015%209'/%3E%3C/svg%3E");
}


.btn-ico.btn-ico-import{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015v4a2%202%200%200%201-2%202H5a2%202%200%200%201-2-2v-4'/%3E%3Cpolyline%20points='17%208%2012%203%207%208'/%3E%3Cline%20x1='12'%20y1='3'%20x2='12'%20y2='15'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015v4a2%202%200%200%201-2%202H5a2%202%200%200%201-2-2v-4'/%3E%3Cpolyline%20points='17%208%2012%203%207%208'/%3E%3Cline%20x1='12'%20y1='3'%20x2='12'%20y2='15'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-save{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M19%2021H5a2%202%200%200%201-2-2V5a2%202%200%200%201%202-2h11l5%205v11a2%202%200%200%201-2%202z'/%3E%3Cpolyline%20points='17%2021%2017%2013%207%2013%207%2021'/%3E%3Cpolyline%20points='7%203%207%208%2015%208'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M19%2021H5a2%202%200%200%201-2-2V5a2%202%200%200%201%202-2h11l5%205v11a2%202%200%200%201-2%202z'/%3E%3Cpolyline%20points='17%2021%2017%2013%207%2013%207%2021'/%3E%3Cpolyline%20points='7%203%207%208%2015%208'/%3E%3C/svg%3E");
}

/* Aprovar / Reprovar / Imprimir (ícones) */
.btn-ico.btn-ico-check{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='20%206%209%2017%204%2012'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='20%206%209%2017%204%2012'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-x{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='18'%20y1='6'%20x2='6'%20y2='18'/%3E%3Cline%20x1='6'%20y1='6'%20x2='18'%20y2='18'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='18'%20y1='6'%20x2='6'%20y2='18'/%3E%3Cline%20x1='6'%20y1='6'%20x2='18'%20y2='18'/%3E%3C/svg%3E");
}

.btn-ico.btn-ico-print{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='6%209%206%202%2018%202%2018%209'/%3E%3Cpath%20d='M6%2018H4a2%202%200%200%201-2-2v-5a2%202%200%200%201%202-2h16a2%202%200%200%201%202%202v5a2%202%200%200%201-2%202h-2'/%3E%3Crect%20x='6'%20y='14'%20width='12'%20height='8'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='6%209%206%202%2018%202%2018%209'/%3E%3Cpath%20d='M6%2018H4a2%202%200%200%201-2-2v-5a2%202%200%200%201%202-2h16a2%202%200%200%201%202%202v5a2%202%200%200%201-2%202h-2'/%3E%3Crect%20x='6'%20y='14'%20width='12'%20height='8'/%3E%3C/svg%3E");
}

/* =========================================================
   Password toggle (olhinho)
   ========================================================= */

.btn-ico.btn-ico-eye-off{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2024%2024%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27%3E%3Cpath%20d%3D%27M1%2012s4-8%2011-8%2011%208%2011%208-4%208-11%208-11-8-11-8z%27%2F%3E%3Ccircle%20cx%3D%2712%27%20cy%3D%2712%27%20r%3D%273%27%2F%3E%3Cline%20x1%3D%274%27%20y1%3D%274%27%20x2%3D%2720%27%20y2%3D%2720%27%2F%3E%3C%2Fsvg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2024%2024%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27%3E%3Cpath%20d%3D%27M1%2012s4-8%2011-8%2011%208%2011%208-4%208-11%208-11-8-11-8z%27%2F%3E%3Ccircle%20cx%3D%2712%27%20cy%3D%2712%27%20r%3D%273%27%2F%3E%3Cline%20x1%3D%274%27%20y1%3D%274%27%20x2%3D%2720%27%20y2%3D%2720%27%2F%3E%3C%2Fsvg%3E");
}

.password-field{position:relative;display:block;}
.password-field > input{padding-right:52px !important;}

.password-toggle{
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  border:1px solid var(--ui-border, rgba(0,0,0,.15));
  background: var(--ui-surface-2, rgba(0,0,0,.03));
  color: var(--ui-muted, #6b7280);
  cursor:pointer;
}
.password-toggle:hover{background: var(--ui-btn-hover, rgba(0,0,0,.06)); color: var(--ui-text, #111827);}
.password-toggle:focus{outline:2px solid rgba(0,67,199,.35); outline-offset:2px;}
.password-toggle .btn-ico{width:16px;height:16px;}

/* =========================================================
   v2.10 — Ajustes de layout (Painel / Empreendimentos / Propostas)
   ========================================================= */

/* Empreendimentos: cards mais limpos (apenas dados essenciais) */
.empreendimento-detalhes.empreendimentos-compact{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:10px;
}
.empreendimento-detalhes.empreendimentos-compact .detalhe-item{
  display:flex;
  align-items:baseline;
  gap:10px;
  padding:6px 0;
  border-bottom:1px dashed var(--ui-border);
}
.empreendimento-detalhes.empreendimentos-compact .detalhe-item:last-child{border-bottom:0;}
.empreendimento-detalhes.empreendimentos-compact .detalhe-label{
  min-width:140px;
  color:var(--ui-muted) !important;
  font-weight:700;
}

/* Propostas: Detalhes em blocos (modal) */
#modal-detalhes .modal-content.modal-detalhes-content{
  border-radius:16px !important;
  border:1px solid var(--ui-border) !important;
  background: var(--ui-bg) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.22);
}
#modal-detalhes .modal-header{
  background: var(--ui-surface) !important;
  border: 1px solid var(--ui-border) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
  margin-bottom:14px !important;
}
#modal-detalhes .modal-header h3{
  margin:0 !important;
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
}
#modal-detalhes .close-modal{
  width:36px;
  height:36px;
  border-radius:12px;
}
#modal-detalhes .close-modal:hover{ background: var(--ui-btn-hover) !important; }

#modal-detalhes .detalhes-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  margin-bottom:14px;
}
@media (max-width: 860px){
  #modal-detalhes .detalhes-grid{grid-template-columns:1fr;}
}

#modal-detalhes .detalhes-section{
  background: var(--ui-surface) !important;
  border:1px solid var(--ui-border) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
  margin-bottom:14px;
}
#modal-detalhes .detalhes-section:last-child{margin-bottom:0;}

#modal-detalhes .detalhes-section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-bottom:10px;
  margin-bottom:10px;
  border-bottom:1px solid var(--ui-border);
}
#modal-detalhes .detalhes-section-header h4{
  margin:0;
  font-size:1rem;
  font-weight:900;
  color:var(--ui-text);
}
#modal-detalhes .detalhes-section-body{
  display:flex;
  flex-direction:column;
  gap:8px;
}

/* Ajuste leve no item de detalhe dentro do modal (sem mudar conteúdo) */
#modal-detalhes .detalhe-item{
  display:grid;
  grid-template-columns: 200px 1fr;
  gap:12px;
  align-items:baseline;
  padding:8px 0;
  margin:0 !important;
  border-bottom:1px dashed var(--ui-border);
}
#modal-detalhes .detalhe-item:last-child{border-bottom:0;}
#modal-detalhes .detalhe-label{ color: var(--ui-muted) !important; font-weight:800 !important; }
#modal-detalhes .detalhe-item > span:last-child{ color: var(--ui-text) !important; }

/* Item que empilha conteúdos (Status) */
#modal-detalhes .detalhe-item.detalhe-item--stack{
  grid-template-columns: 200px 1fr;
}
#modal-detalhes .detalhe-item.detalhe-item--stack .val{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--ui-border);
  background: var(--ui-surface-2);
  font-weight:900;
  width: fit-content;
}

/* Pílulas por status */
#modal-detalhes .status-pill--aprovado{ color: var(--ui-success) !important; border-color: rgba(21,128,61,.25) !important; background: rgba(21,128,61,.08) !important; }
#modal-detalhes .status-pill--reprovado{ color: var(--ui-danger) !important; border-color: rgba(185,28,28,.25) !important; background: rgba(185,28,28,.08) !important; }
#modal-detalhes .status-pill--pendente{ color: var(--ui-warning) !important; border-color: rgba(180,83,9,.25) !important; background: rgba(180,83,9,.08) !important; }

#modal-detalhes .detalhes-note{
  margin-top:10px;
  padding:12px;
  border-radius:12px;
  border:1px solid var(--ui-border);
  background: var(--ui-surface-2);
}
#modal-detalhes .detalhes-note--danger{
  border-color: rgba(185,28,28,.22);
  background: rgba(185,28,28,.06);
}
#modal-detalhes .detalhes-note-title{
  font-weight:900;
  color: var(--ui-text);
  margin-bottom:6px;
}
#modal-detalhes .detalhes-note-body{ color: var(--ui-text); }

#modal-detalhes .detalhes-help{
  margin-top:8px;
  color: var(--ui-muted);
  font-size:.9rem;
}

#modal-detalhes .detalhes-reprovacao{
  margin-top:10px;
  padding-top:10px;
  border-top:1px dashed var(--ui-border);
}
#modal-detalhes .detalhes-label{
  display:block;
  font-size:.9rem;
  font-weight:800;
  color: var(--ui-muted);
  margin-bottom:6px;
}
#modal-detalhes .detalhes-textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--ui-border);
  border-radius:12px;
  background: var(--ui-surface);
  color: var(--ui-text);
  resize: vertical;
}
#modal-detalhes .detalhes-textarea:focus{outline:2px solid rgba(0,67,199,.35); outline-offset:2px;}

#modal-detalhes .detalhes-actions{
  margin-top:10px;
  display:flex;
  gap:8px;
  justify-content:flex-end;
}

#modal-detalhes .detalhes-table-wrap{ overflow:auto; }
#modal-detalhes .detalhes-table{ min-width: 760px; }

/* v2.10.1 — Modal Empreendimento em blocos (mesma linha do modal de Propostas) */
#modalEmpreendimento .modal-content.modal-empreendimento-content{
  border-radius:16px !important;
  border:1px solid var(--ui-border) !important;
  background: var(--ui-bg) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.22);
  max-width: 1080px !important;
  max-height: 90vh;
  overflow-y: auto;
}

#modalEmpreendimento .modal-header{
  background: var(--ui-surface) !important;
  border: 1px solid var(--ui-border) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
  margin-bottom:14px !important;
}
#modalEmpreendimento .modal-header h3{
  margin:0 !important;
  display:flex;
  align-items:center;
  gap:10px;
  color: var(--ui-text) !important;
  font-weight:900;
}
#modalEmpreendimento .close-modal{
  width:36px;
  height:36px;
  border-radius:12px;
  border:1px solid var(--ui-border);
  background: var(--ui-surface-2);
  color: var(--ui-text);
  display:flex;
  align-items:center;
  justify-content:center;
}
#modalEmpreendimento .close-modal:hover{ background: var(--ui-btn-hover) !important; }

#modalEmpreendimento .emp-modal-body{
  display:flex;
  flex-direction:column;
  gap:14px;
}

#modalEmpreendimento .emp-section{
  background: var(--ui-surface) !important;
  border:1px solid var(--ui-border) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
}

#modalEmpreendimento .emp-section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-bottom:10px;
  margin-bottom:10px;
  border-bottom:1px solid var(--ui-border);
}
#modalEmpreendimento .emp-section-header h4{
  margin:0;
  font-size:1rem;
  font-weight:900;
  color:var(--ui-text);
}
#modalEmpreendimento .emp-section-body{
  display:flex;
  flex-direction:column;
  gap:10px;
}
#modalEmpreendimento .emp-section-desc{
  color: var(--ui-muted);
  font-size: .95rem;
  line-height: 1.35;
}

/* Ajustes finos do grid dentro do modal */
#modalEmpreendimento .form-grid{ gap: 16px; }

/* Premissas: harmonizar com tema (claro/escuro) */
#modalEmpreendimento .tabs-premissas{
  background: var(--ui-surface-2) !important;
  border:1px solid var(--ui-border);
  padding:8px;
  border-radius:12px;
  margin-bottom:12px;
}
#modalEmpreendimento .tab-premissa{
  background: var(--ui-surface) !important;
  border:1px solid var(--ui-border);
  border-radius:10px;
  padding:10px 12px;
  font-weight:800;
  color: var(--ui-muted);
}
#modalEmpreendimento .tab-premissa:hover{ background: var(--ui-btn-hover) !important; color: var(--ui-text) !important; }
#modalEmpreendimento .tab-premissa.active{
  background: var(--ui-accent, #0043c7) !important;
  color: #fff !important;
  border-color: transparent;
}

#modalEmpreendimento .premissas-container{
  background: transparent !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#modalEmpreendimento .premissa-item{
  margin:0 0 14px 0;
  padding:0 0 14px 0;
  border-bottom:1px dashed var(--ui-border);
}
#modalEmpreendimento .premissa-item:last-child{ border-bottom:0; margin-bottom:0; padding-bottom:0; }
#modalEmpreendimento .premissa-title{ color: var(--ui-text) !important; font-weight:900; }
#modalEmpreendimento .premissa-description{ color: var(--ui-muted) !important; }

#modalEmpreendimento .range-container input[type="range"]{
  background: var(--ui-surface-2) !important;
}
#modalEmpreendimento .range-container input[type="range"]::-webkit-slider-thumb{
  background: var(--ui-accent, #0043c7) !important;
}
#modalEmpreendimento .range-container input[type="range"]::-moz-range-thumb{
  background: var(--ui-accent, #0043c7) !important;
}

#modalEmpreendimento .numeric-input{
  border:1px solid var(--ui-border) !important;
  background: var(--ui-surface) !important;
  color: var(--ui-text) !important;
  border-radius:10px;
  font-weight:800;
}
#modalEmpreendimento .numeric-input:focus{ outline:2px solid rgba(0,67,199,.28); outline-offset:2px; }

#modalEmpreendimento .hint{ color: var(--ui-muted) !important; }
#modalEmpreendimento .modal-footer{ border-top:1px solid var(--ui-border) !important; margin-top: 16px; padding-top: 16px; }

/* Checkbox "Apenas Pré-Chaves": evita layout quebrado e melhora legibilidade */
#modalEmpreendimento input#empreendimentoSomentePreChaves{
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  margin: 2px 0 0 0 !important;
  padding: 0 !important;
  border-radius: 4px;
  flex: 0 0 16px;
  accent-color: var(--ui-accent, #0043c7);
}

#modalEmpreendimento input#empreendimentoSomentePreChaves + span{
  display: inline-block;
  line-height: 1.35;
  color: var(--ui-text) !important;
}

#modalEmpreendimento .form-group:has(> label > #empreendimentoSomentePreChaves){
  padding: 10px 12px;
  border: 1px solid var(--ui-border);
  border-radius: 12px;
  background: var(--ui-surface-2);
}

#modalEmpreendimento .form-group:has(> label > #empreendimentoSomentePreChaves) > label{
  margin-bottom: 6px;
  align-items: flex-start !important;
}

#modalEmpreendimento .form-group:has(> label > #empreendimentoSomentePreChaves) > .hint{
  margin-left: 24px;
  line-height: 1.35;
}



/* ===== Pop-Ups (v4.0) ===== */
.lon-popup-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 22px;
  z-index: 9999;
}

.lon-popup-box{
  position: relative;
  border: none;
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
  border-radius: 18px;
  overflow: hidden;
  max-width: calc(100vw - 44px);
}

.lon-popup-box.is-image{
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}

.lon-popup-content{ padding: 18px 18px 16px 18px; }
.lon-popup-title{ font-weight: 800; font-size: 1.05rem; margin-bottom: 8px; }
.lon-popup-text{ font-size: 0.98rem; line-height: 1.4; white-space: pre-wrap; }

.lon-popup-img{
  display:block;
  /*
    Evita corte em tamanhos P/M: a imagem deve se ajustar ao box (proporcional)
    sem estourar nem achatar.
  */
  max-width: 100%;
  max-height: 82vh;
  width: auto;
  height: auto;
  object-fit: contain;
  margin: 0 auto;
  border-radius: 14px;
}

.lon-popup-close{
  position:absolute;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: none;
  background: rgba(0,0,0,.35);
  color: #fff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.lon-popup-close:hover{ background: rgba(0,0,0,.5); }

/* Sizes */
.lon-popup-box.size-p{ width: 340px; }
.lon-popup-box.size-m{ width: 520px; }
.lon-popup-box.size-g{ width: 760px; }

/* Positions */
.lon-popup-box.pos-center{ margin-top: 10vh; }
.lon-popup-box.pos-top-left{ align-self:flex-start; margin-top: 12px; margin-right:auto; }
.lon-popup-box.pos-top-right{ align-self:flex-start; margin-top: 12px; margin-left:auto; }
.lon-popup-box.pos-bottom-left{ align-self:flex-end; margin-bottom: 12px; margin-right:auto; }
.lon-popup-box.pos-bottom-right{ align-self:flex-end; margin-bottom: 12px; margin-left:auto; }

/* Bars */
.lon-popup-box.pos-top-bar,
.lon-popup-box.pos-bottom-bar{
  width: min(980px, calc(100vw - 44px));
  border-radius: 16px;
}
.lon-popup-box.pos-top-bar{ align-self:flex-start; margin-top: 12px; }
.lon-popup-box.pos-bottom-bar{ align-self:flex-end; margin-bottom: 12px; }


/* Image sizing (P/M/G): mantém proporcional e faz sentido escolher o tamanho */
.lon-popup-box.is-image.size-p{ width: 340px; }
.lon-popup-box.is-image.size-m{ width: 520px; }
.lon-popup-box.is-image.size-g{ width: 760px; }

.lon-popup-box.is-image.size-p .lon-popup-img{ max-height: 48vh; }
.lon-popup-box.is-image.size-m .lon-popup-img{ max-height: 66vh; }
.lon-popup-box.is-image.size-g .lon-popup-img{ max-height: 82vh; }

@media (max-width: 520px){
  .lon-popup-content{ padding: 14px; }
  .lon-popup-box.size-m{ width: 92vw; }
  .lon-popup-box.size-g{ width: 92vw; }
  .lon-popup-box.size-p{ width: 92vw; }
  .lon-popup-box.pos-center{ margin-top: 7vh; }

/* Em telas pequenas, ainda diferencia P/M/G para imagens */
.lon-popup-box.is-image.size-p{ width: 84vw; }
.lon-popup-box.is-image.size-m{ width: 92vw; }
.lon-popup-box.is-image.size-g{ width: 96vw; }
.lon-popup-box.is-image.size-p .lon-popup-img{ max-height: 45vh; }
.lon-popup-box.is-image.size-m .lon-popup-img{ max-height: 62vh; }
.lon-popup-box.is-image.size-g .lon-popup-img{ max-height: 78vh; }

}


/* ===== Pop-Ups admin UI ===== */
.modal-popup-content{ max-width: 760px; width: min(760px, 96vw); }

/* Estrutura do modal (semelhante aos outros cadastros) */
.popup-toggle{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-top:6px;
  padding:10px 12px;
  border:1px solid #dbe4f2;
  border-radius:10px;
  background:#f8fbff;
  color:#1f2a3a;
  cursor:pointer;
}

.popup-check-inline{
  margin-top:10px;
  padding:7px 10px;
  border-style:dashed;
  background:#fff;
}
.form-error{ color:#b00; font-weight:700; margin-top:12px; }

.popup-checks{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap:10px;
  margin-top:8px;
}

.popup-check{
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid #dbe4f2;
  border-radius:10px;
  background:#f8fbff;
  color:#1f2a3a;
  padding:10px 12px;
  cursor:pointer;
  min-height:42px;
  transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.popup-check:hover,
.popup-toggle:hover{
  border-color:#b8c9e6;
  background:#f2f7ff;
}

.popup-check input[type="checkbox"],
.popup-toggle input[type="checkbox"]{
  width:16px;
  height:16px;
  margin:0;
  accent-color:#0043c7;
  flex:0 0 16px;
  cursor:pointer;
}

.popup-check:has(input:checked),
.popup-toggle:has(input:checked){
  border-color:#0043c7;
  background:#eaf1ff;
  box-shadow: inset 0 0 0 1px rgba(0, 67, 199, 0.18);
}

.popup-roles{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap:10px;
  margin-top:8px;
}

.popup-roles-actions{
  display:flex;
  gap:10px;
  margin-top:10px;
  justify-content:flex-end;
  flex-wrap:wrap;
}

.btn-xs{ padding: 8px 10px; font-size: .9rem; }
.popup-img-preview-wrap{ margin-top: 10px; display:flex; flex-direction:column; gap:10px; }
#popupImagemPreview{ max-width: 420px; max-height: 240px; border-radius: 12px; }
.popup-img-actions{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

@media (max-width: 640px){
  .popup-roles,
  .popup-checks{
    grid-template-columns: 1fr;
  }
}

/* v6.0.0 - Botões mais compactos na lista de Propostas */
.historico-mobile-cards{
  display: none;
}

#tabela-historico td .btn {
  padding: 5px 10px;
  font-size: 0.82rem;
}
#tabela-historico td .btn .btn-ico {
  width: 14px;
  height: 14px;
}

/* v6.1.0 - Propostas com escala visual mais sobria */
#historico .historico-toolbar{
  margin-bottom: 14px !important;
  gap: 8px !important;
}

#historico .historico-control{
  height: 36px !important;
  padding: 7px 10px !important;
  border-radius: 8px !important;
  font-size: 0.86rem !important;
  line-height: 1.1 !important;
}

#historico .historico-control--search{
  min-width: 280px !important;
}

#historico .historico-toggle,
#historico .historico-select-chip{
  min-height: 34px !important;
  height: 34px !important;
  border-radius: 999px !important;
  font-size: 0.83rem !important;
  color: var(--ui-muted) !important;
}

#historico .historico-toggle input[type="checkbox"],
#historico .historico-select-chip input[type="checkbox"]{
  width: 14px;
  height: 14px;
}

#historico .historico-selected-count{
  font-size: 0.82rem !important;
  color: var(--ui-muted) !important;
}

#historico .historico-btn{
  padding: 6px 10px !important;
  border-radius: 8px !important;
  font-size: 0.82rem !important;
  line-height: 1.05 !important;
}

#historico .historico-btn .btn-ico{
  width: 12px;
  height: 12px;
}

#historico #tabela-historico{
  font-size: 0.9rem !important;
  width: max-content !important;
  min-width: 1760px !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

#historico .gestores-container{
  overflow-x: auto !important;
  overflow-y: hidden !important;
  border-radius: 14px !important;
  border: 1px solid var(--ui-border) !important;
  background: var(--ui-surface) !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
}

#historico #tabela-historico th{
  padding: 9px 10px !important;
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
  position: sticky;
  top: 0;
  z-index: 2;
  background: #f8fafc !important;
}

#historico #tabela-historico td{
  padding: 8px 10px !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  vertical-align: top !important;
  white-space: nowrap !important;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08) !important;
}

#historico #tabela-historico td small{
  font-size: 12px;
  display: inline-block;
  margin-left: 6px;
  color: var(--ui-muted);
}

#historico #tabela-historico td br{
  display: none;
}

#historico #tabela-historico tbody tr:nth-child(even){
  background: rgba(15, 23, 42, 0.015);
}

#historico #tabela-historico tbody tr:hover{
  background: rgba(0, 67, 199, 0.04) !important;
}

#historico #tabela-historico tbody tr.historico-row-archived{
  opacity: .58;
  filter: grayscale(.9);
}

#historico #tabela-historico tbody tr.historico-row-archived:hover{
  background: rgba(15, 23, 42, 0.03) !important;
}

#historico #tabela-historico th:nth-child(1),
#historico #tabela-historico td:nth-child(1){
  min-width: 122px;
}

#historico #tabela-historico th:nth-child(3),
#historico #tabela-historico td:nth-child(3),
#historico #tabela-historico th:nth-child(4),
#historico #tabela-historico td:nth-child(4){
  min-width: 180px;
}

#historico #tabela-historico th:nth-child(5),
#historico #tabela-historico td:nth-child(5),
#historico #tabela-historico th:nth-child(6),
#historico #tabela-historico td:nth-child(6){
  min-width: 118px;
}

#historico #tabela-historico th:nth-child(7),
#historico #tabela-historico td:nth-child(7){
  min-width: 240px;
}

#historico #tabela-historico th:nth-child(8),
#historico #tabela-historico td:nth-child(8){
  min-width: 78px;
  text-align: center;
}

#historico #tabela-historico th:nth-child(9),
#historico #tabela-historico td:nth-child(9),
#historico #tabela-historico th:nth-child(10),
#historico #tabela-historico td:nth-child(10){
  min-width: 146px;
}

#historico #tabela-historico th:nth-child(11),
#historico #tabela-historico td:nth-child(11),
#historico #tabela-historico th:nth-child(12),
#historico #tabela-historico td:nth-child(12){
  min-width: 122px;
  text-align: center;
}

#historico #tabela-historico th:nth-child(13),
#historico #tabela-historico td:nth-child(13){
  min-width: 124px;
  text-align: right;
}

#historico #tabela-historico th:nth-child(14),
#historico #tabela-historico td:nth-child(14){
  min-width: 248px;
  text-align: center;
}

#historico #tabela-historico .empreendimento-status{
  margin-bottom: 0 !important;
  padding: 3px 10px !important;
  border-radius: 999px !important;
  font-size: 0.75rem !important;
  line-height: 1.1 !important;
  font-weight: 700 !important;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

#historico #tabela-historico .empreendimento-status--tipo{
  border: 1px solid transparent;
}

#historico #tabela-historico .tipo-imob{
  color: #0f766e !important;
  background: rgba(13, 148, 136, 0.12) !important;
  border-color: rgba(13, 148, 136, 0.22) !important;
}

#historico #tabela-historico .tipo-house{
  color: #1d4ed8 !important;
  background: rgba(29, 78, 216, 0.1) !important;
  border-color: rgba(29, 78, 216, 0.2) !important;
}

#historico #tabela-historico .empreendimento-status--status{
  border: 1px solid transparent;
}

#historico #tabela-historico .status-aprovado{
  color: #166534 !important;
  background: rgba(22, 101, 52, 0.12) !important;
  border-color: rgba(22, 101, 52, 0.2) !important;
}

#historico #tabela-historico .status-reprovado{
  color: #b91c1c !important;
  background: rgba(185, 28, 28, 0.1) !important;
  border-color: rgba(185, 28, 28, 0.2) !important;
}

#historico #tabela-historico .status-analise{
  color: #9a3412 !important;
  background: rgba(154, 52, 18, 0.1) !important;
  border-color: rgba(154, 52, 18, 0.2) !important;
}

#historico #tabela-historico .historico-row-actions{
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  flex-wrap: wrap;
  white-space: normal !important;
  min-width: 240px;
}

#historico #tabela-historico .historico-row-actions .btn{
  width: auto !important;
  height: 28px !important;
  min-width: 42px !important;
  padding: 0 8px !important;
  border-radius: 8px !important;
  border: 1px solid var(--ui-border) !important;
  background: var(--ui-surface-2) !important;
  color: var(--ui-muted) !important;
  box-shadow: none !important;
  filter: none !important;
  transition: background .14s ease, color .14s ease, border-color .14s ease !important;
  flex: 0 0 auto !important;
  margin-right: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
}

#historico #tabela-historico .historico-row-actions .btn.btn-primary{
  color: #1d4ed8 !important;
  background: rgba(29, 78, 216, 0.08) !important;
  border-color: rgba(29, 78, 216, 0.2) !important;
}

#historico #tabela-historico .historico-row-actions .btn.btn-success{
  color: #15803d !important;
  background: rgba(21, 128, 61, 0.08) !important;
  border-color: rgba(21, 128, 61, 0.2) !important;
}

#historico #tabela-historico .historico-row-actions .btn.btn-warning{
  color: #b45309 !important;
  background: rgba(180, 83, 9, 0.08) !important;
  border-color: rgba(180, 83, 9, 0.22) !important;
}

#historico #tabela-historico .historico-row-actions .btn.btn-danger{
  color: #b91c1c !important;
  background: rgba(185, 28, 28, 0.08) !important;
  border-color: rgba(185, 28, 28, 0.22) !important;
}

#historico #tabela-historico .historico-row-actions .btn:hover{
  background: var(--ui-btn-hover) !important;
  border-color: var(--ui-border) !important;
}

#historico #tabela-historico .historico-row-actions .btn .btn-ico{
  width: 10px !important;
  height: 10px !important;
}

#historico #tabela-historico .historico-row-actions .historico-action-text{
  line-height: 1 !important;
  letter-spacing: .01em;
}

#historico #tabela-historico .historico-row-actions .btn.btn-decision-muted,
#modal-detalhes .modal-footer .btn.btn-decision-muted,
#modalHistoricoDetalhes .modal-footer .btn.btn-decision-muted,
#modalHistoricoDetalhes .detalhes-actions .btn.btn-decision-muted{
  opacity: .46 !important;
  filter: saturate(.45) grayscale(.12);
  cursor: not-allowed !important;
  pointer-events: none !important;
  box-shadow: none !important;
}

#historico #tabela-historico .historico-row-actions .btn.btn-decision-muted:hover,
#modal-detalhes .modal-footer .btn.btn-decision-muted:hover,
#modalHistoricoDetalhes .modal-footer .btn.btn-decision-muted:hover,
#modalHistoricoDetalhes .detalhes-actions .btn.btn-decision-muted:hover{
  opacity: .46 !important;
}

#historico #tabela-historico input[type="checkbox"]{
  width: 14px;
  height: 14px;
}

#historico .historico-footer{
  margin-top: 10px !important;
  font-size: 0.82rem !important;
}

#historico #historicoFiltroResumo{
  margin-bottom: 12px;
}

#historico #historico-list td:nth-child(2),
#historico #historico-list td:nth-child(3),
#historico #historico-list td:nth-child(4),
#historico #historico-list td:nth-child(5),
#historico #historico-list td:nth-child(7){
  white-space: normal !important;
}

#historico #historico-list td div{
  color: var(--ui-text);
}

#historico #historico-list .historico-cell-id{
  display:flex;
  align-items:flex-start;
  gap:8px;
}

#historico #historico-list .historico-cell-stack{
  display:flex;
  flex-direction:column;
  gap:3px;
  min-width:0;
}

#historico #historico-list .historico-cell-stack--money{
  align-items:flex-end;
}

#historico #historico-list .historico-cell-main{
  display:block;
  font-weight:700;
  color:var(--ui-text);
}

#historico #historico-list .historico-cell-main--soft{
  font-weight:600;
}

#historico #historico-list .historico-cell-code{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  min-width:84px;
  padding:4px 8px;
  border-radius:9px;
  background:rgba(15,23,42,.04);
  border:1px solid rgba(15,23,42,.08);
  font-weight:700;
  color:var(--ui-text);
}

#historico #historico-list .historico-cell-code--placeholder{
  color:var(--ui-muted);
  background:rgba(15,23,42,.025);
  border-style:dashed;
  font-weight:600;
}

#historico #historico-list .historico-code{
  display:inline-flex;
  align-items:center;
  width:max-content;
  min-height:28px;
  padding:4px 8px;
  border-radius:9px;
  background:rgba(0,67,199,.06);
  border:1px solid rgba(0,67,199,.12);
  color:#123c9c;
  font-weight:800;
}

#historico #historico-list .historico-cell-email{
  color:var(--ui-muted);
  font-size:.82rem;
}

#historico #historico-list .historico-status-stack{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
}

#historico #historico-list td small{
  display:block;
  margin-top:4px;
  font-size: .74rem;
  color: var(--ui-muted);
}

@media (max-width: 980px){
  #historico .historico-toolbar{
    gap: 6px !important;
  }

  #historico .historico-control{
    min-width: 180px;
  }

  #historico .historico-control--search{
    min-width: 220px !important;
  }
}

/* Alias do modal de propostas para a estrutura atual do Django */
#modalHistoricoDetalhes .modal-content.modal-detalhes-content{
  border-radius:16px !important;
  border:1px solid var(--ui-border) !important;
  background: var(--ui-bg) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.22);
}

#modalHistoricoDetalhes .modal-header{
  background: var(--ui-surface) !important;
  border: 1px solid var(--ui-border) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
  margin-bottom:14px !important;
}

#modalHistoricoDetalhes .modal-header h3{
  margin:0 !important;
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
}

#modalHistoricoDetalhes .detalhes-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:14px;
}

#modalHistoricoDetalhes .detalhes-section{
  background: var(--ui-surface) !important;
  border:1px solid var(--ui-border) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
}

#modalHistoricoDetalhes .detalhes-section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-bottom:10px;
  margin-bottom:10px;
  border-bottom:1px solid var(--ui-border);
}

#modalHistoricoDetalhes .detalhes-section-header h4{
  margin:0;
  font-size:1rem;
  font-weight:900;
  color:var(--ui-text);
}

#modalHistoricoDetalhes .detalhes-section-body{
  display:flex;
  flex-direction:column;
  gap:6px;
}

#modalHistoricoDetalhes .detalhe-item{
  display:grid;
  grid-template-columns: 164px 1fr;
  gap:12px;
  align-items:baseline;
  padding:7px 0;
  margin:0 !important;
  border-bottom:1px dashed var(--ui-border);
}

#modalHistoricoDetalhes .detalhe-item:last-child{
  border-bottom:0;
}

#modalHistoricoDetalhes .detalhe-label{
  color: var(--ui-muted) !important;
  font-weight:800 !important;
}

#modalHistoricoDetalhes .detalhe-item > span:last-child{
  color: var(--ui-text) !important;
}

#modalHistoricoDetalhes .detalhe-item.detalhe-item--stack{
  display:inline-grid;
  align-items:center;
}

#modalHistoricoDetalhes .detalhe-item.detalhe-item--stack .val{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--ui-border);
  background: var(--ui-surface-2);
  font-weight:900;
  width: fit-content;
}

#modalHistoricoDetalhes .status-pill--aprovado{
  color: var(--ui-success) !important;
  border-color: rgba(21,128,61,.25) !important;
  background: rgba(21,128,61,.08) !important;
}

#modalHistoricoDetalhes .status-pill--reprovado{
  color: var(--ui-danger) !important;
  border-color: rgba(185,28,28,.25) !important;
  background: rgba(185,28,28,.08) !important;
}

#modalHistoricoDetalhes .status-pill--pendente{
  color: var(--ui-warning) !important;
  border-color: rgba(180,83,9,.25) !important;
  background: rgba(180,83,9,.08) !important;
}

#modalHistoricoDetalhes .detalhes-note{
  margin-top:10px;
  padding:12px;
  border-radius:12px;
  border:1px solid var(--ui-border);
  background: var(--ui-surface-2);
}

#modalHistoricoDetalhes .detalhes-note--warning{
  border-color: rgba(180,83,9,.22);
  background: rgba(180,83,9,.07);
}

#modalHistoricoDetalhes .detalhes-note--danger{
  border-color: rgba(185,28,28,.22);
  background: rgba(185,28,28,.06);
}

#modalHistoricoDetalhes .detalhes-note-title{
  font-weight:900;
  color: var(--ui-text);
  margin-bottom:6px;
}

#modalHistoricoDetalhes .detalhes-note-body{
  color: var(--ui-text);
  white-space: pre-wrap;
}

#modalHistoricoDetalhes .detalhes-reprovacao{
  margin-top:10px;
  padding-top:10px;
  border-top:1px dashed var(--ui-border);
}

#modalHistoricoDetalhes .detalhes-label{
  display:block;
  font-size:.9rem;
  font-weight:800;
  color: var(--ui-muted);
  margin-bottom:6px;
}

#modalHistoricoDetalhes .detalhes-textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--ui-border);
  border-radius:12px;
  background: var(--ui-surface);
  color: var(--ui-text);
  resize: vertical;
}

#modalHistoricoDetalhes .detalhes-summary-strip{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:14px;
}

#modalHistoricoDetalhes .detalhes-meta-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:7px 11px;
  border-radius:999px;
  border:1px solid var(--ui-border);
  background: var(--ui-surface-2);
  color: var(--ui-text);
  font-size:.82rem;
  line-height:1.2;
}

#modalHistoricoDetalhes .detalhes-meta-badge strong{
  font-weight:900;
}

#modalHistoricoDetalhes .detalhes-meta-badge.is-info{
  color:#0f4aa1;
  border-color:rgba(15,74,161,.18);
  background:rgba(15,74,161,.08);
}

#modalHistoricoDetalhes .detalhes-meta-badge.is-success{
  color:var(--ui-success);
  border-color:rgba(21,128,61,.22);
  background:rgba(21,128,61,.08);
}

#modalHistoricoDetalhes .detalhes-meta-badge.is-warning{
  color:#9a4d00;
  border-color:rgba(180,83,9,.22);
  background:rgba(180,83,9,.08);
}

#modalHistoricoDetalhes .detalhes-help{
  margin-top:6px;
  color: var(--ui-muted);
  font-size:.84rem;
}

#modalHistoricoDetalhes .detalhe-value{
  color: var(--ui-text) !important;
  min-width: 0;
}

#modalHistoricoDetalhes .detalhe-value--placeholder{
  color: var(--ui-muted) !important;
  font-style: italic;
}

#modalHistoricoDetalhes .detalhes-metric-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}

#modalHistoricoDetalhes .detalhes-metric-card{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:12px;
  border:1px solid var(--ui-border);
  border-radius:12px;
  background: var(--ui-surface-2);
}

#modalHistoricoDetalhes .detalhes-metric-label{
  font-size:.76rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.03em;
  color: var(--ui-muted);
}

#modalHistoricoDetalhes .detalhes-metric-value{
  font-size:1.02rem;
  line-height:1.15;
  color: var(--ui-text);
}

#modalHistoricoDetalhes .detalhes-metric-helper{
  font-size:.8rem;
  color: var(--ui-muted);
}

#modalHistoricoDetalhes .detalhes-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  width:100%;
}

#modalHistoricoDetalhes .modal-footer{
  align-items:center;
  gap:10px;
  border-top:1px solid rgba(15, 23, 42, 0.08);
  padding-top:12px;
}

#modalHistoricoDetalhes .detalhes-actions .btn,
#modalHistoricoDetalhes .modal-footer > .btn{
  min-height:36px !important;
  padding:7px 12px !important;
  border-radius:9px !important;
  font-size:.84rem !important;
  line-height:1.05 !important;
  box-shadow:none !important;
}

#modalHistoricoDetalhes .detalhes-actions .btn .btn-ico,
#modalHistoricoDetalhes .modal-footer > .btn .btn-ico{
  width:13px !important;
  height:13px !important;
}

@media (max-width: 860px){
  #modalHistoricoDetalhes .detalhes-grid{
    grid-template-columns:1fr;
  }

  #modalHistoricoDetalhes .detalhe-item{
    grid-template-columns: 120px 1fr;
  }

  #modalHistoricoDetalhes .detalhes-metric-grid{
    grid-template-columns:1fr;
  }
}

/* =========================================================
   Access Config + Logs
   ========================================================= */

.page-hicon[data-icon="access-config"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='4'%20y1='21'%20x2='4'%20y2='14'/%3E%3Cline%20x1='4'%20y1='10'%20x2='4'%20y2='3'/%3E%3Cline%20x1='12'%20y1='21'%20x2='12'%20y2='12'/%3E%3Cline%20x1='12'%20y1='8'%20x2='12'%20y2='3'/%3E%3Cline%20x1='20'%20y1='21'%20x2='20'%20y2='16'/%3E%3Cline%20x1='20'%20y1='12'%20x2='20'%20y2='3'/%3E%3Cline%20x1='1'%20y1='14'%20x2='7'%20y2='14'/%3E%3Cline%20x1='9'%20y1='8'%20x2='15'%20y2='8'/%3E%3Cline%20x1='17'%20y1='16'%20x2='23'%20y2='16'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cline%20x1='4'%20y1='21'%20x2='4'%20y2='14'/%3E%3Cline%20x1='4'%20y1='10'%20x2='4'%20y2='3'/%3E%3Cline%20x1='12'%20y1='21'%20x2='12'%20y2='12'/%3E%3Cline%20x1='12'%20y1='8'%20x2='12'%20y2='3'/%3E%3Cline%20x1='20'%20y1='21'%20x2='20'%20y2='16'/%3E%3Cline%20x1='20'%20y1='12'%20x2='20'%20y2='3'/%3E%3Cline%20x1='1'%20y1='14'%20x2='7'%20y2='14'/%3E%3Cline%20x1='9'%20y1='8'%20x2='15'%20y2='8'/%3E%3Cline%20x1='17'%20y1='16'%20x2='23'%20y2='16'/%3E%3C/svg%3E");
}
.page-hicon[data-icon="approval-config"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='3'%20y='4'%20width='18'%20height='16'%20rx='2'/%3E%3Cline%20x1='7'%20y1='9'%20x2='17'%20y2='9'/%3E%3Cline%20x1='7'%20y1='13'%20x2='17'%20y2='13'/%3E%3Cline%20x1='7'%20y1='17'%20x2='13'%20y2='17'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='3'%20y='4'%20width='18'%20height='16'%20rx='2'/%3E%3Cline%20x1='7'%20y1='9'%20x2='17'%20y2='9'/%3E%3Cline%20x1='7'%20y1='13'%20x2='17'%20y2='13'/%3E%3Cline%20x1='7'%20y1='17'%20x2='13'%20y2='17'/%3E%3C/svg%3E");
}

.page-hicon[data-icon="popups"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015a2%202%200%200%201-2%202H7l-4%204V5a2%202%200%200%201%202-2h14a2%202%200%200%201%202%202z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015a2%202%200%200%201-2%202H7l-4%204V5a2%202%200%200%201%202-2h14a2%202%200%200%201%202%202z'/%3E%3C/svg%3E");
}

.page-hicon[data-icon="logs"]::before{
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M9%202H5a2%202%200%200%200-2%202v16a2%202%200%200%200%202%202h14a2%202%200%200%200%202-2V7l-5-5z'/%3E%3Cpath%20d='M14%202v6h6'/%3E%3Cline%20x1='8'%20y1='13'%20x2='16'%20y2='13'/%3E%3Cline%20x1='8'%20y1='17'%20x2='16'%20y2='17'/%3E%3Cline%20x1='8'%20y1='9'%20x2='10'%20y2='9'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M9%202H5a2%202%200%200%200-2%202v16a2%202%200%200%200%202%202h14a2%202%200%200%200%202-2V7l-5-5z'/%3E%3Cpath%20d='M14%202v6h6'/%3E%3Cline%20x1='8'%20y1='13'%20x2='16'%20y2='13'/%3E%3Cline%20x1='8'%20y1='17'%20x2='16'%20y2='17'/%3E%3Cline%20x1='8'%20y1='9'%20x2='10'%20y2='9'/%3E%3C/svg%3E");
}

#access-config .gestores-container,
#logs .gestores-container{
  overflow: auto;
  border-radius: 14px;
}

.access-config-toolbar{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
  padding: 16px 18px;
  border: 1px solid var(--ui-border);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(246,249,255,0.92));
}

.access-config-actions{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
}

.access-config-toolbar-copy{
  display: grid;
  gap: 4px;
}

.access-config-toolbar-copy strong{
  font-size: 1rem;
  color: var(--ui-text);
}

.access-config-toolbar-copy .page-hint.is-dirty{
  color: #9a3412;
  font-weight: 600;
}

.access-shell{
  display: grid;
  gap: 16px;
  margin-top: 18px;
}

.access-rules-list{
  display: grid;
  gap: 12px;
}

.approval-flows{
  display: grid;
  gap: 18px;
}

.approval-flow-section{
  display: grid;
  gap: 10px;
}

.approval-flow-title{
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  color: var(--ui-text);
}

.approval-flow-grid{
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.access-rule-card{
  border: 1px solid var(--ui-border);
  border-radius: 16px;
  background: var(--ui-surface);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
  overflow: hidden;
}

.access-rule-card.is-dirty{
  border-color: rgba(180, 83, 9, 0.28);
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.12), 0 10px 22px rgba(15, 23, 42, 0.05);
}

.access-rule-summary-head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 12px 16px;
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.access-rule-summary-head::-webkit-details-marker{
  display: none;
}

.access-rule-summary-head > div{
  display: grid;
  gap: 4px;
}

.access-rule-summary-meta{
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.access-rule-summary-head strong{
  font-size: 1rem;
  color: var(--ui-text);
}

.access-rule-summary{
  color: var(--ui-muted);
  font-size: 0.8rem;
  white-space: nowrap;
}

.access-rule-card--compact .access-rule-summary-head{
  padding: 10px 12px;
}

.access-rule-card--compact .access-rule-summary{
  font-size: 0.74rem;
}

.access-rule-dirty-badge{
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(245, 158, 11, 0.14);
  border: 1px solid rgba(180, 83, 9, 0.2);
  color: #9a3412;
  font-size: 0.74rem;
  font-weight: 700;
}

.access-rule-visibility-badge{
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 26px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0, 67, 199, 0.14);
  background: rgba(0, 67, 199, 0.08);
  color: #0038a8;
  font-size: 0.78rem;
  font-weight: 600;
}

.access-rule-card[open] .access-rule-summary-head{
  border-bottom: 1px solid var(--ui-border);
  background: color-mix(in srgb, var(--ui-surface-2) 46%, transparent);
}

.access-rule-panel{
  display: grid;
  gap: 12px;
  padding: 14px 16px 16px;
}

.access-rule-controls{
  display: flex;
  gap: 10px;
  align-items: flex-end;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.access-rule-controls .form-group{
  min-width: 260px;
  margin: 0;
}

.access-rule-buttons{
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.access-rule-sections{
  display: grid;
  gap: 12px;
}

.access-rule-section{
  display: grid;
  gap: 8px;
}

.access-rule-section-title,
.access-action-group-title{
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ui-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.access-action-groups{
  display: grid;
  gap: 10px;
}

.access-action-tabs{
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.access-action-tab{
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid var(--ui-border);
  background: var(--ui-surface-2);
  color: var(--ui-muted);
  font-size: 0.76rem;
  font-weight: 700;
  cursor: pointer;
}

.access-action-tab.is-active{
  border-color: rgba(0, 67, 199, 0.22);
  background: rgba(0, 67, 199, 0.1);
  color: #0038a8;
}

.access-action-panels{
  display: grid;
}

.access-action-group{
  display: none;
  gap: 6px;
  padding: 8px 10px;
  border: 1px solid var(--ui-border);
  border-radius: 12px;
  background: color-mix(in srgb, var(--ui-surface-2) 62%, transparent);
}

.access-action-group.is-active{
  display: grid;
}

.access-action-group.is-disabled{
  opacity: 0.58;
}

.access-readonly-list{
  display: grid;
  gap: 12px;
}

.access-readonly-card{
  display: grid;
  gap: 10px;
  padding: 16px 18px;
  border: 1px solid var(--ui-border);
  border-radius: 16px;
  background: var(--ui-surface);
}

.access-readonly-head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.access-readonly-pages{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.access-pill{
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0, 67, 199, 0.16);
  background: rgba(0, 67, 199, 0.08);
  color: #0038a8;
  font-size: 0.8rem;
  font-weight: 600;
}

.access-pill--muted{
  border-color: var(--ui-border);
  background: var(--ui-surface-2);
  color: var(--ui-muted);
}

.access-config-loading{
  padding: 20px;
  border: 1px dashed var(--ui-border);
  border-radius: 16px;
  background: var(--ui-surface);
}
.approval-row-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:10px;
}

.approval-note-wrap{
  grid-column:1 / -1;
}

.access-role-create{
  margin-top: 10px;
}

.access-role-create label{
  display: block;
  font-size: 0.82rem;
  color: var(--ui-muted);
  margin-bottom: 4px;
}

.access-role-create-row{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.access-role-create-row input{
  min-width: 250px;
  max-width: 360px;
}

.access-role-create-row select{
  min-width: 220px;
  max-width: 280px;
}

.access-config-table-wrap{
  border: 1px solid var(--ui-border);
  background: var(--ui-surface);
}

.access-config-table{
  width: max-content;
  min-width: 1560px;
}

.access-config-table th{
  white-space: nowrap;
  font-size: 0.78rem;
  padding: 7px 8px !important;
}

.access-config-table td{
  font-size: 0.82rem;
  padding: 6px 8px !important;
}

.access-role-cell{
  min-width: 190px;
}

.access-role-cell strong{
  display: block;
  font-size: 0.88rem;
  color: var(--ui-text);
}

.access-role-cell small{
  display: inline-block;
  margin-top: 3px;
  color: var(--ui-muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.72rem;
}

.access-visibility-cell{
  min-width: 240px;
}

.access-visibility-cell select{
  width: 100%;
  min-height: 34px;
  border-radius: 8px;
  border: 1px solid var(--ui-border);
  background: var(--ui-surface);
  color: var(--ui-text);
}

.access-visibility-cell .access-visibility-fixed{
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  border-radius: 7px;
  border: 1px solid var(--ui-border);
  background: var(--ui-surface-2);
  color: var(--ui-text);
  font-size: 0.82rem;
}

.access-visibility-cell small{
  display: block;
  margin-top: 4px;
  color: var(--ui-muted);
  font-size: 0.73rem;
}

.access-check-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 6px;
}

.access-check-grid--pages{
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.access-check-grid--actions{
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.access-check-item{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 7px;
  border: 1px solid var(--ui-border);
  border-radius: 8px;
  background: var(--ui-surface-2);
  color: var(--ui-text);
  min-height: 28px;
  cursor: pointer;
  font-size: 0.75rem;
  transition: border-color .14s ease, background .14s ease, box-shadow .14s ease;
}

.access-check-item--compact{
  border-radius: 7px;
  padding: 3px 6px;
}

.access-check-item input[type="checkbox"]{
  width: 12px;
  height: 12px;
  accent-color: #0043c7;
}

.access-check-item:has(input:checked){
  border-color: rgba(0, 67, 199, 0.35);
  background: rgba(0, 67, 199, 0.08);
  box-shadow: 0 0 0 2px rgba(0, 67, 199, 0.07);
}

.access-check-item:has(input:disabled){
  opacity: 0.72;
  cursor: default;
}

.logs-table{
  width: max-content;
  min-width: 1260px;
  font-size: 9px;
}

.logs-toolbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-bottom:14px;
}

.logs-toolbar .historico-control{
  min-width: 180px;
}

.logs-toolbar .historico-control--search{
  min-width: 320px;
}

.logs-meta{
  margin-left:auto;
}

.logs-row{
  cursor:pointer;
}

.logs-table td,
.logs-table th{
  white-space: nowrap;
  font-size: 9px !important;
  line-height: 1.2;
  padding: 4px 6px !important;
}

.logs-details-cell{
  max-width: 560px;
  overflow: hidden;
  text-overflow: ellipsis;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 9px !important;
}

.logs-row:hover{
  background: rgba(0, 67, 199, 0.04) !important;
}

#modalLogsDetalhes .detalhes-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:14px;
}

#modalLogsDetalhes .detalhes-section{
  background: var(--ui-surface) !important;
  border:1px solid var(--ui-border) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
}

#modalLogsDetalhes .detalhes-section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-bottom:10px;
  margin-bottom:10px;
  border-bottom:1px solid var(--ui-border);
}

#modalLogsDetalhes .detalhes-section-header h4{
  margin:0;
}

#modalLogsDetalhes .detalhes-textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--ui-border);
  border-radius:12px;
  background: var(--ui-surface);
  color: var(--ui-text);
  resize: vertical;
  min-height: 260px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .83rem;
}

@media (max-width: 980px){
  .logs-toolbar{
    align-items:stretch;
  }

  .logs-meta{
    margin-left:0;
  }

  .logs-toolbar .historico-control,
  .logs-toolbar .historico-control--search{
    min-width: 0;
    width: 100%;
  }

  #modalLogsDetalhes .detalhes-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 980px){
  .access-config-toolbar{
    flex-direction: column;
    align-items: stretch;
  }
  .access-config-actions{
    justify-content: flex-start;
  }
  .access-rule-summary-head{
    flex-direction: column;
    align-items: flex-start;
  }
  .access-rule-controls{
    justify-content: stretch;
  }
  .access-rule-controls .form-group{
    min-width: 100%;
  }
  .access-role-create-row input{
    min-width: 0;
    width: 100%;
    max-width: none;
  }
  .access-role-create-row select{
    min-width: 0;
    width: 100%;
    max-width: none;
  }
  .approval-flow-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px){
  .approval-flow-grid{
    grid-template-columns: 1fr;
  }
}

/* Mobile base (Fase 1): Painel focado em Propostas */
@media (max-width: 980px){
  #historico .historico-mobile-cards{ display: none; }

  html[data-view="mobile"][data-mobile-scope="propostas"] .admin-sidebar{
    position: sticky;
    top: 0;
    z-index: 120;
    height: auto;
    max-height: none;
    padding: 6px 10px 8px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .logo.logo-only{
    display: none;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .sidebar-logo{
    width: auto;
    height: 40px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .admin-nav{
    padding: 0;
    margin: 0 0 4px;
    overflow: visible;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .admin-nav .nav-item{
    display: none !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .admin-nav .nav-item[href="#historico"]{
    display: flex !important;
    justify-content: center;
    margin: 0;
    border-radius: 10px;
    font-size: 12px;
    padding: 7px 10px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .sidebar-actions{
    padding: 0;
    border-top: none;
    background: transparent;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .sidebar-actions .sidebar-user{
    grid-column: 1 / -1;
    font-size: 10px;
    line-height: 1.15;
    margin-bottom: 0;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .sidebar-actions .btn{
    margin-top: 0;
    min-height: 30px;
    font-size: 9px;
    padding: 3px 5px;
    gap: 5px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .sidebar-actions .btn .btn-ico{
    width: 10px;
    height: 10px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .admin-content{
    margin-left: 0 !important;
    width: 100% !important;
    min-height: auto;
    padding: 12px !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] .tab-content{
    display: none !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico.tab-content{
    display: block !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .page-header{
    padding: 12px !important;
    margin-bottom: 12px !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .page-header h2{
    font-size: 1.2rem;
    margin-bottom: 4px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .gestores-container{
    display: none !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico #historicoBulkBar{
    display: none !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-control{
    width: 100% !important;
    min-width: 0 !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-control--search{
    flex: 1 1 100%;
    min-width: 0 !important;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-cards{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 10px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card{
    border: 1px solid var(--ui-border);
    border-radius: 12px;
    background: var(--ui-surface);
    padding: 10px;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
    cursor: pointer;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card.is-archived{
    opacity: .62;
    filter: grayscale(1);
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card:focus{
    outline: 2px solid rgba(0, 67, 199, 0.35);
    outline-offset: 2px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-head{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-id{
    font-weight: 800;
    color: var(--ui-text);
    font-size: 0.92rem;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-date{
    font-size: 0.76rem;
    color: var(--ui-muted);
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-cliente{
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--ui-text);
    margin-bottom: 2px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-emp{
    font-size: 0.86rem;
    color: var(--ui-muted);
    margin-bottom: 6px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-meta{
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 8px;
    align-items: center;
    font-size: 0.77rem;
    color: var(--ui-muted);
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-meta > span{
    display: inline-flex;
    align-items: center;
    min-height: 24px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-status{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    margin-top: 6px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-status-item{
    display: grid;
    gap: 4px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-status-label{
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--ui-muted);
    text-transform: uppercase;
    letter-spacing: .02em;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card .empreendimento-status{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 0;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 0.76rem;
    font-weight: 700;
    border: 1px solid transparent;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card .empreendimento-status--status::before{
    content: "●";
    font-size: 0.65rem;
    line-height: 1;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card .status-aprovado{
    color: #166534;
    background: rgba(22, 101, 52, 0.12);
    border-color: rgba(22, 101, 52, 0.2);
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card .status-reprovado{
    color: #b91c1c;
    background: rgba(185, 28, 28, 0.1);
    border-color: rgba(185, 28, 28, 0.2);
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card .status-analise{
    color: #9a3412;
    background: rgba(154, 52, 18, 0.1);
    border-color: rgba(154, 52, 18, 0.2);
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-vgv{
    font-size: 0.84rem;
    color: var(--ui-muted);
    margin-bottom: 8px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-vgv strong{
    color: var(--ui-text);
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-actions{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-card-actions .btn{
    width: 100% !important;
    min-height: 34px;
    font-size: 0.74rem !important;
    padding: 6px 8px !important;
    border-radius: 9px !important;
    justify-content: center;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #historico .historico-mobile-empty{
    border: 1px dashed var(--ui-border);
    border-radius: 12px;
    background: var(--ui-surface);
    color: var(--ui-muted);
    padding: 16px 14px;
    text-align: center;
    font-size: 0.86rem;
  }

  html[data-view="mobile"][data-mobile-scope="propostas"] #modal-detalhes .modal-content.modal-detalhes-content{
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    max-height: 100vh !important;
    margin: 0 !important;
    border-radius: 0 !important;
    padding: 12px !important;
  }

html[data-view="mobile"][data-mobile-scope="propostas"] #modal-detalhes .detalhes-grid{
    grid-template-columns: 1fr !important;
  }
}

/* Etapa 2 - acabamento dos botões do catálogo no Django */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:36px;
  border-radius:10px;
  border:1px solid transparent;
  box-shadow:0 6px 14px rgba(15, 23, 42, 0.08);
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease, color .16s ease;
}

.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 18px rgba(15, 23, 42, 0.12);
}

.btn:active{
  transform:translateY(0);
  box-shadow:0 5px 10px rgba(15, 23, 42, 0.10);
}

.btn-primary{
  background:linear-gradient(180deg, #0b57d0 0%, #0043c7 100%);
  border-color:#003aa9;
}

.btn-secondary{
  background:linear-gradient(180deg, #ffffff 0%, #eef3f8 100%);
  color:#16324f;
  border-color:#cfd9e7;
}

.btn-secondary:hover{
  background:linear-gradient(180deg, #ffffff 0%, #e5edf6 100%);
  border-color:#b8c7da;
}

.btn-secondary-alt{
  background:linear-gradient(180deg, #dde6f1 0%, #cad6e6 100%);
  color:#10253d;
  border-color:#bccadd;
}

.btn-success{
  background:linear-gradient(180deg, #2fca79 0%, #22b464 100%);
  border-color:#1f9d58;
}

.btn-warning{
  background:linear-gradient(180deg, #f8b43f 0%, #eb9e1f 100%);
  border-color:#d48b16;
}

.btn-danger{
  background:linear-gradient(180deg, #ef6b5b 0%, #dc4a3b 100%);
  border-color:#c63d30;
}

.btn .btn-ico{
  width:14px;
  height:14px;
}

.btn-action-inline{
  min-height:32px;
  padding:6px 11px;
  border-radius:9px;
  font-size:.82rem;
  box-shadow:none;
}

.btn-action-inline:hover{
  box-shadow:0 6px 12px rgba(15, 23, 42, 0.10);
}

.tabela-gestores td .btn,
.empreendimento-row-actions .btn{
  margin-right:6px;
}

.tabela-gestores td .btn:last-child,
.empreendimento-row-actions .btn:last-child{
  margin-right:0;
}
