/* 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;
}

.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-grid-section .post-grid-image {
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
    object-fit: cover;
}

.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;
}

.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;
}

/* --- 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-wrapper {
  width: 90%;
  margin: 0 auto;
  padding: 0 2rem;
  position: relative;
  z-index: 1;
}

.breadcrumb {
  font-size: 0.9rem;
  padding: 0.5rem 1rem;
  border-radius: 0.3rem;
  border: 1px solid #dee2e6;
  background-color: #f9f9f9;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.03);
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.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;
  height: 72px;
  object-fit: cover;
  border-radius: 4px;
}

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