/* Estilos para la galería de portfolio */
.portfolio {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    background-color: transparent;
    padding: 0;
    position: relative;
    margin-top: 40px;
}

.portfolio-gallery {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px;
    opacity: 0;
    animation: portfolioFadeIn 0.8s ease-out forwards;
    animation-delay: 0.2s;
}

@keyframes portfolioFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Contenedor React */
#portfolio-react-container {
    width: 100%;
}

/* Estilos para complementar Tailwind */
.size-20 {
    width: 5rem;
    height: 5rem;
}

.size-24 {
    width: 6rem;
    height: 6rem;
}

.size-32 {
    width: 8rem;
    height: 8rem;
}

.min-h-120 {
    min-height: 30rem;
}

.grid-cols-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}

.gap-3 {
    gap: 0.75rem;
}

.gap-4 {
    gap: 1rem;
}

.gap-8 {
    gap: 2rem;
}

.rounded-md {
    border-radius: 0.375rem;
}

.flex {
    display: flex;
}

.hidden {
    display: none;
}

.flex-col {
    flex-direction: column;
}

.items-center {
    align-items: center;
}

.bg-background {
    background-color: #ffffff;
}

.border {
    border: 1px solid #e4e4e7;
}

.p-1 {
    padding: 0.25rem;
}

.sm\:px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
}

/* Estilos para los botones de filtro */
.toggle-group {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    background-color: #ffffff;
    border-radius: 0.375rem;
    border: 1px solid #e4e4e7;
    padding: 0.25rem;
    margin-bottom: 2rem;
}

.toggle-item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.375rem;
    height: 2.5rem;
    padding: 0 0.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    transition: all 0.2s ease;
    cursor: pointer;
}

.toggle-item:hover {
    background-color: #f5f5f5;
}

.toggle-item[data-state="on"] {
    background-color: #f4f4f5;
    color: #18181b;
}

/* Animaciones para los elementos de la galería */
[data-flip] {
    transition: transform 0.6s ease, opacity 0.6s ease;
    will-change: transform, opacity;
}

[data-flip] img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0.375rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    transition: transform 0.3s ease;
}

[data-flip]:hover img {
    transform: scale(1.05);
}

/* Responsive */
@media (max-width: 768px) {
    .portfolio-gallery {
        padding: 20px;
    }
    
    .grid-cols-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .grid-cols-3 {
        grid-template-columns: 1fr;
    }
}

/* Estilos responsivos */
@media (max-width: 1200px) {
    .portfolio-gallery {
        padding: 0 30px;
    }
}

@media (max-width: 992px) {
    .portfolio-gallery {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
        padding: 0 25px;
        grid-auto-rows: 220px;
    }
    
    .portfolio-item.large,
    .portfolio-item.wide {
        grid-column: span 2;
        aspect-ratio: 2 / 1;
    }
    
    .portfolio-item.tall {
        grid-row: span 1; /* Changed to avoid vertical rectangles */
        aspect-ratio: 1 / 1; /* Make it square instead of tall */
    }
    
    .portfolio-item {
        aspect-ratio: 1.2 / 1;
    }
}

@media (max-width: 768px) {
    .portfolio-gallery {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
        padding: 0 20px;
        grid-auto-rows: 180px;
    }
    
    .portfolio-item.large,
    .portfolio-item.medium,
    .portfolio-item.wide {
        grid-column: span 2;
        aspect-ratio: 2 / 1;
    }
    
    .portfolio-item.tall {
        aspect-ratio: 1 / 1;
        grid-row: span 1;
    }
    
    .portfolio-item {
        aspect-ratio: 1.2 / 1;
    }
    
    .portfolio-overlay {
        padding: 15px;
        opacity: 1;
        transform: translateY(0);
        background: linear-gradient(to top, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.3) 70%, transparent 100%);
    }
    
    .portfolio-overlay h3 {
        font-size: 1rem;
    }
    
    .portfolio-overlay p {
        font-size: 0.8rem;
    }
}

@media (max-width: 576px) {
    .portfolio-gallery {
        grid-template-columns: 1fr;
        gap: 15px;
        padding: 0 15px;
        grid-auto-rows: auto;
    }
    
    .portfolio-item,
    .portfolio-item.medium,
    .portfolio-item.large,
    .portfolio-item.wide,
    .portfolio-item.tall {
        grid-column: span 1;
        grid-row: span 1;
        aspect-ratio: 1.5 / 1; /* Rectángulo horizontal para todos los elementos en móvil */
        height: 200px; /* Altura fija para mantener consistencia */
        max-height: 200px;
        margin-bottom: 5px;
    }
    
    .portfolio-image img,
    .portfolio-image video {
        height: 100%;
        object-position: center 30%; /* Ajusta la posición vertical de la imagen */
    }
}

/* CSS específico para el layout de tabla del portfolio */
/* Desktop: mantener 3 columnas */
@media (min-width: 769px) {
    #portfolio-react-container [style*="display: table"] {
        display: table !important;
        width: 100% !important;
        border-spacing: 15px !important;
    }
    
    #portfolio-react-container [style*="display: table-row"] {
        display: table-row !important;
    }
    
    #portfolio-react-container .portfolio-item {
        display: table-cell !important;
        width: 33% !important;
        vertical-align: top !important;
    }
}

/* Tablet: 2 columnas - Tamaños estándar 481px-768px */
@media (max-width: 768px) and (min-width: 481px) {
    #portfolio-react-container [style*="display: table"] {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 15px !important;
        width: 100% !important;
        border-spacing: 0 !important;
    }
    
    #portfolio-react-container [style*="display: table-row"] {
        display: contents !important;
    }
    
    #portfolio-react-container .portfolio-item {
        display: block !important;
        width: calc(50% - 7.5px) !important;
    }
    
    #portfolio-react-container .portfolio-item [style*="padding-bottom: 100%"] {
        padding-bottom: 120% !important;
    }
    
    /* Forzar posicionamiento correcto del overlay en tablet */
    #portfolio-react-container .portfolio-item > div {
        position: relative !important;
    }
    
    #portfolio-react-container .portfolio-item div[style*="position: absolute"] {
        position: absolute !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 10 !important;
        background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.75) 50%, rgba(0,0,0,0.4) 80%, rgba(0,0,0,0) 100%) !important;
        min-height: 85px !important;
        height: auto !important;
        padding: 18px 14px 14px !important;
        display: block !important;
    }
    
    /* Asegurar texto visible en tablet */
    #portfolio-react-container .portfolio-item h4 {
        font-size: 15px !important;
        font-weight: 700 !important;
        color: #ffffff !important;
        text-shadow: 1px 1px 3px rgba(0,0,0,0.8) !important;
        margin: 0 0 5px 0 !important;
        line-height: 1.3 !important;
        display: block !important;
        position: relative !important;
        z-index: 11 !important;
    }
    
    #portfolio-react-container .portfolio-item p {
        font-size: 13px !important;
        color: #f0f0f0 !important;
        text-shadow: 1px 1px 2px rgba(0,0,0,0.8) !important;
        margin: 0 !important;
        line-height: 1.2 !important;
        display: block !important;
        position: relative !important;
        z-index: 11 !important;
    }
}

/* Mobile crítico: 390px-450px - iPhone 12 Pro, 13 Pro, etc. */
@media (max-width: 450px) and (min-width: 390px) {
    #portfolio-react-container [style*="display: table"] {
        display: flex !important;
        flex-direction: column !important;
        gap: 20px !important;
        width: 100% !important;
        border-spacing: 0 !important;
        margin-top: 20px !important;
    }
    
    #portfolio-react-container [style*="display: table-row"] {
        display: contents !important;
    }
    
    #portfolio-react-container .portfolio-item {
        display: block !important;
        width: 100% !important;
    }
    
    #portfolio-react-container .portfolio-item [style*="padding-bottom: 100%"] {
        padding-bottom: 70% !important; /* Más ancho para este rango */
    }
    
    /* Overlay específico para este rango crítico */
    #portfolio-react-container .portfolio-item > div {
        position: relative !important;
    }
    
    #portfolio-react-container .portfolio-item div[style*="position: absolute"] {
        position: absolute !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 15 !important;
        background: linear-gradient(to top, rgba(0,0,0,0.98) 0%, rgba(0,0,0,0.85) 40%, rgba(0,0,0,0.6) 65%, rgba(0,0,0,0.3) 80%, rgba(0,0,0,0.1) 95%, rgba(0,0,0,0) 100%) !important;
        min-height: 120px !important;
        height: auto !important;
        padding: 35px 18px 18px !important;
        display: block !important;
    }
    
    /* Texto optimizado para este rango */
    #portfolio-react-container .portfolio-item h4 {
        font-size: 17px !important;
        font-weight: 700 !important;
        color: #ffffff !important;
        text-shadow: 2px 2px 5px rgba(0,0,0,0.95) !important;
        margin: 0 0 7px 0 !important;
        line-height: 1.25 !important;
        display: block !important;
        position: relative !important;
        z-index: 16 !important;
    }
    
    #portfolio-react-container .portfolio-item p {
        font-size: 15px !important;
        color: #f5f5f5 !important;
        text-shadow: 1px 1px 4px rgba(0,0,0,0.95) !important;
        margin: 0 !important;
        line-height: 1.2 !important;
        display: block !important;
        position: relative !important;
        z-index: 16 !important;
    }
}

/* Mobile: 1 columna - Tamaños estándar 320px-480px */
@media (max-width: 480px) {
    #portfolio-react-container [style*="display: table"] {
        display: flex !important;
        flex-direction: column !important;
        gap: 20px !important;
        width: 100% !important;
        border-spacing: 0 !important;
        margin-top: 20px !important;
    }
    
    #portfolio-react-container [style*="display: table-row"] {
        display: contents !important;
    }
    
    #portfolio-react-container .portfolio-item {
        display: block !important;
        width: 100% !important;
    }
    
    #portfolio-react-container .portfolio-item [style*="padding-bottom: 100%"] {
        padding-bottom: 75% !important;
    }
    
    /* Forzar posicionamiento correcto del overlay */
    #portfolio-react-container .portfolio-item > div {
        position: relative !important;
    }
    
    #portfolio-react-container .portfolio-item div[style*="position: absolute"] {
        position: absolute !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 10 !important;
        background: linear-gradient(to top, rgba(0,0,0,0.95) 0%, rgba(0,0,0,0.8) 45%, rgba(0,0,0,0.6) 70%, rgba(0,0,0,0.3) 85%, rgba(0,0,0,0) 100%) !important;
        min-height: 110px !important;
        height: auto !important;
        padding: 30px 15px 15px !important;
        display: block !important;
    }
    
    /* Asegurar que el texto sea visible */
    #portfolio-react-container .portfolio-item h4 {
        font-size: 16px !important;
        font-weight: 700 !important;
        color: #ffffff !important;
        text-shadow: 2px 2px 4px rgba(0,0,0,0.9) !important;
        margin: 0 0 6px 0 !important;
        line-height: 1.3 !important;
        display: block !important;
        position: relative !important;
        z-index: 11 !important;
    }
    
    #portfolio-react-container .portfolio-item p {
        font-size: 14px !important;
        color: #f0f0f0 !important;
        text-shadow: 1px 1px 3px rgba(0,0,0,0.9) !important;
        margin: 0 !important;
        line-height: 1.2 !important;
        display: block !important;
        position: relative !important;
        z-index: 11 !important;
    }
}
