/* ===== THEME UNIFIED CSS - ARCHIVO BASE UNIFICADO ===== */
/* Migrado desde estilos.css - Contiene todos los estilos base del proyecto */
/* Índice de secciones:
   1) Tokens neutrales
   2) Navbar y header
   3) Contenedor principal y tarjetas
   4) Botones
   5) Formularios (bloque fd-*) y utilidades
   6) Buscadores unificados
   7) Breadcrumb y contenedor de módulo
   8) Sidebar y chips
   9) Tablas y contenedores
   10) Componentes especiales (AI, overlays, modales)
*/

/* Tokens neutrales y jerárquicos (no cambian con el tema) */
:root{
  --border-radius: 8px;
  --border-radius-lg: 12px;
  --transition-normal: all 0.3s ease;
  --transition-fast: all 0.2s ease;
  --editor-container-max: min(1800px, 98vw);
  /* Jerarquía BaseDatos */
  --familia-color: #22c55e;
  --capitulo-color: #f97316;
  --subcapitulo-color: #3b82f6;
  --partida-color: #9ca3af;
}

/* Base HTML y Body */
html, body{height:100%} 
body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,Segoe UI,Arial;margin:0}

/* Navbar (se oculta en login) */
.navbar{background:var(--panel)!important;padding:10px 0;box-shadow:0 0 15px var(--shadow);width:100%;position:fixed;top:0;left:0;z-index:1000}
.navbar-brand{margin-left:20px;color:var(--text);font-weight:700;transition:background-color .15s ease,color .15s ease;text-decoration:none;border-radius:6px;padding:4px 8px}
/* Hover solo en el texto de DomedGest (no afecta al logo) */
.navbar-brand span{padding:0;border-radius:0;transition:color .15s ease, text-shadow .15s ease}
/* Sombreado sólo del texto en hover (sin fondo) */
.navbar-brand:hover span{background:transparent!important;color:var(--muted)!important;text-shadow:0 1px 2px var(--shadow)}
.navbar-brand img{height:40px;margin-right:10px;display:block}
/* Regla fija (no modificar salvo petición explícita):
   Hover de enlaces del navbar ("Hola, usuario" y "Salir") SIN recuadro de fondo.
   - Fondo: transparente
   - Texto: var(--text)
   - Sin subrayado
   - Transición suave */
.navbar-nav .nav-link{color:var(--text)!important;border-radius:6px;transition:background-color .15s ease,color .15s ease}
.navbar-nav .nav-link:hover{background:transparent!important;color:var(--text)!important;text-decoration:none}

/* Contenedor autenticado */
/* =============================================================
   Contenedor principal (wrapper de página)
   Problema que soluciona: unifica sombra base y iluminación blanca en hover
   Ubicación: layout global, referencias en módulos Clientes, Proveedores, BaseDatos
   ============================================================= */
.container.main-container{background:var(--panel);padding:20px;border-radius:var(--border-radius);border:1px solid var(--line);box-shadow:var(--shadow);transition:none;width:100%;max-width:1160px;margin:80px auto 20px}
.panel-inner{background:var(--card);border-radius:var(--border-radius)}
h1,h2,h3,h4,h5{color:var(--text)} 
.text-muted{color:var(--muted)!important}

/* Tarjetas menú */
.card{background:var(--card);border:1px solid var(--line);color:var(--text);border-radius:var(--border-radius);box-shadow:var(--shadow)}
.card-title{color:var(--text)} 
.card-text{color:var(--muted)}

/* Botones */
.btn-primary,.btn-dmd{background:var(--primary);border-color:var(--primary);color:#fff;border-radius:var(--border-radius)}
.btn-primary:hover,.btn-dmd:hover{background:var(--primary-hover);border-color:var(--primary-hover)}

/* Formularios */
/* Formularios: usar bloque unificado fd-*; se elimina regla básica duplicada */
.form-label{color:var(--text)}

/* =============================================================
   Formularios: utilidades comunes
   Problema que soluciona: elimina inline en roles y formularios varios
   Ubicación: templates/personal/roles.html, formularios de Proveedores, Clientes
   ============================================================= */
.form-check { display:flex; align-items:center; gap:.5rem; margin:.35rem 0; }
.form-check-input { accent-color: var(--primary); }
.info-text { color: var(--text-secondary); font-size: .9rem; }
.bd-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.grid-stack { display:flex; flex-direction:column; gap:8px; }
.bd-col-span-2 { grid-column: span 2; }
.bd-mt-16 { margin-top: 16px; }

/* Login */
.login-box{background:var(--panel);padding:20px;border-radius:12px;width:360px;text-align:center}
.logo-container{display:flex;justify-content:center;margin-bottom:16px}
.logo-container img{max-width:220px;height:auto}

/* Sidebar */
#sidebar{backdrop-filter:saturate(120%) blur(0px)}
/* Regla legacy ajustada: que no anule el estilo de los nuevos botones de pin (.btn-pin.dg-sidebar-pin) */
#sidebar .pin-btn{background:transparent;border:none;color:inherit;padding:4px 6px;display:inline-flex;align-items:center;gap:6px}
/* En el sidebar v3, los botones .btn-pin llevan borde y contraste propio. */

/* Chip admin con sombra inversa */
/* TRAE:START dg-chip-admin */
.chip-admin {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 12px;
    color: var(--text);
    text-decoration: none;
    transition: transform .15s ease, box-shadow .15s ease;
    font-weight: 500;
    font-size: 0.9em;
    cursor: pointer;
    box-shadow: 0 4px 15px var(--shadow);
    margin-right: 20px;
}

.chip-admin:hover {
    background: var(--card);
    color: var(--text);
    text-decoration: none;
    transform: translateY(0px);
    box-shadow: none;
}
/* TRAE:END dg-chip-admin */

/* TRAE:START dg-chip-admin-unified */
.dg-chip-admin-unified {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 12px;
    color: var(--text);
    text-decoration: none;
    transition: transform .15s ease, box-shadow .15s ease;
    font-weight: 500;
    font-size: 0.9em;
    cursor: pointer;
    box-shadow: 0 4px 15px var(--shadow);
    margin-right: 20px;
}

.dg-chip-admin-unified:hover {
    background: var(--card);
    color: var(--text);
    text-decoration: none;
    transform: translateY(0px);
    box-shadow: none;
}
/* TRAE:END dg-chip-admin-unified */

/* TRAE:START dg-navbar-user */
/* Estilos para elementos de navegación de usuario */
.navbar .hola-text, 
.navbar .logout-link { 
    padding: 8px 12px; 
    display: inline-block; 
    transition: text-shadow .15s ease;
    text-decoration: none !important;
}

.navbar .hola-text:hover,
.navbar .logout-link:hover {
    text-shadow: 0 0 8px rgba(0,0,0,.6);
    text-decoration: none !important;
}
/* TRAE:END dg-navbar-user */

/* Sidebar hover más visible */
#sidebar .d-flex:hover{ background: rgba(255,255,255,.09)!important; }

#sidebar .btn.btn-sm{padding:2px 6px;font-size:12px}

/* TRAE:START dg-menu-card */
.menu-card{ transition: transform .15s ease, box-shadow .15s ease; cursor: pointer; background: var(--card); color: var(--text); border: 1px solid var(--line); }
.menu-card:hover{ transform: translateY(-3px); box-shadow: 0 4px 15px var(--shadow); }
/* TRAE:END dg-menu-card */

/* Favoritos: estrella amarilla */
.pin-btn{background:transparent !important;border:none !important;color:inherit !important;padding:4px;position:absolute;top:8px;right:8px;}

/* Scroll fix global */
html, body{ overflow-x: hidden; }
.container, .panel-inner, #menu-grid{ max-width:100%; }

.menu-card.dragging{ opacity:.85; transform: scale(.98); transition: transform .08s ease; }
/* TRAE:START dg-menu-card-placeholder */
.menu-card.placeholder{ border:1px dashed var(--line); height:100%; }
/* TRAE:END dg-menu-card-placeholder */

/* TRAE:START dg-sidebar-pins */
/* Estilos para botones de pin en sidebar */
.btn-pin .star{color:#bfc5cf !important;pointer-events:none;}
.btn-pin.pinned .star{color:#f5d200 !important;}
.pin-btn .star{color:#bfc5cf !important;pointer-events:none;}
.pin-btn.pinned .star{color:#f5d200 !important;}
/* TRAE:END dg-sidebar-pins */

/* ---- Modal estilo DOMED (oscuro) ---- */
.modal-content.dmd-panel{
  background: var(--panel);
  color: var(--text);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 12px 30px var(--shadow);
  border-radius: 12px;
}
.dmd-panel .modal-header,
.dmd-panel .modal-footer{
  border-color: rgba(255,255,255,.12);
}
.dmd-panel .btn-close{
  filter: invert(1);
  opacity: .7;
}
.dmd-panel .btn-close:hover{ opacity: 1; }
.modal-backdrop.show{ opacity: .55; }

/* --- Tema oscuro global: ajustes adicionales --- */

/* Contenedor principal: asegurar posición relativa para ubicar elementos internos (ej: estado de conexión) */
.container.main-container{ position: relative; }

/* Dropdowns en navbar y globales */
/* TRAE:START dg-navbar-dropdown */
.navbar .dropdown-menu{ background: var(--panel) !important; border: 1px solid var(--line) !important; box-shadow: 0 12px 30px var(--shadow) !important; }
.navbar .dropdown-item{ color: var(--text) !important; }
.navbar .dropdown-item:hover{ background: var(--overlay-hover) !important; }
/* TRAE:END dg-navbar-dropdown */

/* TRAE:START dg-dynamic-logo */
/* TRAE: Logo dinámico por tema */
.logo-dinamico{ display: none; }
html[data-theme="dark"] .logo-dinamico.logo-oscuro{ display: inline-block; }
html[data-theme="light"] .logo-dinamico.logo-claro{ display: inline-block; }
html[data-theme="clear"] .logo-dinamico.logo-claro{ display: inline-block; }
/* Siempre mostrar fallback si existe */
.logo-dinamico.logo-fallback{ display: inline-block; }
html.dark .logo-oscuro, [data-theme="dark"] .logo-oscuro{ display:inline-block; }
html.light .logo-claro, [data-theme="light"] .logo-claro{ display:inline-block; }
.logo-fallback{ display:inline-block; }
/* TRAE:END dg-dynamic-logo */

/* TRAE:START dg-admin-appearance-files */
.file-input-wrapper input[type="file"]{ display:none; }
/* TRAE: eliminado bloque duplicado; ver estilos consolidados más abajo (sección Apariencia - file inputs) */
/* TRAE:END dg-admin-appearance-files */

/* Tarjetas específicas de dashboard y estadísticas */
.dashboard-card, .stat-card{ background: var(--card); border: 1px solid var(--line); color: var(--text); box-shadow: var(--shadow); border-radius: var(--border-radius); }

/* Botones adicionales coherentes con la paleta */
.btn-success{ background: #2ecc71 !important; border-color: #27ae60 !important; color: #fff !important; }
.btn-success:hover{ background: #27ae60 !important; border-color: #1f8e4d !important; }
.btn-warning{ background: #f5a623 !important; border-color: #d48806 !important; color: #fff !important; }
.btn-warning:hover{ background: #d48806 !important; border-color: #b06f04 !important; }

/* Indicador de conexión en tiempo real: estilos globales */
.connection-status, #connectionStatus{ position: absolute; top: 10px; right: 10px; background: rgba(0,0,0,.35); border: 1px solid rgba(255,255,255,.15); color: var(--text); padding: 6px 10px; border-radius: 10px; display: inline-flex; align-items: center; gap: 8px; z-index: 2; }
.connection-status .status-text{ font-size: 0.9rem; color: var(--muted); }
.real-time-indicator{ width: 10px; height: 10px; border-radius: 50%; background: #ff5252; box-shadow: 0 0 8px #ff5252; transition: background .2s ease, box-shadow .2s ease; }
.connection-ok .real-time-indicator{ background: #4caf50; box-shadow: 0 0 8px #4caf50; }

/* (Eliminado) Overrides agresivos que ocultaban #sidebar/#btn-sidebar/#sidebar-overlay.
   Estos IDs también son usados por sidebar.js v3 para montar sus elementos, y deben
   permanecer visibles. Las plantillas duplicadas han sido ajustadas para evitar conflictos. */
.connection-warn .real-time-indicator{ background: #f5a623; box-shadow: 0 0 8px #f5a623; }

/* Ajustes responsivos: evitar solapamiento con la barra superior en pantallas pequeñas */
@media (max-width: 768px){
  .connection-status, #connectionStatus{ position: static; display: flex; margin-top: 8px; }
  .container.main-container{ padding-top: 34px; }
}

/* Colores del indicador en tiempo real según estado actual */
.connection-status.connected .real-time-indicator{ background: #4caf50 !important; box-shadow: 0 0 8px #4caf50 !important; }
.connection-status.disconnected .real-time-indicator{ background: #ff5252 !important; box-shadow: 0 0 8px #ff5252 !important; }
.connection-status.warning .real-time-indicator{ background: #f5a623 !important; box-shadow: 0 0 8px #f5a623 !important; }

/* Estadísticas: colores coherentes con tema oscuro */
.stat-number{ color: var(--text) !important; }
.stat-label{ color: var(--muted) !important; }

/* Dashboard: aplicar paleta oscura global sobre fondo y texto */
.dashboard-container{ background: var(--bg) !important; color: var(--text) !important; }
.chart-title{ color: var(--text) !important; }

/* ---- Bloque de resumen (DOMED2022 y general) ---- */
.summary-box{
  background: var(--panel) !important;
  color: var(--text) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 12px !important;
}
.summary-box label{
  color: var(--text) !important;
}
.summary-box input{
  background: var(--bg) !important;
  color: var(--text) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
}

/* --- Ancho adaptativo para el editor de presupuestos --- */
/* Preferencias de márgenes laterales por usuario */
body.presupuestos-editor{ --editor-side-margin: 0px; }

body.presupuestos-editor .container.main-container{
  max-width: min(var(--editor-container-max), calc(98vw - 2*var(--editor-side-margin))) !important;
}

/* Layout de editor con márgenes simétricos (solo en páginas con resizer) */
body.dmd-resizable .container.main-container{
  max-width: min(var(--editor-container-max, 1200px), calc(98vw - 2*var(--editor-side-margin, 0px)));
  /* Mantener separación con la navbar fija, sin exceso */
  /* Editor: respetar separación con navbar fija usando token neutral */
  margin: var(--topbar-height, 56px) auto 16px;
}

/* Asas laterales para redimensionar el editor */
body.presupuestos-editor .editor-resizer{ position:absolute; top:0; bottom:0; width:14px; z-index:5; cursor: ew-resize; opacity:0; transition: opacity .15s ease; }
body.presupuestos-editor .editor-resizer:hover{ opacity:.35; background: rgba(255,255,255,.06); }
body.presupuestos-editor .editor-resizer.left{ left:-7px; }
body.presupuestos-editor .editor-resizer.right{ right:-7px; }

body.dmd-resizable .bd-container {
    max-width: min(var(--editor-container-max, 1440px), calc(98vw - 2*var(--editor-side-margin, 0px))) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    /* El espaciado superior se aplica al wrapper (main-container o container-fluid) desde base_with_js.js para evitar doble margen */
    margin-top: 0 !important;
    margin-bottom: 16px !important;
}

/* =============================================================
   Presupuestos: plantilla PDF A4 v2
   Problema que soluciona: elimina estilos inline de la plantilla PDF
   Ubicación: templates/presupuestos/pdf/domed_A4_v2.html
   ============================================================= */
@page { size: A4; margin: 16mm 12mm 18mm 12mm; @bottom-right { content: "Página " counter(page) " de " counter(pages); font-size: 10px; color: var(--muted); } }
body.pdf-a4 { font-family: Arial, Helvetica, sans-serif; color: var(--text); font-size: 12px; }
.pdf-a4 table { width: 100%; border-collapse: collapse; }
.pdf-a4 th, .pdf-a4 td { padding: 6px; border-bottom: 1px solid var(--table-border, var(--line)); vertical-align: top; }
.pdf-a4 th { background: var(--table-bg, var(--card)); font-weight: 600; text-align: left; }
.pdf-a4 .text-right { text-align: right; }
.pdf-a4 .mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; color: var(--text); }
.pdf-a4 .lvl0 { font-weight: 700; background: var(--table-stripe-bg, var(--surface)); }
.pdf-a4 .lvl1 { font-weight: 700; background: var(--surface); }
.pdf-a4 .lvl-sub { font-weight: 700; background: var(--bg-secondary); }
.pdf-a4 thead { display: table-header-group; }
/* Utilidades de anchura para columnas del PDF */
.pdf-a4 .bd-w-14 { width: 14%; }
.pdf-a4 .bd-w-8  { width: 8%; }
.pdf-a4 .bd-w-10 { width: 10%; }
.pdf-a4 .bd-w-12 { width: 12%; }

/* =============================================================
   Presupuestos: plantilla PDF A4 Pro
   Problema que soluciona: elimina estilos inline y variables ad-hoc (c1/c2)
   Ubicación: templates/presupuestos/pdf/domed_A4_pro.html
   ============================================================= */
body.pdf-a4-pro { font-family: Arial, Helvetica, sans-serif; color: var(--text); font-size: 12px; }
.pdf-a4-pro .brand { display:flex; justify-content:space-between; align-items:center; border-bottom: 2px solid var(--primary); padding-bottom: 8px; margin-bottom: 12px; }
.pdf-a4-pro .brand .left { display:flex; align-items:center; gap:12px; }
.pdf-a4-pro .brand .title { font-size: 22px; font-weight: 700; color: var(--primary); letter-spacing: .2px; }
.pdf-a4-pro .brand small, .pdf-a4-pro .muted { color: var(--text-secondary); }
.pdf-a4-pro .logo { height: 40px; }
.pdf-a4-pro .grid { display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pdf-a4-pro .card { border:1px solid var(--line); border-radius:8px; padding:10px; }
.pdf-a4-pro .kpi { font-size: 22px; font-weight: 700; text-align:right; }
.pdf-a4-pro .kpi small { display:block; font-size: 10px; color: var(--text-secondary); }
.pdf-a4-pro table { width:100%; border-collapse: collapse; }
.pdf-a4-pro th, .pdf-a4-pro td { padding:6px; border-bottom: 1px solid var(--table-border, var(--line)); vertical-align: top; }
.pdf-a4-pro th { background: var(--table-bg, var(--card)); font-weight:600; text-align:left; }
.pdf-a4-pro .text-right { text-align: right; }
.pdf-a4-pro .mono  { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; color: var(--text); }
.pdf-a4-pro .lvl0 { font-weight:700; background: var(--table-stripe-bg, var(--surface)); }
.pdf-a4-pro .lvl1 { font-weight:700; background: var(--surface); }
.pdf-a4-pro .lvl-sub { font-weight:700; background: var(--bg-secondary); }
.pdf-a4-pro thead { display: table-header-group; }
.pdf-a4-pro .cond-break { break-before: page; }
.pdf-a4-pro .detail-break { break-before: page; }
.bd-mb-4 { margin-bottom: 4px; }

/* ===== Ajuste título principal de páginas de administración ===== */
.admin-page-title,
h2.admin-page-title {
  color: var(--text-primary) !important;
  font-size: 1.75rem !important;
  font-weight: 800 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  margin: 0 0 2.5rem 0 !important; /* más separación bajo la línea */
  padding-bottom: 1rem !important; /* línea un poco más separada del texto */
  border-bottom: 2px solid #ffffff !important; /* por defecto, blanco (oscuro) */
  width: 100% !important;
  text-align: center !important;
}
.admin-page-title i { color: var(--primary) !important; }

/* Ajuste de subrayado del título en modo claro: negro en lugar de blanco */
html[data-theme="light"] .admin-page-title,
html.light .admin-page-title,
:root[data-theme="light"] .admin-page-title,
html[data-theme="light"] h2.admin-page-title,
html.light h2.admin-page-title,
:root[data-theme="light"] h2.admin-page-title {
  border-bottom: 2px solid #000000 !important;
}

/* Dashboard Administración: línea debajo del header en modo CLARO debe ser negra */
html[data-theme="light"] .admin-header,
html.light .admin-header,
:root[data-theme="light"] .admin-header {
  border-bottom: 2px solid #000000 !important;
}

/* Dashboard: icono del encabezado en modo CLARO debe ser negro */
html[data-theme="light"] .admin-header-icon,
html.light .admin-header-icon,
:root[data-theme="light"] .admin-header-icon {
  color: #000000 !important;
}

/* Estilo base compartido: título tipo Usuarios (.bd-title) */
.bd-title {
  font-size: 1.4rem; /* antes 1.6rem: texto ligeramente más pequeño */
  font-weight: 700;
  margin: 0 0 .75rem;
  padding-bottom: .25rem;
  display: flex;
  align-items: center; /* centra verticalmente icono y texto */
  gap: .35rem; /* un poco menos espacio entre icono y texto */
  border-bottom: 2px solid var(--line);
  justify-content: center; /* centrar todos los títulos por norma */
  text-align: center;
  color: var(--text) !important; /* texto blanco en oscuro y negro en claro para todos los módulos */
  /* Línea de punta a punta dentro del contenedor */
  width: 100%;
  box-sizing: border-box;
}

/* Variante: centrar el título en la página */
.bd-title-center { 
  justify-content: center; 
  text-align: center; 
}

/* Variante: más margen inferior debajo del título */
.bd-title-spaced { 
  margin-bottom: 1.25rem; 
}

/* Ajuste del icono dentro del título para que no se vea desproporcionado */
.bd-title i,
.bd-title .fas,
.bd-title .fa {
  font-size: 1.15rem; /* icono más pequeño */
  line-height: 1; 
  vertical-align: middle;
  display: inline-flex;
  align-items: center;
}

/* En modo CLARO, el icono del título debe verse en negro como el texto */
html[data-theme="light"] .bd-title i,
html.light .bd-title i,
:root[data-theme="light"] .bd-title i {
  color: #111111 !important;
}

/* En modo CLEAR, el icono del título también debe verse en negro */
html[data-theme="clear"] .bd-title i,
html.clear .bd-title i,
:root[data-theme="clear"] .bd-title i {
  color: #111111 !important;
}

/* Contadores (Administración): forzar modo CLARO con fondo blanco y texto oscuro */
html[data-theme="light"] .bd-breadcrumb,
html.light .bd-breadcrumb,
:root[data-theme="light"] .bd-breadcrumb {
  background: #ffffff !important;
  border-color: #e5e7eb !important; /* gris claro */
}
/* Tema oscuro: clonar el fondo del breadcrumb al usado en Usuarios (bg primary) */
html[data-theme="dark"] .bd-breadcrumb,
html.dark .bd-breadcrumb,
:root[data-theme="dark"] .bd-breadcrumb {
  background: var(--bg-primary) !important; /* #2d2d2d */
  border-color: var(--border) !important;   /* #404040 */
  /* Breadcrumbs: sombreado visible en oscuro */
  box-shadow: 0 3px 10px var(--shadow) !important;
}
/* Breadcrumbs (oscuro): Inicio blanco y al pasar (hover) azul */
/* Enlaces del breadcrumb: azul por defecto y azul más intenso en hover */
html[data-theme="dark"] .bd-breadcrumb a,
html[data-theme="light"] .bd-breadcrumb a { color: var(--primary) !important; }
html[data-theme="dark"] .bd-breadcrumb a:hover,
html[data-theme="light"] .bd-breadcrumb a:hover { color: var(--primary-hover) !important; }
/* Ajustes de usabilidad: separar iconos y poner texto en negrita en breadcrumb */
.bd-breadcrumb a {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem; /* separación icono-texto */
  font-weight: 700; /* negrita en enlaces */
  text-decoration: none;
}
.bd-breadcrumb-current {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-weight: 700; /* negrita en el elemento actual */
}
.bd-breadcrumb i { margin-right: 0; line-height: 1; }
html[data-theme="light"] .bd-breadcrumb-current,
html.light .bd-breadcrumb-current,
:root[data-theme="light"] .bd-breadcrumb-current,
html[data-theme="dark"] .bd-breadcrumb-current,
html.dark .bd-breadcrumb-current,
:root[data-theme="dark"] .bd-breadcrumb-current { color: var(--text) !important; }
html[data-theme="light"] .bd-breadcrumb-separator,
html.light .bd-breadcrumb-separator,
:root[data-theme="light"] .bd-breadcrumb-separator {
  color: #6b7280 !important; /* gris medio */
}

/* Título principal de Contadores */
html[data-theme="light"] .page-title[data-page-title],
html.light .page-title[data-page-title],
:root[data-theme="light"] .page-title[data-page-title] {
  color: #111111 !important;
}

/* =============================================================
   Proveedores: Listado – clonado del módulo Clientes
   Problema que soluciona: centraliza tarjetas, meta y buscador; elimina CSS inline del template
   Ubicación: templates/proveedores/proveedor_list.html
   ============================================================= */
.bd-actions { display:flex; gap:1rem; align-items:center; justify-content:center; margin:1.5rem 0; flex-wrap:wrap; }
.bd-btn { padding:.75rem 1.5rem; border-radius:8px; font-weight:600; cursor:pointer; transition: all .3s ease; text-decoration:none; display:inline-flex; align-items:center; gap:.5rem; }
.bd-btn:focus-visible { outline: none; box-shadow: 0 0 0 .18rem var(--fd-focus-shadow); border-color: var(--fd-focus-border); }
.bd-btn:active { transform: translateY(1px) scale(.98); box-shadow: inset 0 2px 6px rgba(0,0,0,.15), 0 2px 10px var(--shadow-sm); }
.bd-btn-primary { background: var(--primary); color:white; border:1px solid var(--primary); }
.bd-btn-primary:hover { background: var(--primary-hover); transform: translateY(-2px); }
.bd-btn-primary:active { background: var(--primary-hover); }
.bd-btn-secondary { background: var(--card); color: var(--muted); border:1px solid var(--line); }
.bd-btn-secondary:hover { background: var(--panel); color: var(--text); border-color: var(--primary); }
.bd-btn-secondary:active { background: var(--overlay-hover); }
.bd-search-container { margin-bottom:1.5rem; padding-bottom:.75rem; padding-top:.75rem; border-bottom:1px solid var(--line); }
.bd-search-wrapper { display:flex; max-width:520px; margin:0 auto; position:relative; align-items:center; gap:.5rem; }
.bd-sort-indicator { text-align:left; color: var(--muted); font-size:.9rem; margin-bottom:.5rem; }
.bd-pagination { margin-top:0; padding-top:1rem; border-top:none; display:flex; flex-direction:column; gap:1rem; align-items:center; }
.bd-pagination-info { text-align:center; }
.bd-pagination-text { color: var(--text-secondary); font-size:.9rem; font-weight:500; }
.bd-pagination-controls { display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; justify-content:center; }
.bd-pagination .bd-btn { width:36px; height:36px; min-width:36px; padding:0; border-radius:10px; display:inline-flex; align-items:center; justify-content:center; }
.bd-pagination .bd-btn.bd-btn-secondary { background: var(--card); color: var(--muted); border:1px solid var(--line); }
.bd-pagination .bd-btn.bd-btn-secondary:hover { background: var(--panel); color: var(--text); border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow); }
.cliente-card { position:relative; background: var(--card); border:1px solid var(--line); border-radius:var(--border-radius); padding:16px 18px; margin-bottom:12px; color: var(--text-secondary); box-sizing:border-box; box-shadow:var(--shadow-sm); }
.cliente-card:hover { border-color: rgba(255,255,255,0.7); box-shadow:0 0 0 3px rgba(255,255,255,0.12), 0 4px 12px rgba(0,0,0,0.25); }
.cliente-card-link { position:absolute; inset:0; z-index:1; pointer-events:auto; cursor:pointer; }
.cliente-card-header { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.cliente-title { margin:0; font-size:1.2rem; color: var(--text); letter-spacing:.2px; display:inline-flex; align-items:center; gap:6px; position:relative; z-index:auto; }
.cliente-copy-btn { z-index:10; opacity:0; visibility:hidden; background:none; color:#80868b; border:none; border-radius:8px; width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; cursor:pointer; transition:opacity .15s ease, transform .15s ease, color .2s ease; transform: translateY(2px); }
.cliente-copy-btn i { font-size:12px; }
.cliente-copy-wrapper { position:relative; z-index:auto; width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; }
.cliente-copy-wrapper:hover .cliente-copy-btn { opacity:1; visibility:visible; transform:translateY(0); }
.cliente-card:hover .cliente-copy-btn { opacity:1; visibility:visible; transform:translateY(0); }
.cliente-subheader { display:flex; align-items:center; gap:12px; margin-top:8px; position:relative; z-index:auto; }
.cliente-code { display:inline-block; background: var(--primary); color:#ffffff; padding:6px 10px; border-radius:8px; font-weight:600; letter-spacing:.4px; }
.cliente-meta { display:flex; align-items:baseline; gap:24px; margin-top:14px; flex-wrap:wrap; overflow:visible; }
.meta-item { display:flex; align-items:baseline; gap:10px; white-space:nowrap; position:relative; z-index:auto; }
.meta-label { font-size:.75rem; text-transform:uppercase; letter-spacing:.06em; color: var(--muted); }
.meta-value { font-size:1rem; color: var(--text); }
.meta-copy-btn { opacity:0; visibility:hidden; color:#80868b; background:transparent; border:none; padding:0; width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; cursor:pointer; transition:opacity .15s ease, transform .15s ease, color .2s ease; transform: translateY(2px); z-index:10; margin-left:6px; }
.meta-copy-btn i { font-size:12px; }
.meta-copy-btn:hover { color:#b0b4b9; }
.meta-item:hover .meta-copy-btn, .nombre-copy-wrapper:hover .meta-copy-btn { opacity:1; visibility:visible; transform:translateY(0); }
.cliente-code:hover + .meta-copy-btn { opacity:1; visibility:visible; transform:translateY(0); }
.cliente-title .cliente-nombre:hover + .nombre-copy-wrapper .meta-copy-btn { opacity:1; visibility:visible; transform:translateY(0); }
.obra-title .obra-nombre:hover + .nombre-copy-wrapper .meta-copy-btn { opacity:1; visibility:visible; transform:translateY(0); }
.cliente-nombre { display:inline-flex; align-items:center; }
.nombre-copy-wrapper { display:inline-flex; align-items:center; position:relative; z-index:auto; }

/* =============================================================
   Clientes: Formulario de alta
   Problema que soluciona: grillas, paneles y controles IA sin CSS inline
   Ubicación: templates/clientes/cliente_form.html
   ============================================================= */
.bd-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.bd-contact-grid { grid-template-columns: 1fr; }
.bd-form-actions { display: flex; gap: 10px; margin-top: 16px; }
.bd-panel { background: var(--card); border: 1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow-sm); margin-bottom: 16px; }
.bd-panel-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid var(--line); }
.bd-panel-title { margin: 0; font-weight: 700; color: var(--text); display: inline-flex; align-items: center; gap: 8px; }
.bd-panel-body { padding: 16px; }
.bd-text-muted { color: var(--muted); }
.ia-suggestions-box { white-space: pre-wrap; background: var(--bg); border: 1px dashed var(--line); border-radius: 10px; padding: 12px; min-height: 100px; display: none; }
.grid-stack { display:flex; flex-direction:column; gap:8px; }
.stepper { display:flex; align-items:center; gap:10px; margin: 12px 0 16px; flex-wrap:wrap; }
.step { display:flex; align-items:center; gap:8px; padding:8px 10px; border-radius: 20px; border:1px solid var(--line); background: var(--bg); color: var(--text); }
.step.active { border-color: var(--primary); background: rgba(0, 102, 255, 0.08); }
.step .num { width:22px; height:22px; border-radius:11px; background: var(--primary); color:white; display:flex; align-items:center; justify-content:center; font-size:12px; }
.wizard-actions { display:flex; justify-content:space-between; gap:10px; margin-top: 8px; }
.wizard-actions .left, .wizard-actions .right { display:flex; gap:10px; }
.bd-tabs { display:flex; gap:6px; margin: 12px 0 16px; flex-wrap:wrap; }
.bd-tab { padding:6px 10px; border:1px solid var(--line); border-radius: 6px; background: var(--bg); cursor:pointer; font-weight:600; }
.bd-tab.active { background: rgba(0,0,0,0.05); border-color: var(--primary); color: var(--primary); }
/* Variables IA globales */
/* eliminado: tokens AI no usados */
.ai-btn, .ia-contacts-btn { color: #f1f5f9; background: linear-gradient(135deg, var(--primary), var(--accent)); border: 1px solid var(--line); padding: 7px 12px; border-radius: 10px; display: inline-flex; align-items: center; gap: 8px; box-shadow: var(--shadow-sm); transition: background .2s ease, box-shadow .2s ease, color .2s ease, transform .2s ease, border-color .2s ease; border-left: none; outline: none; }
.ai-btn::before, .ai-btn::after { content: none !important; display: none !important; }
.ai-btn.ai-compact, .ia-contacts-btn.ai-compact { padding: 6px 10px; font-size: 0.95rem; border-radius: 10px; }
.ai-btn.ia-active { color: #ffffff; border-color: transparent; background-image: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%); background-size: 300% 300%; animation: aiGradientMove 6s ease infinite; box-shadow: var(--shadow); }
.ai-gradient { color: #f1f5f9; transition: all .2s ease; }
.ai-btn:hover .ai-gradient, .ia-contacts-btn:hover .ai-gradient { background: linear-gradient(270deg, var(--ai-start), var(--ai-end)); background-size: 300% 300%; -webkit-background-clip: text; background-clip: text; color: transparent; }
@keyframes aiGradientMove { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }
.ai-btn:hover, .ia-contacts-btn:hover { color: #ffffff; border-color: transparent; background-image: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%); box-shadow: var(--shadow); transform: translateY(-1px); }
.ai-btn:active, .ia-contacts-btn:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
/* =============================================================
   IA: botón icono compacto
   Problema que soluciona: permite tener un botón solo icono para IA
   Ubicación: cabeceras de formularios (Clientes, Proveedores, etc.)
   ============================================================= */
.ai-icon-btn { width: 36px; height: 36px; display:inline-flex; align-items:center; justify-content:center; border-radius: 10px; border: 1px solid var(--line); background-image: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%); color:#ffffff; box-shadow: var(--shadow); transition: transform .2s ease, box-shadow .2s ease, filter .2s ease; }
.ai-icon-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-lg); }
.ai-icon-btn:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
.ai-icon-btn i { font-size: 1rem; }
.bd-error { color: #c0392b; font-size: 0.9rem; margin-top: 4px; }
.bd-error ul.errorlist { margin: 0; padding-left: 18px; }
.ia-suggested { outline: 2px dashed var(--primary); background: rgba(0, 102, 255, 0.08); }
.ia-inline-actions { display:flex; align-items:center; gap:6px; margin-top:6px; }
.ia-inline-actions .ia-accept { color: #2ecc71; cursor:pointer; }
.ia-inline-actions .ia-reject { color: #e74c3c; cursor:pointer; }
.ia-apply-all-inline { display: none; opacity: 0.5; background: transparent; border: 1px solid var(--line); color: var(--muted); padding: 4px 8px; font-size: 12px; border-radius: 6px; }
.ia-apply-all-inline:hover { opacity: 0.9; }
.ia-mini-btn { background: transparent; border: 1px solid var(--line); color: var(--muted); padding: 2px 6px; font-size: 12px; border-radius: 6px; }
.ia-status { display: none; margin-left: 6px; padding: 0; border-radius: 0; background: transparent; color: #9eb6ff; font-weight: 700; font-size: 12px; line-height: 1; align-items: center; gap: 4px; }
.ia-status .ia-sparkle { color: #9eb6ff; animation: iaPulse 1.6s ease-in-out infinite; }
.ia-status .ia-text { display: none; }
.ia-status .ia-reflex { display: none; }
@keyframes iaPulse { 0% { transform: scale(1); opacity: 0.7; } 50% { transform: scale(1.2); opacity: 1; } 100% { transform: scale(1); opacity: 0.7; } }
.ia-status.ia-active .ia-sparkle { animation: iaPulse 1.6s ease-in-out infinite, iaSpin 1.4s linear infinite; }
.ia-status.ia-active .ia-text { filter: brightness(1.2); }
@keyframes iaSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.ia-status .ia-reflex { width: 14px; height: 6px; border-radius: 6px; margin: 0 4px; flex: 0 0 14px; background-image: linear-gradient(90deg, var(--primary), var(--accent)); background-size: 200% 200%; animation: iaReflexMove 1.8s linear infinite; box-shadow: var(--shadow-sm); }
@keyframes iaReflexMove { 0% { background-position: 0% 50%; opacity: .8; } 50% { background-position: 100% 50%; opacity: 1; } 100% { background-position: 0% 50%; opacity: .8; } }
.ia-status .ia-thinking { color: #fff; filter: drop-shadow(0 0 2px rgba(45, 183, 198, .6)); }
.bd-layout .container.main-container { width: 100%; max-width: none; }
.bd-contact-row input, .bd-contact-row select, .bd-contact-row textarea { width: 100%; }
.bd-contact-row input[type="text"] { text-transform: capitalize; }
.bd-contact-row input[type="email"], .bd-contact-row textarea { text-transform: none; }
@media (max-width: 900px) { .bd-contact-row { flex-wrap: wrap; } }

/* =============================================================
   Clientes: Confirmación inline de borrado
   Problema que soluciona: tarjeta modal inline consistente, sin CSS inline
   Ubicación: templates/clientes/cliente_detail.html
   ============================================================= */
.dg-inline-confirm { position: fixed; z-index: 1055; left: 50%; top: 20%; transform: translateX(-50%); width: 92%; max-width: 420px; }
.dg-inline-card { background: var(--card); color: var(--text); border: 1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow-lg); }
.dg-inline-card .header { padding: .75rem 1rem; border-bottom: 1px solid var(--line); font-weight: 700; }
.dg-inline-card .body { padding: 1rem; }
.dg-inline-card .footer { padding: .75rem 1rem; border-top: 1px solid var(--line); display:flex; justify-content:flex-end; gap:.5rem; }

/* =============================================================
   Administración: Tablas y acciones comunes (Sync módulos, Contabilidad)
   Problema que soluciona: estilos de tablas, badges y botones; elimina CSS inline
   Ubicación: templates/administracion/sync_modulos.html, contabilidad.html
   ============================================================= */
.form-container { background: var(--card); border-radius: var(--border-radius); padding: 2rem; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.form-section { margin-bottom: 2rem; padding: 1.5rem; background: rgba(255, 255, 255, 0.02); border-radius: var(--border-radius); border: 1px solid var(--line); }
.form-section h3 { color: var(--text-primary); font-size: 1.25rem; font-weight: 600; margin: 0 0 1.5rem 0; display: flex; align-items: center; justify-content: center; gap: 0.75rem; padding-bottom: 0.5rem; text-align: center; border-bottom: 1px solid currentColor; }
.form-section h3 i { color: var(--primary); font-size: 1.1rem; }
.bd-actions { display: flex; gap: 1rem; justify-content: center; margin-bottom: 2rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--line); }

/* =============================================================
   Administración: Panel y tarjetas del dashboard
   Problema que soluciona: elimina CSS inline en dashboard y unifica al estilo Clientes
   Ubicación: templates/administracion/dashboard.html, codigos_ref_dashboard.html
   ============================================================= */
.admin-container { max-width: 1200px; margin: 0 auto; background: var(--card); border-radius: var(--border-radius); padding: 2rem; box-shadow: 0 3px 10px var(--shadow), 0 16px 36px var(--shadow); border: 1px solid var(--line); }
.admin-header { text-align: center; margin-bottom: 2rem; padding-bottom: 1rem; border-bottom: 1px solid var(--line); }
.admin-header-icon { font-size: 2.5rem; color: var(--primary); margin-bottom: .75rem; }
.admin-title { color: var(--text); font-size: 1.5rem; font-weight: 700; margin-bottom: .25rem; }
.admin-description { color: var(--text-secondary); font-size: 1rem; max-width: 640px; margin: 0 auto; }
.admin-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 1.25rem; margin-bottom: 1.5rem; }
.admin-card { background: var(--card); border: 1px solid var(--line); border-radius: var(--border-radius); padding: 1.25rem; position: relative; overflow: hidden; color: var(--text); box-shadow: var(--shadow-sm); transition: box-shadow .2s ease, border-color .2s ease; text-decoration: none; }
.admin-card:hover { border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow), var(--shadow); text-decoration: none; color: var(--text); }
.admin-card-header { display: flex; justify-content: space-between; align-items: start; margin-bottom: 1rem; }
.admin-card-icon { display: flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: var(--border-radius); margin-right: 1rem; font-size: 1.25rem; color: #ffffff; background: var(--primary); }
.admin-card-icon.audit { background: linear-gradient(135deg, #f59e0b, #d97706); }
.admin-card-icon.ref-codes { background: linear-gradient(135deg, #8b5cf6, #7c3aed); }
.admin-card-icon.tools { background: linear-gradient(135deg, #ef4444, #dc2626); }
.admin-card-icon.accounting { background: linear-gradient(135deg, #14b8a6, #0ea5e9); }
.admin-card-title { color: var(--text); font-size: 1.15rem; font-weight: 600; margin: 0; line-height: 1.3; }
.admin-card-content { margin-bottom: 1rem; }
.admin-card-description { color: var(--text-secondary); font-size: .95rem; line-height: 1.5; margin-bottom: 1rem; min-height: 2.5rem; }
.admin-card-actions { display: flex; gap: .5rem; flex-wrap: nowrap; justify-content: space-between; }
.admin-btn { padding: .45rem .85rem; border: none; border-radius: var(--border-radius); font-weight: 600; font-size: .85rem; cursor: pointer; transition: all .2s ease; text-decoration: none; display: inline-flex; align-items: center; gap: .35rem; min-width: 88px; justify-content: center; background: var(--primary); color: #ffffff; flex: 1; }
.admin-btn:hover { background: var(--primary-hover); box-shadow: var(--shadow-sm); text-decoration: none; color: #ffffff; }
.admin-btn-secondary { background: var(--card); color: var(--text-secondary); border: 1px solid var(--line); }
.admin-btn-secondary:hover { background: var(--panel); color: var(--text); border-color: var(--primary); }
.tools-grid { display: flex; flex-direction: column; gap: .75rem; }
.tools-row { display: flex; gap: .5rem; justify-content: space-between; }
.tools-row .admin-btn { flex: 1; min-width: 0; }
.warning-box { background: rgba(245,158,11,0.1); border: 1px solid var(--warning); border-radius: var(--border-radius); padding: .75rem; margin-bottom: 1rem; display: flex; align-items: center; gap: .5rem; }
.warning-box i { color: var(--warning); font-size: 1rem; }
.warning-box span { color: var(--text-secondary); font-size: .85rem; line-height: 1.4; }
@media (max-width: 768px) { .admin-container { padding: 1.5rem; margin: 0 1rem; } .admin-grid { grid-template-columns: 1fr; gap: 1rem; } .admin-card-actions { flex-direction: column; align-items: center; } .tools-row { flex-direction: column; gap: .5rem; } .tools-row .admin-btn { width: 100%; } }
.bd-btn-sm { padding: 0.45rem 0.85rem; font-size: 0.85rem; border-radius: 6px; box-shadow: var(--shadow-sm); }
.bd-btn-sm i { font-size: 0.95rem; }
.sync-table { width: 100%; border-collapse: collapse; }
.sync-table th, .sync-table td { border: 1px solid var(--line); padding: 0.6rem 0.5rem; color: var(--text-primary); }
.sync-table th { background: var(--card); color: var(--text-secondary); text-align: left; }
.badge { display: inline-block; padding: 0.1rem 0.5rem; border-radius: 999px; font-size: 0.75rem; }
.badge.ok { background: #0ea5e9; color: white; }
.badge.warn { background: #ef4444; color: white; }
.inline-form { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.chk { color: var(--text-secondary); font-size: 0.85rem; }
.table-responsive { overflow-x: auto; }


/* Tarjetas de categoría */
html[data-theme="light"] .category-card,
html.light .category-card,
:root[data-theme="light"] .category-card {
  background: #ffffff !important;
  border-color: #e5e7eb !important;
  box-shadow: var(--shadow-sm) !important;
}
html[data-theme="light"] .category-header,
html.light .category-header,
:root[data-theme="light"] .category-header {
  border-bottom: 2px solid #e5e7eb !important;
}
html[data-theme="light"] .category-title,
html.light .category-title,
:root[data-theme="light"] .category-title {
  color: #111111 !important;
}
html[data-theme="light"] .category-description,
html.light .category-description,
:root[data-theme="light"] .category-description {
  color: #6b7280 !important;
}

/* Filas y entradas del formulario */
html[data-theme="light"] .form-header,
html.light .form-header,
:root[data-theme="light"] .form-header {
  color: #6b7280 !important;
}
html[data-theme="light"] .row-input,
html.light .row-input,
:root[data-theme="light"] .row-input {
  background: #ffffff !important;
  border: 1px solid #d1d5db !important;
  color: #111111 !important;
}
html[data-theme="light"] .row-input:focus,
html.light .row-input:focus,
:root[data-theme="light"] .row-input:focus {
  box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow) !important; /* halo de foco canónico */
}

/* Contenedor de envío */
html[data-theme="light"] .submit-container,
html.light .submit-container,
:root[data-theme="light"] .submit-container {
  background: #ffffff !important;
  border-color: #e5e7eb !important;
}
/* Usuarios: título principal con subrayado azul debe ser negro en modo claro */
html[data-theme="light"] .bd-title,
html.light .bd-title,
:root[data-theme="light"] .bd-title {
  border-bottom: 2px solid #000000 !important;
}

/* Plan de Cuentas y módulos unificados: en modo OSCURO la línea inferior del título debe ser blanca */
html[data-theme="dark"] .bd-title,
html.dark .bd-title,
:root[data-theme="dark"] .bd-title {
  border-bottom: 2px solid #ffffff !important;
}
/* Atributo de tema aplicado en cualquier contenedor (no solo html) */
[data-theme="light"] .bd-title { border-bottom: 2px solid var(--line) !important; }
[data-theme="dark"] .bd-title { border-bottom: 2px solid var(--line) !important; }

/* Usuarios: tabla y contenedor deben verse claros en modo CLARO */
html[data-theme="light"] .bd-table-container,
html.light .bd-table-container,
:root[data-theme="light"] .bd-table-container {
  background: #ffffff !important;
  border-color: var(--line, #dee2e6) !important;
}

html[data-theme="light"] .bd-table,
html.light .bd-table,
:root[data-theme="light"] .bd-table {
  background: #ffffff !important;
}

html[data-theme="light"] .bd-table th,
html.light .bd-table th,
:root[data-theme="light"] .bd-table th {
  background: #ffffff !important;
  color: #000000 !important;
  border-bottom: 2px solid var(--line, #dee2e6) !important;
}

html[data-theme="light"] .bd-table td,
html.light .bd-table td,
:root[data-theme="light"] .bd-table td {
  background: #ffffff !important;
  color: #000000 !important;
  border-bottom: 1px solid var(--line, #dee2e6) !important;
}

/* Contenedor principal unificado (.bd-container): modo CLARO con fondo blanco y sombra sutil */
html[data-theme="light"] .bd-container,
html.light .bd-container,
:root[data-theme="light"] .bd-container {
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
}

/* Alias: cuando el atributo de tema está en un contenedor intermedio */
[data-theme="light"] .bd-container { /* sin sombra en modo claro por directriz */ }

/* ===== Sidebar y navegación (migrado desde inline styles) ===== */
/* Botón flotante inferior izquierdo (#btn-sidebar): regla explícita para evitar solapes y asegurar visibilidad */
#btn-sidebar { position: fixed; left: 10px; bottom: 10px; z-index: 11000; }

#sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.4);
  z-index: 1090;
}

/* Sidebar: unificamos la lógica de visibilidad usando transform (sin cambiar left) */
#sidebar {
  position: fixed;
  left: 0;
  top: 0;
  width: 240px; /* ancho unificado */
  height: 100%;
  background: var(--panel);
  color: var(--text);
  box-shadow: 0 0 12px var(--shadow);
  transform: translateX(-240px); /* oculto por defecto usando transform */
  will-change: transform;
  transition: transform .16s ease-out; /* animación coherente con overlay */
  z-index: 1101;
  padding: 14px 10px;
}

/* Cuando el cuerpo indica que el sidebar está abierto, desplazarlo a la vista */
body.sidebar-open #sidebar {
  transform: translateX(0);
}

/* TRAE:START dg-sidebar */
/* Versión compacta para mostrar más botones sin perder legibilidad */
.dg-sidebar-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.dg-sidebar-item {
  display: flex;
  flex-direction: row; /* Asegura orden: enlace a la izquierda, botón a la derecha */
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: 0 2px 10px var(--shadow);
  transition: transform .15s ease, box-shadow .15s ease;
}

.dg-sidebar-item:hover {
  transform: translateY(-1px);
  box-shadow: 0 3px 12px var(--shadow);
}

.dg-sidebar-link {
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
  font-size: .95em;
  flex: 1;
  margin-right: 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Módulos no disponibles: atenuados y sin interacción */
.dg-sidebar-link.dg-disabled{
  color: var(--muted) !important;
  opacity: .55 !important;
  pointer-events: none !important;
  cursor: not-allowed !important;
}

.btn-pin.dg-sidebar-pin {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--text);
  margin-left: 8px; /* Mantener el botón a la derecha del enlace */
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease;
}

.btn-pin.dg-sidebar-pin .star { font-size: 14px; line-height: 1; color: var(--text); text-shadow: 0 0 2px rgba(0,0,0,.35); }
/* Unificar tamaño de la estrella (menor) en todos los contextos */
.pin-btn .star, .pin-btn .fa-star { font-size: 14px; line-height: 1; }
/* Estilo para el botón de pin del sidebar v3 */
#sidebar .pin-button { background: transparent; border: none; padding: 4px; }
#sidebar .pin-button .fa-star { font-size: 9px; line-height: 1; color: #bfc5cf; }
#sidebar .pin-button.pinned .fa-star { color: #f5d200; }
/* Sidebar: mostrar estrella solo al pasar el ratón; siempre visible si está fijado */
#sidebar .navigation-item .pin-button { opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .15s ease; }
#sidebar .navigation-item:hover .pin-button,
#sidebar .nav-link:hover .pin-button,
#sidebar .navigation-item .pin-button.pinned { opacity: 1; visibility: visible; pointer-events: auto; }
/* Alinear la estrella a la derecha del item */
/* Ubicar la estrella casi pegada al nombre dentro del enlace */
#sidebar .nav-link .pin-button { margin-right: 2px; color: var(--muted); display: inline-flex; align-items: center; justify-content: center; }
#sidebar .nav-link .pin-button .fa-star { font-size: 9px; }
#sidebar .nav-link .pin-button { z-index: 1; }
/* En dispositivos táctiles (sin hover), mostrar siempre la estrella */
@media (hover: none) {
  #sidebar .navigation-item .pin-button { opacity: 1; visibility: visible; pointer-events: auto; }
}

/* Mantener el texto del módulo visible y ocupando el espacio adecuado */
/* (Se elimina el override que ponía flex:0 en .nav-label para no recortar nombres) */

/* Ajustes de espaciado dentro del sidebar para ganar unos píxeles y evitar cortes */
#sidebar .nav-link { gap: 6px; padding-left: 12px; padding-right: 10px; margin-right: 0; }
/* Reducir ligeramente el ancho reservado al icono para ganar espacio de texto sin cambiar el diseño */
#sidebar .nav-link i { width: 14px; }

.btn-pin.dg-sidebar-pin:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px var(--shadow);
}

.btn-pin.dg-sidebar-pin.pinned {
  border-color: var(--warning);
  color: var(--warning);
}

/* Garantizar contraste del icono de estrella en todos los contextos */
.btn-pin .star{ color: var(--text); opacity: 1; }
.btn-pin.pinned .star{ color: var(--warning); }

/* Eliminado: estilos de botón Cerrar del sidebar (dg-sidebar-close) */
/* TRAE:END dg-sidebar */

#chat-fab {
  position: fixed;
  right: 18px;
  bottom: 18px;
  border-radius: 999px;
  padding: 14px 16px;
  /* TRAE: Botón chat SIEMPRE visible en todos los módulos */
  display: inline-flex !important;
  visibility: visible !important;
  z-index: 2147483647 !important; /* máxima prioridad: por encima de overlays y contenidos */
}

/* ===== Login específico (migrado desde inline styles) ===== */
.login-navbar-hidden .navbar { display: none !important; }

/* ===== Barra de desplazamiento personalizada (migrado desde inline styles) ===== */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: #f1f1f1; border-radius: 10px; }
::-webkit-scrollbar-thumb { background: #888; border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: #555; }

/* ===== Tarjetas de contacto (migrado desde inline styles) ===== */
.contacto-card {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius);
  margin-bottom: 0.75rem;
  padding: 1rem;
}

.contacto-error {
  background: #dc3545;
  color: white;
  padding: 0.5rem;
  border-radius: var(--border-radius);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* ===== Iconos de administración (migrado desde inline styles) ===== */
.admin-card-icon.bg-success { background: #10b981 !important; }
.admin-card-icon.bg-primary { background: var(--primary) !important; }
.admin-card-icon.bg-warning { background: #f59e0b !important; }
.admin-card-icon.bg-danger { background: #ef4444 !important; }
.admin-card-icon.bg-purple { background: #8b5cf6 !important; }
.admin-card-icon.bg-cyan { background: #06b6d4 !important; }

/* ===== Iconos de categorías con gradientes (migrado desde inline styles) ===== */
.category-icon.gradient-blue { background: linear-gradient(135deg, var(--primary), var(--primary-hover)); }
.category-icon.gradient-green { background: linear-gradient(135deg, #10b981, #059669); }
.category-icon.gradient-yellow { background: linear-gradient(135deg, #f59e0b, #d97706); }
.category-icon.gradient-red { background: linear-gradient(135deg, #ef4444, #dc2626); }
.category-icon.gradient-purple { background: linear-gradient(135deg, #8b5cf6, #7c3aed); }

/* ===== Badges de estado (migrado desde inline styles) ===== */
.status-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 500;
  border-radius: 0.375rem;
  gap: 0.25rem;
}

.status-badge.success {
  background: rgba(16, 185, 129, 0.1);
  color: var(--success);
  border: 1px solid rgba(16, 185, 129, 0.2);
}

.status-badge.warning {
  background: rgba(245, 158, 11, 0.1);
  color: var(--warning);
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.status-badge.danger {
  background: rgba(239, 68, 68, 0.1);
  color: var(--danger);
  border: 1px solid rgba(239, 68, 68, 0.2);
}

.status-badge.info {
  background: rgba(59, 130, 246, 0.1);
  color: #60a5fa;
  border: 1px solid rgba(59, 130, 246, 0.2);
}

.status-badge.primary {
  background: rgba(59, 130, 246, 0.1);
  color: var(--primary);
  border: 1px solid rgba(59, 130, 246, 0.2);
}

/* ===== Código inline (migrado desde inline styles) ===== */
.code-inline {
  background: #1a1a1a;
  color: #a0aec0;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  font-family: monospace;
}

/* ===== Alertas personalizadas (migrado desde inline styles) ===== */
.alert-warning-custom {
  background: rgba(245, 158, 11, 0.2);
  border: 1px solid var(--warning);
  color: var(--warning);
}

/* ===== Contenedores de detalles (migrado desde inline styles) ===== */
.detail-container {
  padding: 1rem;
  background: var(--bg-card);
  border-radius: var(--border-radius);
  border: 1px solid var(--border-color);
}

/* ===== Output de comandos (migrado desde inline styles) ===== */
.command-output {
  background: #f8f8f8;
  padding: 10px;
  border: 1px solid #ddd;
  white-space: pre-wrap;
}

/* ===== Botones primarios personalizados (migrado desde inline styles) ===== */
.bd-btn-primary { background: var(--primary); color: #fff; }

/* ===== Botón admin cyan (migrado desde inline styles) ===== */
.admin-btn-cyan { background: #06b6d4 !important; color: #fff; }

/* ===== Utilidades de botones (migrado desde inline styles) ===== */
.bd-btn-disabled { opacity: .5; cursor: not-allowed; pointer-events: none; }
.cursor-default { cursor: default; }

/* ===== Utilidades adicionales ===== */
.max-w-1200 { max-width: 1200px; }
.min-w-100 { min-width: 100px; }
.max-w-160 { max-width: 160px; }
.text-last-center { text-align-last: center; }
.min-h-40 { min-height: 40px; }
.brand-logo { max-width: 220px; height: auto; }

/* ===== Estilos zona de subida y previsualización de logos (Apariencia) ===== */
.hidden-file { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.file-input-wrapper { position: relative; }
.file-input-display {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: .25rem; padding: 1rem; text-align: center;
  border: 2px dashed var(--border-color); border-radius: 12px;
  color: var(--text-secondary); background: var(--bg-primary);
  cursor: pointer; transition: border-color .15s ease, background-color .15s ease, color .15s ease;
}
.file-input-display i { color: var(--primary); font-size: 1.5rem; margin-bottom: .25rem; }
.file-input-display:hover { border-color: var(--primary); background: var(--bg-secondary); color: var(--text-primary); }
.file-preview { margin-top: .5rem; }
.file-preview-image { max-width: 240px; max-height: 100px; height: auto; width: auto; display: block; background: transparent; }

/* ===== ESTILOS DE AUDITORÍA (migrado desde audit_styles.css) ===== */
/* Estilos para información de auditoría */
.bd-audit-info {
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    padding: 1rem;
    margin-top: 0.5rem;
}

.bd-audit-row, .bd-audit-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.25rem 0;
    border-bottom: 1px solid #e9ecef;
}

.bd-audit-row:last-child, .bd-audit-item:last-child {
    border-bottom: none;
}

.bd-audit-label {
    font-weight: 600;
    color: #495057;
    min-width: 120px;
}

.bd-audit-value {
    color: #6c757d;
    text-align: right;
}

.audit-info {
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    padding: 1rem;
    margin-top: 0.5rem;
}

.audit-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.25rem 0;
    border-bottom: 1px solid #e9ecef;
}

.audit-row:last-child {
    border-bottom: none;
}

.audit-label {
    font-weight: 600;
    color: #495057;
    min-width: 120px;
}

.audit-value {
    color: #6c757d;
    text-align: right;
}

/* Estilos para información descriptiva */
.bd-info-text {
    color: #6c757d;
    font-size: 0.9rem;
    margin-top: 0.25rem;
}

.bd-info-text i {
    margin-right: 0.5rem;
    color: #007bff;
}

/* eliminado: paleta bd-* (usar tokens del tema) */

/* Breadcrumb */
/* Breadcrumb: se usa bloque unificado más abajo – duplicado eliminado */

/* Breadcrumb: se usa bloque unificado en sección de componentes */

/* Container: usar patrón unificado global */

/* Title: usar patrón unificado */

/* Actions: usar patrón unificado */

/* Buttons */
.bd-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    border: none;
    border-radius: var(--border-radius);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: var(--transition-normal);
    box-shadow: var(--shadow-sm);
}

.bd-btn-primary {
    background: var(--primary);
    color: #ffffff;
}

.bd-btn-primary:hover {
    background: var(--primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-lg);
}

.bd-btn-secondary {
    background: var(--panel);
    color: var(--text);
}

.bd-btn-secondary:hover {
    background: var(--card);
    transform: translateY(-1px);
    box-shadow: var(--shadow);
}

.bd-btn-success {
    background: var(--success);
    color: #ffffff;
}

.bd-btn-success:hover {
    background: var(--success);
    transform: translateY(-1px);
    box-shadow: var(--shadow);
}

/* Botón advertencia (amarillo) */
.bd-btn-warning { background: var(--warning); color:#ffffff; }
.bd-btn-warning:hover { background: var(--warning); transform: translateY(-1px); box-shadow: var(--shadow); }

.bd-btn-danger {
    background: var(--danger);
    color: #ffffff;
}

.bd-btn-danger:hover {
    background: var(--danger);
    transform: translateY(-1px);
    box-shadow: var(--shadow);
}

/* Estándar Administración: color de botón primario según tema
   - Modo oscuro: usa --primary
   - Modo claro: negro */
html[data-theme="light"] .bd-btn-primary,
html.light .bd-btn-primary,
:root[data-theme="light"] .bd-btn-primary {
    background: #000000;
    color: #ffffff;
}

/* BaseDatos: forzar primario azul en esta página (Subcapítulos) */
.basedatos-page .bd-btn-primary { background: var(--primary) !important; color:#ffffff !important; border-color: var(--primary) !important; }
.basedatos-page .bd-btn-primary:hover { background: var(--primary-hover) !important; }
html[data-theme="light"] .bd-btn-primary:hover,
html.light .bd-btn-primary:hover,
:root[data-theme="light"] .bd-btn-primary:hover {
    background: #111111;
    transform: translateY(-1px);
    box-shadow: var(--shadow-lg);
}

/* Paneles tipo tarjeta en Administración (igual que Apariencia) */
.card.dmd-panel {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    /* Sombra estándar de Apariencia */
    box-shadow: 0 12px 30px var(--shadow);
}

/* Formularios de Administración (bd-form) */
.bd-form {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: 1.5rem;
    margin-bottom: 1rem;
    box-shadow: var(--shadow-sm);
}

.bd-form-section {
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.bd-form-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.bd-form-section h4 {
    color: var(--text-primary);
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}

.bd-form-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.bd-form-group {
    display: flex;
    flex-direction: column;
}

.bd-form-group label {
    color: var(--text-primary);
    font-weight: 600;
    margin-bottom: .25rem;
    font-size: .95rem;
}

.bd-form-group input,
.bd-form-group select,
.bd-form-group textarea {
    background: var(--bg-input, var(--bg-card));
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: .5rem .75rem;
    color: var(--text-primary);
    font-size: 1rem;
    transition: all .2s ease;
}

.bd-form-group input:focus,
.bd-form-group select:focus,
.bd-form-group textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 2px color-mix(in oklab, var(--primary), transparent 80%);
    background: var(--bg-input, var(--bg-card));
}

.bd-form-group input::placeholder,
.bd-form-group textarea::placeholder {
    color: var(--text-muted);
}

.bd-form-check {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .5rem;
}

.bd-form-check input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--primary);
}

.bd-form-check label {
    color: var(--text-secondary);
    font-weight: 500;
    margin: 0;
    cursor: pointer;
}

.bd-permissions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: .75rem;
    margin-top: .75rem;
}

@media (max-width: 768px) {
    .bd-form-row {
        grid-template-columns: 1fr;
        gap: .75rem;
    }
}

/* Botón oscuro (para pruebas en Usuarios) */
.bd-btn-dark {
    background: #333333; /* gris oscuro */
    color: #ffffff;
}
.bd-btn-dark:hover {
    background: #111111; /* aún más oscuro en hover */
    transform: translateY(-1px);
    box-shadow: var(--shadow-lg);
    color: #ffffff;
}

/* Variables jerárquicas ya definidas en :root arriba */

/* Layout principal mejorado */
.basedatos-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 2rem;
    background: var(--bg-primary);
    min-height: 100vh;
}

.basedatos-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    padding: 1.5rem 2rem;
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(10px);
}

.basedatos-title {
    font-size: 2.25rem;
    font-weight: 800;
    color: var(--text-primary);
    margin: 0;
    background: linear-gradient(135deg, var(--primary-color), var(--info-color));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.header-actions {
    display: flex;
    gap: 1rem;
    align-items: center;
}

/* Breadcrumb mejorado */
.breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
    padding: 1rem 1.5rem;
    background: var(--card-bg);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
}

.breadcrumb a {
    color: var(--primary-color);
    text-decoration: none;
    transition: var(--transition-fast);
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius-sm);
}

.breadcrumb a:hover {
    color: var(--primary-hover);
    background: var(--primary-light);
}

.breadcrumb-separator {
    color: var(--text-muted);
    font-weight: 500;
}

/* Buscador moderno */
.search-container {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 2rem;
    margin-bottom: 2rem;
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(10px);
    position: relative;
    overflow: hidden;
}

.search-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--primary-color), var(--info-color), var(--success-color));
}

.search-form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.5rem;
    align-items: center; /* Centrar verticalmente botón e input */
}

.search-field {
    position: relative;
}

.search-field label {
    display: block;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.75rem;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.search-input {
    width: 100%;
    padding: 1rem 1.25rem;
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    font-size: 1rem;
    background: var(--bg-secondary);
    color: var(--text-primary);
    transition: var(--transition-normal);
    position: relative;
}

.search-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px var(--primary-light);
    background: var(--bg-tertiary);
}

.search-input::placeholder {
    color: var(--text-muted);
}

/* Botones modernos */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center; /* Centrar iconos y texto */
    gap: 0.5rem;
    padding: 0.875rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--radius-md);
    border: 2px solid transparent;
    cursor: pointer;
    transition: var(--transition-normal);
    position: relative;
    overflow: hidden;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

/* Ajuste de altura para iconos SVG y <i> dentro de botones */
.btn svg, .btn i {
    display: inline-block;
    width: 18px;
    height: 18px;
    vertical-align: middle;
}

.btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
    transition: var(--transition-normal);
}

.btn:hover::before {
    left: 100%;
}

.btn-primary {
    background: linear-gradient(135deg, var(--primary-color), var(--primary-hover));
    color: white;
    box-shadow: var(--shadow-md);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.btn-secondary {
    background: var(--bg-secondary);
    color: var(--text-primary);
    border-color: var(--border-color);
}

.btn-secondary:hover {
    background: var(--bg-tertiary);
    border-color: var(--border-hover);
}

.btn-success {
    background: linear-gradient(135deg, var(--success-color), #059669);
    color: white;
    box-shadow: var(--shadow-md);
}

.btn-success:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.btn-icon {
    width: 20px;
    height: 20px;
    stroke-width: 2;
}

/* Efectos hover para botones */
.btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.btn:active {
    transform: translateY(0);
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--primary-color), var(--info-color));
}

.btn-secondary:hover {
    background: var(--text-muted);
    color: var(--bg-primary);
}

.btn-success:hover {
    background: linear-gradient(135deg, var(--success-color), var(--primary-color));
}

.btn-danger:hover {
    background: linear-gradient(135deg, var(--danger-color), var(--warning-color));
}

/* Estilos para las tarjetas de familia mejoradas */
.hierarchy-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-xl);
    border-color: var(--primary-color);
}

.hierarchy-card:hover .hierarchy-card-title a {
    color: var(--primary-color);
}

.hierarchy-card:hover > div:last-child {
    transform: scaleX(1);
}

/* Animaciones para estadísticas */
.stat-card {
    transition: var(--transition-normal);
}

.stat-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

/* Mejoras para el buscador */
.search-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px var(--primary-light);
    outline: none;
}

.search-form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1rem;
    align-items: end;
}

.search-field label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 600;
    color: var(--text-primary);
}

/* Estilos específicos para capítulo detail */
.bd-chapter-info {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: 2rem;
    margin-bottom: 2rem;
    box-shadow: var(--shadow-sm);
}

.bd-chapter-header {
    display: flex;
    justify-content: space-between;
    align-items: start;
    margin-bottom: 1.5rem;
}

.bd-chapter-title {
    margin: 0;
    color: var(--text-primary);
    font-size: 1.5rem;
    font-weight: 700;
}

.bd-chapter-code {
    font-family: 'Courier New', monospace;
    color: var(--primary-color);
    font-weight: 600;
    font-size: 0.875rem;
    background: var(--bg-secondary);
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    margin-top: 0.5rem;
    display: inline-block;
}

.bd-chapter-description {
    color: var(--text-secondary);
    line-height: 1.6;
    margin-bottom: 1.5rem;
}

.bd-chapter-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
}

.bd-stat-item {
    text-align: center;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--border-radius);
    border: 1px solid var(--border-color);
    transition: var(--transition-normal);
}

.bd-stat-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--primary-color);
}

.bd-stat-number {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.bd-stat-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

/* Colores específicos para diferentes tipos de métricas */
.bd-stat-item:nth-child(1) .bd-stat-number {
    color: var(--primary-color);
}

.bd-stat-item:nth-child(2) .bd-stat-number {
    color: var(--success-color);
}

.bd-stat-item:nth-child(3) .bd-stat-number {
    color: var(--warning-color);
}

.bd-stat-subchapters .bd-stat-number {
    color: var(--primary-color);
}

.bd-stat-items .bd-stat-number {
    color: var(--success-color);
}

.bd-stat-price .bd-stat-number {
    color: var(--warning-color);
}

/* Estilos para badges */
.bd-badge {
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.bd-badge-active {
    background: var(--success-light);
    color: var(--success-color);
    border: 1px solid var(--success-color);
}

.bd-badge-inactive {
    background: var(--text-light);
    color: var(--text-muted);
    border: 1px solid var(--text-muted);
}

/* Estilos para el contenedor de búsqueda */
.bd-search-container {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: 1.5rem;
    margin-bottom: 2rem;
    box-shadow: var(--shadow-sm);
}

.bd-search-form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1rem;
    align-items: end;
}

.bd-search-field label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 600;
    color: var(--text-primary);
    font-size: 0.875rem;
}

.bd-search-input {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 1rem;
    transition: var(--transition-normal);
}

.bd-search-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px var(--primary-light);
}

.bd-search-btn {
    padding: 0.75rem 1.5rem;
    background: var(--primary-color);
    color: white;
    border: none;
    border-radius: var(--border-radius);
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition-normal);
    white-space: nowrap;
    display: inline-flex;
    align-items: center;       /* Centrado vertical del icono */
    justify-content: center;   /* Centrado horizontal */
    gap: 0.5rem;
    height: 2.75rem;           /* Igualar a altura del input por defecto */
}

.bd-search-btn svg, .bd-search-btn i {
    width: 18px;
    height: 18px;
}

.bd-search-btn:hover {
    background: var(--primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

/* Estilos para el grid de familias/subcapítulos */
.bd-family-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.bd-family-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: 1.5rem;
    box-shadow: var(--shadow-sm);
    transition: var(--transition-normal);
    position: relative;
    overflow: hidden;
}

.bd-family-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    border-color: var(--primary-color);
}

.bd-family-card-header {
    display: flex;
    justify-content: space-between;
    align-items: start;
    margin-bottom: 1rem;
}

.bd-family-card-title {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.bd-family-card-title a {
    color: var(--text-primary);
    text-decoration: none;
    transition: var(--transition-normal);
}

.bd-family-card-title a:hover {
    color: var(--primary-color);
}

.bd-family-card-code {
    font-family: 'Courier New', monospace;
    color: var(--primary-color);
    font-weight: 600;
    font-size: 0.75rem;
    background: var(--bg-secondary);
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
}

.bd-family-card-description {
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 1rem;
    font-size: 0.875rem;
}

.bd-family-card-stats {
    display: flex;
    gap: 1rem;
    margin-bottom: 1rem;
}

.bd-counter {
    text-align: center;
    flex: 1;
}

.bd-counter-number {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.bd-counter-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.bd-counter-items .bd-counter-number {
    color: var(--success-color);
}

.bd-counter-price .bd-counter-number {
    color: var(--warning-color);
}

.bd-family-card-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
}

.bd-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    color: var(--text-secondary);
    text-decoration: none;
    transition: var(--transition-normal);
    background: var(--bg-primary);
}

.bd-action-btn:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
    transform: translateY(-1px);
}

/* Estado vacío */
.bd-empty-state {
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem;
    color: var(--text-secondary);
}

.bd-empty-state-icon {
    font-size: 3rem;
    margin-bottom: 1rem;
    color: var(--text-muted);
}

.bd-empty-state-title {
    margin: 0 0 0.5rem 0;
    color: var(--text-primary);
    font-size: 1.25rem;
}

.bd-empty-state-description {
    margin: 0 0 1.5rem 0;
    color: var(--text-secondary);
}

/* Paginación */
.bd-pagination {
    display: flex;
    justify-content: center;
    margin: 2rem 0;
}

.bd-pagination-nav {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.bd-pagination-link {
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    text-decoration: none;
    color: var(--text-primary);
    transition: var(--transition-normal);
    background: var(--bg-primary);
}

.bd-pagination-link:hover {
    background: var(--bg-secondary);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

/* Estado activo (página actual) */
.bd-pagination-link.active {
    background: var(--primary-color);
    color: #ffffff;
    border-color: var(--primary-color);
}

.bd-pagination-info {
    padding: 0.5rem 1rem;
    color: var(--text-secondary);
    font-weight: 500;
}

/* Metadatos */
.bd-metadata {
    margin-top: 2rem;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--border-radius);
    font-size: 0.875rem;
    color: var(--text-secondary);
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.bd-metadata-item {
    display: flex;
    gap: 0.5rem;
}

.bd-metadata-item strong {
    color: var(--text-primary);
}

/* Responsive */
/* =============================================================
   BaseDatos: árbol jerárquico de familias (index)
   Problema que soluciona: elimina estilos inline y unifica al sistema
   Ubicación: /basedatos/ index – componentes .bd-tree-*
   ============================================================= */
.bd-tree-view { background: var(--bg-primary); border: 2px solid var(--border-color); border-radius: var(--border-radius); overflow: hidden; box-shadow: var(--shadow); transition: var(--transition-normal); }
/* Árbol jerárquico: neutralizar borde blanco en hover */
.bd-tree-view:hover { border-color: var(--border-color); box-shadow: var(--shadow); }
.bd-tree-node { border-bottom: 1px solid var(--border-color); transition: var(--transition-normal); }
.bd-tree-node:last-child { border-bottom: none; }
.bd-tree-node-header { display:flex; align-items:center; padding: 1.5rem; cursor: pointer; user-select: none; background: var(--bg-primary); border: none; margin: 0; transition: var(--transition-normal); }
.bd-tree-node-header:hover { background: var(--bg-card); transform: translateY(-1px); }
.bd-tree-toggle { display:flex; align-items:center; justify-content:center; width:24px; height:24px; margin-right:1rem; color: var(--primary); font-size:1rem; flex-shrink:0; transition: var(--transition-normal); }
.bd-tree-toggle.bd-tree-leaf { cursor: default; color: var(--muted); }
.bd-tree-chevron { transition: transform var(--transition-normal); }
.bd-tree-node.expanded .bd-tree-chevron { transform: rotate(90deg); }
.bd-tree-title { font-weight: 600; color: var(--text); }
.bd-tree-meta { margin-left: auto; display:flex; gap:1rem; align-items:center; color: var(--text-secondary); }
.bd-tree-children { display: none; background: var(--bg-card); border-top: 1px solid var(--border-color); }
.bd-tree-node.expanded .bd-tree-children { display: block; }
@media (max-width: 768px) { .bd-tree-node-header { padding: 1rem; } .bd-tree-toggle { margin-right: .75rem; width: 20px; height: 20px; } }

/* Espaciado vertical entre contenedores principales en páginas de BaseDatos */
.bd-container + .bd-container { margin-top: 2rem; }

/* Estructura interna de nodos */
.bd-tree-node-content { display:flex; align-items:center; justify-content:space-between; flex:1; gap:1rem; min-height:2rem; }
.bd-tree-node-info { display:flex; align-items:center; gap:1rem; flex:1; min-width:0; }
.bd-tree-node-title { margin:0; font-weight:600; line-height:1.3; flex:1; min-width:0; }

/* =============================================================
   BaseDatos: Listado de Familias – estilos unificados
   Problema que soluciona: quita CSS inline del template y aplica halo blanco
   Ubicación: /basedatos/familias/ – componentes .bd-*
   ============================================================= */




.bd-search-container { margin-bottom:2rem; padding-bottom:2rem; border-bottom:1px solid var(--border-color); }
.bd-search-wrapper { display:flex; max-width:600px; margin:0 auto; position:relative; gap:0; }
.bd-search-input { flex:1; padding:1rem 1.5rem; border:2px solid var(--border-color); border-radius: var(--border-radius) 0 0 var(--border-radius); background: var(--bg-primary); color: var(--text-primary); font-size:1rem; outline:none; transition: all .3s ease; }
.bd-search-input:focus { border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow); }
.bd-search-input::placeholder { color: var(--text-muted); }
.bd-search-btn { padding:1rem 1.5rem; background: var(--primary); color:#fff; border:2px solid var(--primary); border-radius:0 var(--border-radius) var(--border-radius) 0; cursor:pointer; transition: all .3s ease; display:flex; align-items:center; justify-content:center; }
.bd-search-btn:hover { background: var(--primary-hover); border-color: var(--primary-hover); }

.basedatos-page .bd-container { position: relative; }
/* =============================================================
   BaseDatos: botón de acceso al Panel como icono fijo
   Problema que soluciona: convierte el botón grande en icono y lo ubica en esquina
   Ubicación: /basedatos/index – .bd-panel-icon-btn dentro de .bd-container
   ============================================================= */
.bd-panel-icon-btn { position:absolute; top:.75rem; right:.75rem; width:36px; height:36px; display:inline-flex; align-items:center; justify-content:center; border-radius: var(--border-radius); background: var(--bg-secondary); border:1px solid var(--border-color); color: var(--text-secondary); text-decoration:none; transition: var(--transition-normal); }
.bd-panel-icon-btn:hover { background: var(--overlay-hover); color: var(--text); border-color: var(--border-color); transform: translateY(-1px); }

/* Acciones en una sola fila dentro de BaseDatos */
.basedatos-page .bd-actions { display:flex; gap:.75rem; flex-wrap:nowrap; justify-content:center; }

.bd-navigation-list { display:flex; flex-direction:column; gap:1rem; }
.bd-nav-item { background: var(--bg-primary); border:1px solid var(--border-color); border-radius: var(--border-radius-lg); box-shadow: var(--shadow-sm); transition: all .3s ease; overflow:hidden; }
.bd-nav-item:hover { box-shadow: var(--shadow); transform: translateY(-2px); border-color: var(--border-color); }
.bd-nav-header { display:flex; align-items:center; padding:1.5rem; cursor:pointer; transition: background-color .2s; justify-content: space-between; }
/* Navegación: quitar iluminación blanca en hover de la cabecera */
.bd-nav-header:hover { background: var(--bg-secondary); }
.bd-nav-left { display:flex; align-items:center; gap:15px; flex:1; }
.bd-nav-icon { color: var(--primary); margin-right:1rem; font-size:1.5rem; display:flex; align-items:center; justify-content:center; min-width:24px; height:24px; }
.bd-nav-content { flex:1; min-width:0; }
.bd-nav-title { color: var(--text-primary); font-size:1.25rem; font-weight:600; margin-bottom:0; display:flex; align-items:center; gap:10px; }
.bd-nav-badges { display:flex; gap:.5rem; flex-wrap:wrap; }
.bd-badge { padding:.25rem .75rem; border-radius:9999px; font-size:.75rem; font-weight:500; }
.bd-badge-code { background: rgba(156,163,175,0.2); color: var(--text-secondary); }
.bd-badge-family { background: rgba(59,130,246,0.2); color: var(--primary); font-style: italic; }
.bd-nav-metrics { display:flex; gap:1rem; margin-left:auto; margin-right:1rem; }
.bd-metric-pill { display:flex; align-items:center; gap:.25rem; padding:.5rem .75rem; background: rgba(16,185,129,0.2); color: var(--success); border-radius:9999px; font-size:.875rem; font-weight:500; }
.bd-metric-pill.chapters { background: rgba(245,158,11,0.2); color: var(--warning); }
.bd-metric-pill.subcapters { background: rgba(139,92,246,0.2); color: #a855f7; }
.bd-nav-actions { display:flex; gap:.5rem; }
.bd-action-btn { padding:.5rem; border:none; border-radius: var(--border-radius); cursor:pointer; transition: all .2s ease; display:flex; align-items:center; justify-content:center; width:36px; height:36px; text-decoration:none; }
.bd-action-btn.view { background: var(--primary); color:#fff; }
.bd-action-btn.view:hover { background: var(--primary-hover); }
.bd-action-btn.edit { background: var(--warning); color:#fff; }
.bd-action-btn.edit:hover { background: #d97706; }
.bd-action-btn.delete { background: var(--danger); color:#fff; }
.bd-action-btn.delete:hover { background: #dc2626; }
.bd-nav-children { display:none; padding:0 1rem 1rem 1rem; border-top:1px solid var(--border-color); background: rgba(0,0,0,0.1); }
.bd-nav-children.expanded { display:block; animation: slideDown .3s ease-out; }
/* Indentación visual de elementos anidados de familias */
.bd-nav-children .bd-nav-item { margin-left: 2rem; margin-bottom: .5rem; }
@keyframes slideDown { from { opacity:0; max-height:0; } to { opacity:1; max-height:500px; } }
.bd-empty-state { text-align:center; padding:4rem 2rem; color: var(--text-secondary); }
.bd-empty-icon { font-size:4rem; margin-bottom:1rem; opacity:.5; }
.bd-empty-title { font-size:1.5rem; font-weight:600; color: var(--text-primary); margin-bottom:.5rem; }
.bd-empty-description { font-size:1rem; margin-bottom:2rem; }
.bd-text-muted { color: var(--text-muted); }
.bd-text-danger { color: var(--danger); }
.bd-loading { text-align:center; padding:2rem; color: var(--text-secondary); }
.bd-loading-spinner { width:40px; height:40px; border:4px solid var(--border-color); border-top:4px solid var(--primary); border-radius:50%; animation: spin 1s linear infinite; margin:0 auto 1rem; }
@keyframes spin { 0% { transform: rotate(0deg);} 100% { transform: rotate(360deg);} }
.bd-hidden { display:none !important; }
@media (max-width:768px) { .bd-container{padding:1.5rem;} .bd-nav-header{padding:1rem;} .bd-nav-metrics{flex-direction:column; gap:.5rem;} .bd-nav-actions{flex-direction:column;} }
.bd-tree-node-title a { color: var(--text); text-decoration:none; transition: var(--transition-normal); display:block; word-wrap: break-word; }
.bd-tree-node-title a:hover { color: var(--primary); }
.bd-tree-node-code { font-family:'Courier New', monospace; font-size:.875rem; font-weight:600; padding:.25rem .5rem; border-radius:4px; transition: var(--transition-normal); flex-shrink:0; min-width: fit-content; }
.bd-tree-node-stats { display:flex; gap:.75rem; flex-shrink:0; align-items:center; }
.bd-tree-stat-item { font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.5px; padding:.25rem .5rem; border-radius:4px; background: var(--card); color: var(--muted); border:1px solid var(--border-color); transition: var(--transition-normal); white-space:nowrap; min-width:fit-content; }

/* Colores por nivel jerárquico */
.bd-familia-node { background: var(--bg-primary); border-left: 4px solid var(--familia-color); }
.bd-familia-node .bd-tree-node-title { font-size:1.25rem; font-weight:600; color: var(--text); }
.bd-familia-node .bd-tree-node-code { background: rgba(34,197,94,0.10); color: var(--familia-color); border: 1px solid rgba(34,197,94,0.20); }
.bd-familia-node .bd-tree-stat-item { color: var(--familia-color); border-color: rgba(34,197,94,0.20); background: rgba(34,197,94,0.05); }

.bd-capitulo-node { background: var(--bg-primary); margin-left: 2rem; border-left: 4px solid var(--capitulo-color); }
.bd-capitulo-node .bd-tree-node-title { font-size:1.1rem; font-weight:600; color: var(--text); }
.bd-capitulo-node .bd-tree-node-code { background: rgba(249,115,22,0.10); color: var(--capitulo-color); border: 1px solid rgba(249,115,22,0.20); }
.bd-capitulo-node .bd-tree-stat-item { color: var(--capitulo-color); border-color: rgba(249,115,22,0.20); background: rgba(249,115,22,0.05); }

.bd-subcapitulo-node { background: var(--bg-primary); margin-left: 2rem; border-left: 4px solid var(--subcapitulo-color); }
.bd-subcapitulo-node .bd-tree-node-title { font-size:1rem; font-weight:500; color: var(--text); }
.bd-subcapitulo-node .bd-tree-node-code { background: rgba(59,130,246,0.10); color: var(--subcapitulo-color); border: 1px solid rgba(59,130,246,0.20); }
.bd-subcapitulo-node .bd-tree-stat-item { color: var(--subcapitulo-color); border-color: rgba(59,130,246,0.20); background: rgba(59,130,246,0.05); }
.bd-subcapitulo-node .bd-tree-node-header { cursor: default; }

.bd-partida-node { background: var(--bg-primary); margin-left: 2rem; border-left: 4px solid var(--partida-color); }
.bd-partida-node .bd-tree-node-title { font-size:.9rem; font-weight:500; color: var(--text); }
.bd-partida-node .bd-tree-node-code { background: rgba(31,41,55,0.10); color: var(--partida-color); border: 1px solid rgba(31,41,55,0.20); }
.bd-partida-node .bd-tree-stat-item { color: var(--partida-color); border-color: rgba(31,41,55,0.20); background: rgba(31,41,55,0.05); }
.bd-partida-node .bd-tree-node-header { cursor: default; }

/* Imágenes de partida */
.bd-tree-node-image { flex-shrink:0; margin-right:1rem; }
.bd-partida-tree-img { width:48px; height:48px; object-fit:cover; border-radius:8px; border:2px solid var(--border-color); background: var(--bg-secondary); }
.bd-partida-tree-img-placeholder { width:48px; height:48px; display:flex; align-items:center; justify-content:center; background: var(--bg-secondary); border:2px solid var(--border-color); border-radius:8px; color: var(--text-secondary); font-size:1.2rem; }

/* Acciones y feedback de copiar */
.bd-tree-node-actions { display:flex; gap:.5rem; margin-left:1rem; opacity:0; transition: opacity .2s ease; }
.bd-tree-node:hover .bd-tree-node-actions { opacity:1; }
.bd-tree-copy-btn { background: var(--primary); color:#fff; border:none; border-radius:4px; padding:.25rem .5rem; cursor:pointer; font-size:.75rem; transition: var(--transition-normal); display:flex; align-items:center; justify-content:center; min-width:24px; height:24px; }
.bd-tree-copy-btn:hover { background: var(--primary-hover); transform: scale(1.1); }
.bd-tree-copy-btn:active { transform: scale(0.95); }
.bd-tree-copy-btn i { font-size:.7rem; }
.bd-tree-price { color: var(--success) !important; font-weight:600; font-family:'Courier New', monospace; }
.bd-tree-copy-btn.copied { background: var(--success); animation: bdPulse .3s ease; }
@keyframes bdPulse { 0% { transform: scale(1);} 50% { transform: scale(1.2);} 100% { transform: scale(1);} }

/* Estado vacío del árbol */
.bd-tree-empty { text-align:center; padding: 4rem 2rem; color: var(--text-secondary); background: var(--bg-primary); border:none; margin:0; }
.bd-tree-empty-icon { font-size:3rem; margin-bottom:1rem; color: var(--primary); }
.bd-tree-empty-title { font-size:1.25rem; font-weight:600; margin-bottom:.5rem; color: var(--text); }
.bd-tree-empty-desc { margin:0 0 2rem 0; font-size:1rem; color: var(--text-secondary); line-height:1.5; }

/* =============================================================
   BaseDatos: tarjetas y grid de familias/capítulos/subcapítulos/items
   Problema que soluciona: recupera estilo original sin inline
   Ubicación: /basedatos/ index – clases legacy .bd-family-*
   ============================================================= */
.bd-families-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(350px, 1fr)); gap: 1.5rem; margin-bottom: 2rem; }
.bd-families-grid .bd-family-card { background: var(--panel); border: 2px solid var(--border-color); border-radius: var(--border-radius); padding: 1.5rem; transition: var(--transition-normal); position: relative; overflow: hidden; text-decoration: none; color: inherit; }
.bd-families-grid .bd-family-card:hover { border-color: var(--fd-focus-border); transform: translateY(-2px); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow), var(--shadow-md); text-decoration: none; color: inherit; }
.bd-family-header { display:flex; justify-content: space-between; align-items: start; margin-bottom: 1rem; }
.bd-family-title { color: var(--text); font-size: 1.25rem; font-weight: 600; margin: 0; line-height: 1.3; }
.bd-family-code { font-family: 'Courier New', monospace; color: var(--primary); font-weight: 600; font-size: 0.875rem; background: rgba(59,130,246,0.10); padding: 0.25rem 0.5rem; border-radius: 4px; }
.bd-family-description { color: var(--text-secondary); font-size: 0.95rem; line-height: 1.5; margin-bottom: 1.5rem; min-height: 3rem; }
.bd-family-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-bottom: 1.5rem; }
.bd-family-stats .bd-stat-item { text-align: center; padding: 0.75rem; background: var(--card); border-radius: var(--border-radius); border: 1px solid var(--border-color); }
.bd-family-stats .bd-stat-number { display: block; font-size: 1.25rem; font-weight: 700; color: var(--primary); margin-bottom: 0.25rem; }
.bd-family-stats .bd-stat-label { font-size: 0.75rem; color: var(--muted); text-transform: uppercase; font-weight: 600; letter-spacing: 0.5px; }
/* (retirado) BaseDatos: etiqueta "Última actualización" en cards */
/* Colores específicos por tipo */
.bd-family-card.families .bd-family-code { background: rgba(16,185,129,0.10); color: var(--success); }
.bd-family-card.families .bd-stat-number { color: var(--success); }
.bd-family-card.chapters .bd-family-code { background: rgba(245,158,11,0.10); color: var(--warning); }
.bd-family-card.chapters .bd-stat-number { color: var(--warning); }
.bd-family-card.subchapters .bd-family-code { background: rgba(239,68,68,0.10); color: var(--danger); }
.bd-family-card.subchapters .bd-stat-number { color: var(--danger); }
.bd-family-card.items .bd-family-code { background: rgba(59,130,246,0.10); color: var(--muted); }
.bd-family-card.items .bd-stat-number { color: var(--muted); }
@media (max-width: 768px) { .bd-families-grid { grid-template-columns: 1fr; gap: 1rem; } .bd-family-stats { grid-template-columns: repeat(2, 1fr); } }

/* =============================================================
   BaseDatos: contadores generales (cards grandes)
   Problema que soluciona: reintroduce los contadores originales sin inline
   Ubicación: /basedatos/ index – .bd-stats-*
   ============================================================= */
.bd-stats-container { margin-top: 2rem; }
.bd-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; }
.bd-stat-card { background: var(--card); padding: 1.5rem; border-radius: var(--border-radius); border: 1px solid var(--border-color); text-align: center; box-shadow: var(--shadow-sm); transition: var(--transition-normal); }
.bd-stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.bd-stat-card-number { font-size: 2rem; font-weight: 700; }
.bd-stat-card-label { font-weight: 500; }
.bd-stat-card--familia .bd-stat-card-number, .bd-stat-card--familia .bd-stat-card-label { color: var(--success); }
.bd-stat-card--capitulo .bd-stat-card-number, .bd-stat-card--capitulo .bd-stat-card-label { color: var(--warning); }
.bd-stat-card--subcapitulo .bd-stat-card-number, .bd-stat-card--subcapitulo .bd-stat-card-label { color: var(--danger); }
.bd-stat-card--partida .bd-stat-card-number, .bd-stat-card--partida .bd-stat-card-label { color: var(--muted); }
@media (max-width: 768px) {
    .bd-family-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    
    .bd-search-form {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    
    .bd-chapter-header {
        flex-direction: column;
        align-items: start;
        gap: 1rem;
    }
    
    .bd-chapter-stats {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .bd-metadata {
        flex-direction: column;
        gap: 0.5rem;
    }
}

/* Responsive design mejorado */
@media (max-width: 768px) {
    .hierarchy-grid {
        grid-template-columns: 1fr !important;
    }
    
    .stats-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    
    .search-form {
        grid-template-columns: 1fr !important;
    }
}

/* ===== ESTILOS DE DASHBOARD (migrado desde dashboard.css) ===== */
/* Dashboard Styles - DomedGest */

/* Dashboard neutrals migrados: usan tokens globales */

/* Dashboard Layout */
.dashboard-container {
    background-color: #f5f6fa;
    min-height: 100vh;
    padding: 2rem 0;
}

.dashboard-card {
    background: white;
    border-radius: var(--border-radius);
  box-shadow: var(--shadow);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
  transition: var(--transition-normal);
    border: none;
}

.dashboard-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

/* Statistics Cards */
.stat-card {
    text-align: center;
    border-left: 4px solid var(--primary-color);
    position: relative;
    overflow: hidden;
}

.stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 60px;
    height: 60px;
    background: linear-gradient(45deg, transparent 50%, rgba(255, 255, 255, 0.1) 50%);
    border-radius: 0 0 0 60px;
}

.stat-card.success {
    border-left-color: var(--success-color);
}

.stat-card.warning {
    border-left-color: var(--warning-color);
}

.stat-card.danger {
    border-left-color: var(--danger-color);
}

.stat-card.info {
    border-left-color: var(--info-color);
}

.stat-number {
    font-size: 2.5rem;
    font-weight: 700;
    margin: 0;
    color: var(--dark-color);
    line-height: 1.2;
}

.stat-label {
    color: #6c757d;
    font-size: 0.9rem;
    margin-top: 0.5rem;
    font-weight: 500;
}

.stat-icon {
    position: absolute;
    top: 1rem;
    right: 1rem;
    font-size: 2rem;
    opacity: 0.1;
}

/* Chart Containers */
.chart-container {
    position: relative;
    height: 400px;
    margin: 1rem 0;
}

.chart-container.small {
    height: 250px;
}

.chart-container.large {
    height: 500px;
}

.chart-header {
    display: flex;
    justify-content: between;
    align-items: center;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid #e9ecef;
}

.chart-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--dark-color);
    margin: 0;
}

.chart-controls {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Real-time Indicators */
.real-time-indicator {
    display: inline-block;
    width: 8px;
    height: 8px;
    background-color: var(--success-color);
    border-radius: 50%;
    margin-right: 8px;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% { 
        opacity: 1; 
        transform: scale(1);
    }
    50% { 
        opacity: 0.5; 
        transform: scale(1.1);
    }
    100% { 
        opacity: 1; 
        transform: scale(1);
    }
}

.connection-status {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 0.5rem 1rem;
    border-radius: 20px;
    font-size: 0.8rem;
    z-index: 1050;
    transition: var(--transition-normal);
    box-shadow: var(--shadow);
}

.connection-status.connected {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.connection-status.disconnected {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

/* Alerts and Updates */
.alert-item {
    padding: 0.75rem;
    margin-bottom: 0.5rem;
    border-radius: 8px;
    border-left: 4px solid var(--warning-color);
    background-color: #fff3cd;
    transition: var(--transition-normal);
}

.alert-item:hover {
    transform: translateX(2px);
}

.alert-item.danger {
    border-left-color: var(--danger-color);
    background-color: #f8d7da;
}

.alert-item.success {
    border-left-color: var(--success-color);
    background-color: #d4edda;
}

.alert-item.info {
    border-left-color: var(--info-color);
    background-color: #d1ecf1;
}

.update-item {
    padding: 0.75rem;
    margin-bottom: 0.5rem;
    border-radius: 8px;
    background-color: var(--light-color);
    border-left: 3px solid var(--primary-color);
    transition: var(--transition-normal);
}

.update-item:hover {
    background-color: #e9ecef;
    transform: translateX(2px);
}

.update-item.external {
    border-left-color: #7b1fa2;
}

/* Trend Indicators */
.trend-indicator {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.875rem;
    font-weight: 500;
    transition: var(--transition-normal);
}

.trend-indicator.up {
    background-color: #ffebee;
    color: #c62828;
}

.trend-indicator.down {
    background-color: #e8f5e8;
    color: #2e7d32;
}

/* (sección removida: duplicaba reglas de panel de filtros; ver bloque unificado más abajo) */

.trend-indicator.stable {
    background-color: #f5f5f5;
    color: #616161;
}

/* Price Badges */
.price-badge {
    font-size: 1.5rem;
    font-weight: bold;
    padding: 0.5rem 1rem;
    border-radius: 8px;
    display: inline-block;
    transition: var(--transition-normal);
}

.price-badge.current {
    background-color: #e3f2fd;
    color: #1976d2;
}

.price-badge.external {
    background-color: #f3e5f5;
    color: #7b1fa2;
}

.price-badge:hover {
    transform: scale(1.05);
}

/* Reliability Badges */
.reliability-badge {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    border-radius: 12px;
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.reliability-badge.high {
    background-color: #d4edda;
    color: #155724;
}

.reliability-badge.medium {
    background-color: #fff3cd;
    color: #856404;
}

.reliability-badge.low {
    background-color: #f8d7da;
    color: #721c24;
}

/* Loading States */
.loading-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid #f3f3f3;
    border-top: 3px solid var(--primary-color);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.loading-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--border-radius);
    z-index: 10;
}

/* Buttons and Controls */
.refresh-btn {
    background: none;
    border: none;
    color: var(--primary-color);
    cursor: pointer;
    font-size: 1.1rem;
    padding: 0.25rem;
    border-radius: 4px;
    transition: var(--transition-normal);
}

.refresh-btn:hover {
    background-color: #e9ecef;
    transform: rotate(180deg);
}

.back-button {
    background: none;
    border: 1px solid var(--primary-color);
    color: var(--primary-color);
    padding: 0.5rem 1rem;
    border-radius: 6px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    transition: var(--transition);
    font-weight: 500;
}

.back-button:hover {
    background-color: var(--primary-color);
    color: white;
    text-decoration: none;
    transform: translateX(-2px);
}

/* Filter Controls */
.filter-controls {
    background-color: var(--light-color);
    padding: 1rem;
    border-radius: 8px;
    margin-bottom: 1rem;
    border: 1px solid #dee2e6;
}

.filter-group {
    margin-bottom: 1rem;
}

.filter-group:last-child {
    margin-bottom: 0;
}

.filter-label {
    font-weight: 500;
    color: var(--dark-color);
    margin-bottom: 0.5rem;
    display: block;
}

/* Metadata Items */
.metadata-item {
    background-color: var(--light-color);
    padding: 0.5rem;
    border-radius: 4px;
    margin-bottom: 0.25rem;
    font-size: 0.875rem;
    border-left: 2px solid var(--primary-color);
}

/* =============================================================
   Utilidades generales
   Problema que soluciona: reemplaza estilos inline repetidos en templates
   Ubicación: usado en administración, clientes, proveedores y más
   ============================================================= */
.bd-text-center { text-align: center; }
.bd-col-span-all { grid-column: 1 / -1; }
.bd-row { display:flex; align-items:center; }
.bd-gap-6 { gap:6px; }
.bd-gap-8 { gap:8px; }
.bd-gap-12 { gap:12px; }
.bd-flex-1 { flex:1; }
.bd-text-sm { font-size: .9rem; }
.bd-avatar-64 { width:64px; height:64px; border:1px solid var(--line); border-radius:8px; overflow:hidden; background: var(--bg); display:flex; align-items:center; justify-content:center; }
.bd-img-contain { max-width:100%; max-height:100%; object-fit:contain; }
.bd-min-w-0 { min-width:0; }
.bd-strong-md { font-size:1.1rem; color: var(--text); }
.bd-justify-between { justify-content: space-between; }
.bd-mb-075 { margin-bottom: .75rem; }
.bd-avatar-48 { width:48px; height:48px; border:1px solid var(--line); border-radius:8px; overflow:hidden; background: var(--bg); display:flex; align-items:center; justify-content:center; }
.bd-relative { position: relative; }
.bd-hidden { display: none !important; }
.bd-absolute-center { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color: var(--muted); }
.bd-menu-popover { position:absolute; top:52px; right:0; min-width:180px; z-index:50; display:none; }
.bd-icon-28 { font-size:28px; }
.bd-items-end { align-items:flex-end; }
.bd-items-start { align-items:flex-start; }
.bd-nowrap { flex-wrap: nowrap; }
.bd-hr-16 { margin:16px 0; }
.bd-flex-18 { flex: 1.8; }
.bd-flex-12 { flex: 1.2; }
/* Enlaces unificados */
.bd-link { color: var(--primary); text-decoration: none; }
.bd-link:hover { text-decoration: underline; }
/* =============================================================
   Admin: Updates Panel
   Problema que soluciona: estilos del panel de actualizaciones sin CSS inline
   Ubicación: templates/admin/updates_panel.html
   ============================================================= */
.history-tools .form-control { background: var(--panel); color: var(--text); border:1px solid var(--line); }
.history-container details { background: var(--card); border:1px solid var(--line); border-radius: var(--border-radius); margin-bottom:8px; }
.history-container summary { cursor:pointer; padding:10px 12px; color: var(--text); font-weight:600; }
.history-container pre { margin:0; padding:12px; background: var(--panel); border-top:1px solid var(--line); }
.bd-loading-overlay { position:absolute; inset:0; background: rgba(0,0,0,0.5); display:flex; align-items:center; justify-content:center; z-index:10; border-radius: var(--border-radius); }
.bd-loading-box { text-align:center; color: var(--text); }
.bd-spinner { width:34px; height:34px; border:3px solid rgba(255,255,255,0.25); border-top-color: var(--primary); border-radius:50%; animation: bdSpin 0.9s linear infinite; margin: 0 auto 8px; }
@keyframes bdSpin { to { transform: rotate(360deg);} }
/* ============================================================= */
/* ============================================================= */

.metadata-item strong {
    color: var(--dark-color);
}

/* =============================================================
   Administración: Verificación de Códigos REF
   Problema que soluciona: conservar la esencia visual del módulo sin CSS inline
   Ubicación: templates/administracion/verificar_codigos_ref.html
   ============================================================= */
.admin-verificacion-ref .verification-actions { display:flex; gap:1rem; justify-content:center; margin-bottom:2rem; }
.admin-verificacion-ref .section-title { color: var(--text); font-size:1.5rem; font-weight:600; margin-bottom:1.5rem; display:flex; align-items:center; gap:.5rem; }
.admin-verificacion-ref .section-title i { color: var(--warning); }
.admin-verificacion-ref .problems-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(400px, 1fr)); gap:1.5rem; margin-bottom:2rem; }
.admin-verificacion-ref .problem-card { background: var(--bg); border: 1px solid var(--line); border-radius: var(--border-radius); padding:1.5rem; transition: all .2s ease; }
.admin-verificacion-ref .problem-card:hover { border-color: var(--warning); transform: translateY(-2px); box-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,0.08)); }
.admin-verificacion-ref .problem-header { display:flex; align-items:center; gap:1rem; margin-bottom:1rem; }
.admin-verificacion-ref .problem-icon { display:flex; align-items:center; justify-content:center; width:48px; height:48px; border-radius: var(--border-radius); font-size:1.5rem; color:white; background: var(--warning); }
.admin-verificacion-ref .problem-title { color: var(--text); font-size:1.1rem; font-weight:600; margin:0 0 .25rem 0; }
.admin-verificacion-ref .problem-type { color: var(--text-secondary); font-size:.9rem; margin:0; }
.admin-verificacion-ref .problem-count { text-align:center; }
.admin-verificacion-ref .count-number { display:block; color: var(--warning); font-size:1.5rem; font-weight:700; }
.admin-verificacion-ref .count-label { color: var(--text-secondary); font-size:.8rem; }
.admin-verificacion-ref .problem-content { margin-bottom:1.5rem; }
.admin-verificacion-ref .examples-title { color: var(--text); font-size:.95rem; font-weight:600; margin-bottom:.75rem; }
.admin-verificacion-ref .examples-list { display:flex; flex-direction:column; gap:.5rem; }
.admin-verificacion-ref .example-item { display:flex; justify-content:space-between; align-items:center; padding:.5rem; background: rgba(0,0,0,0.05); border-radius:4px; }
.admin-verificacion-ref .example-code { color: var(--primary); font-weight:600; font-size:.85rem; }
.admin-verificacion-ref .example-name { color: var(--text-secondary); font-size:.85rem; text-align:right; }
.admin-verificacion-ref .more-items { justify-content:center; }
.admin-verificacion-ref .more-text { color: var(--muted); font-style: italic; font-size:.8rem; }
.admin-verificacion-ref .problem-actions { display:flex; justify-content:center; }
.admin-verificacion-ref .mass-action-section { margin-top:2rem; }
.admin-verificacion-ref .mass-action-card { background: var(--bg); border: 1px solid var(--primary); border-radius: var(--border-radius); padding:1.5rem; }
.admin-verificacion-ref .mass-action-header { display:flex; align-items:center; gap:1rem; margin-bottom:1rem; }
.admin-verificacion-ref .mass-action-icon { display:flex; align-items:center; justify-content:center; width:48px; height:48px; border-radius: var(--border-radius); font-size:1.5rem; color:white; background: var(--primary); }
.admin-verificacion-ref .mass-action-title { color: var(--text); font-size:1.2rem; font-weight:600; margin:0 0 .25rem 0; }
.admin-verificacion-ref .mass-action-description { color: var(--text-secondary); font-size:.95rem; margin:0; }
.admin-verificacion-ref .mass-action-actions { display:flex; justify-content:center; }
.admin-verificacion-ref .mass-action-btn { padding:.75rem 1.5rem; font-size:.9rem; }
.admin-verificacion-ref .success-section { display:flex; justify-content:center; align-items:center; min-height:300px; }
.admin-verificacion-ref .success-card { background: var(--bg); border: 1px solid var(--success); border-radius: var(--border-radius); padding:3rem; text-align:center; max-width:500px; }
.admin-verificacion-ref .success-icon { font-size:4rem; color: var(--success); margin-bottom:1.5rem; }
.admin-verificacion-ref .success-title { color: var(--text); font-size:1.5rem; font-weight:700; margin-bottom:1rem; }
.admin-verificacion-ref .success-description { color: var(--text-secondary); font-size:1rem; line-height:1.5; margin-bottom:2rem; }
.admin-verificacion-ref .success-actions { display:flex; justify-content:center; }
/* ============================================================= */

/* Export Buttons */
.export-buttons {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.export-buttons .btn {
    margin: 0;
}

/* Responsive Design */
@media (max-width: 768px) {
    .dashboard-card {
        padding: 1rem;
        margin-bottom: 1rem;
    }
    
    .stat-number {
        font-size: 2rem;
    }
    
    .chart-container {
        height: 300px;
    }
    
    .chart-container.small {
        height: 200px;
    }
    
    .connection-status {
        position: relative;
        top: auto;
        right: auto;
        margin-bottom: 1rem;
        display: inline-block;
    }
    
    .export-buttons {
        justify-content: center;
        margin-top: 1rem;
    }
    
    .back-button {
        width: 100%;
        justify-content: center;
        margin-bottom: 1rem;
    }
}

@media (max-width: 576px) {
    .dashboard-container {
        padding: 1rem 0;
    }
    
    .stat-number {
        font-size: 1.8rem;
    }
    
    .price-badge {
        font-size: 1.2rem;
        padding: 0.4rem 0.8rem;
    }
    
    .chart-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }
    
    .chart-controls {
        width: 100%;
        justify-content: center;
    }
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
    :root {
        --light-color: #2d3748;
        --dark-color: #f7fafc;
    }
    
    .dashboard-container {
        background-color: #1a202c;
    }
    
    .dashboard-card {
        background: #2d3748;
        color: #f7fafc;
    }
    
    .metadata-item {
        background-color: #4a5568;
    }
    
    .update-item {
        background-color: #4a5568;
    }
    
    .filter-controls {
        background-color: #4a5568;
        border-color: #718096;
    }
}

/* Print Styles */
@media print {
    .connection-status,
    .refresh-btn,
    .back-button,
    .export-buttons,
    .filter-controls {
        display: none !important;
    }
    
    .dashboard-card {
        box-shadow: none;
        border: 1px solid #dee2e6;
        break-inside: avoid;
    }
    
    .chart-container {
        height: 300px;
    }
}

/* Accessibility */
.dashboard-card:focus-within {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

.refresh-btn:focus,
.back-button:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

/* High contrast mode */
@media (prefers-contrast: high) {
    .dashboard-card {
        border: 2px solid var(--dark-color);
    }
    
    .stat-card {
        border-left-width: 6px;
    }
    
    .alert-item,
    .update-item {
        border-left-width: 6px;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    
    .real-time-indicator {
        animation: none;
    }
    
    .loading-spinner {
        animation: none;
        border-top-color: transparent;
    }
}
/* ===== PANEL THEME (migrado desde basedatos/panel/css/theme.css) ===== */

/* Variables de tema */
/* Variables de tema eliminadas (duplicadas)
   Uso: se delega en static/css/theme-light.css y theme-dark.css
   Problema: evitamos sobrescribir el acento global y mantener consistencia */

/* TRAE:START tokens-form */
/* Form tokens (política: estilos de formularios centralizados en unified, variando por tema) */
/* eliminado: tokens fd-* por tema; definidos en theme-light.css y theme-dark.css */

/* Formularios genéricos basados en tokens */
[data-theme] .form-control,
[data-theme] .form-select,
[data-theme] textarea,
[data-theme] input[type="text"],
[data-theme] input[type="password"],
[data-theme] input[type="email"],
[data-theme] input[type="number"],
[data-theme] input[type="search"],
[data-theme] .input-group-text {
  background-color: var(--fd-bg) !important;
  border-color: var(--fd-border) !important;
  color: var(--fd-text) !important;
}
[data-theme] .form-control::placeholder,
[data-theme] textarea::placeholder,
[data-theme] input::placeholder,
[data-theme] .form-text,
[data-theme] .help-text {
  color: var(--fd-muted) !important;
}
[data-theme] .form-label,
[data-theme] label,
[data-theme] .form-floating label {
  color: var(--fd-text) !important;
}
[data-theme] .form-control:focus,
[data-theme] .form-select:focus,
[data-theme] textarea:focus,
[data-theme] input:focus {
  background-color: var(--fd-bg-focus) !important;
  border-color: var(--fd-focus-border, var(--fd-focus)) !important;
  box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow) !important;
  outline: none !important;
}
[data-theme] .form-check-input {
  background-color: var(--fd-bg) !important;
  border-color: var(--fd-border) !important;
}
[data-theme] .form-check-input:checked {
  background-color: var(--fd-focus) !important;
  border-color: var(--fd-focus) !important;
}
[data-theme] .form-check-label { color: var(--fd-text) !important; }
.form-check.form-switch .form-check-input:checked { background-color: var(--primary) !important; border-color: var(--primary) !important; }
.form-check.form-switch .form-check-input:focus { box-shadow: none !important; }
/* Evitar tinte azul en hover sobre los iconos de toggle dentro de botones */
.btn:hover .fa-toggle-on, .btn:hover .fa-toggle-off { color: inherit !important; }
.btn.btn-outline-light:focus { box-shadow: none !important; }
.btn:hover .fa-trash { color: inherit !important; }
.bd-delete { background: transparent !important; border-color: var(--border-color) !important; }
.bd-delete:hover, .bd-delete:focus { background: transparent !important; border-color: var(--fd-focus-border, var(--primary)) !important; box-shadow: 0 0 0 3px var(--fd-focus-shadow) !important; }
.bd-delete .fa-trash { transition: color .15s ease; }
.bd-delete{ display:inline-flex; align-items:center; justify-content:center; height:28px; width:36px; padding:0; }
.bd-delete i{ line-height:1; }
.btn.bd-delete{ display:inline-flex; align-items:center; justify-content:center; height:28px; width:36px; padding:0!important; }
.btn.bd-delete i{ line-height:1; }

/* Botón de toggle de acciones: sin relleno, halo exterior en hover/focus */
.bd-toggle { background: transparent !important; border-color: var(--border-color) !important; }
.bd-toggle:hover, .bd-toggle:focus { background: transparent !important; border-color: var(--fd-focus-border, var(--primary)) !important; box-shadow: 0 0 0 3px var(--fd-focus-shadow) !important; }
.bd-toggle .fa-toggle-on, .bd-toggle .fa-toggle-off { transition: color .15s ease; }
.bd-toggle{ display:inline-flex; align-items:center; justify-content:center; height:28px; width:36px; padding:0; }
.bd-toggle i{ line-height:1; }
.btn.bd-toggle{ display:inline-flex; align-items:center; justify-content:center; height:28px; width:36px; padding:0!important; }
.btn.bd-toggle i{ line-height:1; }

/* Switch compacto para botones de acción */

/* Evitar halo azul/global en icono switch dentro de botones */

/* TRAE:END tokens-form */

/* Reset y base */
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
  transition: background-color 0.2s, color 0.2s;
}

/* Header */
.panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.5rem;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 2px 4px var(--shadow);
}

/* Loader */
.loader {
  width: 18px;
  height: 18px;
  border: 2px solid var(--line);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  display: inline-block;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Count badges */
.count-badge {
  background: var(--primary);
  color: white;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.2rem 0.5rem;
  border-radius: 12px;
  min-width: 20px;
  text-align: center;
  display: inline-block;
}

.panel-header .title {
  font-size: 1.25rem;
  font-weight: 600;
}

/* TRAE:START toast-native */
.toast-native {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 9999;
  padding: .75rem 1rem;
  border-radius: var(--border-radius, 8px);
  background: var(--surface);
  color: var(--text);
  box-shadow: 0 4px 12px var(--shadow);
  border: 1px solid var(--border);
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity .18s ease, transform .18s ease;
}
.toast-native.show { opacity: 1; transform: translateY(0); }
.toast-native.success { border-color: var(--success); }
.toast-native.error { border-color: var(--danger); }
.toast-native.info { border-color: var(--info); }
/* TRAE:END toast-native */

/* TRAE:START dg-login-component */
/* Login container (fuente de verdad: estilos de componente) */
.dg-login-container {
  width: 360px;
  max-width: 92vw;
  padding: 20px;
  margin: 60px auto 24px;
  border-radius: 12px;
  text-align: center;
  background: var(--login-bg);
  color: var(--login-text);
  box-shadow: var(--login-shadow);
}

.dg-login-title { font-size: 1.25rem; font-weight: 600; margin-bottom: 0.75rem; }
.dg-login-actions { margin-top: 12px; }
.dg-login-input { height: 40px; padding: 8px 12px; border-radius: 8px; }
.dg-login-submit { height: 42px; border-radius: 10px; }

.alert-login { margin: 10px 0 16px; padding: 10px 12px; border-radius: 10px; border: 1px solid var(--line); background: rgba(255,255,255,.04); color: var(--text); }
.alert-login.error { border-color: var(--danger, #ef4444); }
.alert-login.warning { border-color: var(--warning, #f59e0b); }

/* Formularios del login (override escopado para invariancia) */
.dg-login-container .form-control,
.dg-login-container .form-select,
.dg-login-container textarea,
.dg-login-container input[type="text"],
.dg-login-container input[type="password"],
.dg-login-container input[type="email"],
.dg-login-container input[type="number"],
.dg-login-container input[type="search"],
.dg-login-container .input-group-text {
  background-color: var(--login-fd-bg) !important;
  border-color: var(--login-fd-border) !important;
  color: var(--login-fd-text) !important;
}
.dg-login-container .form-control::placeholder,
.dg-login-container textarea::placeholder,
.dg-login-container input::placeholder,
.dg-login-container .form-text,
.dg-login-container .help-text { color: var(--login-fd-muted) !important; }
.dg-login-container .form-label,
.dg-login-container label,
.dg-login-container .form-floating label { color: var(--login-fd-text) !important; }
.dg-login-container .form-control:focus,
.dg-login-container .form-select:focus,
.dg-login-container textarea:focus,
.dg-login-container input:focus {
  background-color: var(--login-fd-bg-focus) !important;
  border-color: var(--login-fd-focus-border, var(--login-fd-focus)) !important;
  box-shadow: 0 0 0 0.18rem var(--login-fd-focus-shadow) !important;
  outline: none !important;
}
.dg-login-container .form-check-input {
  background-color: var(--login-fd-bg) !important;
  border-color: var(--login-fd-border) !important;
}
.dg-login-container .form-check-input:checked {
  background-color: var(--login-fd-focus) !important;
  border-color: var(--login-fd-focus) !important;
}
.dg-login-container .form-check-label { color: var(--login-fd-text) !important; }

/* Botón primario dentro del login: usar acento fijo */
.dg-login-container .btn-primary {
  background: var(--login-accent) !important;
  border-color: var(--login-accent) !important;
  color: #fff !important;
}
.dg-login-container .btn-primary:hover {
  filter: brightness(0.92);
}

@media (min-width: 768px) {
  .dg-login-container { margin-top: 80px; }
}
/* TRAE:END dg-login-component */
/* TRAE:END dg-login-component */

/* Layout principal */
.bd-layout {
  display: flex;
  height: calc(100vh - 80px);
}

.bd-sidebar {
  width: 300px;
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
}

.bd-sidebar-top {
  padding: 1rem;
  border-bottom: 1px solid var(--border);
}

.bd-tree {
  flex: 1;
  overflow-y: auto;
  padding: 0.5rem;
}

.bd-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.bd-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.5rem;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

.bd-breadcrumb {
  font-size: 0.875rem;
  color: var(--text-muted);
}

.bd-search {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.bd-toolbar {
  padding: 1rem 1.5rem;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  display: flex;
  gap: 0.5rem;
}

.bd-panel {
  flex: 1;
  overflow: auto;
  position: relative;
}

/* Componentes */
.btn {
  padding: 0.5rem 1rem;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.875rem;
  transition: all 0.2s;
}

.btn:hover {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}

.btn.primary {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}

.btn.primary:hover {
  background: var(--primary-hover);
  border-color: var(--primary-hover);
}

.input, .select {
  padding: 0.5rem;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  border-radius: 4px;
  font-size: 0.875rem;
}

.input:focus, .select:focus {
  outline: none;
  border-color: var(--fd-focus-border);
  box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow);
}

/* Árbol */
.tree-node {
  margin: 2px 0;
}

.tree-item {
  display: flex;
  align-items: center;
  padding: 0.25rem 0.5rem;
  cursor: pointer;
  border-radius: 4px;
  font-size: 0.875rem;
  transition: background-color 0.2s;
}

.tree-item:hover {
  background: var(--border);
}

.tree-item.active {
  background: var(--primary);
  color: white;
}

.tree-item.dragging {
  opacity: 0.5;
}

.tree-toggle {
  width: 16px;
  height: 16px;
  margin-right: 0.25rem;
  border: none;
  background: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}

.tree-toggle:before {
  content: "▶";
  font-size: 10px;
  transition: transform 0.2s;
}

.tree-toggle.expanded:before {
  transform: rotate(90deg);
}

.tree-children {
  margin-left: 1rem;
  display: none;
}

.tree-children.expanded {
  display: block;
}

/* Tabla */
.bd-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg);
}

.bd-table th,
.bd-table td {
  padding: 0.75rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
  font-size: 0.875rem;
}

.bd-table th {
  background: var(--surface);
  font-weight: 600;
  position: sticky;
  top: 0;
  z-index: 1;
}

.bd-table tbody tr:hover {
  background: var(--surface);
}

.bd-empty {
  padding: 3rem;
  text-align: center;
  color: var(--text-muted);
  font-style: italic;
}

/* Drag & Drop */
.sortable-ghost {
  opacity: 0.4;
}

.sortable-chosen {
  background: var(--primary) !important;
  color: white !important;
}

.drop-zone {
  min-height: 2px;
  background: var(--primary);
  margin: 2px 0;
  border-radius: 1px;
}

/* Responsive */
@media (max-width: 768px) {
  .bd-layout {
    flex-direction: column;
  }
  
  .bd-sidebar {
    width: 100%;
    height: 200px;
  }
  
  .bd-topbar {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
  }
  
  .bd-search {
    flex-wrap: wrap;
  }
}

/* === ESTILOS PARA SELECCIÓN MÚLTIPLE === */

/* Fila seleccionada */
.bd-table tbody tr.selected {
  background: rgba(255, 255, 255, 0.10) !important;
  border-left: 3px solid var(--line);
}

.bd-table tbody tr.selected:hover {
  background: rgba(255, 255, 255, 0.15) !important;
}

/* =============================================================
   Tablas: contenedor y utilidades
   Problema que soluciona: elimina inline overflow/nowrap en M365 y otros módulos
   Ubicación: templates/m365/inspector_firmas_ia.html, listados varios
   ============================================================= */
.bd-table-container { background: var(--card); border: 1px solid var(--line); border-radius: var(--border-radius); padding: 1rem; overflow-x: auto; }
.bd-nowrap { white-space: nowrap; }
.bd-border-top { border-top: 1px solid var(--line); }

/* Información de selección */
#selection-info {
  position: fixed;
  bottom: 20px;
  right: 20px;
  background: var(--primary);
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 20px;
  font-size: 0.875rem;
  font-weight: 600;
  box-shadow: var(--shadow);
  z-index: 1000;
  display: none;
}

/* Botones de acciones masivas */
.bulk-action-btn {
  background: var(--warning);
  color: white;
  border: none;
  display: none;
}

.bulk-action-btn:hover {
  background: #d97706;
}

/* === OVERLAY PARA ACTUALIZACIÓN MASIVA === */

.overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.overlay-content {
  background: var(--surface);
  border-radius: 8px;
  width: 90%;
  max-width: 500px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
}

.overlay-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.overlay-header h3 {
  margin: 0;
  color: var(--text);
  font-size: 1.25rem;
  font-weight: 600;
}

.close-btn {
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.2s;
}

.close-btn:hover {
  background: var(--border);
  color: var(--text);
}

.overlay-body {
  padding: 1.5rem;
}

.overlay-footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--border);
  background: var(--bg);
}

.form-group {
  margin-bottom: 1rem;
}

.form-group label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--text);
  font-weight: 500;
}

/* Formularios: reemplazado por bloque canónico basado en fd-* (líneas ~3080) */

.btn-secondary {
  background: var(--border);
  color: var(--text);
}

.btn-secondary:hover {
  background: var(--text-muted);
}

.btn-primary {
  background: var(--primary);
  color: white;
}

.btn-primary:hover {
  background: #2563eb;
}

/* TRAE:START dg-profile-tabs */
/* Pestañas de perfil con soporte para temas */
#profileTabs.nav-tabs { 
  border-bottom: none; 
}

#profileTabs .nav-link {
  color: var(--text) !important;
  border: 1px solid var(--line);
  border-radius: .375rem;
  margin-right: .25rem;
  background-color: transparent;
  transition: all 0.2s ease;
}

#profileTabs .nav-link:hover {
  border-color: var(--primary);
  background-color: var(--overlay-hover);
}

#profileTabs .nav-link.active {
  color: var(--text-inverse) !important;
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

/* Separador bajo las pestañas */
.tab-separator {
  border-top: 1px solid var(--line);
  opacity: 1;
  margin-top: .25rem;
  margin-bottom: 1rem;
}
/* TRAE:END dg-profile-tabs */

/* TRAE:START dg-theme-select */
/* Selector de tema con apariencia unificada (sin romper Bootstrap) */
.dg-theme-select {
  max-width: 220px;
  background-color: var(--fd-bg);
  color: var(--fd-text);
  border-color: var(--fd-border);
}

.dg-theme-select:focus {
  background-color: var(--fd-bg-focus);
  border-color: var(--fd-focus-border, var(--fd-focus));
  box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow);
}

.dg-pref-row {
  display: flex;
  align-items: center;
  gap: .75rem;
}

.dg-pref-row .dg-pref-label {
  min-width: 160px;
  color: var(--text);
}

.dg-pref-row .dg-pref-range {
  flex: 1;
}

.dg-pref-row .dg-pref-value {
  min-width: 48px;
  text-align: right;
  color: var(--muted);
}

.dg-pref-row .dg-pref-reset {
  border-color: var(--fd-border);
  color: var(--text);
}

.dg-pref-row .dg-pref-status {
  color: var(--muted);
}
/* TRAE:END dg-theme-select */
/* --- Sidebar v3 extended styles ported from DomedGest8 (stable) --- */
.sidebar-toggle-btn { display: none !important; }
.sidebar-overlay { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background: rgba(0, 0, 0, 0.6); z-index: 1040; backdrop-filter: blur(4px); opacity: 0; pointer-events: none; transition: opacity .16s ease; }
/* Mostrar suavemente el overlay cuando el sidebar está abierto, evitando parpadeos por cambios bruscos de display */
body.sidebar-open .sidebar-overlay { opacity: 1; pointer-events: auto; }
.sidebar { position: fixed; top: 0; left: 0; width: 240px; height: 100vh; background: var(--panel); border-right: 1px solid rgba(255,255,255,.12); box-shadow: 4px 0 20px var(--shadow); z-index: 1050; transition: transform 0.16s ease; overflow: hidden; display: flex; flex-direction: column; }
.sidebar-container { display: flex; flex-direction: column; height: 100%; padding: 0; animation: slideInLeft 0.3s ease; }
.sidebar-container.width-mini { width: 80px; }
.sidebar-container.width-normal { width: 240px; }
.sidebar-container.width-wide { width: 400px; }
.sidebar-search-header { padding: 16px; border-bottom: 1px solid var(--line); background: var(--bg); }
.search-container { position: relative; }
.sidebar-search-input { width: 100%; padding: 10px 12px 10px 40px; background: var(--card); border: 1px solid var(--line); border-radius: 8px; color: var(--text); font-size: 14px; transition: all 0.2s ease; }
.sidebar-search-input:focus { outline: none; border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow); }
.sidebar-search-input::placeholder { color: var(--muted); }
.search-icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--muted); font-size: 14px; }
.sidebar-section-title { color: var(--muted); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; margin: 0 0 8px 0; padding: 0 16px; }
.sidebar-favorites { padding: 16px 0; border-bottom: 1px solid rgba(255,255,255,.08); }
.favorites-container { display: flex; flex-wrap: wrap; gap: 8px; padding: 0 16px; max-height: 120px; overflow-y: auto; }
.favorite-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: var(--card); border: 1px solid var(--line); border-radius: 20px; color: var(--text); font-size: 12px; font-weight: 500; text-decoration: none; transition: all 0.2s ease; cursor: pointer; white-space: nowrap; }
.favorite-chip:hover { background: var(--primary); border-color: var(--primary); color: white; transform: translateY(-1px); }
.favorite-chip i { font-size: 10px; }
.favorite-chip.more-favorites { background: var(--bg); border-style: dashed; color: var(--muted); }
.favorite-chip.more-favorites:hover { background: var(--primary); border-style: solid; color: white; }
.chip-label { max-width: 80px; overflow: hidden; text-overflow: ellipsis; }
.sidebar-navigation { flex: 1; overflow-y: auto; padding: 16px 0; }
.navigation-group { margin-bottom: 4px; }
.group-header { width: 100%; display: flex; align-items: center; gap: 8px; padding: 8px 16px; background: transparent; border: none; color: var(--text); font-size: 13px; font-weight: 600; text-align: left; cursor: pointer; transition: background-color .08s ease, color .08s ease; }
.group-header:hover { background: transparent; }
.group-count{ display:none !important; }
.group-header.collapsed .group-toggle { transform: rotate(0deg); }
.group-toggle { color: var(--muted); font-size: 10px; transition: transform 0.2s ease; }
.group-title { flex: 1; }
.group-count { color: var(--muted); font-size: 11px; background: rgba(255,255,255,.08); padding: 2px 6px; border-radius: 10px; min-width: 18px; text-align: center; }
.group-items { padding-left: 8px; }
.navigation-item { position: relative; display: flex; align-items: center; margin-bottom: 2px; }
.nav-link { flex: 1; display: flex; align-items: center; gap: 8px; padding: 8px 16px; color: var(--text); text-decoration: none; font-size: 13px; border-radius: 6px; transition: background-color .08s ease, color .08s ease; margin-right: 10px; }
.nav-link:hover { background: rgba(255,255,255,.06); color: inherit; text-decoration: none; }
.nav-link.disabled { color: var(--muted); cursor: not-allowed; opacity: 0.5; }
.nav-link i { width: 16px; text-align: center; font-size: 12px; color: var(--muted); }
.nav-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
/* Eliminado: estilos de botón de pin en el sidebar */
/* Eliminado: estilos del botón Cerrar específico del sidebar v3 (.sidebar-close-btn) */
.favorites-modal-overlay { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background: rgba(0, 0, 0, 0.7); z-index: 1060; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
.favorites-modal { background: var(--panel); border: 1px solid rgba(255,255,255,.12); border-radius: 12px; box-shadow: 0 12px 30px var(--shadow); width: 90%; max-width: 400px; max-height: 80vh; overflow: hidden; display: flex; flex-direction: column; }
.modal-header { padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,.08); display: flex; align-items: center; justify-content: space-between; }
.modal-header h5 { margin: 0; color: var(--text); font-size: 16px; font-weight: 600; }
.modal-close { background: transparent; border: none; color: var(--muted); font-size: 20px; cursor: pointer; padding: 4px; border-radius: 4px; transition: all 0.2s ease; }
.modal-close:hover { background: rgba(255,255,255,.1); color: var(--text); }
.modal-body { padding: 16px 20px; overflow-y: auto; }
.favorite-item { display: flex; align-items: center; gap: 12px; padding: 10px 0; color: var(--text); text-decoration: none; border-bottom: 1px solid rgba(255,255,255,.05); transition: all 0.2s ease; }
.favorite-item:last-child { border-bottom: none; }
.favorite-item:hover { color: var(--primary); text-decoration: none; padding-left: 8px; }
.favorite-item i { width: 16px; text-align: center; color: var(--muted); }
.sidebar-safe-mode { display: none !important; visibility: hidden !important; pointer-events: none !important; }
.safe-mode-content { display: none !important; }
.btn-reset { background: rgba(255,255,255,.2); border: 1px solid rgba(255,255,255,.3); color: white; padding: 4px 8px; border-radius: 4px; font-size: 11px; cursor: pointer; transition: all 0.2s ease; }
.btn-reset:hover { background: rgba(255,255,255,.3); }
body.sidebar-open { overflow: hidden; }
@media (max-width: 768px) { .sidebar { width: 280px; } .sidebar-container.width-wide { width: 280px; } .favorites-container { max-height: 80px; } .chip-label { max-width: 60px; } }
@keyframes slideInLeft { from { transform: translateX(-100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.sidebar-navigation{ scrollbar-width: none; }
.sidebar-navigation::-webkit-scrollbar{ width: 0; height: 0; }
.sidebar-navigation::-webkit-scrollbar-track{ background: transparent; }
.sidebar-navigation::-webkit-scrollbar-thumb{ background: transparent; }
.favorites-container::-webkit-scrollbar, .modal-body::-webkit-scrollbar { width: 6px; }
.favorites-container::-webkit-scrollbar-track, .modal-body::-webkit-scrollbar-track { background: transparent; }
.favorites-container::-webkit-scrollbar-thumb, .modal-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); border-radius: 3px; }
.favorites-container::-webkit-scrollbar-thumb:hover, .modal-body::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.3); }
/* === DG FIX: Botón sidebar siempre visible y por encima === */
#btn-sidebar{
  position: fixed !important;
  left: 12px !important;
  bottom: 12px !important;
  z-index: 2147483646 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 42px; height: 42px;
  border-radius: 10px;
  /* Color ajustado a gris oscuro consistente con el tema */
  background-color: #2b2b2b !important;
  color: var(--dg-btn-fg, #fff);
  border: 1px solid rgba(255,255,255,.15);
  opacity: .98;
  pointer-events: auto !important;
  visibility: visible !important;
}
#btn-sidebar[hidden]{
  display: inline-flex !important;
}
#sidebar-overlay{
  position: fixed !important;
  inset: 0 !important;
  z-index: 2147483600 !important; /* por debajo del botón */
}
/* Evitar que layouts de apps tapen la esquina inferior izquierda */
.modal-backdrop, .offcanvas-backdrop, .page-mask, .overlay,
.admin-overlay, .basedatos-overlay, .obras-overlay, .clientes-overlay{
  z-index: 9999 !important;
}
/* Asegurar que el modal quede por encima del backdrop y overlays para no bloquear clics */
.modal { z-index: 10001 !important; pointer-events: none !important; background: transparent !important; }
.modal-dialog { pointer-events: auto !important; }
.modal-backdrop { z-index: 0 !important; display: none !important; opacity: 0 !important; pointer-events: none !important; }

/* Cuando hay un modal abierto, desactivar overlays de sidebar u otros que puedan interferir */
body.dg-modal-open #sidebar-overlay,
body.dg-modal-open .sidebar-overlay { z-index: 0 !important; pointer-events: none !important; opacity: 0 !important; }
/* Neutralizar ocultaciones comunes */
.d-none#btn-sidebar, .hidden#btn-sidebar, .visually-hidden#btn-sidebar{
  display: inline-flex !important;
}
/* =============================================================
   Breadcrumb y contenedores comunes
   Problema que soluciona: elimina duplicación de estilos de breadcrumb
   Ubicación: múltiples listados y detalle (Clientes, Proveedores, Obras)
   ============================================================= */
.bd-breadcrumb { display:flex; align-items:center; gap:.5rem; margin-bottom:1.5rem; padding:.75rem 1rem; background: var(--card); border-radius: var(--border-radius); border:1px solid var(--line); box-shadow:0 3px 10px var(--shadow), 0 1px 3px rgba(0,0,0,0.08); }
.bd-breadcrumb a { color: var(--primary); text-decoration:none; font-weight:700; transition:color .2s; display:inline-flex; align-items:center; gap:.45rem; }
.bd-breadcrumb a:hover { color: var(--primary-hover); }
.bd-breadcrumb-separator { color: var(--muted); font-weight:700; font-size:1.1rem; }
.bd-breadcrumb-current { color: var(--text); font-weight:700; display:inline-flex; align-items:center; gap:.45rem; }
.bd-breadcrumb i { margin-right:0; line-height:1; }
/* =============================================================
   Contenedor de módulo (contenido principal)
   Problema que soluciona: aplica sombra base y iluminación blanca en hover, consistente con Clientes
   Ubicación: usado por la mayoría de vistas con contenido central
   ============================================================= */
.bd-container { max-width: 1000px; margin:0 auto; background: var(--card); color: var(--text); border-radius: var(--border-radius); padding: 1.5rem; border:1px solid var(--line); box-shadow: var(--shadow); transition: none; }
/* Regla universal: el contenedor principal no cambia en hover/focus/active (sin halo ni incremento de sombra) */
.bd-container:hover, .bd-container:focus, .bd-container:active { box-shadow: none !important; border-color: var(--line) !important; transition: none !important; }

/* Tarjetas/paneles: iluminación blanca sutil coherente con el contenedor */
.bd-panel:hover, .bd-card:hover, .cliente-card:hover, .obra-card:hover { border-color: var(--line); box-shadow: var(--shadow); }
/* Evitar bordes solapados dentro de contenedores principales */
.bd-container .bd-panel { border: none; box-shadow: 0 1px 2px rgba(0,0,0,0.08); }
@media (max-width: 768px) { .bd-container { padding: 1.5rem; margin: 0 1rem; } }
/* =============================================================
   Listas: eliminar borde exterior, mantener borde de tarjeta
   Problema que soluciona: evita doble línea sin quitar el borde de cada tarjeta
   Ubicación: listas con .bd-partidas-list y contenedores que las rodean
   ============================================================= */
.bd-partidas-list { border: none !important; box-shadow: none !important; }
/* Clientes: sin halo blanco en contenedor principal */
.clientes-page .bd-container { box-shadow: var(--shadow) !important; border-color: var(--line) !important; }
.clientes-page .bd-container:hover,
.clientes-page .bd-container:focus,
.clientes-page .bd-container:active { box-shadow: var(--shadow) !important; border-color: var(--line) !important; }
.clientes-page .container.main-container:hover { box-shadow: var(--shadow) !important; border-color: var(--line) !important; }
/* Clientes: wrapper global con sombra base en ambos temas */
.clientes-page .container.main-container { box-shadow: var(--shadow) !important; }
/* Regla universal: wrapper global mantiene la misma sombra en hover/focus/active */
.container.main-container:hover,
.container.main-container:focus,
.container.main-container:active { box-shadow: var(--shadow) !important; border-color: var(--line) !important; transition: none !important; }
/* Clientes: evitar brillo en bloques de búsqueda y resultados dentro de la página */
.clientes-page .bd-search-container:hover { box-shadow: none !important; border-color: var(--line) !important; }
.clientes-page .search-result-item:hover { box-shadow: none !important; border-color: var(--line) !important; }
/* Clientes: neutralizar sombras de paginación en hover */
.clientes-page .bd-page:hover,
.clientes-page .bd-pagination .bd-btn:hover,
.clientes-page .bd-pagination-link:hover,
.clientes-page .bd-pagination-btn:hover { box-shadow: none !important; }
/* Clientes: neutralizar cualquier sombra dentro del contenedor principal en hover */
.clientes-page .bd-container *:hover { box-shadow: none !important; }
/* Clientes: evitar micro-animaciones del contenedor principal */
.clientes-page .bd-container { transition: none !important; }
/* Clientes: desactivar halo blanco en tarjetas/paneles dentro del contenedor */
.clientes-page .bd-panel:hover,
.clientes-page .bd-card:hover,
.clientes-page .obra-card:hover { box-shadow: var(--shadow) !important; border-color: var(--line) !important; }
/* Clientes: las tarjetas de la lista se iluminan con halo blanco en hover */
[data-theme="dark"] .clientes-page .cliente-card:hover { border-color: rgba(255,255,255,0.80) !important; box-shadow: 0 0 0 3px rgba(255,255,255,0.18), 0 8px 20px rgba(0,0,0,0.35) !important; }
[data-theme="light"] .clientes-page .cliente-card:hover { border-color: var(--primary) !important; box-shadow: 0 0 0 3px rgba(255,255,255,0.10), 0 8px 20px rgba(0,0,0,0.20) !important; }
/* Clientes: desactivar halo por focus dentro de tarjetas */
.clientes-page .obra-card:focus-within,
.clientes-page .obra-card:focus-visible,
.clientes-page .cliente-card:focus-within,
.clientes-page .bd-card:focus-within { box-shadow: none !important; outline: none; border-color: var(--line) !important; }

/* Clientes: también desactivar brillo de panel interior para que no parezca el contenedor iluminado */
/* Clientes: mantener brillo en tarjetas y paneles; solo desactivar en contenedor principal */

/* =============================================================
   Hero y utilidades de espaciado (Clientes alta)
   Problema que soluciona: elimina inline styles de encabezado del formulario
   Ubicación: templates/clientes/cliente_form.html
   ============================================================= */
.page-hero { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:6px 0; gap:6px; }
.hero-icon { width:64px; height:64px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--bg); border:1px solid var(--line); }
.bd-gap-10 { gap:10px; }
.ai-btn-group { display:flex; gap:6px; align-items:center; }
.ai-model-switch { display:flex; gap:4px; }
.bd-title.bd-title-center { margin:0 0 8px 0; padding-bottom:8px; }
.bd-title-icon { color: var(--muted); }

/* =============================================================
   Panel de filtros en listados
   Problema que soluciona: elimina inline styles del panel de filtros
   Ubicación: templates/proveedores/proveedor_list.html y similares
   ============================================================= */
#filter-panel { position:absolute; z-index:1000; right:0; top: calc(100% + 8px); background: var(--panel); color: var(--text); border: 1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow); padding: 0.5rem 0.6rem; min-width: 220px; transition: opacity 150ms ease, transform 150ms ease; transform: translateY(-6px); opacity:0; }
#filter-panel[aria-hidden="true"] { display: none !important; pointer-events: none; }
#filter-panel[aria-hidden="false"] { display: block !important; pointer-events: auto; }
.bd-select { width:100%; min-height:32px; height:32px; border:1px solid var(--line); border-radius:8px; background: var(--bg); color:var(--text); padding:0.25rem 0.5rem; }
.bd-label { color:var(--text); font-size:.85rem; }
.bd-check { display:inline-flex; align-items:center; gap:.35rem; color:var(--text-secondary); font-size:.9rem; }
.bd-stack { display:flex; flex-direction:column; gap:.35rem; margin-bottom:.6rem; }

/* =============================================================
   Alertas y mensajes
   Problema que soluciona: elimina inline styles en paneles de error
   Ubicación: templates/clientes/cliente_form.html y otras
   ============================================================= */
.bd-alert { background: rgba(255,255,255,.06); border: 1px solid var(--line); border-radius: var(--border-radius); }
.bd-alert-error { background: #fff5f5; border-color: #ffd7d7; }
.bd-alert .bd-error { margin:0; }

/* =============================================================
   Obras: Listado
   Problema que soluciona: tarjeta de obra, lista y estados; elimina CSS inline
   Ubicación: templates/obras/obra_list.html
   ============================================================= */
.obra-card { position: relative; background: var(--card); border: 1px solid var(--line); border-radius: var(--border-radius); padding: 16px 18px; margin-bottom: 12px; color: var(--text); box-shadow: var(--shadow-sm); }
.obra-card:hover { border-color: rgba(255,255,255,0.7); box-shadow: 0 0 0 3px rgba(255,255,255,0.12), 0 4px 12px rgba(0,0,0,0.25); }
.obra-card:focus-within, .obra-card:focus-visible { box-shadow: 0 0 0 3px rgba(255,255,255,0.18); outline: none; }
.obra-card-link { position: absolute; inset: 0; z-index: 1; }
.obra-card-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.obra-title { margin: 0; font-size: 1.2rem; color: var(--text); letter-spacing: 0.2px; }
.obra-copy-btn { z-index: 2; opacity: 0; visibility: hidden; background: none; color: #80868b; border: none; border-radius: 8px; width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: opacity .15s ease, transform .15s ease, color .2s ease; }
.obra-copy-btn i { font-size: 12px; }
.obra-card-header .obra-copy-btn:hover { opacity: 1; visibility: visible; transform: translateY(0); color: #a3a8ad; }
.obra-card-header:hover .obra-copy-btn { opacity: 1; visibility: visible; transform: translateY(0); }
.obra-card:hover .obra-copy-btn { opacity: 1; visibility: visible; transform: translateY(0); }
.obra-code:hover + .meta-copy-btn { opacity: 1; visibility: visible; transform: translateY(0); }
.obra-cliente:hover + .meta-copy-btn { opacity: 1; visibility: visible; transform: translateY(0); }
.obra-subheader { display: flex; align-items: center; gap: 12px; margin-top: 8px; }
.obra-code { display: inline-block; background: var(--primary); color: #ffffff; padding: 6px 10px; border-radius: 8px; font-weight: 600; letter-spacing: 0.4px; }
.obra-cliente { color: var(--text); font-size: 0.95rem; }
.obra-meta { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; margin-top: 14px; }
@media (max-width: 768px) { .obra-meta { grid-template-columns: 1fr; } }
.bd-partidas-list { display: flex; flex-direction: column; gap: 0; background: var(--card); border-radius: var(--border-radius); border: 1px solid var(--line); box-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,0.08)); overflow: hidden; }
.bd-partida-item { display: flex; align-items: center; padding: 1rem; border-bottom: 1px solid var(--line); transition: all 0.3s ease; text-decoration: none; color: inherit; gap: 1rem; position: relative; }
.bd-partida-item:last-child { border-bottom: none; }
.bd-partida-item:hover { background: rgba(255, 255, 255, 0.06); transform: translateX(2px); box-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,0.08)); }
.bd-partida-image { width: 60px; height: 60px; border-radius: var(--border-radius); object-fit: cover; background: var(--line); display: flex; align-items: center; justify-content: center; color: var(--muted); font-size: 1.5rem; flex-shrink: 0; }
.bd-partida-content { flex: 1; display: flex; flex-direction: column; gap: 0.25rem; }
.bd-partida-description { color: var(--text); font-size: 1rem; font-weight: 500; line-height: 1.4; margin: 0; }
.bd-partida-unit { color: var(--text-secondary); font-size: 0.875rem; font-weight: 400; }
.bd-partida-price { color: var(--primary); font-size: 1.1rem; font-weight: 700; background: rgba(59, 130, 246, 0.1); padding: 0.5rem 1rem; border-radius: var(--border-radius); min-width: 100px; text-align: center; flex-shrink: 0; position: relative; cursor: pointer; }
.bd-partida-price:hover { background: rgba(59, 130, 246, 0.15); }
.bd-copy-btn { position: absolute; top: -8px; right: -8px; width: 20px; height: 20px; border-radius: 50%; background: var(--primary); color: white; border: none; font-size: 0.75rem; cursor: pointer; opacity: 0; transition: opacity 0.2s; display: flex; align-items: center; justify-content: center; z-index: 2; }
.bd-partida-item:hover .bd-copy-btn { opacity: 1; }
.bd-copy-description { background: none; border: none; color: var(--text-secondary); cursor: pointer; padding: 0; font-size: 0.75rem; opacity: 0; transition: opacity 0.2s; margin-left: 0.5rem; z-index: 2; position: relative; }
.bd-partida-item:hover .bd-copy-description { opacity: 1; }
.bd-empty-state { text-align: center; padding: 2rem; color: var(--text-secondary); }
.bd-empty-icon { font-size: 2rem; margin-bottom: 0.5rem; opacity: 0.5; }
.bd-empty-title { font-size: 1.5rem; font-weight: 600; color: var(--text); margin-bottom: 0.5rem; }
.bd-empty-description { font-size: 1rem; margin-bottom: 2rem; color: var(--text-secondary); }
.bd-loading { text-align: center; padding: 2rem; color: var(--text-secondary); }
.bd-loading-spinner { display: inline-block; width: 2rem; height: 2rem; border: 3px solid var(--line); border-top: 3px solid var(--primary); border-radius: 50%; animation: spin 1s linear infinite; margin-bottom: 1rem; }
@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px);} to { opacity: 1; transform: translateY(0);} }
.bd-container { animation: fadeIn 0.5s ease-out; }
.bd-partida-item { animation: fadeIn 0.5s ease-out; }
/* =============================================================
   Buscadores unificados
   Problema que soluciona: estilo único con halo blanco y alias legacy
   Ubicación: Clientes, Proveedores, Obras, Administración
   ============================================================= */
.bd-search-container { background: var(--card); border: 1px solid var(--line); border-radius: var(--border-radius); padding: 1rem; margin-bottom: 1.5rem; box-shadow: 0 3px 10px var(--shadow); }
.bd-search-wrapper { display:flex; align-items:center; gap:.5rem; max-width: 640px; margin: 0 auto; }
.bd-search-input { flex:1; min-height: 38px; padding: .6rem 1rem; border:1px solid var(--line); border-radius: var(--border-radius); background: var(--bg); color: var(--text); font-size:.95rem; outline:none; transition: all .2s ease; }
.bd-search-input::placeholder { color: var(--muted); }
.bd-search-input:focus { border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow); }
.bd-search-btn { width: 38px; height: 38px; display:inline-flex; align-items:center; justify-content:center; border-radius: 50%; border: none; background: transparent; color: var(--muted); cursor: pointer; transition: color .2s ease, background-color .2s ease; }
.bd-search-btn:hover { background: rgba(255,255,255,0.06); color: var(--text); }
/* Buscador inteligente (Basedatos): cabecera visual
   Uso: d:\DomedGest\apps\basedatos\templates\basedatos\busqueda_ajax.html
   Problema: eliminar estilos inline de títulos/subtítulos y unificar colores */
.bd-search-header { text-align: center; margin-bottom: 1.5rem; }
.bd-search-title { color: var(--text); margin-bottom: .5rem; font-weight: 600; font-size: 1.5rem; }
.bd-search-subtitle { color: var(--text-secondary); font-size: 1rem; }
.bd-search-icon { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); color: var(--muted); font-size: 1.1rem; }

/* Filtros como chips interactivos
   Uso: botones de filtro en buscador inteligente
   Problema: sustituye .filter-btn con gradientes/box-shadow por estilo limpio y temable */
.bd-filter-group { display:flex; gap:.75rem; margin-bottom: 1.25rem; flex-wrap: wrap; justify-content: center; }
.bd-chip { padding: .5rem .9rem; border: 1px solid var(--line); background: var(--panel); border-radius: 9999px; cursor: pointer; transition: all .2s ease; font-weight: 600; font-size: .85rem; text-transform: uppercase; letter-spacing: .4px; color: var(--text-secondary); box-shadow: 0 2px 6px var(--shadow-sm); }
.bd-chip:hover { border-color: var(--fd-focus-border); color: var(--text); transform: translateY(-1px); box-shadow: 0 4px 12px var(--shadow); }
.bd-chip.active { background: var(--primary); border-color: var(--primary); color: var(--text-inverse); box-shadow: 0 6px 16px var(--shadow); }

/* Sugerencias rápidas (chips reutilizados)
   Uso: lista de sugerencias bajo resultados
   Problema: eliminar gradientes y sombras inline, reutilizar .bd-chip */
.bd-suggestions { background: var(--surface); border: 1px solid var(--line); border-radius: var(--border-radius); padding: .9rem; margin-top: 1rem; }
.bd-suggestion { display:inline-block; margin: .25rem; }
.bd-suggestion .bd-chip { position: relative; overflow: hidden; }
.bd-suggestion .bd-chip::before { content:''; position:absolute; inset:0; background: linear-gradient(90deg, transparent, rgba(59,130,246,0.10), transparent); opacity:0; transition: opacity .3s ease; border-radius: inherit; }
.bd-suggestion .bd-chip:hover::before { opacity:1; }

/* Resultados del buscador inteligente
   Uso: tarjetas de resultados (familia/capítulo/subcapítulo/partida)
   Problema: unificar tipografías, bordes y hover; colores por tipo via tokens */
.bd-search-results { margin-top: 1.5rem; }
.bd-results-header { display:flex; justify-content: space-between; align-items: center; margin-bottom: .75rem; padding-bottom: .5rem; border-bottom: 1px solid var(--line); }
.bd-results-count { font-weight: 600; color: var(--text); }
.bd-results-time { color: var(--text-secondary); font-size: .9rem; }
.bd-search-result-item { background: var(--panel); border: 1px solid var(--line); border-radius: 8px; padding: 1rem; margin-bottom: .9rem; transition: all .2s ease; box-shadow: 0 2px 6px var(--shadow-sm); }
.bd-search-result-item:hover { box-shadow: 0 6px 16px var(--shadow); transform: translateY(-2px); }
.bd-result-header { display:flex; justify-content: space-between; align-items: flex-start; margin-bottom: .5rem; }
.bd-result-title { font-weight: 600; color: var(--text); margin: 0; font-size: 1.05rem; }
.bd-result-type { background: var(--primary); color: var(--text-inverse); padding: .2rem .6rem; border-radius: 12px; font-size: .8rem; font-weight: 600; }
.bd-result-type.familia { background: var(--danger); }
.bd-result-type.capitulo { background: var(--warning); color: #000; }
.bd-result-type.subcapitulo { background: var(--success); }
.bd-result-type.partida { background: var(--info); }
.bd-result-code { color: var(--text-secondary); font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: .9rem; margin-bottom: .25rem; }
.bd-result-description { color: var(--text-secondary); line-height: 1.5; margin-bottom: .5rem; }
.bd-result-relevance { background: var(--surface); padding: .15rem .5rem; border-radius: 10px; font-size: .8rem; color: var(--muted); }
.bd-fade-in { animation: fadeIn .5s ease-in; }

/* Estado de error en resultados
   Uso: mensaje de error del buscador
   Problema: eliminar estilos inline en showError() y usar tokens */
.bd-error-box { border: 1px solid var(--danger); background: rgba(220,53,69,0.08); }
.bd-error-box .bd-result-title { color: var(--danger); }
/* Alias de compatibilidad para clases legacy */
.search-container { background: var(--card); border: 1px solid var(--line); border-radius: var(--border-radius); padding: 1rem; margin-bottom: 1.5rem; box-shadow: 0 3px 10px var(--shadow); }
.search-form { display:flex; align-items:center; gap:.5rem; max-width: 640px; margin: 0 auto; }
/* alias legacy 'search-input' y 'search-btn' eliminados: usar bd-search-* */
/* =============================================================
   Utilidades globales migradas desde base.html
   Problema que soluciona: elimina estilos inline globales (scrollbar, breadcrumb links)
   Ubicación: layout base.html (aplicación completa)
   ============================================================= */
* { scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.2) transparent; }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.25); border-radius: 8px; }
::-webkit-scrollbar-track { background: transparent; }
.bd-breadcrumb a,
.bd-breadcrumb a:visited,
.bd-breadcrumb a:hover,
.bd-breadcrumb a:focus,
.bd-breadcrumb a:active { text-decoration: none !important; }
#btn-sidebar { display: inline-flex !important; visibility: visible !important; opacity: 1 !important; }
/* Alias visual: unificar .breadcrumb al estilo de .bd-breadcrumb */
.breadcrumb { display:flex; align-items:center; gap:.5rem; margin-bottom:1.5rem; padding:.75rem 1rem; background: var(--card); border-radius: var(--border-radius); border:1px solid var(--line); box-shadow:0 3px 10px var(--shadow), 0 1px 3px rgba(0,0,0,0.08); }
.breadcrumb a { color: var(--text); text-decoration:none; font-weight:700; transition:color .2s; display:inline-flex; align-items:center; gap:.45rem; }
.breadcrumb a:hover { color: var(--primary); }
.breadcrumb .active, .breadcrumb-current { color: var(--text) !important; }
.breadcrumb-separator { color: var(--muted); font-weight:700; font-size:1.1rem; }
/* =============================================================
   Paginación unificada
   Problema que soluciona: estilo común de controles y estados en todos los módulos
   Ubicación: Clientes, Proveedores, Obras, Administración, M365 (alias incluidos)
   ============================================================= */
.bd-pagination { margin-top: 0; padding-top: 1.25rem; border-top: none; display: flex; flex-direction: column; gap: 1rem; align-items: center; }
.bd-pagination-info { text-align: center; }
.bd-pagination-text { color: var(--text-secondary); font-size: .95rem; font-weight: 600; }
.bd-pagination-controls { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; justify-content: center; }
/* Botón base de página */
.bd-page, .bd-pagination .bd-btn, .bd-pagination-btn, .bd-pagination-link {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 0; border-radius: 12px;
  border: 1px solid var(--line); background: var(--card); color: var(--text-secondary);
  text-decoration: none; font-weight: 700; font-size: .95rem; transition: all .2s ease;
}
.bd-page:hover, .bd-pagination .bd-btn:hover, .bd-pagination-btn:hover, .bd-pagination-link:hover {
  background: var(--panel); color: var(--text); border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow);
}
/* Estado actual */
.bd-page-current, .bd-pagination-btn-current, .bd-pagination-link.active {
  background: var(--primary); color: #ffffff; border-color: var(--primary);
}
.bd-page-current:hover, .bd-pagination-btn-current:hover, .bd-pagination-link.active:hover {
  background: var(--primary-hover); border-color: var(--primary-hover);
}
/* Estados de navegación y deshabilitado */
.bd-page-first, .bd-page-last, .bd-page-prev, .bd-page-next,
.bd-pagination-btn-first, .bd-pagination-btn-last, .bd-pagination-btn-prev, .bd-pagination-btn-next { font-size: 1rem; color: var(--text-secondary); }
.bd-page-disabled, .bd-pagination-btn-disabled { opacity: .45; cursor: not-allowed; pointer-events: none; }
/* Tema oscuro: mantener contraste y brillo blanco sutil al foco */
html[data-theme="dark"] .bd-page:focus,
html[data-theme="dark"] .bd-pagination .bd-btn:focus,
html[data-theme="dark"] .bd-pagination-btn:focus,
html[data-theme="dark"] .bd-pagination-link:focus { box-shadow: 0 0 0 3px rgba(255,255,255,0.18); outline: none; }
.search-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 9999; display: flex; align-items: flex-start; justify-content: center; padding-top: 10vh; }
.search-modal-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.7); backdrop-filter: blur(5px); }
.search-modal-content { position: relative; background: var(--card); border-radius: 12px; width: 90%; max-width: 600px; box-shadow: 0 20px 60px rgba(0,0,0,0.25); border: 1px solid var(--line); animation: modalSlideIn .3s ease-out; }
@keyframes modalSlideIn { from { opacity: 0; transform: translateY(-50px) scale(.95);} to { opacity: 1; transform: translateY(0) scale(1);} }
.search-modal-header { display: flex; justify-content: space-between; align-items: center; padding: 20px 25px 15px; border-bottom: 1px solid var(--line); }
.search-modal-header h3 { margin: 0; color: var(--text); font-size: 18px; font-weight: 600; }
.search-modal-close { background: none; border: none; color: var(--muted); font-size: 24px; cursor: pointer; padding: 0; width: 30px; height: 30px; display:flex; align-items:center; justify-content:center; border-radius:6px; transition: all .2s; }
.search-modal-close:hover { background: var(--panel); color: var(--text); }
.search-modal-body { padding: 25px; }
.modal-search-input { width: 100%; padding: 15px 20px; font-size: 16px; border: 1px solid var(--line); border-radius: 8px; background: var(--bg); color: var(--text); outline: none; transition: all .3s; box-sizing: border-box; }
.modal-search-input:focus { border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow); }
.search-results { margin-top: 20px; max-height: 300px; overflow-y: auto; }
.search-result-item { padding: 12px 15px; border-radius: 6px; margin-bottom: 8px; background: var(--panel); border: 1px solid var(--line); cursor: pointer; transition: all .2s; }
.search-result-item:hover { background: var(--card); border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow); }
.search-result-name { font-weight: 600; color: var(--text); margin-bottom: 4px; }
.search-result-details { font-size: 12px; color: var(--muted); }
.search-modal-footer { padding: 15px 25px; border-top: 1px solid var(--line); text-align: center; }
.search-modal-footer small { color: var(--muted); }
.search-modal-footer kbd { background: var(--panel); color: var(--text); padding: 2px 6px; border-radius: 3px; font-size: 11px; margin: 0 2px; }
.search-loading, .search-more-results, .no-results { text-align: center; padding: 20px; color: var(--muted); }

/* =============================================================
   M365: Inspector de Firmas IA
   Problema que soluciona: elimina estilos inline y bloque <style>, unifica resizers y filtros
   Ubicación: templates/m365/inspector_firmas_ia.html
   ============================================================= */
.bd-search-actions { margin-bottom: .75rem; padding-bottom: .5rem; border-bottom: 1px solid var(--line); display: flex; align-items: center; gap: .5rem; justify-content: flex-end; }
.bd-filter-panel { position: absolute; z-index: 1000; right: 0; top: calc(100% + 8px); background: var(--panel); color: var(--text); border: 1px solid var(--line); border-radius: var(--border-radius); box-shadow: 0 6px 18px rgba(0,0,0,0.18); padding: .6rem; min-width: 260px; }
.bd-filter-section { border-top: 1px solid var(--line); padding-top: .5rem; display: flex; flex-direction: column; gap: .35rem; }
.bd-label-sm { font-size: .85rem; }
.bd-w-100 { width: 100%; }
.bd-select-sm { min-height: 32px; height: 32px; }
.bd-form-grid-auto { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem; align-items: end; }
.bd-align-end { align-items: end; }
.bd-col-span-all { grid-column: 1 / -1; }
.bd-mb-16 { margin-bottom: 1rem; }
.bd-inline-form { display: flex; gap: .4rem; align-items: center; }
.bd-max-w-160 { max-width: 160px; }
.bd-max-w-140 { max-width: 140px; }
.bd-w-36 { width: 36px; }
.bd-w-160 { width: 160px; }
.bd-w-180 { width: 180px; }
.bd-w-200 { width: 200px; }
.bd-w-220 { width: 220px; }
.bd-justify-end { justify-content: flex-end; }
.bd-actions-end { justify-content: flex-end; }
.dg-resizable-table { table-layout: fixed; }
.dg-resizable-th { position: relative; }
.dg-resizer { position: absolute; right: -4px; top: 0; width: 12px; height: 100%; cursor: col-resize; background: transparent; }
.dg-resizer::after { content: ''; position: absolute; right: 5px; top: 0; width: 1px; height: 100%; background: transparent; }
.dg-resizable-th:hover .dg-resizer::after { background: rgba(255,255,255,.12); }
.accent-danger .dg-resizer:hover::after { background: var(--danger); }
.accent-success .dg-resizer:hover::after { background: var(--success); }
.accent-warning .dg-resizer:hover::after { background: var(--warning); }
.accent-secondary .dg-resizer:hover::after { background: var(--primary-hover); }
.accent-primary .dg-resizer:hover::after { background: var(--primary); }
.ai-thinking { display: none; align-items: center; gap: .5rem; margin-left: .75rem; }
.ai-thinking.visible { display: inline-flex; }
.ai-icon { width: 28px; height: 28px; display: inline-block; background-image: url('/static/img/ai-thinking.png'); background-size: contain; background-repeat: no-repeat; animation: spin 1.6s linear infinite; }
.ai-thinking-text { color: var(--text); font-weight: 600; }
.bd-progress { height: 10px; background: var(--bg); border: 1px solid var(--line); border-radius: 6px; overflow: hidden; }
.bd-progress-bar { height: 100%; background: var(--primary); width: 0; transition: width .3s ease; }
.wide-mode .bd-container { margin: 0; padding: 0; }
.wide-mode .card.dmd-panel { margin: 0; }
.wide-mode nav.bd-breadcrumb { display: none; }
.wide-mode .bd-table-container { padding: 0; }
/* Ajuste de paddings de .bd-container para páginas específicas (no global) */
/* Nota: Evitamos modificar .bd-container global para no afectar Clientes.
   Si se requiere en un módulo concreto, aplicar con un wrapper contextual. */
/* =============================================================
   BaseDatos: Buscar Partidas – filtros y tarjetas
   Problema que soluciona: elimina CSS inline y centraliza grid/cards
   Ubicación: apps/basedatos/templates/basedatos/buscar_partidas.html
   ============================================================= */
.bd-advanced-filters { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--line); }
.bd-filters-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.bd-filter-group { display: flex; flex-direction: column; }
.bd-filter-group label { color: var(--text); font-weight: 600; margin-bottom: 0.5rem; font-size: 0.875rem; }
.bd-filter-select, .bd-filter-input { padding: 0.5rem 0.75rem; background: var(--bg); border: 1px solid var(--line); border-radius: var(--border-radius); color: var(--text); font-size: 0.9rem; }
.bd-filter-select:focus, .bd-filter-input:focus { outline: none; border-color: var(--fd-focus-border); box-shadow: 0 0 0 0.18rem var(--fd-focus-shadow); }

.bd-results-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 1rem; margin-top: 1.25rem; }
.bd-partida-card { background: var(--card); border: 1px solid var(--line); border-radius: var(--border-radius); padding: 1rem; transition: var(--transition); cursor: pointer; text-decoration: none; color: inherit; box-shadow: 0 1px 2px rgba(0,0,0,0.08); }
.bd-partida-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--primary); }
.bd-partida-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.75rem; margin-bottom: 0.75rem; }
.bd-partida-title { color: var(--text); font-size: 1.05rem; font-weight: 700; margin: 0; line-height: 1.3; }
.bd-partida-codes { display: inline-flex; align-items: center; gap: 0.35rem; }
.bd-partida-code-full, .bd-partida-code-small { background: var(--primary); color: #ffffff; padding: 0.15rem 0.6rem; border-radius: 20px; font-size: 0.75rem; font-weight: 700; white-space: nowrap; }
.bd-partida-description { color: var(--text-secondary); font-size: 0.9rem; line-height: 1.4; margin-bottom: 0.75rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.bd-partida-hierarchy { font-size: 0.8rem; color: var(--muted); margin-bottom: 0.5rem; }
.bd-partida-hierarchy a { color: var(--primary); text-decoration: none; }
.bd-partida-hierarchy a:hover { text-decoration: underline; }
.bd-partida-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.5rem; }
.bd-partida-price { color: var(--success); font-size: 1.05rem; font-weight: 800; }
.bd-partida-mode { background: var(--warning); color: #1a1a1a; padding: 0.2rem 0.5rem; border-radius: 6px; font-size: 0.75rem; font-weight: 600; }
@media (max-width: 768px) { .bd-results-grid { grid-template-columns: 1fr; gap: 1rem; } .bd-partida-header { flex-direction: column; gap: 0.5rem; align-items: flex-start; } }

/* =============================================================
   Utilidad de espaciado
   Problema que soluciona: reemplaza style="margin-top:1rem" en detalle proveedor
   Ubicación: templates/proveedores/proveedor_detail.html
   ============================================================= */
.bd-mt-1 { margin-top: 1rem; }
/* =============================================================
   Clientes: tarjetas seleccionadas – sombra blanca
   Problema que soluciona: resalta selección sin hover luminoso en contenedor
   Ubicación: templates/clientes/cliente_list.html
   ============================================================= */
[data-theme="dark"] .clientes-page .cliente-card.is-selected,
[data-theme="dark"] .clientes-page .cliente-card[aria-selected="true"] {
  border-color: rgba(255,255,255,0.80) !important;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.18), 0 10px 28px rgba(0,0,0,0.35) !important;
}
[data-theme="light"] .clientes-page .cliente-card.is-selected,
[data-theme="light"] .clientes-page .cliente-card[aria-selected="true"] {
  border-color: var(--primary) !important;
  box-shadow: var(--shadow) !important;
}
/* =============================================================
   Modo CLARO: sombra del contenedor igual a la del breadcrumb
   Problema que soluciona: el contenedor no tenía sombra en claro
   Ubicación: todas las páginas con .bd-container y wrapper
   ============================================================= */
[data-theme="light"] .bd-container,
html[data-theme="light"] .bd-container,
html.light .bd-container { box-shadow: 0 3px 10px var(--shadow) !important; }
[data-theme="light"] .container.main-container,
html[data-theme="light"] .container.main-container,
html.light .container.main-container { box-shadow: 0 3px 10px var(--shadow) !important; }
/* Clientes: código (numero de cliente) azul canónico
   Uso: templates/clientes/cliente_list.html (.bd-item-code)
   Problema: restablecer estilo azul original para visibilidad del código */
.bd-item-code { font-family: 'Courier New', monospace; color: var(--primary); font-weight: 600; font-size: 0.875rem; background: rgba(59, 130, 246, 0.1); padding: 0.25rem 0.5rem; border-radius: 4px; display: inline-block; }
/* Halo de foco negro en MODO CLARO
   Uso: inputs de búsqueda, selects, modales y filtros en todos los módulos
   Problema: plantillas con halo azul; se fuerza negro sin tocar templates */
html.light .bd-search-input:focus,
html.light .bd-select:focus,
html.light .modal-search-input:focus,
html.light .search-box:focus,
html.light .bd-filter-select:focus,
html.light .bd-filter-input:focus,
html.light .sidebar-search-input:focus,
:root[data-theme="light"] .bd-search-input:focus,
:root[data-theme="light"] .bd-select:focus,
:root[data-theme="light"] .modal-search-input:focus,
:root[data-theme="light"] .search-box:focus,
:root[data-theme="light"] .bd-filter-select:focus,
:root[data-theme="light"] .bd-filter-input:focus,
:root[data-theme="light"] .sidebar-search-input:focus,
[data-theme="light"] .bd-search-input:focus,
[data-theme="light"] .bd-select:focus,
[data-theme="light"] .modal-search-input:focus,
[data-theme="light"] .search-box:focus,
[data-theme="light"] .bd-filter-select:focus,
[data-theme="light"] .bd-filter-input:focus,
[data-theme="light"] .sidebar-search-input:focus,
:root[data-theme="clear"] .bd-search-input:focus,
:root[data-theme="clear"] .bd-select:focus,
:root[data-theme="clear"] .modal-search-input:focus,
:root[data-theme="clear"] .search-box:focus,
:root[data-theme="clear"] .bd-filter-select:focus,
:root[data-theme="clear"] .bd-filter-input:focus,
:root[data-theme="clear"] .sidebar-search-input:focus,
html.light input:focus,
:root[data-theme="light"] input:focus,
[data-theme="light"] input:focus,
:root[data-theme="clear"] input:focus,
html.light select:focus,
:root[data-theme="light"] select:focus,
[data-theme="light"] select:focus,
:root[data-theme="clear"] select:focus,
html.light textarea:focus,
:root[data-theme="light"] textarea:focus,
[data-theme="light"] textarea:focus,
:root[data-theme="clear"] textarea:focus {
  border-color: var(--fd-focus-border) !important;
  box-shadow: 0 0 0 3px var(--fd-focus-shadow) !important;
  outline: none !important;
}
/* Pestañas canónicas (Clientes y módulos similares)
   Uso: .tabs-nav /.tab-btn /.tab-panel (templates de Clientes y otros)
   Problema: pestañas con bordes negros y aspecto anticuado; se moderniza sin tocar HTML */
.tabs-nav { display:flex; gap:0; align-items:center; margin:1rem 0; padding:0; border-bottom:1px solid var(--line); }
.tab-btn { background: transparent; color: var(--muted); border:none; border-bottom: 2px solid transparent; border-radius: 0; margin-bottom: -1px; padding:.6rem 1rem; font-weight:600; font-size:.95rem; cursor:pointer; transition: color .2s ease, border-color .2s ease; }
.tab-btn:hover { color: var(--text); border-bottom-color: var(--fd-focus-border); }
.tab-btn:focus { outline:none; color: var(--text); border-bottom-color: var(--fd-focus-border); }
.tab-btn.active { color: var(--text); border-bottom-color: var(--primary); }
.tab-panel { background: var(--card); border:1px solid var(--line); border-radius: var(--border-radius); box-shadow: 0 2px 10px var(--shadow-sm); padding: 1rem; }
/* Visibilidad de paneles de pestañas
   Uso: .tab-panel (Clientes); mostrar solo el activo */
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* Subpestañas (Historial de Clientes)
   Uso: .bd-tabs /.bd-tab /.hist-panel
   Problema: apariencia de botones; convertir a pestañas con subrayado y controlar visibilidad */
.bd-tabs { display:flex; gap:0; align-items:center; margin:.75rem 0; padding:0; border-bottom:1px solid var(--line); }
.bd-tab { background: transparent; color: var(--muted); border:none; border-bottom: 2px solid transparent; border-radius: 0; margin-bottom: -1px; padding:.5rem .9rem; font-weight:600; font-size:.95rem; cursor:pointer; transition: color .2s ease, border-color .2s ease; }
.bd-tab:hover { color: var(--text); border-bottom-color: var(--fd-focus-border); }
.bd-tab:focus { outline:none; color: var(--text); border-bottom-color: var(--fd-focus-border); }
.bd-tab.active { color: var(--text); border-bottom-color: var(--primary); }
.hist-panel { display:none; }
.hist-panel.active { display:block; }
@media (max-width: 768px) { .tabs-nav { flex-wrap: wrap; } .tab-btn { padding:.5rem .9rem; font-size:.9rem; } }
/* Clientes: asociados (Obras/Presupuestos) – moderniza listado en tarjetas
   Uso: templates/clientes/cliente_detail.html → .card .list-group.list-group-flush
   Problema: lista simple poco legible; se convierte en filas con layout y chips sin tocar HTML */
.card .list-group.list-group-flush { margin: 0; padding: 0; border: 1px solid var(--fd-border); border-radius: var(--border-radius); overflow: hidden; }
.card .list-group.list-group-flush .list-group-item { 
  display: flex; align-items: center; justify-content: space-between;
  gap: .75rem; padding: .65rem .9rem; margin: 0; /* sin espacios entre filas */
  border: 0; border-top: 1px solid var(--fd-border); border-radius: 0;
  transition: background-color .12s ease;
}
/* Bordes y esquinas visibles en el bloque completo */
.card .list-group.list-group-flush .list-group-item:first-child { border-top: 0; }
/* Franja oscura: en modo oscuro usar fondo base para dar mayor contraste */
/* Franjas tipo listado (oscuro: alterna tonos del sistema de formularios) */
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item,
html.dark .card .list-group.list-group-flush .list-group-item,
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item { 
  background: var(--fd-bg);
  color: var(--fd-text);
}
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item:nth-child(even),
html.dark .card .list-group.list-group-flush .list-group-item:nth-child(even),
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item:nth-child(even) {
  background: var(--fd-bg-focus);
}
/* Forzar franja completa cuando el template usa utilidades bootstrap */
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item.bg-transparent,
html.dark .card .list-group.list-group-flush .list-group-item.bg-transparent,
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item.bg-transparent {
  background: var(--bg) !important;
}
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item.border-0,
html.dark .card .list-group.list-group-flush .list-group-item.border-0,
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item.border-0 {
  border: 1px solid var(--line) !important;
}
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item.ps-0,
html.dark .card .list-group.list-group-flush .list-group-item.ps-0,
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item.ps-0 {
  padding-left: .9rem !important;
}
/* Franjas tipo listado (claro: alterna tonos del sistema de formularios) */
html[data-theme="light"] .card .list-group.list-group-flush .list-group-item,
html.light .card .list-group.list-group-flush .list-group-item,
:root[data-theme="light"] .card .list-group.list-group-flush .list-group-item { 
  background: var(--fd-bg);
  color: var(--fd-text);
}
html[data-theme="light"] .card .list-group.list-group-flush .list-group-item:nth-child(even),
html.light .card .list-group.list-group-flush .list-group-item:nth-child(even),
:root[data-theme="light"] .card .list-group.list-group-flush .list-group-item:nth-child(even) { 
  background: var(--fd-bg-focus);
}
.card .list-group.list-group-flush .list-group-item:hover { background: var(--surface); }
.card .list-group.list-group-flush .list-group-item .bd-link { font-weight: 600; color: var(--primary); }
/* Chip de estado/fecha acorde a franja oscura */
.card .list-group.list-group-flush .list-group-item small.text-muted { 
  color: var(--text); background: transparent; border: none;
  border-radius: 0; padding: 0; font-size: .85rem; white-space: nowrap;
}
/* En franja oscura, el enlace debe ser blanco (sin azul) */
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item .bd-link,
html.dark .card .list-group.list-group-flush .list-group-item .bd-link,
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item .bd-link,
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item a,
html.dark .card .list-group.list-group-flush .list-group-item a,
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item a {
  color: var(--fd-text) !important;
}
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item .bd-link:hover,
html.dark .card .list-group.list-group-flush .list-group-item .bd-link:hover,
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item .bd-link:hover,
html[data-theme="dark"] .card .list-group.list-group-flush .list-group-item a:hover,
html.dark .card .list-group.list-group-flush .list-group-item a:hover,
:root[data-theme="dark"] .card .list-group.list-group-flush .list-group-item a:hover {
  color: var(--fd-text) !important; text-decoration: underline;
}

/* Tarjetas: mejorar legibilidad de textos secundarios en modo oscuro
   Uso: .card .card-body .text-muted/.text-body-secondary (IA cliente, avisos, etc.)
   Problema: contraste insuficiente en fondos oscuros */
html[data-theme="dark"] .card .card-body .text-muted,
html.dark .card .card-body .text-muted,
:root[data-theme="dark"] .card .card-body .text-muted,
html[data-theme="dark"] .card .card-body .text-body-secondary,
html.dark .card .card-body .text-body-secondary,
:root[data-theme="dark"] .card .card-body .text-body-secondary {
  color: var(--text) !important;
}
/* Calendario: estilo del año (pill 2025)
   Uso: popups de datepicker en filtros de Clientes/Historial (.bd-date)
   Problema: el año aparece con fondo negro; se ilumina con fondo claro y texto blanco */
.flatpickr-calendar .flatpickr-months .flatpickr-current-month .numInputWrapper input,
.air-datepicker .air-datepicker-nav--title .air-datepicker-nav--title-year,
.pika-title .pika-label,
.ui-datepicker .ui-datepicker-year,
.datepicker .datepicker-years .datepicker-switch {
  background: var(--surface) !important;
  color: #ffffff !important;
  border: 1px solid var(--line) !important;
  border-radius: 6px !important;
  padding: 0 .45rem !important;
}
/* Botón 'Ver todas' – iluminación sutil en modo oscuro (sin borde)
   Uso: templates/clientes/cliente_detail.html → .bd-btn.bd-btn-secondary.bd-btn-sm
   Problema: iluminación excesiva; se reduce a sombra y leve fondo, sin borde */
html[data-theme="dark"] .bd-btn.bd-btn-secondary:hover,
html.dark .bd-btn.bd-btn-secondary:hover,
:root[data-theme="dark"] .bd-btn.bd-btn-secondary:hover,
html[data-theme="dark"] .bd-btn.bd-btn-secondary:focus,
html.dark .bd-btn.bd-btn-secondary:focus,
:root[data-theme="dark"] .bd-btn.bd-btn-secondary:focus,
html[data-theme="dark"] .bd-btn.bd-btn-secondary:active,
html.dark .bd-btn.bd-btn-secondary:active,
:root[data-theme="dark"] .bd-btn.bd-btn-secondary:active {
  border-color: transparent !important;
  box-shadow: 0 0 0 0.08rem rgba(255, 255, 255, 0.12) !important;
  background-color: rgba(255, 255, 255, 0.06) !important;
  color: #ffffff !important;
}
/* IA: Icono global reutilizable
   Uso: cualquier acción relacionada con IA en toda la plataforma
   Problema que soluciona: unifica el estilo de icono IA sin botón ni texto */
#ia-cliente-panel .card-header { gap:.5rem; }
#btn-ia-refrescar, .dg-ia-icon { 
  position: relative;
  display:inline-flex; align-items:center; justify-content:center;
  width: 48px; height: 48px; padding: 0; font-size: 0; /* ocultar texto */
  background-color: transparent; color: var(--text-inverse);
  border: none; border-radius: 12px;
  box-shadow: none;
  /* Icono IA exacto: usa archivo proporcionado (svg/png) */
  background-image: image-set(
    url('/static/img/ia-badge.svg') type('image/svg+xml') 1x,
    url('/static/img/ia-badge.png') type('image/png') 1x
  );
  background-size: 82%; background-repeat: no-repeat; background-position: center;
}
#btn-ia-refrescar::after, .dg-ia-icon::after{ content:""; position:absolute; inset:-2px; border-radius:14px; opacity:.18; pointer-events:none; box-shadow: 0 0 16px var(--primary); animation: iaIconBreathe 3.6s ease-in-out infinite; }
#btn-ia-refrescar > *, .dg-ia-icon > * { display: none !important; }
#btn-ia-refrescar:hover, .dg-ia-icon:hover { filter: brightness(1.03); }
#btn-ia-refrescar:focus, .dg-ia-icon:focus { outline:none; box-shadow: 0 0 0 0.12rem var(--fd-focus-shadow); }
@keyframes iaIconBreathe{ 0%,100%{ opacity:.12; transform: scale(1);} 50%{ opacity:.28; transform: scale(1.03);} }
@media (prefers-reduced-motion: reduce){ #btn-ia-refrescar::after, .dg-ia-icon::after{ animation: none; opacity:.16; } }

/* =============================================================
   Administración: Configuración IA (OpenAI)
   Problema que soluciona: elimina estilos inline y head-local en la vista
   Ubicación: templates/administracion/configuracion_ia.html
   ============================================================= */
.result-box { margin-top:.5rem; padding:.75rem 1rem; border:1px solid var(--border-color); border-radius: var(--border-radius); background: var(--card); }
.result-ok { border-color: var(--success); }
.result-error { border-color: var(--danger); }
.result-inline { margin-top:.5rem; padding:.5rem .75rem; border:1px solid var(--border-color); border-radius: var(--border-radius); background: var(--card); }
.bd-result-title { margin-bottom:.35rem; font-weight:600; }
.bd-pre { white-space: pre-wrap; margin: 0; }

.ia-switch-row { display:flex; align-items:center; gap:.5rem; }
.ia-switch { width:34px; height:20px; border-radius:9999px; border:1px solid var(--border-color); background: var(--card); position:relative; box-shadow: var(--shadow-sm); cursor:pointer; display:inline-flex; align-items:center; }
.ia-switch .ia-knob { width:14px; height:14px; border-radius:9999px; background: var(--text); position:absolute; left:18px; transition: left .18s ease; }
.ia-switch.active { background: var(--primary); border-color: var(--primary-dark); }
.ia-switch.active .ia-knob { left:2px; background: var(--text-inverse); }

.ia-toggle-group { display:flex; gap:.5rem; margin-top:.5rem; }
.ia-toggle { padding:.35rem .8rem; border-radius:9999px; border:1px solid var(--border-color); background: var(--panel); color: var(--text); font-weight:600; cursor:pointer; }
.ia-toggle.active { background: var(--primary); color: var(--text-inverse); border-color: var(--primary-dark); }
.ia-toggle.ia-sm { padding:.38rem .8rem; font-size:.95rem; white-space:nowrap; }

.inline-row { display:flex; align-items:center; gap:.6rem; width:100%; flex-wrap:nowrap; }
.inline-row .bd-form-input { flex:1 1 420px; max-width:480px; height:36px; padding:6px 10px; font-size:.95rem; }

/* Utilidades de color para iconos/textos de estado */
.bd-text-success { color: var(--success) !important; }
.bd-text-warning { color: var(--warning) !important; }
.bd-text-danger  { color: var(--danger) !important; }

/* Utilidades de visibilidad y espaciado */
.bd-hidden { display:none !important; }
.bd-visible { display:block !important; }
.bd-hr { border-color: var(--border-color) !important; }
.bd-mt-4 { margin-top: .25rem !important; }
.bd-mt-8 { margin-top: .5rem !important; }
.bd-m-0 { margin: 0 !important; }

/* Formularios: eliminar flechas en inputs numéricos (consistencia visual) */
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input[type=number] { -moz-appearance: textfield; }

/* =============================================================
   BaseDatos: tarjetas del dashboard – iluminar en blanco (hover)
   Problema que soluciona: el hover mostraba acento azul; se pide blanco
   Ubicación: apps/basedatos/templates/basedatos/dashboard/main.html
   ============================================================= */
[data-theme="dark"] .dashboard-card:hover { 
  background-color: var(--overlay-hover) !important; 
  box-shadow: 0 6px 18px var(--shadow); 
  border-color: var(--border-color) !important; 
  transform: translateY(-2px);
}
[data-theme="light"] .dashboard-card:hover { 
  background-color: var(--btn-hover-bg) !important; 
  box-shadow: 0 6px 18px var(--shadow); 
  border-color: var(--border-color) !important; 
  transform: translateY(-2px);
}
/* Subcapítulos: banner de filtro activo – elimina estilos inline y unifica visual */
.bd-filter-banner { display: block; margin-bottom: 1.25rem; padding: .75rem 1rem; background: var(--bg); border: 1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow-sm); }
.bd-filter-banner-inner { display: flex; align-items: center; gap: .6rem; }
.bd-filter-banner-inner i { color: var(--fd-accent, var(--primary)); }
.bd-filter-banner-inner span { color: var(--text-muted); }
.bd-filter-banner-inner strong { color: var(--text); font-weight: 600; }
.bd-filter-clear { margin-left: auto; }
/* =============================================================
   Presupuestos: Editor SaaS 2026
   Ubicación: templates/presupuestos/editor.html
   Problema que soluciona: moderniza el layout del editor, elimina CSS inline
   y centraliza estilos en el sistema de temas (claro/oscuro)
   ============================================================= */
.dmd-modern-header { display:flex; gap:.75rem; align-items:center; padding:.75rem 1rem; background: var(--card); border:1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow-sm); }
.dmd-modern-header .chip { padding:.25rem .5rem; border:1px solid var(--line); border-radius: 999px; font-size:.85rem; color: var(--text); background: rgba(255,255,255,.04); }
.dmd-modern-header .total { margin-left:auto; display:flex; align-items:center; gap:.5rem; font-weight:700; }
.dmd-modern-header .actions { display:flex; gap:.5rem; }
.dmd-toolbar { display:flex; gap:.5rem; align-items:center; margin:.75rem 0; }
.dmd-panel-card { background: var(--card); border:1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow); padding:.75rem 1rem; }
.dmd-summary { margin-top:8px; text-align:right; position:sticky; bottom:0; padding:12px; border-top:1px solid var(--line); background: var(--card); z-index:5; box-shadow: var(--shadow-sm); }
.dmd-drag-over { outline: 2px dashed var(--primary); }
.dmd-row-section td { background-color: rgba(255,255,255,.06); font-weight: 600; }

/* =============================================================
   Presupuestos: SaaS 2026 Premium – Header, Toolbar y Tabla
   Ubicación: templates/presupuestos/editor.html
   Problema que soluciona: rediseña por completo la estética del editor
   ============================================================= */
.pg-premium-header{ display:flex; align-items:flex-start; gap: 18px; padding: 20px 24px; background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: var(--border-radius-lg); box-shadow: 0 10px 30px var(--shadow); }
.pg-premium-title{ font-family: Inter, system-ui, Segoe UI; font-size: 28px; font-weight: 800; letter-spacing:.2px; color: var(--text); margin:0; }
.pg-premium-subtitle{ margin-top:6px; color: var(--text-secondary, var(--muted)); font-size: 13px; }
.pg-premium-right{ margin-left:auto; display:flex; flex-direction:column; align-items:flex-end; gap:6px; }
.pg-premium-total{ font-size: 36px; font-weight: 800; color: var(--text); line-height: 1; }
.pg-premium-total-note{ color: var(--text-secondary, var(--muted)); font-size: 12px; }
.premium-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.premium-btn{ display:inline-flex; align-items:center; gap:8px; height:36px; padding: 0 12px; border-radius: 12px; border:1px solid var(--border-color, var(--line)); background: var(--btn-bg, var(--card)); color: var(--text); text-decoration:none; font-weight:600; font-size: 13px; transition: all .2s ease; }
.premium-btn i{ font-size: 14px; }
.premium-btn:hover{ border-color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.14); color: var(--text); }
.premium-btn-primary{ background: var(--primary); color: #fff; border-color: var(--primary); }
.premium-btn-primary:hover{ filter: brightness(1.05); box-shadow: 0 10px 26px rgba(59,130,246,.25); }
/* Variante peligrosa (roja) */
.premium-btn-danger{ background: var(--danger); color: #fff; border-color: var(--danger); }
.premium-btn-danger:hover{ filter: brightness(1.06); box-shadow: 0 10px 26px rgba(239,68,68,.25); }

/* Presupuestos: estado disabled en acciones premium
   Uso: templates/presupuestos/editor.html (.premium-btn:disabled)
   Problema que soluciona: estilo coherente de botón deshabilitado sin CSS inline */
.premium-btn:disabled{ opacity:.6; cursor:not-allowed; box-shadow:none; }

.premium-toolbar{ display:flex; align-items:center; gap:8px; margin: 14px 0; padding: 10px 12px; background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: 12px; }
.premium-chip{ display:inline-flex; align-items:center; height:24px; padding:0 10px; border-radius:999px; border: 1px solid var(--border-color, var(--line)); background: var(--card); color: var(--text); font-size: 12px; }

.premium-table{ width:100%; border-collapse: separate; border-spacing:0; background: var(--table-bg); border:1px solid var(--table-border); border-radius: 12px; overflow:hidden; }
.premium-table thead th{ background: var(--panel); color: var(--text); font-weight:700; font-size: 13px; border-bottom: 1px solid var(--table-border); padding: 10px 12px; }
.premium-table tbody td{ border-top: 1px solid var(--border-color, var(--table-border)); color: var(--text); font-size: 14px; padding: 8px 10px; vertical-align: middle; }
.premium-table tbody tr:hover{ background: var(--table-hover-bg); }
.premium-table tbody tr:nth-child(even){ background: var(--table-stripe-bg); }
.premium-table .drag{ width: 42px; text-align:center; color: var(--text-secondary, var(--muted)); cursor: grab; }
.premium-table .drag::before{ content: '⋮⋮'; display:inline-block; opacity:.7; }
.premium-table input, .premium-table select{ background: var(--input-bg); border: 1px solid var(--input-border); color: var(--text); border-radius: 10px; height: 30px; padding: 2px 8px; }
.premium-table input:focus{ outline: none; border-color: var(--input-focus-border); box-shadow: 0 0 0 4px var(--input-focus-shadow); }
.premium-table .badge-letra{ display:inline-flex; align-items:center; height: 24px; padding:0 10px; border-radius: 999px; border:1px solid var(--border-color, var(--line)); background: var(--panel); color: var(--text); font-weight:700; }

/* Sangría elegante según tipo/nivel */
.lvl-0 .col-descripcion{ padding-left: 0; }
.lvl-1 .col-descripcion{ padding-left: 20px; }
.lvl-2 .col-descripcion{ padding-left: 40px; }

/* Footer de totales estilo Stripe */
.premium-footer{ position: sticky; bottom: 0; z-index: 8; background: rgba(26,29,33,.9); backdrop-filter: blur(8px); border-top: 1px solid var(--border-color); padding: 10px 14px; border-radius: 12px; margin-top: 12px; box-shadow: 0 -10px 30px var(--shadow); }
.premium-footer .footer-grid{ display:grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; align-items:center; }
.premium-footer .footer-item{ color: var(--text-secondary, var(--muted)); font-size: 12px; }
.premium-footer .footer-value{ color: var(--text); font-size: 16px; font-weight: 800; }

/* =============================================================
   Presupuestos: Panel lateral unificado
   Ubicación: templates/presupuestos/editor.html (aside .editor-inspector)
   Problema que soluciona: simetría y consistencia del inspector, elimina estilos inline
   ============================================================= */
.editor-layout{ display:grid; grid-template-columns: 1fr 420px; gap: 16px; align-items:start; }
.editor-inspector{ background: var(--card); border: 1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow-sm); padding: 12px 12px; position: static; top: auto; max-height: none; overflow: visible; }
.inspector-section{ background: var(--panel); border: 1px solid var(--line); border-radius: var(--border-radius); padding: 10px 12px; margin-bottom: 10px; }
.inspector-section h6{ margin:0 0 8px; font-weight: 700; color: var(--text); }

/* Adjuntos: listado y acciones
   Uso: bloque #adjuntosList dentro del panel lateral del editor
   Problema: unifica visual de filas y badges con modo claro/oscuro */
.adjuntos-list{ display:flex; flex-direction:column; gap:8px; }
.adjunto-item{ display:flex; align-items:center; gap:8px; padding:8px 10px; background: var(--card); border:1px solid var(--line); border-radius: 8px; color: var(--text); }
.adjunto-name{ flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.adjunto-type{ display:inline-flex; align-items:center; height:22px; padding:0 8px; border-radius:999px; background: var(--panel); border:1px solid var(--line); color: var(--text); font-size:.8rem; }
.adjunto-actions{ display:inline-flex; align-items:center; gap:6px; }
.adjunto-actions .btn{ padding:4px 8px; }
.adjunto-upload{ display:flex; align-items:center; gap:8px; }

/* Firma digital: estado y acciones
   Uso: bloque .firma-card dentro del inspector del editor
   Problema: estilo coherente con Clientes y legible en ambos temas */
.firma-card{ background: var(--panel); border:1px solid var(--line); border-radius: var(--border-radius); padding: 10px 12px; }
.firma-status{ display:inline-flex; align-items:center; gap:6px; padding:4px 8px; border-radius:999px; border:1px solid var(--line); background: var(--card); color: var(--text); font-weight:700; }
.firma-actions{ display:flex; gap:8px; margin-top:8px; }

/* Notas internas: área de texto
   Uso: textarea.notas-internas dentro del inspector
   Problema: tamaño compacto y contraste correcto */
.notas-internas{ width:100%; min-height:90px; resize:vertical; }

/* Responsivo: colapsar inspector debajo de la tabla en pantallas estrechas */
@media (max-width: 992px){
  .editor-layout{ grid-template-columns: 1fr; }
  .editor-inspector{ position: relative; top: 0; max-height: none; }
}

/* =============================================================
   Presupuestos: Panel IA Premium (SaaS 2026)
   Ubicación: templates/presupuestos/editor.html (aside .editor-inspector)
   Problema que soluciona: crea un asistente IA lateral moderno, minimal y elegante
   ============================================================= */
.ia-panel{ display:flex; flex-direction:column; gap:12px; }
.ia-card{ background: var(--panel); border: 1px solid var(--border-color, var(--line)); border-radius: var(--border-radius-lg); box-shadow: 0 8px 24px var(--shadow); padding: 12px 14px; }
.ia-header{ display:flex; align-items:flex-start; gap:8px; }
.ia-title{ font-size: 20px; font-weight: 600; margin:0; color: var(--text); display:flex; align-items:center; gap:6px; }
.ia-subtitle{ margin-top:4px; font-size: 13px; color: var(--text-secondary, var(--muted)); }
.ia-actions{ display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:8px; }
.ia-chip-btn{ display:inline-flex; align-items:center; gap:8px; padding: 10px 12px; border-radius: 12px; border: 1px solid var(--border-color, var(--line)); background: var(--card); color: var(--text); font-size: 12px; font-weight: 600; cursor:pointer; transition: all .2s ease; }
.ia-chip-btn i{ font-size: 14px; color: var(--text-secondary, var(--muted)); }
.ia-chip-btn:hover{ border-color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.12); }
.ia-chat{ display:flex; flex-direction:column; gap:10px; }
.ia-msg{ display:flex; align-items:flex-start; gap:8px; }
.ia-avatar{ width:26px; height:26px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; background: var(--card); border:1px solid var(--border-color, var(--line)); color: var(--primary); font-size: 14px; }
.ia-bubble{ flex:1; background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: 12px; padding: 10px 12px; color: var(--text); font-size: 14px; }
.ia-bubble code, .ia-bubble pre{ background: var(--card); border:1px solid var(--border-color, var(--line)); border-radius: 10px; padding: 8px; display:block; color: var(--text); overflow:auto; }
.ia-results{ display:flex; flex-direction:column; gap:10px; }
.ia-result-card{ background: var(--panel); border: 1px solid var(--border-color, var(--line)); border-radius: 12px; padding: 10px 12px; }
.ia-result-card .title{ font-size: 14px; font-weight: 700; color: var(--text); margin-bottom:6px; }
.ia-result-card .text{ font-size: 13px; color: var(--text-secondary, var(--muted)); }
.ia-inputbar{ position: sticky; bottom: 0; background: var(--panel); border: 1px solid var(--border-color, var(--line)); border-radius: 12px; padding: 8px 10px; display:flex; align-items:center; gap:8px; box-shadow: 0 -8px 24px var(--shadow); }
.ia-input{ flex:1; background: var(--input-bg); border:1px solid var(--input-border); color: var(--text); border-radius: 10px; height: 32px; padding: 4px 10px; }
.ia-input:focus{ outline:none; border-color: var(--input-focus-border); box-shadow: 0 0 0 4px var(--input-focus-shadow); }
/* Barra de búsqueda destacada */
.bd-searchbar{ background: var(--panel); border: 1px solid var(--line); border-radius: var(--border-radius); padding: 6px; box-shadow: var(--shadow-sm); }
.ia-icon-btn{ width:32px; height:32px; display:inline-flex; align-items:center; justify-content:center; border-radius:10px; border:1px solid var(--border-color, var(--line)); background: var(--card); color: var(--text-secondary, var(--muted)); cursor:pointer; transition: all .2s ease; }
.ia-icon-btn:hover{ border-color: var(--primary); color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.12); }

/* Tooltips de chips e iconos (sin JS)
   Uso: botones .ia-chip-btn y .ia-icon-btn con atributo [data-tip]
   Problema que soluciona: añade ayudas modernas sin CSS inline ni scripts extra */
.ia-chip-btn[data-tip], .ia-icon-btn[data-tip]{ position: relative; }
.ia-chip-btn[data-tip]::after, .ia-icon-btn[data-tip]::after{
  content: attr(data-tip);
  position: absolute;
  left: 50%; transform: translateX(-50%) translateY(-6px);
  bottom: calc(100% + 8px);
  white-space: nowrap;
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border-color, var(--line));
  border-radius: 10px;
  padding: 6px 8px;
  font-size: 12px; font-weight: 600;
  box-shadow: 0 8px 24px var(--shadow);
  opacity: 0; pointer-events: none;
  transition: opacity .15s ease, transform .15s ease;
  z-index: 50;
}
.ia-chip-btn[data-tip]:hover::after, .ia-icon-btn[data-tip]:hover::after{
  opacity: 1; transform: translateX(-50%) translateY(0);
}
.dmd-row-subtotal td { background-color: rgba(255,255,255,.03); font-weight: 600; }
.dmd-col-tiempo, .dmd-col-pt { /* columnas tiempo/precio tiempo en editor */ }
.dmd-resizable-th{ position:relative; }
.dmd-column-resizer{ position:absolute; top:0; right:0; width:4px; height:100%; cursor:col-resize; background:transparent; z-index:10; }
.dmd-column-resizer:hover{ background: rgba(0,123,255,.3); }
.dmd-column-resizing, .dmd-column-resizing *{ cursor: col-resize !important; }
.resizable-th{ position:relative; }
.column-resizer{ position:absolute; top:0; right:0; width:4px; height:100%; cursor:col-resize; background:transparent; z-index:10; }
.column-resizer:hover{ background: rgba(0,123,255,.3); }
.column-resizing, .column-resizing *{ cursor: col-resize !important; }

/* =============================================================
   Presupuestos: utilidades de ancho para cabecera
   Ubicación: templates/presupuestos/editor.html (Serie/Fecha/Estado)
   Problema que soluciona: reemplaza estilos inline de width
   ============================================================= */
.bd-w-60{ width:60px !important; }
.bd-w-90{ width:90px !important; }
.bd-w-70{ width:70px !important; }
.bd-w-80{ width:80px !important; }
.bd-w-110{ width:110px !important; }
.bd-w-120{ width:120px !important; }
.bd-w-140{ width:140px !important; }
.bd-w-170{ width:170px !important; }
.bd-w-100{ width:100px !important; }
.bd-w-130{ width:130px !important; }
.bd-w-160{ width:160px !important; }

/* Utilidades de grid compacta (configuración de columnas en editor) */
.bd-grid-2-compact{ display:grid; grid-template-columns: repeat(2, 1fr); gap:.25rem .75rem; }

/* Utilidades generales de tamaño/overflow usadas en editor */
.bd-overflow-auto{ overflow:auto !important; }
.bd-max-w-720{ max-width:720px !important; }
.bd-max-h-360{ max-height:360px !important; }

/* Etiqueta pequeña para input-group en modo compacto */
.bd-input-tag-sm{ font-size:.875rem !important; padding:.25rem .5rem !important; }

/* =============================================================
   Presupuestos: panel IA y resultados
   Ubicación: pestaña IA del editor
   Problema que soluciona: estructura visual limpia y moderna
   ============================================================= */
.ia-panel-output{ min-height:160px; overflow:auto; }
.ia-propuesta-item{ display:flex; align-items:center; gap:.5rem; padding:.25rem 0; }
.ia-propuesta-item .badge{ display:inline-flex; align-items:center; justify-content:center; min-width:32px; }
.presupuestos-editor .modal-backdrop.show{ background: transparent !important; }
.presupuestos-editor.modal-cliente-open .editor-layout{ filter: none; }
.presupuestos-editor.modal-cliente-open .pg-premium-header{ filter: none; }
.presupuestos-editor.modal-cliente-open .split-panels{ filter: none; }
.presupuestos-editor.modal-cliente-open .premium-footer{ filter: none; }
.presupuestos-editor.modal-cliente-open .summary-box{ filter: none; }
/* =============================================================
   Presupuestos: Importación Excel – Pantalla Premium SaaS 2026
   Ubicación: templates/presupuestos/import_excel.html
   Problema que soluciona: crea UI moderna para importar y mapear Excel
   ============================================================= */
.import-premium-container{ max-width: 1200px; margin: 0 auto; }
.import-header{ display:flex; flex-direction:column; gap:6px; padding: 18px 22px; background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: var(--border-radius-lg); box-shadow: 0 10px 30px var(--shadow); }
.import-title{ font-size: 26px; font-weight: 800; color: var(--text); margin:0; }
.import-subtitle{ font-size: 14px; color: var(--text-secondary, var(--muted)); }

.import-dropzone{ margin-top: 14px; background: var(--card); border: 1px dashed var(--border-color, var(--line)); border-radius: 16px; padding: 40px 28px; display:flex; flex-direction:column; align-items:center; gap:12px; transition: border-color .2s ease, box-shadow .2s ease; }
.import-dropzone.hover{ border-color: var(--primary); box-shadow: 0 0 0 6px rgba(59,130,246,.12); }
.import-icon{ width: 72px; height: 72px; border-radius: 16px; display:inline-flex; align-items:center; justify-content:center; background: var(--panel); border:1px solid var(--border-color, var(--line)); color: var(--text); font-size: 36px; }
.import-drop-title{ font-size: 18px; font-weight: 700; color: var(--text); }
.import-drop-desc{ font-size: 13px; color: var(--text-secondary, var(--muted)); }
.import-btn{ display:inline-flex; align-items:center; gap:8px; height:36px; padding:0 14px; border-radius: 12px; border:1px solid var(--border-color, var(--line)); background: var(--btn-bg, var(--card)); color: var(--text); font-weight:600; font-size: 13px; text-decoration:none; transition: all .2s ease; }
.import-btn:hover{ border-color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.12); }
.import-btn-primary{ background: var(--primary); color: #fff; border-color: var(--primary); }
.import-btn-primary:hover{ filter: brightness(1.05); box-shadow: 0 10px 26px rgba(59,130,246,.25); }

.mapper-section{ margin-top: 18px; }
.mapper-grid{ display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.mapper-card{ background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: 12px; padding: 12px; display:flex; gap: 10px; align-items:flex-start; }
.mapper-card .mapper-title{ font-size: 12px; font-weight: 700; color: var(--text-secondary, var(--muted)); margin-bottom:4px; }
.mapper-card .mapper-name{ font-size: 14px; color: var(--text); }
.mapper-card .mapper-actions{ margin-left:auto; display:flex; flex-direction:column; gap:8px; align-items:flex-end; }
.mapper-badge{ display:inline-flex; align-items:center; height:22px; padding:0 8px; border-radius:999px; border:1px solid var(--border-color, var(--line)); font-size:12px; font-weight:700; }
.mapper-badge.success{ background: rgba(74,222,128,.15); color: var(--success); }
.mapper-badge.warn{ background: rgba(255,193,7,.18); color: var(--warning); }
.mapper-select{ background: var(--input-bg); border: 1px solid var(--input-border); color: var(--text); border-radius: 10px; height: 30px; padding: 2px 8px; min-width: 180px; }
.mapper-select:focus{ outline:none; border-color: var(--input-focus-border); box-shadow: 0 0 0 4px var(--input-focus-shadow); }

.preview-section{ margin-top: 18px; }
.preview-table{ width:100%; border-collapse: separate; border-spacing:0; background: var(--table-bg); border:1px solid var(--table-border); border-radius: 12px; overflow:hidden; }
.preview-table thead th{ background: var(--panel); color: var(--text); font-weight:700; font-size: 13px; border-bottom: 1px solid var(--table-border); padding: 10px 12px; }
.preview-table tbody td{ border-top: 1px solid var(--border-color, var(--table-border)); color: var(--text); font-size: 14px; padding: 8px 10px; vertical-align: middle; }
.preview-table tbody tr:hover{ background: var(--table-hover-bg); }
.cell-error{ background: rgba(248,113,113,.15); color: var(--danger); }
.cell-warn{ background: rgba(255,193,7,.15); color: var(--warning); }

.advanced-toggle{ display:flex; justify-content:flex-end; margin-top: 12px; }
.advanced-btn{ display:inline-flex; align-items:center; gap:8px; height:32px; padding:0 10px; border-radius: 10px; border:1px solid var(--border-color, var(--line)); background: var(--card); color: var(--text); font-size: 12px; font-weight: 700; }
.advanced-btn:hover{ border-color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.12); }
.advanced-panel{ position: fixed; right: 0; top: 0; width: 360px; height: 100vh; background: var(--panel); border-left: 1px solid var(--border-color, var(--line)); box-shadow: -10px 0 30px var(--shadow); transform: translateX(100%); transition: transform .25s ease; z-index: 1050; padding: 12px 14px; }
.advanced-panel.open{ transform: translateX(0); }
.adv-item{ display:flex; align-items:flex-start; justify-content:space-between; gap:8px; padding: 10px 0; border-bottom: 1px solid var(--border-color, var(--line)); }
.adv-item .text{ font-size: 13px; color: var(--text); }
.adv-item .desc{ font-size: 12px; color: var(--text-secondary, var(--muted)); }
.adv-switch{ width:42px; height:24px; border-radius:999px; border: 1px solid var(--border-color, var(--line)); background: var(--card); position: relative; cursor:pointer; transition: all .2s ease; }
.adv-switch::after{ content:''; position:absolute; top:3px; left:3px; width:18px; height:18px; border-radius:999px; background: var(--text-secondary, var(--muted)); transition: left .2s ease, background .2s ease; }
.adv-switch.active{ border-color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.12); }
.adv-switch.active::after{ left:21px; background: var(--primary); }

.import-footer{ position: sticky; bottom: 0; z-index: 8; background: rgba(26,29,33,.9); backdrop-filter: blur(8px); border-top: 1px solid var(--border-color); padding: 10px 14px; border-radius: 12px; margin-top: 12px; box-shadow: 0 -10px 30px var(--shadow); display:flex; align-items:center; gap:10px; }
.import-status{ color: var(--text-secondary, var(--muted)); font-size: 13px; }
.import-footer .actions{ margin-left:auto; display:flex; gap:8px; }
/* =============================================================
   Presupuestos: Editor de Condiciones & Observaciones (SaaS 2026)
   Ubicación: templates/presupuestos/condiciones_editor.html
   Problema que soluciona: módulo premium tipo Notion para redactar y ordenar bloques
   ============================================================= */
.cond-container{ max-width: 1200px; margin: 0 auto; }
.cond-header{ display:flex; align-items:flex-start; gap:12px; padding: 18px 22px; background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: var(--border-radius-lg); box-shadow: 0 10px 30px var(--shadow); }
.cond-title{ font-size: 22px; font-weight: 700; color: var(--text); margin:0; }
.cond-subtitle{ font-size: 14px; color: var(--text-secondary, var(--muted)); }
.cond-actions{ margin-left:auto; display:flex; gap:8px; flex-wrap:wrap; }
.cond-btn{ display:inline-flex; align-items:center; gap:8px; height:34px; padding:0 12px; border-radius: 12px; border:1px solid var(--border-color, var(--line)); background: var(--btn-bg, var(--card)); color: var(--text); font-weight:600; font-size: 13px; text-decoration:none; transition: all .2s ease; }
.cond-btn:hover{ border-color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.12); }

.cond-layout{ display:grid; grid-template-columns: 300px 1fr; gap: 14px; align-items:start; margin-top: 16px; }
.cond-sidebar{ background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: var(--border-radius); padding: 12px; position: sticky; top: 12px; max-height: calc(100vh - 140px); overflow: auto; }
.tpl-title{ font-size: 14px; font-weight: 700; color: var(--text); margin-bottom:8px; }
.tpl-grid{ display:flex; flex-direction:column; gap:8px; }
.tpl-card{ background: var(--card); border:1px solid var(--border-color, var(--line)); border-radius: 12px; padding: 10px 12px; display:flex; align-items:flex-start; gap:8px; }
.tpl-name{ font-size: 13px; font-weight: 700; color: var(--text); }
.tpl-desc{ font-size: 12px; color: var(--text-secondary, var(--muted)); }
.tpl-insert{ margin-left:auto; }

.cond-editor{ background: var(--card); border:1px solid var(--border-color, var(--line)); border-radius: 16px; padding: 14px; }
.blocks{ display:flex; flex-direction:column; gap:10px; }
.block{ display:flex; align-items:flex-start; gap:10px; background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: 12px; padding: 10px 12px; transition: box-shadow .15s ease, border-color .15s ease; }
.block:hover{ box-shadow: 0 8px 24px var(--shadow); border-color: var(--primary); }
.handle{ width:22px; color: var(--text-secondary, var(--muted)); cursor:grab; display:flex; align-items:center; justify-content:center; }
.handle::before{ content:'⋮⋮'; opacity:.6; }
.content{ flex:1; color: var(--text); font-size: 14px; }
.menu{ display:inline-flex; align-items:center; gap:6px; }
.menu .cond-btn{ height:28px; padding:0 8px; font-size:12px; }

/* Variantes de bloque */
.block.text .content{ }
.block.list .content{ }
.block.ol .content{ }
.block.h1 .content{ font-size: 20px; font-weight: 700; }
.block.h2 .content{ font-size: 18px; font-weight: 700; }
.block.h3 .content{ font-size: 16px; font-weight: 700; }
.block.warn{ background: rgba(255,193,7,.12); border-color: rgba(255,193,7,.35); }
.block.warn .content{ color: var(--warning); }
.block.important{ background: rgba(59,130,246,.12); border-color: rgba(59,130,246,.35); }
.block.important .content{ color: var(--primary); }
.block.legal .content{ font-size: 13px; color: var(--text-secondary, var(--muted)); }
.block.signature .content{ font-size: 13px; }

.cond-footer{ position: sticky; bottom: 0; z-index: 8; background: rgba(26,29,33,.9); backdrop-filter: blur(8px); border-top: 1px solid var(--border-color); padding: 10px 14px; border-radius: 12px; margin-top: 12px; box-shadow: 0 -10px 30px var(--shadow); display:flex; align-items:center; gap:10px; }
.cond-status{ color: var(--success); font-size: 13px; font-weight: 700; }
.cond-tools{ margin-left:auto; display:flex; gap:8px; }

/* Feedback de guardado
   Uso: .cond-status.ok para guardado correcto, .cond-status.error para fallo */
.cond-status.ok{ color: var(--success); }
.cond-status.error{ color: var(--danger); }
/* =============================================================
   Presupuestos: Módulo Firma Digital (SaaS 2026 Premium)
   Ubicación: templates/presupuestos/firma_digital.html
   Problema que soluciona: interfaz elegante para gestión de firma
   ============================================================= */
.sign-container{ max-width: 1280px; margin: 0 auto; }
.sign-header{ display:flex; align-items:flex-start; gap:12px; padding: 20px 24px; background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: var(--border-radius-lg); box-shadow: 0 10px 30px var(--shadow); }
.sign-title{ font-size: 28px; font-weight: 800; color: var(--text); margin:0; }
.sign-subtitle{ font-size: 14px; color: var(--text-secondary, var(--muted)); }
.sign-actions{ margin-left:auto; display:flex; gap:8px; flex-wrap:wrap; }
.sign-btn{ display:inline-flex; align-items:center; gap:8px; height:36px; padding:0 12px; border-radius: 12px; border:1px solid var(--border-color, var(--line)); background: var(--btn-bg, var(--card)); color: var(--text); font-weight:600; font-size: 13px; text-decoration:none; transition: all .2s ease; }
.sign-btn:hover{ border-color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.12); }
.sign-btn-primary{ background: var(--primary); color: #fff; border-color: var(--primary); }
.sign-btn-primary:hover{ filter: brightness(1.05); box-shadow: 0 10px 26px rgba(59,130,246,.25); }

.sign-grid{ display:grid; grid-template-columns: 360px 1fr 420px; gap: 14px; align-items:start; margin-top: 16px; }
.sign-card{ background: var(--panel); border:1px solid var(--border-color, var(--line)); border-radius: 16px; padding: 14px; box-shadow: 0 8px 24px var(--shadow); }

/* Columna izquierda: estado y auditoría */
.status-chip{ display:inline-flex; align-items:center; height:26px; padding:0 10px; border-radius:999px; border:1px solid var(--border-color, var(--line)); font-size:12px; font-weight:700; }
.status-chip.ok{ background: rgba(74,222,128,.15); color: var(--success); }
.status-chip.pend{ background: rgba(250,204,21,.15); color: var(--warning); }
.status-chip.rej{ background: rgba(239,68,68,.15); color: var(--danger); }
.sign-field{ display:flex; align-items:center; gap:8px; padding:6px 0; border-bottom:1px solid var(--border-color, var(--line)); }
.sign-field .label{ font-size:12px; color: var(--text-secondary, var(--muted)); min-width: 120px; }
.sign-field .value{ font-size:14px; color: var(--text); }
.sign-actions-list{ display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.audit-title{ font-size: 13px; font-weight:700; color: var(--text); margin-top:10px; }
.audit-list{ display:flex; flex-direction:column; gap:6px; font-size:13px; color: var(--text-secondary, var(--muted)); }

/* Columna central: visor de documento */
.doc-view{ display:flex; flex-direction:column; gap:10px; }
.doc-frame{ background: var(--card); border:1px solid var(--border-color, var(--line)); border-radius: 16px; padding: 12px; box-shadow: 0 10px 30px var(--shadow); }
.doc-iframe{ width:100%; height: 520px; border:0; border-radius: 12px; }
.doc-controls{ display:flex; align-items:center; gap:8px; }
.doc-options{ display:flex; align-items:center; gap:12px; font-size:12px; color: var(--text-secondary, var(--muted)); }

/* Columna derecha: signature pad */
.pad-title{ font-size: 18px; font-weight:700; color: var(--text); }
.pad-subtitle{ font-size: 13px; color: var(--text-secondary, var(--muted)); margin-bottom:8px; }
.pad-area{ background: var(--card); border:1px solid var(--border-color, var(--line)); border-radius: 12px; padding: 8px; display:flex; align-items:center; justify-content:center; }
.pad-canvas{ width: 100%; height: 380px; border-radius: 8px; background: rgba(255,255,255,.02); }
.pad-controls{ display:flex; align-items:center; gap:8px; margin-top:8px; }
.pad-color{ width:26px; height:26px; border-radius:999px; border:1px solid var(--border-color, var(--line)); cursor:pointer; }
.pad-color.black{ background:#000; }
.pad-color.primary{ background: var(--primary); }
.pad-range{ width:140px; }
.pad-msg{ font-size: 12px; margin-top:6px; }
.pad-msg.ok{ color: var(--success); }
.pad-msg.err{ color: var(--danger); }

/* Firma Digital: acciones del pad
   Uso: templates/presupuestos/firma_digital.html (.pad-actions)
   Problema que soluciona: elimina margen inline y unifica espaciado claro/oscuro */
.pad-actions{ margin-top:8px; }

.sign-footer{ position: sticky; bottom: 0; z-index: 8; background: rgba(26,29,33,.9); backdrop-filter: blur(8px); border-top: 1px solid var(--border-color); padding: 10px 14px; border-radius: 12px; margin-top: 12px; box-shadow: 0 -10px 30px var(--shadow); display:flex; align-items:center; gap:10px; }
.sign-status{ color: var(--text-secondary, var(--muted)); font-size: 13px; }
.sign-footer .actions{ margin-left:auto; display:flex; gap:8px; }
/* =============================================================
   Certificaciones: layout premium SaaS 2026
   Ubicación: templates/certificaciones/editor.html
   Problema que soluciona: diseño independiente, limpio y uniforme (sin inline)
   ============================================================= */
.cf-container{ max-width: 1320px; margin: 0 auto; }
.cf-header{ display:flex; align-items:flex-start; gap:18px; padding: 18px 20px; background: var(--panel); border:1px solid var(--line); border-radius: var(--border-radius-lg); box-shadow: var(--shadow); }
.cf-title{ margin:0; font-size:26px; font-weight:700; color: var(--text); }
.cf-subtitle{ margin-top:6px; color: var(--text-secondary, var(--muted)); font-size: 14px; }
.cf-h-right{ margin-left:auto; display:flex; gap:8px; align-items:center; }
.cf-btn{ display:inline-flex; align-items:center; gap:8px; height:34px; padding:0 12px; border-radius: 12px; border:1px solid var(--border-color, var(--line)); background: var(--btn-bg, var(--card)); color: var(--text); font-weight:600; font-size: 13px; text-decoration:none; }
.cf-btn:hover{ border-color: var(--primary); box-shadow: 0 0 0 4px rgba(59,130,246,.12); }
.cf-btn-primary{ background: var(--primary); color: #fff; border-color: var(--primary); }
.cf-layout{ display:grid; grid-template-columns: 1fr 360px; gap:16px; align-items:start; margin-top: 16px; }
.cf-editor{ background: var(--card); border:1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow-sm); padding: 12px; }
.cf-toolbar{ display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.cf-chip{ display:inline-flex; align-items:center; height:24px; padding:0 10px; border-radius:999px; border: 1px solid var(--line); background: var(--panel); color: var(--text); font-size: 12px; }
.cf-spacer{ margin-left:auto; }
.cf-table-wrap{ background: var(--panel); border:1px solid var(--line); border-radius: var(--border-radius); overflow:auto; }
.cf-table{ width:100%; border-collapse: separate; border-spacing:0; }
.cf-table thead th{ background: var(--card); color: var(--text); font-weight:700; font-size: 13px; border-bottom: 1px solid var(--line); padding: 10px 12px; position: sticky; top:0; }
.cf-table tbody td{ border-top: 1px solid var(--line); color: var(--text); font-size: 14px; padding: 8px 10px; vertical-align: middle; }
.cf-row.cf-capitulo td{ background: rgba(255,255,255,.03); font-weight:700; color: var(--text-secondary, var(--muted)); }
.indent-20{ padding-left:20px; }
.indent-40{ padding-left:40px; }
.cf-sidebar{ background: var(--card); border:1px solid var(--line); border-radius: var(--border-radius); box-shadow: var(--shadow-sm); padding: 12px; position: sticky; top: 12px; max-height: calc(100vh - 160px); overflow:auto; }
.cf-panel{ background: var(--panel); border:1px solid var(--line); border-radius: var(--border-radius); margin-bottom:10px; }
.cf-panel-title{ padding: 10px 12px; border-bottom:1px solid var(--line); font-weight:700; color: var(--text); display:flex; align-items:center; gap:8px; }
.cf-panel-body{ padding: 10px 12px; display:flex; flex-direction:column; gap:8px; }
.cf-input{ background: var(--input-bg, var(--panel)); border: 1px solid var(--input-border, var(--line)); color: var(--text); border-radius: 10px; padding: 6px 8px; }
.cf-input-sm{ height:30px; }
.cf-extras-list{ display:flex; flex-direction:column; gap:10px; }
.cf-extra{ background: var(--card); border:1px solid var(--line); border-radius: 12px; padding: 10px 12px; display:flex; flex-direction:column; gap:8px; }
.cf-extra-row{ display:flex; align-items:center; gap:8px; }
.cf-extra-code{ font-weight:700; color: var(--text-secondary, var(--muted)); }
.cf-total{ margin-left:auto; font-weight:700; color: var(--text); }
.cf-footer{ position: sticky; bottom: 0; z-index: 8; background: rgba(26,29,33,.9); backdrop-filter: blur(8px); border-top: 1px solid var(--border-color); padding: 10px 14px; border-radius: 12px; margin-top: 12px; box-shadow: 0 -10px 30px var(--shadow); display:flex; align-items:center; gap:10px; }
.cf-status{ color: var(--text-secondary, var(--muted)); font-size: 13px; }
.cf-summary{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.cf-s-item .label{ display:block; font-size: 11px; color: var(--text-secondary, var(--muted)); }
.cf-s-item .value{ display:block; font-size: 16px; font-weight:700; color: var(--text); }
.cf-badge{ display:inline-block; margin-left:8px; padding:2px 8px; border-radius:999px; border:1px solid var(--line); background: var(--panel); color: var(--text-secondary, var(--muted)); font-size: 11px; }
.cf-badge-warn{ color: var(--text); font-weight:600; }
/* Certificaciones: feedback visual de aplicación de propuestas – destaca celdas actualizadas */
.cf-cell-updated{ background: rgba(59,130,246,.12); box-shadow: inset 0 0 0 1px var(--primary); transition: background .6s ease; }
.cf-badge-applied{ display:inline-block; margin-left:6px; padding:2px 6px; border-radius:999px; background: var(--primary); color:#fff; font-size:10px; font-weight:600; }
.inspector-hidden .editor-layout{ grid-template-columns: 1fr; }
.inspector-hidden #editorInspector{ position: fixed; right: -460px; top: 96px; width: 420px; max-height: calc(100vh - 120px); overflow:auto; z-index: 1020; transition: right .2s ease, opacity .2s ease; opacity: 0; }
.inspector-visible #editorInspector{ right: 16px; opacity: 1; }
.inspector-visible .editor-layout{ grid-template-columns: 1fr 420px; }
.presupuestos-editor.blur-active .editor-layout{ filter: blur(1px) brightness(0.94) saturate(0.98); transition: filter .18s ease; }
.presupuestos-editor.blur-active .pg-premium-header{ filter: blur(1px) brightness(0.94) saturate(0.98); }
.presupuestos-editor.blur-active .split-panels{ filter: blur(1px) brightness(0.94) saturate(0.98); }
.presupuestos-editor.blur-active .premium-footer{ filter: blur(1px) brightness(0.94) saturate(0.98); }
.presupuestos-editor.blur-active .summary-box{ filter: blur(1px) brightness(0.94) saturate(0.98); }
.presupuestos-editor.modal-cliente-open .modal-backdrop.show{ background-color: rgba(0,0,0,0.42) !important; }
.presupuestos-editor .modal-backdrop,
.presupuestos-editor .modal-backdrop.show{
  opacity: 0 !important;
  background: transparent !important;
}
/* Presupuestos: modal clientes sin bloqueo ni full overlay */
body.presupuestos-editor.modal-open { overflow: auto !important; }
#clienteModal.modal { position: absolute; inset: auto; top: 80px; left: 50%; transform: translateX(-50%); z-index: 1060; }
#clienteModal .modal-dialog { margin: 0; }
#clienteOverlay{ position: fixed; inset: 0; background: transparent; z-index: 1060; display: flex; align-items: flex-start; justify-content: center; padding-top: 72px; }
#clienteOverlay.hidden{ display: none; }
#clienteOverlay .cliente-overlay-panel{ width: 720px; max-width: 92vw; position: absolute; top: 96px; left: 50%; transform: translateX(-50%); cursor: default; }
#clienteOverlay .cliente-overlay-panel .search-results{ background: var(--panel); border: 1px solid var(--border-color); border-radius: var(--border-radius); padding: 6px; max-height: 300px; overflow: auto; }
#clienteOverlay .cliente-overlay-panel .search-results li.search-item{ display:flex; align-items:center; gap:.5rem; padding:.4rem .5rem; border-radius: 8px; background: var(--card); color: var(--text); cursor: pointer; }
#clienteOverlay .cliente-overlay-panel .search-results li.search-item:hover{ background: var(--table-hover-bg); border: 1px solid var(--line); box-shadow: 0 0 0 3px rgba(255,255,255,0.18); }
/* Overlay cliente: panel sólido sin transparencia y borde suave */
#clienteOverlay .cliente-overlay-panel.dmd-panel{ background: var(--panel); border: 1px solid var(--border-color); border-radius: var(--border-radius); box-shadow: 0 12px 30px var(--shadow); overflow: visible; }

/* Barra de búsqueda – override para borde menos llamativo y sombra completa */
.bd-searchbar{ background: var(--panel); border: 1px solid var(--border-color); border-radius: var(--border-radius); padding: 8px; box-shadow: 0 6px 16px var(--shadow); }
#dgConfirmOverlay{ position: fixed; inset: 0; z-index: 1070; display: none; align-items: center; justify-content: center; }
#dgConfirmOverlay.show{ display: flex; }
#dgConfirmOverlay .dg-panel{ width: 520px; max-width: 92vw; background: var(--panel); border: 1px solid var(--border-color); border-radius: var(--border-radius); box-shadow: 0 20px 40px var(--shadow); }
#dgConfirmOverlay .dg-head{ display:flex; align-items:center; justify-content:space-between; padding: 14px 16px; border-bottom: 1px solid var(--border-color); color: var(--text); }
#dgConfirmOverlay .dg-body{ padding: 16px; color: var(--text); }
#dgConfirmOverlay .dg-actions{ display:flex; gap:.5rem; justify-content:flex-end; padding: 12px 16px; border-top: 1px solid var(--border-color); }
#dgConfirmOverlay .dg-btn{ height:32px; padding:0 14px; border-radius: 999px; border:1px solid var(--border-color); background: var(--card); color: var(--text); }
#dgConfirmOverlay .dg-btn.primary{ background: var(--primary); color: #fff; border-color: var(--primary); }
#presupuestos-container a.row-link{ color: var(--text); font-weight: 700; text-decoration: none; }
#presupuestos-container a.row-link:visited{ color: var(--text); }
#presupuestos-container a.row-link:hover{ text-decoration: underline; }
