/*
  compact.css - Reglas para una interfaz más "compacta" y apretada.
  - Incluye variables al inicio para ajustar rápido.
  - Está pensado para cargarse en todas las vistas (commons/css.twig).
  - Mantén cambios simples: modifica las variables si quieres mayor o menor compacidad.
*/

:root {
  /* Espaciado compacto */
  --compact-header-padding-y: 0.45rem; /* header vertical padding */
  --compact-header-padding-x: 0.6rem;  /* header horizontal padding */
  --compact-card-padding: 0.6rem; /* padding de cards */
  --compact-card-radius: 12px; /* border radius de cards */
  --compact-gap: 0.5rem;      /* gap entre elementos */
  --compact-font-scale: 0.95; /* factor para reducir tamaño de fuentes */
}

/* --------------------------------------------------------------------------
   Global compact adjustments
   -------------------------------------------------------------------------- */
html, body {
  font-size: calc(1rem * var(--compact-font-scale));
}

/* Ajustes generales para contenedores y filas */
.container-fluid, .container {
  padding-left: calc(.75rem * var(--compact-font-scale));
  padding-right: calc(.75rem * var(--compact-font-scale));
}

.row.g-3, .row.g-2, .row.g-1 {
  --bs-gutter-x: 0.5rem;
  --bs-gutter-y: 0.5rem;
}

/* --------------------------------------------------------------------------
   Header (más arriba / compacto)
   -------------------------------------------------------------------------- */
#main header,
.main-header,
header {
  padding: var(--compact-header-padding-y) var(--compact-header-padding-x);
  margin-bottom: 0.4rem !important; /* reducir separación entre header y contenido */
}

/* Icono Burger, aviso y versión más compactos */
.burger-btn i,
.header-right .bi {
  font-size: 1.15rem; /* reducir iconos */
}

.header-right .version-link small {
  font-size: 0.72rem;
}

/* Badge de mensajes más pequeño y con posición menos intrusiva */
#message-count {
  font-size: 0.55rem !important;
  top: -4px !important;
  right: -8px !important;
}

/* --------------------------------------------------------------------------
   Card Neumorphism - más compacto
   -------------------------------------------------------------------------- */
.card-neumorphism {
  padding: calc(var(--compact-card-padding) - 0.1rem) !important;
  border-radius: var(--compact-card-radius) !important;
  margin-bottom: 0.65rem !important;
}

.card-neumorphism .card-body {
  padding: calc(var(--compact-card-padding) - 0.1rem) !important;
}

.card-neumorphism .card-header,
.card-neumorphism .card-footer {
  padding: 0.5rem 0.75rem !important;
}

.card-neumorphism .card-title {
  font-size: 0.95rem;
  line-height: 1.05;
}

/* H3 dentro de card - reducir padding y tamaño (como Panel de Control) */
.card-neumorphism h3.h4 {
  margin-bottom: 0.25rem;
  padding: 0.4rem 0.5rem;
  font-size: 1.05rem;
}

/* Panel title visual (mover estilos inline aquí para centralizar) */
.panel-title {
  background: var(--neumorphism-bg);
  box-shadow: inset 8px 8px 16px var(--neumorphism-shadow-dark), inset -8px -8px 16px var(--neumorphism-shadow-light);
  border-radius: calc(var(--compact-card-radius) - 6px);
}

/* Botones dentro de cards más compactos */
.btn-neumorphism {
  padding: 0.45rem 0.6rem !important;
  font-size: 0.9rem !important;
}

/* --------------------------------------------------------------------------
   Panel de Control - específico
   -------------------------------------------------------------------------- */
#panel_de_control {
  padding: 0.45rem !important;
  margin-bottom: 0.75rem !important;
}

#panel_de_control .row.row-cards > * {
  padding-left: 0.35rem;
  padding-right: 0.35rem;
}

#panel_de_control .card-body .row > .col-md-4 {
  padding: 0.15rem;
}

/* --------------------------------------------------------------------------
   Search card y resultados - se mantienen compactos
   -------------------------------------------------------------------------- */
.search-card-neumorphism.compact .search-card-header {
  padding: 0.45rem 0.75rem;
}

.search-card-neumorphism.compact .search-card-body {
  padding: 0.45rem 0.75rem 0.75rem;
}

.results-card .search-card-header {
  padding: 0.45rem 0.75rem;
}

.results-card .results-body {
  padding: 0.45rem 0.75rem 0.75rem;
}

/* Inputs y selects más compactos */
.input-neumorphism,
.select-neumorphism,
.form-control-sm,
.form-select-sm {
  padding: 0.5rem 0.6rem !important;
  font-size: 0.92rem !important;
}

/* Icon & control spacing */
.search-icon-wrapper i,
.card-paciente .icon,
.nav-item-neumorphism .icon {
  width: 34px;
  height: 34px;
}

/* --------------------------------------------------------------------------
   Responsive tweaks para pantallas pequeñas
   -------------------------------------------------------------------------- */
@media (max-width: 576px) {
  :root {
    --compact-header-padding-y: 0.35rem;
    --compact-header-padding-x: 0.55rem;
    --compact-card-padding: 0.5rem;
    --compact-gap: 0.35rem;
  }

  .card-neumorphism,
  .search-card-neumorphism.compact,
  .results-card {
    border-radius: calc(var(--compact-card-radius) - 4px);
  }

  .burger-btn i { font-size: 1rem }
}

/* --------------------------------------------------------------------------
   Layout special: expand single result card
   - When only one tarjeta-paciente is visible, make it wider and taller.
   -------------------------------------------------------------------------- */
.cards-container.single-result .row {
  justify-content: center;
}

.cards-container.single-result .row > [class*="col-"] {
  flex: 0 0 70% !important;
  max-width: 70% !important;
}

.cards-container .row > [class*="col-"] {
  transition: flex-basis 0.25s ease, max-width 0.25s ease;
}

.cards-container.single-result .dashboard-card-neumorphism {
  min-height: 300px !important;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

@media (max-width: 768px) {
  .cards-container.single-result .row > [class*="col-"] {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
  .cards-container.single-result .dashboard-card-neumorphism {
    min-height: 250px !important;
  }
}

/* --------------------------------------------------------------------------
   Estilos movidos desde App/Views/assets/js/evoluciones.js
   -------------------------------------------------------------------------- */
.evolucion-card {
  transition: transform 0.2s, box-shadow 0.2s;
  border-left-width: 3px !important;
}
.evolucion-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.08) !important;
}
.evolucion-info i {
  width: 20px;
  display: inline-block;
  text-align: center;
  margin-right: 8px;
  color: #6c757d;
}
.card-header {
  padding: 0.75rem 1rem;
}
.loading-overlay {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.8);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
}
.btn-scroll-top { position: fixed; bottom: 20px; right: 20px; z-index: 1000; display: none; width: 40px; height: 40px; border-radius: 50%; background: #0d6efd; color: white; box-shadow: 0 2px 10px rgba(0,0,0,0.1); border: none; cursor: pointer; transition: all 0.3s ease; align-items: center; justify-content: center; }
.btn-scroll-top:hover { transform: translateY(-3px); box-shadow: 0 4px 15px rgba(0,0,0,0.2); }
.btn-scroll-top.visible { display: flex; }
@media (max-width: 576px) {
  .evolucion-info { font-size: 0.8rem; }
  .card-header h6 { font-size: 0.9rem; }
  .card-body { padding: 0.75rem; }
}


/* --------------------------------------------------------------------------
   Comentarios adicionales
   - Para aumentar compactación, disminuir las variables al inicio.
   - Si querés revertir solo algunos espacios (ej: panel de control), aplica
     clases CSS a elementos concretos y ajusta ahí los paddings.
*/

/* --------------------------------------------------------------------------
   Reglas movidas desde App/Views/assets/js/pacientes.js
   - Originalmente inyectadas dinámicamente; movidas aquí para mantenimiento
   - Si algo debe ajustarse solo para Pacientes, usar este bloque.
   -------------------------------------------------------------------------- */

.tab-pane {
  animation: fadeIn 0.3s ease-in;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.table-responsive {
  border-radius: 0.5rem;
  box-shadow: 0 0 10px rgba(0,0,0,0.05);
}

.card-columns { column-count: 1; }

@media (max-width: 768px) {
  .card-columns { column-count: 1; }
}

.btn-sm { padding: 0.25rem 0.5rem; font-size: 0.875rem; }

.card { border: none; box-shadow: 0 2px 4px rgba(0,0,0,0.04); background: linear-gradient(145deg, #ffffff, #f6f9fc); border-left-width: 6px !important; }

.hover-card { transition: all 0.2s ease; }
.hover-card:hover { transform: translateY(-3px); box-shadow: 0 4px 12px rgba(0,0,0,0.1); }

.card-title { font-size: 0.9rem; font-weight: 600; }

.badge { font-size: 0.75rem; padding: 0.35em 0.65em; }

.btn.ver-detalles { background-color: #f8f9fa; border: 1px solid #dee2e6; color: #0d6efd; padding: 0.2rem 0.5rem; font-size: 0.75rem; }
.btn.ver-detalles:hover { background-color: #0d6efd; color: white; transform: translateY(-1px); }

.card-text { font-size: 0.8rem; }
.card-text i { font-size: 0.75rem; }

@media (max-width: 576px) {
  .col-sm-6 { padding: 0.25rem; }
}

.row.g-2 { margin-right: -0.5rem; margin-left: -0.5rem; }
.row.g-2 > * { padding-right: 0.5rem; padding-left: 0.5rem; }

.card-female { background: linear-gradient(145deg, #ffffff, #fff5f8) !important; border-left: 6px solid #ff69b4 !important; }
.card-male { background: linear-gradient(145deg, #ffffff, #f6f9fc); border-left: 6px solid #0d6efd !important; }
.bi-gender-female { color: #ff69b4; }
.card-female .badge { background-color: #ff69b4 !important; }
.card-female .btn.ver-detalles:hover { background-color: #ff69b4; border-color: #ff69b4; }

.card-text small { font-size: 0.75rem; opacity: 0.8; }

.card-active { background: linear-gradient(145deg, #ffffff, #e8f5e9) !important; border-left: 6px solid #4caf50 !important; }
.card-finished { background: linear-gradient(145deg, #ffffff, #ffebee) !important; border-left: 6px solid #f44336 !important; }
.card-internacion { background: linear-gradient(145deg, #ffffff, #f3e5f5) !important; border-left: 6px solid #9c27b0 !important; }
.card-no-services { background: linear-gradient(145deg, #ffffff, #fffde7) !important; border-left: 6px solid #fbc02d !important; }
.bg-purple { background-color: #9c27b0 !important; }

.estado-container { font-size: 0.75rem; }

/* Ajustes específicos para pacientes: cards más compactas y botón subir */
.card { height: 140px !important; display: flex; flex-direction: column; }
.card-body { display: flex; flex-direction: column; height: 100%; overflow-y: auto; scrollbar-width: thin; scrollbar-color: rgba(0,0,0,0.2) transparent; padding: 0.75rem; }

.btn-scroll-top { position: fixed; bottom: 20px; right: 20px; z-index: 1000; display: none; width: 40px; height: 40px; border-radius: 50%; background: #0d6efd; color: white; box-shadow: 0 2px 10px rgba(0,0,0,0.1); border: none; cursor: pointer; transition: all 0.3s ease; }
.btn-scroll-top:hover { transform: translateY(-3px); box-shadow: 0 4px 15px rgba(0,0,0,0.2); }
.btn-scroll-top.visible { display: flex; align-items: center; justify-content: center; }

/* Ajustes responsive para el formulario de búsqueda (movido desde JS) */
@media (max-width: 576px) {
  .card-body { padding: 0.75rem !important; }
  #searchForm { margin: 0; }
  #searchForm .col-12:last-child { margin-bottom: 0.5rem; }
  #searchForm .btn { font-size: 0.875rem; padding: 0.375rem 0.75rem; }
  #searchForm .d-flex { padding: 0 !important; }
  .gap-2 { gap: 0.375rem !important; }
  .input-group { margin-bottom: 0.5rem; }
  .form-select { margin-bottom: 0.5rem; }
}

