/* ===== Shared interactions: custom cursor + scroll reveals ===== */

/* ---- Custom cursor (desktop, fine pointer only) ---- */
@media (hover: hover) and (pointer: fine) {
    .cursor-ring, .cursor-dot {
        position: fixed; top: 0; left: 0; z-index: 9999;
        pointer-events: none;
        border-radius: 9999px !important;
        mix-blend-mode: difference;
    }
    .cursor-ring {
        width: 40px; height: 40px; margin: -20px 0 0 -20px;
        border: 1px solid rgba(255,255,255,0.9);
        opacity: 0;
        transition: width .3s ease, height .3s ease, margin .3s ease, background .3s ease, opacity .3s ease;
    }
    .cursor-dot {
        width: 5px; height: 5px; margin: -2.5px 0 0 -2.5px;
        background: #fff; opacity: 0;
    }
    .cursor-ring.hovering { width: 64px; height: 64px; margin: -32px 0 0 -32px; background: rgba(255,255,255,0.15); }
    body.cursor-on, body.cursor-on * { cursor: none; }
}

/* ---- Scroll reveal: fade + rise ---- */
.reveal { opacity: 0; transform: translateY(28px); }
.reveal.is-in {
    opacity: 1; transform: none;
    transition: opacity 1s ease, transform 1s cubic-bezier(0.16,1,0.3,1);
}

/* ---- Drawing line ---- */
.draw { transform: scaleX(0); transform-origin: left; }
.draw-center { transform-origin: center; }
.draw.is-in { transform: scaleX(1); transition: transform 1.1s cubic-bezier(0.16,1,0.3,1); }

/* ---- Staggered children inside a revealed block ---- */
.reveal .stagger > * { opacity: 0; transform: translateY(16px); }
.reveal.is-in .stagger > * {
    opacity: 1; transform: none;
    transition: opacity .9s ease, transform .9s cubic-bezier(0.16,1,0.3,1);
}
.reveal.is-in .stagger > *:nth-child(1) { transition-delay: .12s; }
.reveal.is-in .stagger > *:nth-child(2) { transition-delay: .24s; }
.reveal.is-in .stagger > *:nth-child(3) { transition-delay: .36s; }
.reveal.is-in .stagger > *:nth-child(4) { transition-delay: .48s; }

@media (prefers-reduced-motion: reduce) {
    .reveal, .draw, .reveal .stagger > * {
        opacity: 1 !important; transform: none !important; transition: none !important;
    }
}

/* ===== Mobile menu ===== */
.menu-toggle { display: none; }
@media (max-width: 767px) {
    .menu-toggle {
        display: flex; flex-direction: column; justify-content: center; gap: 6px;
        position: fixed; top: 22px; right: 24px;
        width: 30px; height: 30px; padding: 0;
        background: transparent; border: 0; cursor: pointer; z-index: 10001;
    }
}
.menu-toggle span { display: block; width: 28px; height: 2px; background: #000; transition: transform .4s cubic-bezier(0.16,1,0.3,1), opacity .25s ease, background .3s ease; }
.menu-toggle.is-open span { background: #fff; }
.menu-toggle.is-open span:nth-child(1) { transform: translateY(4px) rotate(45deg); }
.menu-toggle.is-open span:nth-child(2) { transform: translateY(-4px) rotate(-45deg); }

.mobile-menu {
    position: fixed; inset: 0; z-index: 10000;
    background: #0d0d0d;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transform: translateY(-8px);
    transition: opacity .5s cubic-bezier(0.16,1,0.3,1), transform .5s cubic-bezier(0.16,1,0.3,1);
}
body.menu-open { overflow: hidden; }
body.menu-open .mobile-menu { opacity: 1; pointer-events: auto; transform: none; }
.mobile-menu nav { display: flex; flex-direction: column; align-items: center; gap: 30px; }
.mobile-menu a {
    color: rgba(255,255,255,0.8);
    font-family: 'Hanken Grotesk', sans-serif; text-transform: uppercase;
    letter-spacing: 0.25em; font-size: 18px; font-weight: 500;
    opacity: 0; transform: translateY(14px);
    transition: opacity .5s ease, transform .5s cubic-bezier(0.16,1,0.3,1), color .3s ease;
}
.mobile-menu a:hover { color: #fff; }
.mobile-menu a.active { color: #fff; border-bottom: 1px solid #fff; padding-bottom: 4px; }
.mobile-menu a.mm-cta { margin-top: 20px; border: 1px solid rgba(255,255,255,0.5); padding: 16px 40px; font-size: 11px; letter-spacing: 0.25em; }
.mobile-menu a.mm-cta:hover { background: #fff; color: #0d0d0d; }
body.menu-open .mobile-menu a { opacity: 1; transform: none; }
body.menu-open .mobile-menu a:nth-child(1) { transition-delay: .10s; }
body.menu-open .mobile-menu a:nth-child(2) { transition-delay: .16s; }
body.menu-open .mobile-menu a:nth-child(3) { transition-delay: .22s; }
body.menu-open .mobile-menu a:nth-child(4) { transition-delay: .28s; }
body.menu-open .mobile-menu a:nth-child(5) { transition-delay: .34s; }
body.menu-open .mobile-menu a:nth-child(6) { transition-delay: .40s; }
body.menu-open .mobile-menu a:nth-child(7) { transition-delay: .48s; }

/* ===== Language toggle (EN / ES with active state) ===== */
.lang-toggle { display: inline-flex; align-items: center; gap: 7px; }
.lang-toggle button {
    background: none; border: 0; cursor: pointer; padding: 0; line-height: 1;
    font-family: 'Hanken Grotesk', sans-serif; font-size: 11px; font-weight: 500;
    letter-spacing: 0.2em; text-transform: uppercase;
    color: #5d5f5f; opacity: .4; transition: opacity .3s ease, color .3s ease;
}
.lang-toggle button:hover { opacity: .75; }
.lang-toggle button.active { opacity: 1; color: #000; font-weight: 700; }
.lang-sep { color: #5d5f5f; opacity: .35; font-size: 11px; }
.mobile-menu .lang-toggle { margin-top: 12px; gap: 10px; }
.mobile-menu .lang-toggle button { color: #fff; font-size: 13px; opacity: .4; }
.mobile-menu .lang-toggle button.active { opacity: 1; color: #fff; }
.mobile-menu .lang-sep { color: rgba(255,255,255,0.4); }
