/* Ajustes Galactea sobre Tabler */

:root {
    /* Ancho fijo de campos fecha (input type="date" + icono calendario). Ajustar solo aquí. */
    --galactea-date-field-width: 10.5rem;
    --galactea-field-width-tipo: 16rem;
    --galactea-field-width-pod: 12rem;
    --galactea-field-width-contacto: 20rem;
    --galactea-table-cell-padding-y: 0.625rem;
    --galactea-table-cell-padding-y-sm: 0.5rem;
}

.azul-clarito {
    color: #828385 !important;
    opacity: 0.7;
}

.galactea-brand-color {
    color: #004494 !important;
}

.galactea-top-bar {
    background-color: #004494;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.galactea-top-bar .galactea-brand,
.galactea-top-bar .galactea-top-bar-link,
.galactea-top-bar .galactea-external-links-nav .nav-link {
    color: #fff !important;
}

.galactea-top-bar .galactea-brand:hover,
.galactea-top-bar .galactea-top-bar-link:hover,
.galactea-top-bar .galactea-external-links-nav .nav-link:hover {
    color: rgba(255, 255, 255, 0.85) !important;
}

.galactea-top-bar .galactea-brand {
    font-weight: 700;
    font-size: 1.1rem;
    letter-spacing: 0.01em;
}

.galactea-top-bar-toggler {
    border-color: rgba(255, 255, 255, 0.35);
}

.galactea-top-bar-toggler .navbar-toggler-icon {
    filter: brightness(0) invert(1);
}

.galactea-external-links-nav .nav-link {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    padding: 0.35rem 0.65rem;
    white-space: nowrap;
}

@media (min-width: 768px) {
    .galactea-external-links-nav {
        flex: 1 1 auto;
        justify-content: center;
    }
}

/* Formularios Tabler */
.form-label.required::after {
    content: " *";
    color: var(--tblr-danger);
}

.card .input,
.card .form-control,
.card .form-select {
    font-size: 0.875rem;
}

.card .chosen-container {
    width: 100% !important;
    font-size: 0.875rem;
}

.card .chosen-container-multi .chosen-choices {
    border: 1px solid var(--tblr-border-color);
    border-radius: var(--tblr-border-radius);
    background: var(--tblr-bg-forms);
    min-height: 2.25rem;
    padding: 0.25rem 0.5rem;
}

.card .chosen-container-active .chosen-choices {
    border-color: var(--tblr-primary);
    box-shadow: 0 0 0 0.25rem rgba(var(--tblr-primary-rgb), 0.25);
}

/* Salida de texto plano / prompts (EoI, IA, etc.) */
.galactea-plaintext-output {
    color: #1e293b !important;
    background-color: #f1f5f9 !important;
    border-color: #cbd5e1 !important;
    white-space: pre-wrap;
    word-break: break-word;
}

/* Modal prompt IA (edit empresa) */
.galactea-modal-prompt-descripcion {
    max-width: 58rem;
}

.galactea-modal-prompt-actions {
    flex-wrap: nowrap !important;
    gap: 0.5rem;
}

.galactea-modal-prompt-actions .btn {
    white-space: nowrap;
}

@media (max-width: 767.98px) {
    .galactea-modal-prompt-actions {
        flex-wrap: wrap !important;
    }
}

/* Quill en formularios (resto de la app) */
.ql-editor {
    background-color: var(--tblr-bg-forms);
    min-height: 200px;
}

.ql-toolbar.ql-snow {
    background-color: var(--tblr-bg-surface);
    border-color: var(--tblr-border-color);
}

.ql-container.ql-snow {
    border-color: var(--tblr-border-color);
}

/* Listado de empresas y formularios */
.galactea-page-header-inset .page-title {
    padding-left: 0;
}

/* Enlace a empresa en títulos de edición (servicio, interacción, etc.) */
.galactea-page-header-inset .page-title .galactea-page-title-empresa-link {
    color: #066fd1 !important;
    font-weight: 600;
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 0.2em;
    margin-left: 0.45em;
}

.galactea-page-header-inset .page-title .galactea-page-title-empresa-link:hover,
.galactea-page-header-inset .page-title .galactea-page-title-empresa-link:focus {
    color: #044a91 !important;
}

.galactea-page-header-inset .page-title .galactea-page-title-meta {
    color: var(--tblr-secondary, #6b7280);
    font-weight: 400;
    margin-left: 0.45em;
    white-space: nowrap;
}

/* Botones con icono en cabecera: misma altura que Guardar/Volver */
.page-header .btn-list {
    align-items: center;
}

.btn.btn-icon-header {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.75rem;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.btn.btn-icon-header .icon,
.btn.btn-icon-header > i {
    margin: 0 !important;
    line-height: 1;
}

.btn.btn-icon-header > i::before {
    line-height: 1;
    vertical-align: 0;
}

/* Pestañas contactos / eventos / servicios */
.empresa-relaciones {
    margin-top: 2.5rem;
}

.empresa-relaciones-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.625rem;
    padding: 1rem 1rem 0.5rem;
    margin-bottom: 0;
    background: var(--tblr-bg-surface-secondary);
    border: 1px solid var(--tblr-border-color);
    border-bottom: none;
    border-radius: var(--tblr-border-radius) var(--tblr-border-radius) 0 0;
}

.empresa-relaciones-tabs .nav-item {
    margin-bottom: 0;
}

.empresa-relaciones-tabs .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.7rem 1.25rem;
    margin-bottom: 0;
    border: 1px solid transparent;
    border-bottom: none;
    border-radius: var(--tblr-border-radius) var(--tblr-border-radius) 0 0;
    background: rgba(0, 0, 0, 0.03);
    color: var(--tblr-secondary);
    font-weight: 500;
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.empresa-relaciones-tabs .nav-link:hover {
    background: rgba(255, 255, 255, 0.75);
    border-color: var(--tblr-border-color);
    color: var(--tblr-body-color);
}

.empresa-relaciones-tabs .nav-link.active {
    margin-bottom: -1px;
    background: var(--tblr-bg-surface);
    border-color: var(--tblr-border-color);
    border-bottom: 1px solid var(--tblr-bg-surface);
    color: #004494;
    font-weight: 600;
    box-shadow: 0 -1px 0 rgba(0, 68, 148, 0.15);
}

.empresa-relaciones-content {
    padding: 1.25rem 1rem 1.5rem;
    background: var(--tblr-bg-surface);
    border: 1px solid var(--tblr-border-color);
    border-top: none;
    border-radius: 0 0 var(--tblr-border-radius) var(--tblr-border-radius);
}

.empresa-relaciones-content .tab-pane > p.text-secondary {
    margin-bottom: 0.75rem;
}

.empresa-relaciones .table-responsive > .table.card-table > :not(caption) > * > *:first-child,
.empresa-relaciones-content > .tab-pane > .table.card-table > :not(caption) > * > *:first-child {
    padding-left: 0;
}

.empresa-relaciones .table-responsive > .table.card-table > :not(caption) > * > *:last-child,
.empresa-relaciones-content > .tab-pane > .table.card-table > :not(caption) > * > *:last-child {
    padding-right: 0;
}

.galactea-tabla-accion {
    display: inline-block;
    margin-top: 1rem;
}

.galactea-list-filters,
.empresas-filtros {
    padding: 0.75rem 1rem;
}

.card > .table-responsive > .table.card-table > :not(caption) > * > *:first-child {
    padding-left: 1rem;
}

.card > .table-responsive > .table.card-table > :not(caption) > * > *:last-child {
    padding-right: 1rem;
}

/* Tablas: padding vertical equilibrado (Tabler/Bootstrap dejan el texto visualmente alto) */
.table > :not(caption) > * > * {
    vertical-align: middle;
}

.table.card-table > :not(caption) > * > * {
    padding-top: var(--galactea-table-cell-padding-y) !important;
    padding-bottom: var(--galactea-table-cell-padding-y) !important;
}

.table.card-table tbody > tr > td {
    padding-top: calc(var(--galactea-table-cell-padding-y) + 0.05rem) !important;
    padding-bottom: calc(var(--galactea-table-cell-padding-y) - 0.05rem) !important;
}

.table.card-table.table-sm > :not(caption) > * > * {
    padding-top: var(--galactea-table-cell-padding-y-sm) !important;
    padding-bottom: var(--galactea-table-cell-padding-y-sm) !important;
}

.table.card-table.table-sm tbody > tr > td {
    padding-top: calc(var(--galactea-table-cell-padding-y-sm) + 0.05rem) !important;
    padding-bottom: calc(var(--galactea-table-cell-padding-y-sm) - 0.05rem) !important;
}

.table.card-table thead > tr > th {
    padding-top: calc(var(--galactea-table-cell-padding-y) + 0.075rem) !important;
    padding-bottom: calc(var(--galactea-table-cell-padding-y) - 0.075rem) !important;
}

.table.card-table.table-sm thead > tr > th {
    padding-top: calc(var(--galactea-table-cell-padding-y-sm) + 0.0625rem) !important;
    padding-bottom: calc(var(--galactea-table-cell-padding-y-sm) - 0.0625rem) !important;
}

.card .table:not(.card-table) > :not(caption) > * > * {
    padding-top: var(--galactea-table-cell-padding-y) !important;
    padding-bottom: var(--galactea-table-cell-padding-y) !important;
    vertical-align: middle;
}

.card .table:not(.card-table).table-sm > :not(caption) > * > * {
    padding-top: var(--galactea-table-cell-padding-y-sm) !important;
    padding-bottom: var(--galactea-table-cell-padding-y-sm) !important;
}

.galactea-list-filters-form,
.empresas-filtros-form {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
}

/* Fila de filtros: 100% ancho, campos reparten espacio, acciones a la derecha */
.galactea-list-filters-form > .row,
.empresas-filtros-form > .row {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    flex-wrap: wrap;
    align-items: flex-end;
}

.galactea-list-filters-form > .row > *:not(.galactea-filter-actions):not(.galactea-date-field-col):not(:has(> .btn)):not(:has(> a.btn)),
.empresas-filtros-form > .row > *:not(.galactea-filter-actions):not(.galactea-date-field-col):not(:has(> .btn)):not(:has(> a.btn)) {
    flex: 1 1 9rem;
    width: auto !important;
    min-width: 0;
    max-width: none !important;
}

.galactea-list-filters-form > .row > .galactea-filter-actions,
.empresas-filtros-form > .row > .galactea-filter-actions,
.galactea-list-filters-form > .row > .col-auto:has(.btn),
.empresas-filtros-form > .row > .col-auto:has(.btn) {
    flex: 0 0 auto;
    width: auto !important;
    max-width: none !important;
    margin-left: auto !important;
    padding-right: 0 !important;
    align-self: flex-end;
}

/* Fila que es a la vez formulario de filtros (p. ej. EmpresasEventos) */
.row.galactea-list-filters-form > *:not(.galactea-filter-actions):not(.galactea-date-field-col):not(:has(> .btn)):not(:has(> a.btn)) {
    flex: 1 1 9rem;
    width: auto !important;
    min-width: 0;
    max-width: none !important;
}

.row.galactea-list-filters-form > .galactea-filter-actions,
.row.galactea-list-filters-form > .col-auto:has(.btn) {
    flex: 0 0 auto;
    width: auto !important;
    margin-left: auto !important;
    padding-right: 0 !important;
}

.galactea-list-filters-form .form-control,
.galactea-list-filters-form .form-select,
.empresas-filtros-form .form-control,
.empresas-filtros-form .form-select {
    width: 100%;
    max-width: 100%;
}

.galactea-list-filters label,
.galactea-list-filters .galactea-filter-label,
.empresas-filtros label,
.empresas-filtros .galactea-filter-label {
    font-size: 0.68rem;
    font-weight: 500;
    margin-bottom: 0.2rem;
    padding-left: 0;
    color: var(--tblr-secondary);
    text-transform: none;
    letter-spacing: normal;
}

.galactea-list-filters .mb-3,
.empresas-filtros .mb-3 {
    margin-bottom: 0.35rem !important;
}

.galactea-list-filters-actions,
.empresas-filtros-actions {
    gap: 0.25rem;
}

/* Campos fecha: ancho fijo global (--galactea-date-field-width) */
.galactea-date-field-col {
    flex: 0 0 var(--galactea-date-field-width) !important;
    width: var(--galactea-date-field-width) !important;
    min-width: var(--galactea-date-field-width) !important;
    max-width: var(--galactea-date-field-width) !important;
}

.galactea-date-field,
input[type="date"].galactea-date-field.form-control {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

[class*='col-'] > .galactea-date-field-col {
    flex: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
}

/* Editores Quill en formularios de boletín */
.galactea-quill-field {
    flex: 0 0 100%;
    width: 100%;
    max-width: 100%;
}

.galactea-quill-field .form-label {
    margin-bottom: 0.35rem;
}

.galactea-quill-wrap {
    display: block;
    width: 100%;
}

.galactea-quill-field--titulo .galactea-quill-wrap {
    min-height: 7rem;
}

.galactea-quill-field--descripcion .galactea-quill-wrap {
    min-height: 18.5rem;
}

.galactea-quill-wrap .ql-toolbar.ql-snow {
    border: 1px solid var(--tblr-border-color);
    border-radius: var(--tblr-border-radius) var(--tblr-border-radius) 0 0;
    background: var(--tblr-bg-surface-secondary);
}

.galactea-quill-wrap .ql-container.ql-snow {
    border: 1px solid var(--tblr-border-color);
    border-top: 0;
    border-radius: 0 0 var(--tblr-border-radius) var(--tblr-border-radius);
    font-size: inherit;
    height: auto !important;
}

.galactea-quill-field--titulo .galactea-quill-wrap .ql-editor {
    min-height: 4.5rem;
    height: auto !important;
}

.galactea-quill-field--descripcion .galactea-quill-wrap .ql-editor {
    min-height: 16rem;
    height: auto !important;
}

/* Filas compactas en formularios: anchos fijos + campos que crecen */
.galactea-form-fields-row {
    flex-wrap: wrap;
    align-items: flex-end;
}

.galactea-form-fields-row > .galactea-field-col-grow {
    flex: 1 1 12rem;
    min-width: 0;
    max-width: none !important;
    width: auto !important;
}

.galactea-field-col-contacto {
    flex: 1 1 var(--galactea-field-width-contacto) !important;
    width: auto !important;
    min-width: var(--galactea-field-width-contacto) !important;
    max-width: 24rem !important;
}

.galactea-field-col-tipo {
    flex: 0 0 var(--galactea-field-width-tipo) !important;
    width: var(--galactea-field-width-tipo) !important;
    min-width: var(--galactea-field-width-tipo) !important;
    max-width: var(--galactea-field-width-tipo) !important;
}

.galactea-field-col-pod {
    flex: 0 0 var(--galactea-field-width-pod) !important;
    width: var(--galactea-field-width-pod) !important;
    min-width: var(--galactea-field-width-pod) !important;
    max-width: var(--galactea-field-width-pod) !important;
}

.galactea-form-fields-row .form-control,
.galactea-form-fields-row .form-select {
    width: 100%;
    max-width: 100%;
}

@media (max-width: 767.98px) {
    .galactea-form-fields-row > .galactea-field-col-grow,
    .galactea-form-fields-row > .galactea-field-col-contacto,
    .galactea-form-fields-row > .galactea-field-col-tipo,
    .galactea-form-fields-row > .galactea-field-col-pod,
    .galactea-form-fields-row > .galactea-date-field-col {
        flex: 1 1 100% !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
    }
}

.galactea-filter-col-id {
    flex: 0 1 5.5rem !important;
    min-width: 4.75rem !important;
    max-width: 6.5rem !important;
}

@media (max-width: 767.98px) {
    .galactea-list-filters-form > .row > *:not(.galactea-filter-actions):not(.galactea-date-field-col):not(:has(> .btn)):not(:has(> a.btn)),
    .empresas-filtros-form > .row > *:not(.galactea-filter-actions):not(.galactea-date-field-col):not(:has(> .btn)):not(:has(> a.btn)) {
        flex: 1 1 100% !important;
        min-width: 0 !important;
        max-width: none !important;
    }

    .galactea-date-field-col {
        flex: 1 1 100% !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
    }

    .galactea-list-filters-form > .row > .galactea-filter-actions,
    .empresas-filtros-form > .row > .galactea-filter-actions,
    .galactea-list-filters-form > .row > .col-auto:has(.btn),
    .empresas-filtros-form > .row > .col-auto:has(.btn) {
        flex: 1 1 100% !important;
        margin-left: 0 !important;
        display: flex;
        justify-content: flex-end;
    }
}

/* Badges de estado en notificaciones */
.badge.galactea-notif-badge,
span.badge.galactea-notif-badge {
    --tblr-badge-color: #fff;
    --tblr-badge-bg-color: var(--galactea-notif-badge-bg, #6c757d);
    display: inline-block;
    color: #fff !important;
    font-size: 0.65rem !important;
    font-weight: 600 !important;
    padding: 0.45rem 0.8rem !important;
    letter-spacing: 0.04em;
    line-height: 1.25 !important;
    border-radius: var(--tblr-border-radius);
    vertical-align: middle;
}

.badge.galactea-notif-badge.bg-warning,
span.badge.galactea-notif-badge.bg-warning {
    --galactea-notif-badge-bg: #e67e00;
    background-color: #e67e00 !important;
    color: #fff !important;
}

.badge.galactea-notif-badge.bg-success,
span.badge.galactea-notif-badge.bg-success {
    --galactea-notif-badge-bg: #2fb344;
    background-color: #2fb344 !important;
    color: #fff !important;
}

.badge.galactea-notif-badge.bg-info,
span.badge.galactea-notif-badge.bg-info {
    --galactea-notif-badge-bg: #4299e1;
    background-color: #4299e1 !important;
    color: #fff !important;
}

/* Filas de notificaciones: el gris de fila no debe afectar al badge */
tr.galactea-notif-finalizada td {
    color: #999;
}

tr.galactea-notif-finalizada .galactea-notif-badge,
tr.galactea-notif-vencida .galactea-notif-badge,
tr.galactea-notif-proxima .galactea-notif-badge {
    color: #fff !important;
}

tr.galactea-notif-finalizada {
    background-color: #f0f0f0;
}

tr.galactea-notif-vencida {
    background-color: #f8d7da;
}

tr.galactea-notif-proxima {
    background-color: #d4edda;
}

/* Acciones de fila: web, editar, borrar juntos */
.galactea-row-actions {
    gap: 0.125rem !important;
}

.galactea-row-actions .btn-icon {
    width: 1.625rem;
    height: 1.625rem;
    min-width: 1.625rem;
}

/* Botones solo con icono (tamaño pequeño, p. ej. filtros y tablas) */
.btn.btn-sm.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    min-width: 2rem;
    padding: 0;
    line-height: 1;
}

.btn.btn-sm.btn-icon .icon,
.btn.btn-sm.btn-icon > i,
.btn.btn-icon-header .icon,
.btn.btn-icon-header > i {
    margin: 0 !important;
    width: 1rem;
    height: 1rem;
    font-size: 1rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn.btn-sm.btn-icon > i::before,
.btn.btn-icon-header > i::before {
    line-height: 1;
    vertical-align: 0;
}
