/* --- TRABAJOS — CRUZ ESTUDIO ® --- */

/* FIX FOOTER: Empuja el footer siempre al fondo */
.site-wrapper { display: flex; flex-direction: column; min-height: 100vh; background: #1D1E1C; }
.archive-main-content { flex: 1; }

.archive-wrapper { padding: 160px 45px 80px 45px; }

/* HEADER */
.archive-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 60px; padding-bottom: 40px; border-bottom: 1px solid rgba(255, 253, 243, 0.1); }
.all-projects-title { font-family: 'cofo-sans-mono-variable', monospace; font-size: 14px; letter-spacing: 0.15em; margin-bottom: 25px; }
.view-switcher-cta { display: inline-flex; background: rgba(255, 253, 243, 0.05); padding: 5px; border-radius: 6px; border: 1px solid rgba(255, 253, 243, 0.1); }
.view-btn { background: none; border: none; color: rgba(255, 253, 243, 0.4); font-family: 'cofo-sans-mono-variable', monospace; font-size: 11px; padding: 10px 20px; cursor: pointer; transition: 0.4s; }
.view-btn.active { background: #FFFDF3; color: #1D1E1C; border-radius: 4px; font-weight: 700; }
.intro-text { max-width: 480px; font-size: 24px; line-height: 1.6; color: #FFFDF3; text-align: right; }

/* AISLAMIENTO DE VISTAS */
.projects-container.grid-mode .list-component { display: none; }
.projects-container.grid-mode { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
.projects-container.grid-mode .project-item.featured { grid-column: span 2; }

.projects-container.list-mode .grid-component { display: none; }
.projects-container.list-mode { display: flex; flex-direction: column; border-top: 1px solid rgba(255, 253, 243, 0.1); }

/* GRID STYLE */
.visual-box { position: relative; aspect-ratio: 16 / 9; overflow: hidden; background: #111; }
.featured .visual-box { aspect-ratio: 21 / 9; margin-bottom: 15px; }
.visual-box img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(100%); transition: 1.2s cubic-bezier(0.16, 1, 0.3, 1); }
.project-item:hover img { filter: grayscale(0%); transform: scale(1.04); }
.inner-info {
    position: absolute;
    bottom: 0; left: 0;
    width: 100%;
    padding: 25px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 100%);
    z-index: 5;
    transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1),
                transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
}
.project-name { font-size: 22px; font-weight: 600; color: #FFFDF3; margin: 0; }
.tag-outline { font-family: 'cofo-sans-mono-variable', monospace; font-size: 9px; color: #FFFDF3; border: 1px solid #FFFDF3; padding: 5px 12px; border-radius: 20px; text-transform: uppercase; }

/* LIST STYLE & HOVER AMARILLO */
.list-row { display: grid; grid-template-columns: 2.5fr 1.5fr 1fr 1fr; padding: 30px 0; border-bottom: 1px solid rgba(255, 253, 243, 0.1); transition: 0.4s; }
.l-name { font-size: 20px; font-weight: 600; color: #FFFDF3; transition: color 0.4s; }
.l-cat, .l-year, .l-link { font-family: 'cofo-sans-mono-variable', monospace; font-size: 12px; color: rgba(255, 253, 243, 0.5); transition: 0.4s; }
.l-link { text-align: right; color: #FFFDF3; }

.project-item:hover .list-row { background: rgba(255, 215, 0, 0.02); }
.project-item:hover .l-name, .project-item:hover .l-link { color: #FFD700 !important; }
.project-item:hover .l-link { transform: translateX(8px); }

/* MOBILE RESPONSIVE */
@media (max-width: 1024px) {
    .archive-header { flex-direction: column; align-items: flex-start; gap: 30px; }
    .intro-text { text-align: left; }
    .projects-container.grid-mode { grid-template-columns: 1fr; }
    .projects-container.grid-mode .project-item.featured { grid-column: span 1; }
    .inner-info { padding: 15px; flex-direction: column; align-items: flex-start; gap: 10px; }
    .tag-outline { font-size: 8px; padding: 4px 10px; }
    .list-row { grid-template-columns: 1.5fr 1fr; }
    .l-cat, .l-year { display: none; }
}

/* ==========================================================================
   FOOTER GLOBAL - SISTEMA CRUZ ESTUDIO ®
   Inspiración: Mother Design / Studio Okay
   Fondo: Crema | Texto: Dark | Estilo: Swiss Editorial
   ========================================================================== */

.footer-global {
    background-color: var(--crema);
    color: var(--bg-dark);
    padding: 100px 45px 60px 45px;
    width: 100%;
    position: relative;
    border-top: 1px solid rgba(29, 30, 28, 0.1);
    /* Rigor Flair Digital: el cursor personalizado toma el control */
    cursor: none; 
}

.footer-line {
    width: 100%;
    height: 1px;
    background-color: var(--bg-dark);
    margin-bottom: 60px;
    opacity: 0.1;
}

/* Grilla Técnica Asimétrica */
.footer-grid {
    display: grid;
    grid-template-columns: 1.2fr 1.5fr 1fr 1.5fr;
    gap: 40px;
    align-items: flex-start;
}

/* --- ELEMENTOS DE TEXTO Y MARCA --- */
.copyright-text {
    font-family: var(--font-header);
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 0.85;
    letter-spacing: -0.04em;
    color: var(--bg-dark);
    margin: 0;
}

.footer-link {
    font-family: var(--font-header);
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--bg-dark);
    text-decoration: none;
    display: block;
    margin-bottom: 8px;
    transition: color 0.3s var(--swiss-easing);
}

.footer-link:hover {
    color: var(--amarillo-acento);
}

/* Visibilidad técnica de etiquetas */
.mono-label {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: #1D1E1C !important; /* Forzamos contraste sobre crema */
    opacity: 0.5;
    display: block;
    margin-bottom: 30px;
    visibility: visible !important;
}

.reading-small {
    font-family: var(--font-reading);
    font-size: 14px;
    line-height: 1.5;
    color: rgba(29, 30, 28, 0.7);
}

/* Sello Pluma */
.pluma-seal {
    height: 45px;
    width: auto;
    filter: brightness(0); /* Negro puro sobre fondo claro */
    margin-bottom: 20px;
    display: block;
}

/* --- CURSOR PERSONALIZADO --- */
.custom-cursor {
    width: 18px;
    height: 18px;
    background-color: var(--amarillo-acento);
    border-radius: 50%;
    position: fixed;
    pointer-events: none;
    z-index: 9999;
    mix-blend-mode: multiply; 
    transition: transform 0.15s ease-out;
}

/* ==========================================================================
   RESPONSIVE: FIX DE ENCUADRE Y GRIDS
   ========================================================================== */

/* Ajuste para Tablets y Laptops pequeñas (1024px) */
@media (max-width: 1024px) {
    .footer-grid {
        grid-template-columns: 1fr 1fr; /* Colapsamos a 2 columnas */
        gap: 60px 40px;
    }
}

/* Ajuste Crítico para Móviles (768px) */
@media (max-width: 768px) {
    .footer-global {
        padding: 60px 35px;
        cursor: auto; /* Devolvemos el cursor estándar en táctil */
    }

    .footer-grid {
        grid-template-columns: 1fr; /* Una sola columna vertical */
        gap: 50px;
    }

    .custom-cursor {
        display: none; /* Innecesario en mobile */
    }

    /* Reducción del sello para no saturar el encuadre */
    .pluma-seal {
        height: 30px; 
        margin-bottom: 15px;
    }

    .copyright-text {
        font-size: 1.6rem; 
        letter-spacing: -0.03em;
    }

    /* Forzamos alineación segura a la izquierda */
    .footer-col, 
    .footer-brand-end {
        align-items: flex-start !important;
        text-align: left !important;
    }
}
/* ==========================================================================
   HOVER CAROUSEL — En cada .project-item las imágenes adicionales se
   stackean dentro del .visual-box y crossfadean al hover (estilo
   estrela.studio/work). JS controla la imagen activa via .is-active.
   ========================================================================== */

.visual-box {
    isolation: isolate;
}

/* Las imágenes adicionales se inyectan como .pi-cycle-img dentro del visual-box.
   Stack absoluto, opacity 0 por defecto, crossfade suave. */
.visual-box .pi-cycle-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(100%);
    opacity: 0;
    transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1),
                filter 1.0s cubic-bezier(0.16, 1, 0.3, 1),
                transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);
    pointer-events: none;
    z-index: 2;
}

/* Imagen actualmente activa en el ciclo */
.visual-box .pi-cycle-img.is-active {
    opacity: 1;
}

/* Al hover, las imágenes del carousel (incluida la base) salen de grayscale */
.project-item:hover .visual-box .pi-cycle-img {
    filter: grayscale(0%);
    transform: scale(1.04);
}

/* Indicador de progreso del carousel — pequeña línea inferior */
.visual-box .pi-cycle-indicator {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 2px;
    width: 100%;
    background: rgba(255, 253, 243, 0.08);
    z-index: 3;
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
}
.project-item:hover .visual-box .pi-cycle-indicator {
    opacity: 1;
}
.visual-box .pi-cycle-indicator-fill {
    height: 100%;
    width: 0;
    background: #FFD700;
    transition: width 0.6s linear;
}

@media (prefers-reduced-motion: reduce) {
    .visual-box .pi-cycle-img,
    .visual-box .pi-cycle-indicator-fill {
        transition: none !important;
    }
}

/* Card placeholder cuando solo tenemos el logo SVG (sin foto principal) */
.visual-box.pi-logo-cover {
    background: linear-gradient(135deg, #1a1a18 0%, #2a2a26 100%);
}
.visual-box.pi-logo-cover .pi-logo-placeholder {
    object-fit: contain;
    padding: 18%;
    filter: brightness(0) invert(1) opacity(0.85);
    transition: filter 0.5s ease, transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}
.project-item:hover .visual-box.pi-logo-cover .pi-logo-placeholder {
    filter: brightness(0) invert(1) opacity(1);
    transform: scale(1.04);
}
