/* static/css/theme.css */

/*
 * =========================================
 *           TAVATA "BEE THEME"
 * =========================================
 * Define nuestras variables de color personalizadas
 * y las usamos para sobrescribir las de Bootstrap.
 */

:root {
    /* 1. Definimos nuestros colores base */
    --tavata-yellow: #ffc107;
    --tavata-dark: #212529;
    --tavata-light: #f8f9fa;
    --tavata-body-bg: var(--tavata-light);
    --tavata-body-color: var(--tavata-dark);
    --tavata-card-box-bg: #f1f3f5;
    --tavata-card-box-border: #dee2e6;
    --tavata-home-notice-bg: #eef2f5;
    --tavata-home-notice-color: #495057;
    --tavata-font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --tavata-base-font-size: 16px;
    --tavata-slogan-font-size: 28px;
    --tavata-logo-height: 50px;
    --tavata-banner-max-height: 50px;
    --tavata-border-radius: 4px;
    --tavata-layout-max-width: 1440px;
    --tavata-layout-horizontal-padding: 16px;
    --tavata-content-width: 64%;
    --tavata-left-sidebar-width: 18%;
    --tavata-right-sidebar-width: 18%;

    /* 2. Sobrescribimos las variables de color principales de Bootstrap */
    --bs-primary: var(--tavata-yellow);       /* El color primario ahora es nuestro amarillo */
    --bs-primary-rgb: 255, 193, 7;           /* La versión RGB para transparencias (muy importante) */

    --bs-dark: var(--tavata-dark);
    --bs-dark-rgb: 33, 37, 41;

    --bs-light: var(--tavata-light);
    --bs-light-rgb: 248, 249, 250;

    /* Ajustamos el color del texto sobre nuestro color primario para mejor contraste */
    --bs-body-color-rgb: 33, 37, 41; /* Texto principal oscuro */
}

.site-main-layout {
    width: min(100%, var(--tavata-layout-max-width));
    margin-inline: auto;
    padding-inline: var(--tavata-layout-horizontal-padding);
}

.site-content-grid {
    display: grid;
    grid-template-columns:
        minmax(0, var(--tavata-left-sidebar-width))
        minmax(0, var(--tavata-content-width))
        minmax(0, var(--tavata-right-sidebar-width));
    gap: 1.5rem;
}

.site-content-column,
.site-sidebar {
    min-width: 0;
}

@media (min-width: 992px) {
    .site-sidebar > .sticky-top {
        max-height: calc(100vh - 1rem);
        overflow-y: auto;
        overscroll-behavior: contain;
        scrollbar-gutter: stable;
        scrollbar-width: thin;
    }
}

.card {
    background-color: var(--tavata-card-box-bg);
    border-color: var(--tavata-card-box-border);
}

.card-header,
.card-footer,
.card .list-group-item {
    background-color: var(--tavata-card-box-bg);
    border-color: var(--tavata-card-box-border);
}

.homepage-main-content-display .alert-info {
    background-color: var(--tavata-home-notice-bg);
    border-color: var(--tavata-card-box-border);
    color: var(--tavata-home-notice-color);
}

.tvt-float {
    animation: tvtFloat 3.5s ease-in-out infinite;
}

.tvt-pulse {
    animation: tvtPulse 2.4s ease-in-out infinite;
}

.tvt-slide-icon {
    animation: tvtSlideIcon 3s ease-in-out infinite;
}

.tvt-card-hover {
    transition: transform .25s ease, box-shadow .25s ease;
}

.tvt-card-hover:hover {
    transform: translateY(-6px);
    box-shadow: 0 22px 55px rgba(0, 0, 0, 0.10);
}

.tvt-dot-pattern {
    background-image: radial-gradient(var(--tavata-card-box-border) 2px, transparent 2px);
    background-size: 16px 16px;
}

.tvt-section {
    background-color: var(--tavata-body-bg);
    color: var(--tavata-body-color);
}

.tvt-section-muted {
    background-color: var(--tavata-card-box-bg);
    color: var(--tavata-body-color);
}

.tvt-section-notice {
    background-color: var(--tavata-home-notice-bg);
    color: var(--tavata-home-notice-color);
}

.tvt-surface {
    background-color: var(--tavata-category-tree-bg);
    border: 1px solid var(--tavata-category-tree-border);
    border-radius: var(--tavata-border-radius);
}

.tvt-text-muted {
    color: var(--tavata-home-notice-color);
}

.tvt-accent-badge {
    background-color: var(--tavata-yellow);
    color: var(--tavata-dark);
}

.tvt-accent-link {
    color: var(--tavata-body-color);
    border-bottom: 3px solid var(--tavata-yellow);
    padding-bottom: .35rem;
}

@keyframes tvtFloat {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-12px);
    }
}

@keyframes tvtPulse {
    0%, 100% {
        transform: scale(1);
        opacity: 1;
    }
    50% {
        transform: scale(1.08);
        opacity: .82;
    }
}

@keyframes tvtSlideIcon {
    0%, 100% {
        transform: translateX(0);
    }
    50% {
        transform: translateX(8px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .tvt-float,
    .tvt-pulse,
    .tvt-slide-icon {
        animation: none;
    }

    .tvt-card-hover {
        transition: none;
    }

    .tvt-card-hover:hover {
        transform: none;
    }

    .featured-tag-cloud__item {
        animation: none;
    }
}

.post-carousel-section .carousel {
    overflow: hidden;
    border-radius: var(--tavata-border-radius);
    background-color: var(--tavata-dark);
}

.post-carousel-section .carousel-item {
    aspect-ratio: 16 / 9;
    background-color: var(--tavata-dark);
}

.post-carousel-section .carousel-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    margin: 0;
}

.post-carousel-empty-frame {
    align-items: center;
    aspect-ratio: 16 / 9;
    background-color: var(--tavata-dark);
    display: flex;
    justify-content: center;
    padding: 1rem;
}

.post-grid-section .post-grid-image {
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
    object-fit: cover;
}

.post-grid-section .post-grid-image-square {
    aspect-ratio: 1 / 1;
}

.featured-tag-cloud {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.7rem;
    justify-content: center;
    min-height: 8rem;
    padding: 0.35rem 0.1rem;
}

.featured-tag-cloud__item {
    --tag-delay: 0;
    --tag-score: 0;
    --tag-rotate: -2deg;
    animation: featuredTagDrift 7s ease-in-out infinite;
    animation-delay: calc(var(--tag-delay) * -0.45s);
    background-color: color-mix(in srgb, var(--tavata-card-box-bg) 84%, var(--tavata-yellow));
    border: 1px solid color-mix(in srgb, var(--tavata-card-box-border) 72%, var(--tavata-yellow));
    border-radius: 999px;
    color: var(--tavata-body-color);
    display: inline-flex;
    line-height: 1;
    padding: 0.48rem 0.72rem;
    text-decoration: none;
    transform-origin: center;
    transition: background-color .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
    will-change: transform;
}

.featured-tag-cloud__item:nth-child(3n + 1) {
    --tag-rotate: -4deg;
}

.featured-tag-cloud__item:nth-child(3n + 2) {
    --tag-rotate: 3deg;
}

.featured-tag-cloud__item:nth-child(4n) {
    background-color: var(--tavata-body-bg);
}

.featured-tag-cloud__item:nth-child(5n) {
    border-color: var(--tavata-yellow);
}

.featured-tag-cloud__item:hover,
.featured-tag-cloud__item:focus {
    background-color: var(--tavata-yellow);
    border-color: var(--tavata-yellow);
    color: var(--tavata-dark);
    transform: translateY(-2px) scale(1.04);
}

.featured-tag-cloud__item--md {
    font-size: 0.92rem;
    font-weight: 500;
}

.featured-tag-cloud__item--lg {
    font-size: 1.12rem;
    font-weight: 650;
}

.featured-tag-cloud__item--xl {
    font-size: 1.32rem;
    font-weight: 750;
    letter-spacing: 0;
    padding: 0.58rem 0.9rem;
}

@keyframes featuredTagDrift {
    0%, 100% {
        transform: translateY(0) rotate(var(--tag-rotate));
    }
    50% {
        transform: translateY(-5px) rotate(calc(var(--tag-rotate) * -1));
    }
}

.post-carousel-section .carousel-caption {
    right: 8%;
    bottom: 2rem;
    left: 8%;
    padding-bottom: 0;
}

.post-carousel-caption-box {
    width: min(100%, 720px);
    margin-inline: auto;
    padding: 1rem 1.25rem;
    color: #fff;
    background-color: rgba(11, 11, 11, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: var(--tavata-border-radius);
    box-shadow: 0 0.75rem 2rem rgba(0, 0, 0, 0.28);
    backdrop-filter: blur(4px);
}

.post-carousel-caption-box h5,
.post-carousel-caption-box p {
    margin-bottom: 0.65rem;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

.post-carousel-caption-box p {
    font-size: 0.95rem;
}

.hero-carousel .carousel-inner {
    background: #1d2127;
}

.hero-carousel__image {
    margin: 0;
}

.hero-carousel__empty-frame {
    position: relative;
    display: flex;
    align-items: stretch;
    justify-content: stretch;
    min-height: 360px;
    background:
        radial-gradient(circle at 78% 22%, rgba(255, 193, 7, 0.22), transparent 22%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0)),
        linear-gradient(180deg, #6a6f79 0%, #4f5661 38%, #2d333b 100%);
}

.hero-carousel__empty-glow {
    flex: 1 1 auto;
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0.34));
}

.hero-carousel .carousel-caption {
    right: 7%;
    bottom: 1.75rem;
    left: 7%;
    padding-bottom: 0;
}

.hero-carousel__caption-box {
    width: min(100%, 40rem);
    color: #fff;
    background-color: rgba(17, 24, 39, 0.42);
    border: 1px solid rgba(255, 255, 255, 0.16);
    box-shadow: 0 1rem 2.5rem rgba(0, 0, 0, 0.22);
    backdrop-filter: blur(6px);
}

.hero-carousel__caption-box h3 {
    margin-bottom: 0.75rem;
    font-size: clamp(2rem, 2.2vw + 1rem, 3.2rem);
    line-height: 1.08;
    text-wrap: balance;
}

.hero-carousel__caption-box p {
    max-width: 42ch;
    margin-bottom: 1rem;
    font-size: 1.05rem;
    line-height: 1.45;
    text-wrap: pretty;
}

.hero-carousel__item--no-image .carousel-caption {
    top: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    padding-top: 1.75rem;
    right: 4.5rem;
    left: 2.75rem;
}

.hero-carousel__item--no-image .hero-carousel__caption-box {
    width: 100%;
    max-width: none;
    min-height: min(100%, 17.5rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 1.6rem 1.75rem;
    background:
        linear-gradient(90deg, rgba(17, 24, 39, 0.78) 0%, rgba(17, 24, 39, 0.72) 58%, rgba(17, 24, 39, 0.44) 100%);
}

.hero-carousel__item--no-image .hero-carousel__caption-box h3 {
    font-size: clamp(1.8rem, 1.8vw + 1rem, 2.9rem);
    line-height: 1.08;
}

.hero-carousel__item--no-image .hero-carousel__caption-box p {
    font-size: 1rem;
}

@media (max-width: 767.98px) {
    .hero-carousel__empty-frame {
        min-height: 300px;
    }

    .hero-carousel .carousel-caption {
        right: 5%;
        left: 5%;
        bottom: 1.15rem;
    }

    .hero-carousel__caption-box h3 {
        font-size: clamp(1.55rem, 4vw + 1rem, 2.3rem);
    }

    .hero-carousel__caption-box p {
        font-size: 0.98rem;
    }

    .hero-carousel__item--no-image .carousel-caption {
        align-items: end;
        padding-top: 0;
        right: 5%;
        left: 5%;
    }

    .hero-carousel__item--no-image .hero-carousel__caption-box {
        min-height: auto;
        padding: 1.1rem 1.15rem;
    }
}

.category-tree-container {
    max-width: min(100%, var(--tavata-category-tree-max-width));
}

.category-tree-container > .list-group {
    background-color: var(--tavata-category-tree-bg);
    border: 1px solid var(--tavata-category-tree-border);
    border-radius: var(--tavata-border-radius);
    overflow: hidden;
}

.category-tree-node {
    background-color: var(--tavata-category-tree-bg);
    padding-top: var(--tavata-category-tree-row-padding-y);
    padding-bottom: var(--tavata-category-tree-row-padding-y);
    padding-left: var(--tavata-category-tree-base-padding);
    padding-right: var(--tavata-category-tree-base-padding);
}

@media (max-width: 991.98px) {
    .site-content-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .site-sidebar {
        display: none;
    }
}

body {
    background-color: var(--tavata-body-bg) !important;
    color: var(--tavata-body-color);
    font-family: var(--tavata-font-family);
    font-size: var(--tavata-base-font-size);
}

.text-tavata-yellow-outlined {
    color: var(--tavata-yellow);
    text-shadow:
        0 0 1px rgba(0, 0, 0, 0.5);
}
/* 3. Pequeños ajustes y clases de utilidad */
img.zoomable {
  cursor: zoom-in;
  transition: opacity 0.2s ease;
  max-width: 100%;
  height: auto;
  display: block;
  margin: 1rem auto;
}

/* Overlay modal para imagen ampliada */
.image-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.8);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 2000;
}

.image-modal-overlay img {
  max-width: 90%;
  max-height: 90%;
  border-radius: 4px;
  border-radius: var(--tavata-border-radius);
  cursor: zoom-out;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.6);
}

/* Asegurarnos de que el texto en botones primarios sea negro para legibilidad */
.btn-primary {
    /* 1. Definimos explícitamente el color de fondo normal */
    --bs-btn-bg: var(--tavata-yellow);
    --bs-btn-border-color: var(--tavata-yellow);

    /* 2. Definimos el color del texto para buen contraste */
    --bs-btn-color: var(--tavata-dark);
    --bs-btn-hover-color: var(--tavata-dark);
    --bs-btn-active-color: var(--tavata-dark);

    /* 3. Definimos los colores para el estado :hover */
    --bs-btn-hover-bg: #e6ac00; /* Un dorado un poco más oscuro al pasar el ratón */
    --bs-btn-hover-border-color: #e6ac00;
}


/* Tavata-flavoured outline buttons */
.btn-outline-primary {
    --bs-btn-color: var(--tavata-dark);
    --bs-btn-border-color: var(--tavata-yellow);
    --bs-btn-hover-color: var(--tavata-dark);
    --bs-btn-hover-bg: var(--tavata-yellow);
    --bs-btn-hover-border-color: var(--tavata-yellow);
    --bs-btn-active-color: var(--tavata-dark);
    --bs-btn-active-bg: var(--tavata-yellow);
    --bs-btn-active-border-color: var(--tavata-yellow);
    --bs-btn-focus-shadow-rgb: var(--bs-primary-rgb);
    font-weight: 650;
}

.btn-outline-secondary {
    --bs-btn-color: var(--tavata-body-color);
    --bs-btn-border-color: var(--tavata-card-box-border);
    --bs-btn-hover-color: var(--tavata-dark);
    --bs-btn-hover-bg: color-mix(in srgb, var(--tavata-yellow) 18%, var(--tavata-card-box-bg));
    --bs-btn-hover-border-color: color-mix(in srgb, var(--tavata-yellow) 45%, var(--tavata-card-box-border));
    --bs-btn-active-color: var(--tavata-dark);
    --bs-btn-active-bg: color-mix(in srgb, var(--tavata-yellow) 24%, var(--tavata-card-box-bg));
    --bs-btn-active-border-color: color-mix(in srgb, var(--tavata-yellow) 55%, var(--tavata-card-box-border));
}

/* --- NEW THEME UTILITY CLASS --- */
/* A background class for our primary theme color with dark text for contrast */
.bg-tavata-primary {
    background-color: var(--tavata-yellow) !important;
    color: var(--tavata-dark) !important;
}

/* Ensure links within this background are also dark */
.bg-tavata-primary a {
    color: var(--tavata-dark) !important;
    transition: opacity 0.2s ease-in-out;
}

.bg-tavata-primary a:hover {
    opacity: 0.75;
}
/* --- END NEW CLASS --- */

/* Clases de utilidad para usar nuestros colores directamente */
.text-tavata-yellow {
    color: var(--tavata-yellow) !important;
}

.bg-tavata-dark {
    background-color: var(--tavata-dark) !important;
}


/* --- Collapsible Widget Icon (Bootstrap Native Rotation) --- */

.TAVATA-collapse-icon {
    transition: transform 0.25s ease-in-out;
}

/* Cuando el botón NO está colapsado (es decir, el contenido es visible)... */
[aria-expanded="true"] .TAVATA-collapse-icon {
    /* ...la flecha apunta hacia arriba. */
    transform: rotate(-180deg);
}

header,
.navbar,
.main-navbar-menu {
    position: relative;
    z-index: 1100;
}

.navbar,
.navbar .container,
.navbar-collapse,
.main-navbar-menu,
.main-navbar-menu .nav-item,
.main-navbar-menu .dropdown {
    overflow: visible;
}

.main-navbar-menu .dropdown-menu {
    z-index: 1200;
}

/* --- Bootstrap Multi-level Dropdown --- */
.dropdown-menu li {
    position: relative;
}
.dropdown-menu .dropdown-submenu {
    display: none;
    position: absolute;
    left: 100%;
    top: -7px;
}
.dropdown-menu .dropdown-submenu-left {
    right: 100%;
    left: auto;
}
.dropdown-menu > li:hover > .dropdown-submenu {
    display: block;
}

/* --- BOOTSTRAP MULTI-LEVEL DROPDOWN SUPPORT --- */

.dropdown-menu li {
    position: relative;
}

/* Style for the nested submenu */
.dropdown-menu .dropdown-submenu {
    display: none;
    position: absolute;
    left: 100%;
    top: -7px; /* Adjust this value to vertically align the submenu */
}

/* Show the nested submenu on hover */
.dropdown-menu > li:hover > .dropdown-submenu {
    display: block;
}

/* Optional: add an arrow to items that have a submenu */
.dropdown-submenu-toggle::after {
    content: '▸';
    display: inline-block;
    margin-left: .5em;
    vertical-align: middle;
}
/* --- END MULTI-LEVEL DROPDOWN --- */

/* --- Breadcrumb refinement: TVT/Tavata style --- */
.breadcrumb-wrapper {
  width: min(100%, var(--tavata-layout-max-width));
  margin: 0 auto 1.25rem;
  padding-inline: var(--tavata-layout-horizontal-padding);
  position: relative;
  z-index: 1;
}

.breadcrumb-area,
.breadcrumb-container,
.breadcrumb-wrapper,
nav[aria-label="breadcrumb"] {
  overflow: visible !important;
  margin-top: 0.85rem;
  margin-bottom: 1.5rem
}

/* Evita que el contenido de la página quede demasiado pegado al breadcrumb */
.breadcrumb + *,
.breadcrumb-area + *,
.breadcrumb-container + *,
.breadcrumb-wrapper + *,
nav[aria-label="breadcrumb"] + * {
  margin-top: 1rem;
}

.breadcrumb {
  align-items: center;
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb, var(--tavata-yellow) 12%, var(--tavata-card-box-bg)),
      var(--tavata-card-box-bg)
    );
  border: 1px solid var(--tavata-card-box-border);
  border-left: 4px solid var(--tavata-yellow);
  border-radius: calc(var(--tavata-border-radius) * 1.6);
  box-shadow: 0 0.35rem 1rem rgba(0, 0, 0, 0.035);
  color: var(--tavata-body-color);
  display: flex;
  flex-wrap: wrap;
  font-size: 0.92rem;
  gap: 0.15rem 0.35rem;
  line-height: 1.45;
  margin: 0;
  min-height: 44px;
  overflow: visible !important;
  overflow-wrap: anywhere;
  padding: 0.7rem 1rem;
  white-space: normal;
  word-break: normal;
}

.breadcrumb-item {
  align-items: center;
  display: inline-flex;
  min-width: 0;
}

.breadcrumb-item + .breadcrumb-item::before {
  color: var(--tavata-home-notice-color);
  opacity: 0.8;
}

.breadcrumb-item a {
  color: var(--tavata-dark);
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.breadcrumb-item a:hover,
.breadcrumb-item a:focus {
  color: var(--tavata-yellow);
  opacity: 0.95;
}

.breadcrumb-item.active {
  color: var(--tavata-home-notice-color);
  font-weight: 500;
}

@media (max-width: 575.98px) {
  .breadcrumb-wrapper {
    padding-inline: 0.75rem;
  }

  .breadcrumb {
    font-size: 0.86rem;
    padding: 0.65rem 0.8rem;
  }
}

.pagination {
  --bs-pagination-color: var(--tavata-dark);
  --bs-pagination-bg: var(--tavata-card-box-bg);
  --bs-pagination-border-color: var(--tavata-card-box-border);
  --bs-pagination-hover-color: var(--tavata-dark);
  --bs-pagination-hover-bg: var(--tavata-yellow);
  --bs-pagination-hover-border-color: var(--tavata-yellow);
  --bs-pagination-focus-color: var(--tavata-dark);
  --bs-pagination-focus-bg: var(--tavata-yellow);
  --bs-pagination-focus-box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.25);
  --bs-pagination-active-color: var(--tavata-dark);
  --bs-pagination-active-bg: var(--tavata-yellow);
  --bs-pagination-active-border-color: var(--tavata-yellow);
  --bs-pagination-disabled-color: var(--tavata-body-color);
  --bs-pagination-disabled-bg: var(--tavata-light);
  --bs-pagination-disabled-border-color: var(--tavata-card-box-border);
}

.search-result-thumbnail {
  display: block;
  width: 96px;
  aspect-ratio: 1 / 1;
  height: auto;
  object-fit: cover;
  border-radius: 4px;
}

@media (max-width: 575.98px) {
  .search-result-thumbnail {
    width: 72px;
  }
}

/* --- Account profile/CV page helpers --- */
.profile-cv-page .cv-hero .btn {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    min-height: 42px;
    white-space: nowrap;
}

.profile-cv-page .cv-hero {
    border-color: var(--tavata-card-box-border) !important;
}

.profile-cv-page .card-header {
    border-color: var(--tavata-card-box-border);
}

/* --- Navbar Right Side Buttons Responsive --- */
.navbar .d-flex.gap-2 {
  flex-wrap: wrap;
}

.navbar .d-flex.gap-2 > .btn {
  margin-bottom: 0.25rem;
}

@media (max-width: 575.98px) {
  .navbar .d-flex.gap-2 > .btn,
  .navbar .d-flex.gap-2 > a.btn {
    padding: 0.375rem 0.5rem;
    font-size: 0.8rem;
  }

  .navbar .d-flex.gap-2 > .btn i,
  .navbar .d-flex.gap-2 > a.btn i {
    margin-right: 0;
  }

  .navbar form[role="search"] input[type="search"],
  .navbar .search-form input[type="search"] {
    max-width: 80px;
    font-size: 0.85rem;
  }
}

/* --- Navbar: ajustes mínimos seguros --- */

.main-navbar-menu .nav-link,
.navbar .nav-link {
  white-space: normal;
  line-height: 1.2;
}

.main-navbar-menu .navbar-nav,
.navbar .navbar-nav {
  flex-wrap: wrap;
  gap: 0.25rem;
}

.main-navbar-menu .dropdown-menu,
.navbar .dropdown-menu {
  white-space: normal;
  min-width: min(20rem, calc(100vw - 2rem));
  max-width: min(26rem, calc(100vw - 2rem));
}

.main-navbar-menu > .nav-item {
  min-width: 0;
}

.main-navbar-menu .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  max-width: 100%;
}

.main-navbar-menu .dropdown-item {
  white-space: normal;
  line-height: 1.35;
}

/* Buscador un poco más contenido, sin romper layout */
.navbar form[role="search"] input[type="search"],
.navbar .search-form input[type="search"] {
  max-width: 150px;
}

/* --- Navbar Two-Line Layout --- */
.navbar-collapse-wrapper {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
}

.navbar-collapse-wrapper > .main-navbar-menu {
  order: 1;
  flex: 1 1 auto;
  flex-wrap: wrap;
  margin-bottom: 0;
  display: flex;
  flex-direction: row;
  row-gap: 0.35rem;
  min-width: 0;
}

.navbar-collapse-wrapper > .navbar-right-actions {
  order: 2;
  align-self: center;
  flex: 0 0 auto;
  flex-wrap: nowrap;
  margin-bottom: 0;
  width: auto;
  margin-left: auto;
}

.navbar-collapse-wrapper.navbar-two-level {
  flex-direction: column;
  align-items: stretch;
  gap: 0.45rem;
}

.navbar-collapse-wrapper.navbar-two-level > .navbar-right-actions {
  order: 1;
  align-self: flex-end;
}

.navbar-collapse-wrapper.navbar-two-level > .main-navbar-menu {
  order: 2;
  width: 100%;
  padding-top: 0.45rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

/* Let the main menu wrap naturally on desktop without forcing the last items down */
@media (min-width: 992px) {
  .navbar-collapse-wrapper {
    row-gap: 0.4rem;
  }
}

@media (max-width: 991.98px) {
  .navbar-collapse-wrapper {
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
  }

  .navbar-collapse-wrapper > .navbar-right-actions {
    order: 2;
    align-self: flex-start;
    width: 100%;
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    flex-wrap: wrap;
  }

  .main-navbar-menu .nav-link,
  .navbar .nav-link {
    white-space: normal;
  }

  .navbar-collapse-wrapper > .main-navbar-menu {
    order: 1;
    width: 100%;
  }
}

/* --- Navbar Right Actions: Icon-only buttons --- */
.navbar-right-actions {
  row-gap: 0.5rem;
  align-items: center;
}

.navbar-right-actions .btn {
  padding: 0 !important;
  border-radius: 4px;
  transition: all 0.2s ease-in-out;
  position: relative;
}

.navbar-right-actions .btn:hover,
.navbar-right-actions .btn:focus {
  transform: scale(1.05);
}

.navbar-right-actions .btn i {
  font-size: 1rem;
}

.navbar-right-actions .position-absolute.badge {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
}

.navbar-right-actions a > img {
  border: 2px solid transparent;
  transition: border-color 0.2s ease-in-out;
}

.navbar-right-actions a > img:hover,
.navbar-right-actions a > img:focus {
  border-color: var(--tavata-yellow);
}

/* --- Compact brand icon in navbar --- */
.tavata-navbar-brand-icon {
  color: var(--tavata-yellow) !important;
  font-size: 1.35rem;
  line-height: 1;
  margin-right: 0.75rem;
  padding-inline: 0.25rem;
  text-decoration: none;
  white-space: nowrap;
}

.tavata-navbar-brand-icon:hover,
.tavata-navbar-brand-icon:focus {
  color: var(--tavata-yellow) !important;
  opacity: 0.85;
}

/* --- Navbar search strip --- */
.tavata-navbar-search-strip {
  background-color: color-mix(in srgb, var(--tavata-dark) 94%, var(--tavata-yellow));
  border-top: 1px solid color-mix(in srgb, var(--tavata-yellow) 20%, transparent);
  padding: 0.4rem 0;
}

.tavata-navbar-search-form {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-left: auto;
}

.tavata-navbar-search-input {
  width: min(100%, 320px);
  min-width: 220px;
  height: 34px;
  border-radius: var(--tavata-border-radius);
  border-color: var(--tavata-card-box-border);
}

.tavata-navbar-search-input:focus {
  border-color: var(--tavata-yellow);
  box-shadow: 0 0 0 0.15rem color-mix(in srgb, var(--tavata-yellow) 35%, transparent);
}

.tavata-navbar-search-button {
  height: 34px;
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}

@media (max-width: 575.98px) {
  .tavata-navbar-search-form {
    justify-content: stretch;
  }

  .tavata-navbar-search-input {
    min-width: 0;
    width: 100%;
  }
}

/* --- Topbar compact language switcher --- */
.topbar-slogan {
  font-size: var(--tavata-slogan-font-size);
}

.topbar-actions {
  flex-shrink: 0;
}

.topbar-language-switcher .btn {
  --bs-btn-padding-y: 0.16rem;
  --bs-btn-padding-x: 0.45rem;
  --bs-btn-font-size: 0.78rem;
  border-radius: calc(var(--tavata-border-radius) * 1.2);
  font-weight: 700;
  line-height: 1.2;
  min-width: 34px;
}

.topbar-language-switcher .btn-dark {
  background-color: var(--tavata-dark);
  border-color: var(--tavata-dark);
  color: var(--tavata-yellow);
}

.topbar-language-switcher .btn-outline-dark:hover,
.topbar-language-switcher .btn-outline-dark:focus {
  background-color: var(--tavata-dark);
  border-color: var(--tavata-dark);
  color: var(--tavata-yellow);
}

.user-avatar-toggle::after {
  display: none;
}

.user-avatar-toggle {
  box-shadow: none !important;
}

.user-avatar-toggle img {
  border: 2px solid rgba(255, 193, 7, 0.85);
}

.user-avatar-menu {
  min-width: 260px;
  border-radius: 0.9rem;
  border: 1px solid rgba(255, 193, 7, 0.2);
}

.user-avatar-menu .dropdown-header {
  padding-top: 0.85rem;
  padding-bottom: 0.75rem;
}

.user-avatar-menu .dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding-top: 0.55rem;
  padding-bottom: 0.55rem;
}

@media (max-width: 767.98px) {
  .top-bar .container {
    align-items: flex-start !important;
    flex-direction: column;
  }

  .topbar-actions {
    width: 100%;
    justify-content: space-between;
  }

  .topbar-slogan {
    font-size: calc(var(--tavata-slogan-font-size) * 0.72);
  }

  .top-bar-banner {
    display: none;
  }
}

.publication-detail {
    max-width: 1040px;
}

.publication-subtitle {
    max-width: 760px;
    line-height: 1.65;
}

.publication-meta {
    background: var(--tavata-card-box-bg, #f8f9fa);
    border: 1px solid var(--tavata-card-box-border, #dee2e6) !important;
    border-radius: 1rem;
}

.publication-hero-image img {
    max-height: 460px;
    object-fit: cover;
}

.publication-abstract-block,
.publication-section {
    background: var(--tavata-card-box-bg, #f8f9fa);
    border: 1px solid var(--tavata-card-box-border, #dee2e6);
    border-radius: 1rem;
    padding: 1.5rem;
}

.publication-abstract-block h2,
.publication-section h2 {
    font-size: 1.35rem;
    margin-bottom: 1rem;
    color: var(--tavata-body-color, #212529);
    border-bottom: 2px solid var(--tavata-yellow, #F5C518);
    padding-bottom: 0.5rem;
}

.publication-section-body {
    line-height: 1.75;
}

.publication-section-body p:last-child {
    margin-bottom: 0;
}

.publication-social-image {
    aspect-ratio: 1 / 1;
    object-fit: cover;
    width: 100%;
}

@media (max-width: 991.98px) {
    .publication-abstract-block,
    .publication-section {
        padding: 1rem;
    }
}

/* ==========================================================
   Publications: clean WYSIWYG content styling
   ========================================================== */

.publication-section-body {
    line-height: 1.75;
    color: var(--tavata-body-color, #212529);
}

/* Limpia fondos raros heredados desde TinyMCE o contenido pegado */
.publication-section-body p,
.publication-section-body div,
.publication-section-body span,
.publication-section-body strong,
.publication-section-body em {
    background: transparent !important;
    background-color: transparent !important;
}

/* Evita que los párrafos parezcan cajas independientes */
.publication-section-body p {
    margin-top: 0;
    margin-bottom: 1rem;
    padding: 0;
    border: 0;
}

/* Último párrafo sin margen extra */
.publication-section-body p:last-child {
    margin-bottom: 0;
}

/* Listas más académicas y limpias */
.publication-section-body ul,
.publication-section-body ol {
    margin-top: 0.5rem;
    margin-bottom: 1rem;
    padding-left: 1.5rem;
}

.publication-section-body li {
    margin-bottom: 0.35rem;
}

/* Enlaces dentro de publicaciones */
.publication-section-body a {
    color: inherit;
    text-decoration: underline;
    text-decoration-color: var(--tavata-yellow, #F5C518);
    text-underline-offset: 0.2rem;
}

/* ==========================================================
   Publications: clean card/list excerpt styling
   ========================================================== */

.publication-card-abstract,
.publication-card-abstract p,
.publication-card-abstract div,
.publication-card-abstract span,
.publication-card-abstract strong,
.publication-card-abstract em,
.publication-card-abstract ul,
.publication-card-abstract ol,
.publication-card-abstract li {
    background: transparent !important;
    background-color: transparent !important;
}

.publication-card-abstract {
    font-size: 0.95rem;
    line-height: 1.6;
    color: var(--tavata-body-color, #212529);
}

.publication-card-abstract p {
    margin: 0;
    padding: 0;
    border: 0;
}

.publication-card-abstract [style*="background"],
.publication-card-abstract [style*="background-color"] {
    background: transparent !important;
    background-color: transparent !important;
}

.publication-section-body ul,
.publication-section-body ol,
.publication-section-body li {
    background: transparent !important;
    background-color: transparent !important;
}

.publication-section-body [style*="background"],
.publication-section-body [style*="background-color"] {
    background: transparent !important;
    background-color: transparent !important;
}

.publication-document-page {
    margin-top: 0.35rem;
    margin-bottom: 0.35rem;
    max-width: 1600px;
}

.publication-document-viewer {
    background: var(--tavata-category-tree-bg, #ffffff);
    border: 1px solid var(--tavata-card-box-border, #dee2e6);
    border-radius: 14px;
}

.publication-document-viewer iframe {
    display: block;
    width: 100%;
    min-height: calc(100vh - 170px);
    background: var(--tavata-category-tree-bg, #ffffff);
}


/* ==========================================================
   Publications: document viewer responsive
   ========================================================== */

@media (max-width: 767.98px) {
  .publication-document-page {
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-top: 0.15rem;
        margin-bottom: 0.15rem;
    }

    .publication-document-viewer {
        border-radius: 0;
        border-left: 0;
        border-right: 0;
    }

    .publication-document-viewer iframe {
        min-height: calc(100vh - 120px);
    }
}


/* ==========================================================
   Navbar: medium screens compression
   ========================================================== */

@media (min-width: 992px) and (max-width: 1399.98px) {
  .main-navbar-menu .nav-link,
  .navbar .nav-link {
    font-size: 0.88rem;
    padding-left: 0.38rem;
    padding-right: 0.38rem;
  }

  .main-navbar-menu .nav-link i,
  .navbar .nav-link i {
    margin-right: 0.2rem;
  }

  .navbar form[role="search"] input[type="search"],
  .navbar .search-form input[type="search"] {
    max-width: 120px;
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {
  .main-navbar-menu .nav-link,
  .navbar .nav-link {
    font-size: 0.78rem;
    padding-left: 0.25rem;
    padding-right: 0.25rem;
  }

  .main-navbar-menu .nav-link i,
  .navbar .nav-link i {
    margin-right: 0.1rem;
  }

  .navbar form[role="search"] input[type="search"],
  .navbar .search-form input[type="search"] {
    max-width: 100px;
  }

  .navbar .container {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
}

@media (max-width: 767.98px) {
  .main-navbar-menu .nav-link,
  .navbar .nav-link {
    font-size: 0.875rem;
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }

  .main-navbar-menu .navbar-nav,
  .navbar .navbar-nav {
    gap: 0;
  }
}
