/*
Theme Name: Naix Child
Theme URI: http://drfuri.com/naix
Author: DrFuri
Author URI: http://drfuri.com
Description: Naix Child Theme.
Version: 1.0
License: GNU General Public License v2+
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: naix
Domain Path: /lang/
Tags: one-column, two-columns, left-sidebar, right-sidebar, full-width-template, post-formats, theme-options, threaded-comments, translation-ready
Template: naix
*/

.single-portfolio-layout-5 .naix-portfolio-summary {
  width: 40% !important;
  float: left;
}

.single-portfolio-layout-5 .portfolio-gallery {
  padding-right: 1rem !important;
  width: auto !important;
  float: none !important;
}

.portfolio-beaf-wrap {
  margin: 180px auto 0;
  margin-right: 5px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  height: auto;
  min-height: 80vh;
  padding: 1rem;
}

/* ==== BEAF Portfolio Layout: ocupa toda la mitad del ancho ==== */
.portfolio-beaf-wrap .bafg-gallery-row,
.portfolio-beaf-wrap .bafg-row,
.custom-galery-container-page .bafg-gallery-row,
.custom-galery-container-page .bafg-row {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  justify-content: center;
  align-items: start;
}

/* Una columna en móviles */
@media (max-width: 992px) {

  .portfolio-beaf-wrap .bafg-gallery-row,
  .portfolio-beaf-wrap .bafg-row,
  .custom-galery-container-page .bafg-gallery-row,
  .custom-galery-container-page .bafg-row {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
}

/* Asegura que cada slider ocupe todo su columna */
.portfolio-beaf-wrap .bafg-col,
.portfolio-beaf-wrap .bafg-col-6,
.custom-galery-container-page .bafg-col,
.custom-galery-container-page .bafg-col-6 {
  width: 100% !important;
  max-width: 100% !important;
  flex: 1 1 50%;
  justify-self: stretch;
}

/* Contenedor visual del slider */
.portfolio-beaf-wrap .bafg-twentytwenty-wrapper,
.custom-galery-container-page .bafg-twentytwenty-wrapper {
  width: 100% !important;
  max-width: none !important;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
  background: #fff;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.portfolio-beaf-wrap .bafg-twentytwenty-wrapper:hover,
.custom-galery-container-page .bafg-twentytwenty-wrapper:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1);
}

/* Ajusta altura automática y mantiene proporción */
.portfolio-beaf-wrap .bafg-twentytwenty-container,
.custom-galery-container-page .bafg-twentytwenty-container {
  width: 100% !important;
  max-width: 100% !important;
  aspect-ratio: 1/1;
  height: auto !important;
}

/* Imágenes llenan el contenedor */
.portfolio-beaf-wrap .twentytwenty-container img,
.custom-galery-container-page .twentytwenty-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Oculta sliders vacíos o bugueados */
.portfolio-beaf-wrap .bafg-col:has(img[src=""]),
.portfolio-beaf-wrap .bafg-col:has(.twentytwenty-before[src=""]),
.custom-galery-container-page .bafg-col:has(img[src=""]),
.custom-galery-container-page .bafg-col:has(.twentytwenty-before[src=""]) {
  display: none !important;
}

/* Slider visual */
.portfolio-beaf-wrap .twentytwenty-horizontal .twentytwenty-handle,
.custom-galery-container-page .twentytwenty-horizontal .twentytwenty-handle {
  opacity: 1 !important;
  border: 2px solid #fff;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
}

/* Apilado en móvil */
@media (max-width: 767px) {

  .portfolio-beaf-wrap .bafg-row,
  .custom-galery-container-page .bafg-row {
    display: flex;
    flex-wrap: wrap;
  }

  .portfolio-beaf-wrap .bafg-row .bafg-col-6,
  .custom-galery-container-page .bafg-row .bafg-col-6 {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
  }

  .portfolio-beaf-wrap .bafg-twentytwenty-container,
  .custom-galery-container-page .bafg-twentytwenty-container {
    max-width: 100% !important;
    height: auto !important;
  }

  .single-portfolio-layout-5 .naix-portfolio-summary {
    width: 100% !important;
  }
}

.custom-galery-container-page .elementor-widget-container .twentytwenty-right-arrow {
  right: 50%;
  margin-right: -26px;
}

.custom-galery-container-page .design-6 .twentytwenty-left-arrow {
  margin-left: -25px;
}

.naix-portfolio-list .portfolio-wapper {
  padding: 15px;
}

/* ====== Tarjetas ====== */
.naix-portfolio-list .portfolio-wapper .entry-content {
  position: relative;
  border: 1px solid rgba(0, 0, 0, .06);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 2px 10px rgb(0 0 0 / 61%);
  transform: translateZ(0);
  transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
}

/* Imagen */
.naix-portfolio-list .portfolio-wapper .entry-format img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1/1;
  object-fit: cover;
  transition: transform .4s ease, filter .25s ease;
}

/* Overlay base */
.naix-portfolio-list .portfolio-wapper .overlay {
  position: absolute;
  inset: 0;
  background: rgba(255, 29, 93, 0.0);
  /* Invisible al inicio */
  opacity: 0;
  transition: background .3s ease, opacity .3s ease;
  pointer-events: none;
}

/* Header */
.naix-portfolio-list .portfolio-wapper .entry-header {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 14px 16px;
  color: #111;
  transition: transform .25s ease, opacity .25s ease;
  z-index: 2;
}

/* ====== Hover / Focus ====== */
.naix-portfolio-list .portfolio-wapper:hover .entry-content,
.naix-portfolio-list .portfolio-wapper:focus-within .entry-content {
  transform: translateY(-6px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, .12);
}

/* Efecto hover en imagen */
.naix-portfolio-list .portfolio-wapper:hover .entry-format img,
.naix-portfolio-list .portfolio-wapper:focus-within .entry-format img {
  transform: scale(1.05);
  filter: brightness(1.05);
}

/* Efecto de color al enfocar */
.naix-portfolio-list .portfolio-wapper:hover .overlay,
.naix-portfolio-list .portfolio-wapper:focus-within .overlay {
  background: rgb(245 127 37);
  opacity: 0.6;
  /* Puedes ajustar la intensidad */
  z-index: 1;
}

/* Etiquetas */
.naix-portfolio-list .entry-cats,
.naix-portfolio-list .entry-cats-bottom {
  display: inline-block;
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(17, 17, 17, .06);
}

/* ====== Accesibilidad ====== */
.naix-portfolio-list .portfolio-wapper .entry-link:focus-visible {
  outline: 2px solid #ff1d5d;
  outline-offset: 4px;
  border-radius: 12px;
}

/* ====== Motion-safe ====== */
@media (prefers-reduced-motion: reduce) {
  * {
    transition: none !important;
  }
}

.bafg-twentytwenty-container .popup_button {
  width: 40px !important;
  height: 40px !important;
  border: none !important;
  background: transparent !important;
  cursor: pointer !important;
  color: #ff1d5d !important;
  /* hereda al SVG */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: color 0.3s ease, transform 0.2s ease !important;
}

.bafg-twentytwenty-container .popup_button::before {
  content: '' !important;
  display: inline-block !important;
  width: 24px !important;
  height: 24px !important;
  mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" stroke="#ff1d5d" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M15 3h6v6"/><path d="M9 21H3v-6"/><path d="M21 3l-7 7"/><path d="M3 21l7-7"/></svg>') no-repeat center !important;
  mask-size: contain !important;
  background-color: currentColor !important;
}

.bafg-twentytwenty-container .popup_button:hover {
  color: #111 !important;
  transform: scale(1.1) !important;
}

/* ===== Gallery Before/After - máximo 3 columnas autoajustables ===== */
/* Aplica solo a la galería con id 131 */
.elementor-shortcode .bafg-row  {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 566px), 1fr)) !important;
    gap: 24px;
    align-items: start;
    justify-content: center;
    margin: 0 auto;
    max-width: 1900px;
}

