/* ============================================================
   index_reports.css — Sección "Reportá / Carrusel últimos"
   Premium · motion ≥ 2000ms · cubic-bezier(.22,1,.36,1)
   Brand: ea580c · f59e0b · ec4899 / lost · 16a34a · 0ea5e9 / found
   ============================================================ */

:root {
    --ix-ease:   cubic-bezier(.22,1,.36,1);
    --ix-spring: cubic-bezier(.34,1.56,.64,1);
    --ix-orange: #ea580c;
    --ix-amber:  #f59e0b;
    --ix-pink:   #ec4899;
    --ix-red:    #dc2626;
    --ix-green:  #16a34a;
    --ix-cyan:   #0ea5e9;
    --ix-ink:    #1d1d1f;
    --ix-muted:  #6e6e73;
}

/* ============================================================
   SECTION CONTAINER
   ============================================================ */
.ix-rep {
    position: relative;
    padding: 96px 24px 96px;
    overflow: hidden;
    isolation: isolate;
    background:
        radial-gradient(ellipse 70% 50% at 20% 0%, rgba(234,88,12,0.06) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 80% 100%, rgba(22,163,74,0.05) 0%, transparent 60%),
        linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

/* Orbs ambientales — drift dramatic 28s */
.ix-rep-amb {
    position: absolute; inset: 0;
    z-index: 0;
    pointer-events: none;
}
.ix-rep-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(110px);
    opacity: 0.45;
    animation: ix-orb-drift 28000ms ease-in-out infinite alternate;
}
.ix-rep-orb-1 {
    width: 460px; height: 460px;
    top: -160px; left: -10%;
    background: radial-gradient(circle, rgba(234,88,12,0.40) 0%, transparent 70%);
}
.ix-rep-orb-2 {
    width: 420px; height: 420px;
    top: 30%; right: -8%;
    background: radial-gradient(circle, rgba(236,72,153,0.32) 0%, transparent 70%);
    animation-delay: -10000ms;
}
.ix-rep-orb-3 {
    width: 380px; height: 380px;
    bottom: -120px; left: 35%;
    background: radial-gradient(circle, rgba(22,163,74,0.28) 0%, transparent 70%);
    animation-delay: -18000ms;
}
@keyframes ix-orb-drift {
    0%   { transform: translate3d(0,0,0) scale(1.00);    opacity: 0.40; }
    50%  { transform: translate3d(40px,-30px,0) scale(1.12); opacity: 0.65; }
    100% { transform: translate3d(-30px,20px,0) scale(0.95); opacity: 0.45; }
}

.ix-rep-inner {
    position: relative; z-index: 1;
    max-width: 1240px;
    margin: 0 auto;
}

/* ============================================================
   HEADER de la sección
   ============================================================ */
.ix-rep-head {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 48px;
}
.ix-rep-tag {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 7px 16px; margin-bottom: 22px;
    background: linear-gradient(135deg, rgba(234,88,12,0.10), rgba(236,72,153,0.10));
    border: 1px solid rgba(234,88,12,0.22);
    border-radius: 999px;
    color: var(--ix-orange);
    font-size: 11.5px; font-weight: 700;
    letter-spacing: 0.18em; text-transform: uppercase;
    box-shadow: 0 8px 20px -12px rgba(234,88,12,0.30);
}
.ix-rep-tag svg { color: var(--ix-pink); }

.ix-rep-title {
    margin: 0 0 16px;
    font-size: clamp(34px, 5vw, 56px);
    font-weight: 700;
    color: var(--ix-ink);
    letter-spacing: -0.026em;
    line-height: 1.04;
}
.ix-rep-grad {
    background: linear-gradient(135deg, var(--ix-orange) 0%, var(--ix-amber) 50%, var(--ix-pink) 100%);
    background-size: 200% 200%;
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: ix-grad-flow 8000ms ease-in-out infinite;
    filter: drop-shadow(0 4px 16px rgba(234,88,12,0.18));
}
@keyframes ix-grad-flow {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}
.ix-rep-lead {
    color: var(--ix-muted);
    font-size: clamp(15.5px, 1.4vw, 17px);
    line-height: 1.6;
    margin: 0;
    font-weight: 400;
}

/* ============================================================
   CTA GRID — 2 cards lost + found
   ============================================================ */
.ix-rep-cta-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 64px;
}

.ix-rep-cta {
    position: relative;
    display: block;
    padding: 36px 32px 32px;
    border-radius: 24px;
    text-decoration: none;
    color: #fff;
    overflow: hidden;
    isolation: isolate;
    box-shadow:
        0 24px 48px -16px rgba(0,0,0,0.20),
        0 8px 16px -8px rgba(0,0,0,0.10);
    transition:
        transform 480ms var(--ix-spring),
        box-shadow 480ms var(--ix-ease);
    will-change: transform;
}
.ix-rep-cta:hover {
    transform: translateY(-6px) scale(1.01);
}
.ix-rep-cta--lost {
    background:
        linear-gradient(135deg, #dc2626 0%, #ea580c 50%, #f59e0b 100%);
}
.ix-rep-cta--lost:hover {
    box-shadow:
        0 32px 64px -16px rgba(220,38,38,0.55),
        0 12px 24px -12px rgba(234,88,12,0.40);
}
.ix-rep-cta--found {
    background:
        linear-gradient(135deg, #0ea5e9 0%, #16a34a 100%);
}
.ix-rep-cta--found:hover {
    box-shadow:
        0 32px 64px -16px rgba(22,163,74,0.55),
        0 12px 24px -12px rgba(14,165,233,0.40);
}

/* Shine sweep al hover */
.ix-rep-cta-shine {
    position: absolute; inset: 0;
    z-index: -1;
    background:
        linear-gradient(105deg, transparent 30%, rgba(255,255,255,0.20) 50%, transparent 70%);
    transform: translateX(-100%);
    pointer-events: none;
}
.ix-rep-cta:hover .ix-rep-cta-shine {
    animation: ix-shine 1400ms var(--ix-ease);
}
@keyframes ix-shine {
    to { transform: translateX(100%); }
}

/* Icon container con anillo decorativo */
.ix-rep-cta-icon {
    position: relative;
    display: inline-flex; align-items: center; justify-content: center;
    width: 72px; height: 72px;
    margin-bottom: 24px;
    background: rgba(255,255,255,0.18);
    border: 1.5px solid rgba(255,255,255,0.30);
    border-radius: 20px;
    color: #fff;
    backdrop-filter: blur(8px);
    box-shadow:
        0 12px 28px -8px rgba(0,0,0,0.20),
        inset 0 1px 0 rgba(255,255,255,0.20);
}

/* Pulse en LOST: ring concéntrico expandiendo */
.ix-rep-cta-pulse {
    position: absolute; inset: 0;
    border: 2px solid rgba(255,255,255,0.55);
    border-radius: 20px;
    opacity: 0;
    animation: ix-cta-pulse 2400ms var(--ix-ease) infinite;
}
@keyframes ix-cta-pulse {
    0%   { transform: scale(0.85); opacity: 0.85; }
    100% { transform: scale(1.30); opacity: 0; }
}

/* Sparkles en FOUND: 3 estrellas alrededor */
.ix-rep-cta-sparkle {
    position: absolute;
    width: 6px; height: 6px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 0 12px rgba(255,255,255,0.85);
    animation: ix-spk 3000ms var(--ix-ease) infinite;
}
.ix-rep-spk-1 { top: -6px; left: 14px; animation-delay:    0ms; }
.ix-rep-spk-2 { top: 18px; right: -6px; animation-delay: 1000ms; }
.ix-rep-spk-3 { bottom: 4px; left: -6px; animation-delay: 2000ms; }
@keyframes ix-spk {
    0%, 100% { transform: scale(0); opacity: 0; }
    20%      { transform: scale(1); opacity: 1; }
    40%      { transform: scale(0.6); opacity: 0.6; }
    60%      { transform: scale(0); opacity: 0; }
}

.ix-rep-cta-title {
    margin: 0 0 8px;
    font-size: 26px; font-weight: 700;
    letter-spacing: -0.022em;
    line-height: 1.10;
    color: #fff;
}
.ix-rep-cta-sub {
    margin: 0 0 24px;
    font-size: 15px; line-height: 1.55;
    color: rgba(255,255,255,0.92);
    font-weight: 400;
    max-width: 360px;
}
.ix-rep-cta-action {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 22px;
    background: rgba(255,255,255,0.18);
    border: 1px solid rgba(255,255,255,0.30);
    border-radius: 999px;
    font-size: 14px; font-weight: 700;
    color: #fff;
    backdrop-filter: blur(8px);
    transition: all 320ms var(--ix-ease);
}
.ix-rep-cta:hover .ix-rep-cta-action {
    background: #fff;
    color: var(--ix-ink);
    border-color: #fff;
    transform: translateX(2px);
}
.ix-rep-cta-action svg { transition: transform 320ms var(--ix-spring); }
.ix-rep-cta:hover .ix-rep-cta-action svg { transform: translateX(3px); }

/* ============================================================
   CARRUSEL — scroll-snap horizontal + botones nav
   ============================================================ */
.ix-rep-carousel-wrap {
    position: relative;
}
.ix-rep-carousel-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 22px;
    gap: 16px;
}
.ix-rep-carousel-title {
    display: inline-flex; align-items: center; gap: 9px;
    margin: 0;
    font-size: 22px; font-weight: 700;
    color: var(--ix-ink);
    letter-spacing: -0.018em;
}
.ix-rep-carousel-title svg { color: var(--ix-orange); }

.ix-rep-carousel-nav {
    display: inline-flex; align-items: center; gap: 8px;
}
.ix-rep-nav-btn {
    width: 40px; height: 40px;
    background: #fff;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 12px;
    color: var(--ix-ink);
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 12px -4px rgba(0,0,0,0.10);
    transition: all 280ms var(--ix-ease);
    font-family: inherit;
}
.ix-rep-nav-btn:hover {
    background: var(--ix-ink);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 8px 20px -8px rgba(0,0,0,0.30);
}
.ix-rep-viewall {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 16px;
    background: linear-gradient(135deg, var(--ix-orange), var(--ix-pink));
    background-size: 200% 200%;
    color: #fff !important;
    border-radius: 12px;
    font-size: 13.5px; font-weight: 700;
    text-decoration: none;
    box-shadow: 0 8px 20px -6px rgba(234,88,12,0.45);
    transition: all 280ms var(--ix-ease);
    animation: ix-grad-flow 5000ms ease-in-out infinite;
    letter-spacing: -0.005em;
}
.ix-rep-viewall:hover { transform: translateY(-1px); box-shadow: 0 12px 24px -8px rgba(234,88,12,0.55); }
.ix-rep-viewall svg { transition: transform 320ms var(--ix-spring); }
.ix-rep-viewall:hover svg { transform: translateX(3px); }

.ix-rep-carousel {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(260px, 280px);
    gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 6px 4px 24px;
    margin: 0 -4px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: rgba(0,0,0,0.18) transparent;
}
.ix-rep-carousel::-webkit-scrollbar { height: 6px; }
.ix-rep-carousel::-webkit-scrollbar-track { background: transparent; }
.ix-rep-carousel::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.18); border-radius: 999px; }
.ix-rep-carousel::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,0.30); }

/* ============================================================
   MINI CARDS del carrusel
   ============================================================ */
.ix-rep-mini {
    scroll-snap-align: start;
    background: #fff;
    border: 1px solid rgba(0,0,0,0.05);
    border-radius: 18px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
    transition:
        transform 480ms var(--ix-ease),
        box-shadow 480ms var(--ix-ease),
        border-color 320ms var(--ix-ease);
}
.ix-rep-mini:hover {
    transform: translateY(-6px);
    box-shadow: 0 24px 40px -16px rgba(0,0,0,0.18);
}
.ix-rep-mini--lost:hover  { border-color: rgba(220,38,38,0.30); }
.ix-rep-mini--found:hover { border-color: rgba(22,163,74,0.30); }

.ix-rep-mini-photo {
    position: relative;
    aspect-ratio: 5 / 4;
    background: #f1f1f4;
    overflow: hidden;
}
.ix-rep-mini-photo img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: transform 1200ms var(--ix-ease);
}
.ix-rep-mini:hover .ix-rep-mini-photo img { transform: scale(1.06); }
/* Overlay legibilidad pill */
.ix-rep-mini-photo::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.30) 0%, transparent 36%);
    pointer-events: none;
}

/* Fallback imagen rota */
.ix-rep-mini-photo.is-img-fallback {
    background:
        linear-gradient(135deg, rgba(234,88,12,0.10), rgba(245,158,11,0.10)),
        repeating-linear-gradient(45deg, rgba(0,0,0,0.02) 0 8px, transparent 8px 16px),
        #fafafa;
}
.ix-rep-mini--found .ix-rep-mini-photo.is-img-fallback {
    background:
        linear-gradient(135deg, rgba(22,163,74,0.10), rgba(14,165,233,0.10)),
        repeating-linear-gradient(45deg, rgba(0,0,0,0.02) 0 8px, transparent 8px 16px),
        #fafafa;
}
.ix-rep-mini-photo.is-img-fallback::before {
    content: '';
    position: absolute; inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='%23ea580c' opacity='0.30'><ellipse cx='32' cy='42' rx='11' ry='9'/><ellipse cx='18' cy='28' rx='4.5' ry='6'/><ellipse cx='46' cy='28' rx='4.5' ry='6'/><ellipse cx='25' cy='18' rx='3.8' ry='5.5'/><ellipse cx='39' cy='18' rx='3.8' ry='5.5'/></svg>");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 38% auto;
    pointer-events: none;
}

.ix-rep-mini-pill {
    position: absolute; top: 12px; left: 12px;
    z-index: 2;
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 10.5px; font-weight: 800;
    letter-spacing: 0.10em; text-transform: uppercase;
    color: #fff;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 6px 14px -4px rgba(0,0,0,0.30);
}
.ix-rep-mini-pill--lost  { background: linear-gradient(135deg, rgba(220,38,38,0.94), rgba(234,88,12,0.94)); }
.ix-rep-mini-pill--found { background: linear-gradient(135deg, rgba(22,163,74,0.94), rgba(14,165,233,0.94)); }

.ix-rep-mini-dot {
    width: 6px; height: 6px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 0 8px rgba(255,255,255,0.85);
    animation: ix-mini-pulse 2000ms var(--ix-ease) infinite;
}
@keyframes ix-mini-pulse {
    0%, 100% { transform: scale(1.0); opacity: 0.85; }
    50%      { transform: scale(1.4); opacity: 1.00; }
}

.ix-rep-mini-body {
    padding: 14px 16px 16px;
}
.ix-rep-mini-title {
    margin: 0 0 5px;
    font-size: 15px; font-weight: 700;
    color: var(--ix-ink);
    letter-spacing: -0.014em;
    -webkit-line-clamp: 1; -webkit-box-orient: vertical;
    display: -webkit-box; overflow: hidden;
}
.ix-rep-mini--lost:hover  .ix-rep-mini-title { color: var(--ix-red); }
.ix-rep-mini--found:hover .ix-rep-mini-title { color: var(--ix-green); }
.ix-rep-mini-loc {
    display: inline-flex; align-items: center; gap: 4px;
    color: var(--ix-muted);
    font-size: 12.5px; font-weight: 600;
    letter-spacing: -0.005em;
}
.ix-rep-mini--lost  .ix-rep-mini-loc svg { color: var(--ix-red); }
.ix-rep-mini--found .ix-rep-mini-loc svg { color: var(--ix-green); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 760px) {
    .ix-rep { padding: 64px 18px 64px; }
    .ix-rep-cta-grid { grid-template-columns: 1fr; gap: 16px; margin-bottom: 48px; }
    .ix-rep-cta { padding: 28px 24px 26px; }
    .ix-rep-cta-icon { width: 60px; height: 60px; margin-bottom: 18px; border-radius: 16px; }
    .ix-rep-cta-title { font-size: 22px; }
    .ix-rep-cta-sub { font-size: 14px; margin-bottom: 18px; }
    .ix-rep-carousel-head { flex-wrap: wrap; gap: 12px; }
    .ix-rep-carousel-title { font-size: 18px; }
    .ix-rep-carousel { grid-auto-columns: minmax(220px, 240px); gap: 12px; }
    .ix-rep-orb { filter: blur(70px); }
}
@media (max-width: 480px) {
    .ix-rep-nav-btn { display: none; }  /* En mobile, gesture-driven scroll */
    .ix-rep-viewall { padding: 9px 14px; font-size: 13px; }
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    .ix-rep-orb,
    .ix-rep-grad,
    .ix-rep-cta-pulse,
    .ix-rep-cta-sparkle,
    .ix-rep-mini-dot,
    .ix-rep-viewall {
        animation: none !important;
    }
    .ix-rep-cta,
    .ix-rep-mini,
    .ix-rep-mini-photo img,
    .ix-rep-cta-action,
    .ix-rep-nav-btn {
        transition: none !important;
    }
}
