.overflow-hidden {
  overflow: hidden;
}

.vue-posts {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.vue-load-more {
  margin-top: var(--gapX5);
  align-self: center;
}

:is(.posts-container) :is(.post-tag-group) {
  display: flex;
  flex-flow: wrap;
  gap: var(--gapX1);
}

:is(.posts-container) .post-tag-group .post-tag {
  /* border: 1px solid;
  border-radius: 4px; */
  /* padding: 0 6px; */
  margin: unset;
  font-size: var(--textSsize);
  line-height: var(--textSheightS);
}

.filter-taxonomies .filter .posts-counter {
  opacity: 0.5;
  font-size: var(--textSsize);
  line-height: var(--textSheightT);
  letter-spacing: var(--textSspacing);
}

.filter-taxonomies .filter {
  transition: all 0.1s ease-in-out;
}

.filters-container .filter-taxonomies .filter.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

.filters-container.side-filters .filter-header {
  margin-bottom: var(--gapX6);
}

.filters-container.side-filters {
  position: fixed;
  top: 0;
  right: -500px;
  width: 400px;
  height: 100%;
  background-color: #ffffff;
  padding: 38px 20px 20px;
  box-sizing: border-box;
  transition: right 0.3s ease-in-out;
  z-index: 9998;
  display: flex;
  flex-flow: column;
  box-shadow: 0 15px 30px 10px rgb(0 0 0 / 9%);
  overflow-y: scroll;
}

.filters-container.side-filters::-webkit-scrollbar {
  display: none;
}

.filters-container.side-filters .filter-taxonomies {
  flex-flow: column;
}

.filters-container.side-filters .filter-taxonomies .filter {
  height: fit-content;
  background: unset;
  display: flex;
  padding: unset;
  align-items: center;
  gap: var(--gapX2);
  position: relative;
  flex-flow: row;
}

.filters-container.side-filters .close-filters {
  position: fixed;
  right: -300px;
  z-index: 9999;
  transition: right 0.3s ease-in-out;
  cursor: pointer;
}

.filters-container.side-filters .close-filters.show {
  right: 20px;
}

.filters-container.side-filters .apply-filters {
  text-align: center;
  margin-top: auto;
  position: sticky;
  bottom: 0;
}

.filters-container.side-filters .filter-taxonomies:not(:has(~ .filter-taxonomies)) {
  padding-bottom: var(--gapX5);
}

.filter-title {
  flex-basis: 100%;
}

.filters-container.side-filters.show {
  right: 0;
}

.taxonomy-buttons-container {
  display: flex;
  flex-flow: row;
  gap: var(--gapX2);
  flex-wrap: wrap;
}

.filters-controls-container {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--gapX3);
}

.sort-container {
  display: flex;
  gap: var(--gapX2);
  align-items: center;
  margin-left: auto;
}

.sort-container .sort-dropdown {
  padding: calc(var(--gapX4) - 1px + var(--textStopT)) var(--gapX3)
    calc(var(--gapX3) - 1px + var(--textSbottomT)) !important;
  font-size: var(--textSsize);
  line-height: var(--textSheightT);
  border: 1px solid var(--blackOpacity200);
  border-radius: var(--gapX1);
}

.sort-container .found-posts {
  color: var(--contentOpacityColor);
}

.filters-controls-container + .posts-container {
  margin-top: var(--gapX10);
}

/* .taxonomy-buttons-container .btn {
  border: 1px solid var(--accentColor) !important;
  padding: calc(var(--gapX4) - 1px) var(--gapX3) calc(var(--gapX3) - 1px);
}

.taxonomy-buttons-container .btn.taxonomy-toggle-button:hover{
  background: var(--accentColor);
  color: var(--onAccentColor);
  border: 1px solid var(--accentColor) !important;
}

.taxonomy-buttons-container .btn.toggle-filters:hover {
  background: var(--onAccentColor);
  color: var(--accentColor);
  border: 1px solid var(--accentColor) !important;
}

.taxonomy-buttons-container .btn.taxonomy-toggle-button {
  background: var(--white);
  color: var(--accentColor);
}

.taxonomy-buttons-container .btn span {
  font-size: var(--textSsize);
  margin-top: var(--textStopT);
  margin-bottom: var(--textSbottomT);
  line-height: var(--textSheightT);
  display: flex;
} */

.toggle-filters {
  margin-top: unset;
  margin-left: unset;
  cursor: pointer;
  width: fit-content;
}

.filters-container.side-filters .filter.all {
  display: none;
}

.filters-container.side-filters .filter:before {
  content: '';
  border: unset !important;
  height: 16px !important;
  width: 16px !important;
  display: inline-block !important;
  border: 2px solid black !important;
}

.filters-container.side-filters .filter.active:before {
  background-color: black;
  box-shadow: inset 0 0 0 2px white;
}

.filters-container.side-filters .filter.active {
  color: var(--mainColor);
  background-color: unset;
}

.filters-container.side-filters .filter-taxonomies + .filter-taxonomies {
  margin-top: var(--gapX6);
}

.skeleton-wrapper {
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
}

.skeleton-filters {
  display: flex;
  flex-direction: row;
  gap: 10px;
  flex-wrap: wrap;
  align-items: end;
}

.skeleton-filter-line {
  height: 30px;
  background-color: #e0e0e0;
  border-radius: 5px;
  animation: skeleton-animation 1.5s infinite ease-in-out;
}

.skeleton-posts {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  width: 100%;
}

.skeleton-filters .toggle-filters {
  width: 100px;
}

/* .grid .article-item.skeleton-post .image-wrapper, .keen-slider .article-item.skeleton-post .image-wrapper {
  background: none;
} */

.vue-posts .posts-container.fading-in  {
  opacity: 1;
  transition: opacity 0.2s;
}

.vue-posts .posts-container.fading-in {
  opacity: 0.5;
}

.vue-posts .skeleton-filters {
  display: none;
}

.vue-posts .skeleton-filters.show {
  display: block;
}

.vue-posts .skeleton-post .image-wrapper {
  animation: skeleton-animation 1.5s infinite ease-in-out;
  border-radius: 4px;
}

.vue-posts .skeleton-post .skeleton-post-title {
  height: 30px;
  animation: skeleton-animation 1.5s infinite ease-in-out;
  border-radius: 4px;
}

.vue-posts .description-wrapper {
  display: flex;
}


.custom-select {
  position: relative;
}

.select-trigger {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #ccc;
  background-color: #fff;
  cursor: pointer;
  text-align: left;
  border-radius: 4px;
  font-size: inherit; /* Inherit from parent */
  line-height: inherit;
  transition: border-color 0.2s ease;
}

.select-trigger:hover,
.custom-select.is-open .select-trigger {
  border-color: #888;
}

.selected-text {
  flex-grow: 1;
  white-space: nowrap;
}

.arrow-icon {
  transition: transform 0.2s ease;
}

.custom-select.is-open .arrow-icon {
  transform: rotate(180deg);
}

.options-list {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background-color: var(--white);
  border: 1px solid var(--blackOpacity200);
  border-radius: var(--gapX1);
  list-style: none;
  margin: var(--gapX1) 0;
  padding: 0;
  max-height: 200px; /* Limit height and allow scrolling */
  overflow-y: auto;
  z-index: 10; /* Ensure it appears above other elements */
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  width: fit-content;
}

.option-item {
  padding: var(--gapX2) var(--gapX3);
  cursor: pointer;
  transition: background-color 0.2s ease;
  white-space: nowrap;
  font-size: var(--textSsize);
  margin-top: unset !important;
  margin-bottom: unset;
  width: 100%;
}

.option-item:hover {
  background-color: #f0f0f0;
}

.option-item.is-selected {
  background-color: var(--blackOpacity100);
}

/* Basic fade transition */
.fade-enter-active, .fade-leave-active {
  transition: opacity 0.2s ease;
}
.fade-enter, .fade-leave-to /* .fade-leave-active in <2.1.8 */ {
  opacity: 0;
}

/* Animation */
@keyframes skeleton-animation {
  0% {
    background-color: #e0e0e0;
  }
  50% {
    background-color: #f5f5f5;
  }
  100% {
    background-color: #e0e0e0;
  }
}