/* ============================================================
   web.css — Web pública Zona Ceta (rediseño). Estructura de INICIO.
   Tema claro sobre fondo = imagen completa.
   ============================================================ */
* { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --zc-rojo: #e2231a;
    --zc-rojo-osc: #b3140c;
    --zc-tinta: #1f2a3b;
    --zc-panel: rgba(255,255,255,0.92);
    --zc-borde: rgba(20,30,50,0.10);
}

html, body { height: 100%; }
body {
    font-family: 'Segoe UI', system-ui, Arial, sans-serif;
    color: var(--zc-tinta);
    /* Fondo: una sola imagen que LLENA todo (cover, centrada), igual que el
       gestor. Recorta lo que sobre para no dejar franjas. */
    background: url('../img/fondo_inicio.jpg') center center / cover no-repeat fixed, #0f1620;
    min-height: 100vh;
}

/* ─────────────────────────── BARRA SUPERIOR ─────────────────────────── */
/* Contenedor: posiciona el logo (absoluto, izquierda) y la barra (empieza en INICIO) */
.zc-top {
    position: sticky; top: 14px; z-index: 100;
    width: calc(100% - 44px); max-width: 1516px;
    margin: 14px auto 0;
    min-height: 70px;
}

/* Logo: imagen en div absoluto, esquinas redondeadas (máscara) + transparencia */
.zc-logo-abs {
    position: absolute; left: 4px; top: 50%; transform: translateY(-50%);
    z-index: 2;
    border-radius: 16px; overflow: hidden;   /* máscara que redondea la imagen */
}
.zc-logo-img {
    height: 64px; width: auto; display: block;
    border-radius: 16px;        /* esquinas redondeadas */
    opacity: 0.55;              /* más transparencia (se veía demasiado) */
}

/* Barra: empieza tras el logo (≈ botón INICIO) hasta el borde derecho */
.zc-bar {
    margin-left: 630px;          /* el logo queda a la izquierda y la barra empieza después */
    display: flex; align-items: center; gap: 24px;
    padding: 11px 22px;
    /* Degradado izquierda→derecha: transparente al inicio, blanco al final */
    background: linear-gradient(to right,
        rgba(255,255,255,0) 0%,
        rgba(255,255,255,0.45) 32%,
        rgba(255,255,255,0.92) 100%);
    border: none;
    border-radius: 18px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.15);
}

.zc-nav { display: flex; gap: 6px; }
.zc-nav-item {
    padding: 10px 18px; border-radius: 8px;
    font-size: 14px; font-weight: 800; letter-spacing: .5px;
    color: #3a4a60; cursor: pointer; user-select: none;
    transition: background .15s, color .15s;
}
.zc-nav-item:hover { background: rgba(20,30,50,0.06); }
.zc-nav-item.active { background: var(--zc-rojo); color: #fff; box-shadow: 0 4px 12px rgba(226,35,26,0.32); }

.zc-login {
    margin-left: auto;          /* a la derecha de la barra */
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 18px; border-radius: 10px;
    background: #fff; border: 1px solid var(--zc-borde);
    font-size: 13.5px; font-weight: 800; letter-spacing: .5px; color: #2b3648;
    cursor: pointer; transition: border-color .15s, box-shadow .15s;
}
.zc-login:hover { border-color: rgba(226,35,26,0.45); box-shadow: 0 4px 12px rgba(0,0,0,0.08); }

/* ─────────────────────────── CONTENIDO ─────────────────────────── */
.zc-main { max-width: 1560px; margin: 0 auto; padding: 22px; }
.zc-page { display: none; }
.zc-page.active { display: block; }
.zc-stub {
    background: var(--zc-panel); border: 1px solid var(--zc-borde); border-radius: 16px;
    padding: 60px; text-align: center; color: #6b7a90; font-size: 18px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

/* ─────────────────────────── INICIO ─────────────────────────── */
.zc-inicio-top {
    display: grid;
    /* Hero a la izquierda · hueco central (deja ver la imagen de fondo) · mapa
       a la derecha con el MISMO ancho que el panel de sponsors (560px). */
    grid-template-columns: minmax(360px, 520px) 1fr 560px;
    gap: 22px;
    margin-bottom: 6px;       /* menos hueco: el bloque inferior sube más */
    align-items: start;       /* sin altura mínima: el bloque inferior sube */
}
.zc-inicio-top .zc-hero { grid-column: 1; align-self: center; }
.zc-inicio-top .zc-mapa { grid-column: 3; align-self: start; }

.zc-inicio-bottom {
    /* Próximas partidas (ancho) + sponsors (560px), alineado con el mapa. */
    display: grid; grid-template-columns: 1fr 560px; gap: 22px;
}

/* Hero */
.zc-hero { padding: 30px 16px; align-self: center; }
.zc-hero-title {
    font-size: 64px; font-weight: 900; line-height: 1.02; letter-spacing: 1px;
    color: #ffffff;                 /* "VIVE LA EXPERIENCIA" en blanco */
    -webkit-text-fill-color: #ffffff;
    /* Textura desgastada (grunge) con una máscara de ruido SVG: erosiona
       ligeramente las letras dándoles aspecto gastado, como el boceto.
       Para una textura EXACTA pásame un PNG grunge y lo enchufo. */
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.6' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -1.3 1.62'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23g)'/%3E%3C/svg%3E");
            mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.6' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -1.3 1.62'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23g)'/%3E%3C/svg%3E");
    -webkit-mask-size: 180px; mask-size: 180px;
    -webkit-mask-repeat: repeat; mask-repeat: repeat;
    filter: drop-shadow(0 3px 10px rgba(0,0,0,0.55));   /* legibilidad sobre la foto */
    text-shadow: none;
}
.zc-hero-title .rojo {
    color: var(--zc-rojo);          /* "ZONA CETA" en rojo (hereda la misma textura) */
    -webkit-text-fill-color: var(--zc-rojo);
    font-size: 1.1em;               /* más grande que el resto del título (≈ +6px) */
    display: inline-block;
    line-height: 1;
}
.zc-hero-sub { margin-top: 22px; font-size: 22px; font-weight: 800; color: #ffffff; letter-spacing: .5px; text-shadow: 0 1px 6px rgba(0,0,0,0.6); }
.zc-hero-tag { margin-top: 16px; font-size: 16px; color: rgba(255,255,255,0.92); line-height: 1.5; text-shadow: 0 1px 5px rgba(0,0,0,0.55); }
.zc-hero-actions { margin-top: 28px; display: flex; gap: 14px; flex-wrap: wrap; }

.zc-btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 14px 26px; border-radius: 10px;
    font-size: 15px; font-weight: 800; letter-spacing: .5px; cursor: pointer;
    border: 1px solid transparent; transition: transform .12s, box-shadow .15s, filter .15s;
}
.zc-btn-rojo { background: linear-gradient(to bottom, #ff5247, #e2231a 55%, #b3140c); color: #fff; box-shadow: 0 8px 22px rgba(226,35,26,0.35); }
.zc-btn-rojo:hover { transform: translateY(-1px); filter: brightness(1.05); }
.zc-btn-ghost { background: rgba(255,255,255,0.85); border-color: var(--zc-borde); color: #2b3648; }
.zc-btn-ghost:hover { border-color: rgba(20,30,50,0.25); }

/* Mapa */
.zc-mapa {
    background: var(--zc-panel); border: 1px solid var(--zc-borde); border-radius: 16px;
    overflow: hidden; box-shadow: 0 12px 30px rgba(0,0,0,0.10);
    display: flex; flex-direction: column;
}
.zc-mapa-head {
    padding: 16px 20px; font-size: 14px; font-weight: 900; letter-spacing: 1px; color: #2b3648;
    border-bottom: 1px solid var(--zc-borde);
}
.zc-mapa-body { flex: 1; min-height: 210px; padding: 14px; }
.zc-mapa-placeholder {
    height: 100%; min-height: 186px; border-radius: 12px;
    border: 2px dashed rgba(20,30,50,0.18);
    background: rgba(20,30,50,0.04);
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px;
    color: #8a97a8;
}
.zc-mapa-placeholder span { font-size: 44px; }
.zc-mapa-legend {
    display: flex; flex-wrap: wrap; gap: 8px 18px;
    padding: 14px 20px; border-top: 1px solid var(--zc-borde);
    font-size: 11.5px; font-weight: 700; color: #44566e;
}
.zc-mapa-legend span { display: inline-flex; align-items: center; gap: 6px; }
.zc-mapa-legend i { width: 12px; height: 12px; border-radius: 4px; display: inline-block; }
.lg-base { background: #2b3648; } .lg-reunion { background: #2e9e5b; } .lg-objetivo { background: var(--zc-rojo); }
.lg-bosque { background: #3a7d44; } .lg-abierta { background: #c9a24b; }

/* Paneles inferiores */
.zc-panel {
    background: var(--zc-panel); border: 1px solid var(--zc-borde); border-radius: 16px;
    padding: 20px; box-shadow: 0 12px 30px rgba(0,0,0,0.10);
}
.zc-panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.zc-panel-head h2 { font-size: 16px; font-weight: 900; letter-spacing: 1px; color: #2b3648; }
.zc-verlink { font-size: 13px; font-weight: 800; color: var(--zc-rojo); cursor: pointer; }
.zc-verlink:hover { text-decoration: underline; }

/* Tarjetas de partida */
.zc-partidas-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.zc-sin-partidas { grid-column: 1 / -1; padding: 30px; text-align: center; color: #6b7a90; font-style: italic; }
/* Tarjeta = imagen de la partida (íntegra, contain) + overlay oscuro con los datos */
.zc-partida-card {
    position: relative; height: 240px;
    border: 1px solid var(--zc-borde); border-radius: 12px; overflow: hidden;
    background: #14202f;   /* relleno oscuro de los huecos del contain */
    box-shadow: 0 6px 16px rgba(0,0,0,0.10); cursor: pointer;
    transition: transform .12s, box-shadow .15s;
}
.zc-partida-card:hover { transform: translateY(-3px); box-shadow: 0 14px 26px rgba(0,0,0,0.18); }
.zc-partida-foto {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: contain; object-position: center;   /* imagen sin recortar ni deformar */
}
.zc-partida-overlay {
    position: absolute; left: 0; right: 0; bottom: 0;
    padding: 14px 12px 11px;
    background: linear-gradient(to top, rgba(8,12,18,0.94) 50%, rgba(8,12,18,0.55) 80%, rgba(8,12,18,0) 100%);
    color: #fff;
}
.zc-partida-overlay .zc-partida-title { font-size: 15.5px; font-weight: 900; color: #fff; line-height: 1.15; }
.zc-partida-overlay .zc-partida-type { font-size: 12px; color: rgba(255,255,255,0.75); margin-top: 2px; }
.zc-partida-overlay .zc-partida-meta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 7px; font-size: 11.5px; color: rgba(255,255,255,0.88); }
.zc-partida-overlay .zc-partida-bar { margin-top: 9px; height: 6px; border-radius: 999px; background: rgba(255,255,255,0.22); overflow: hidden; }
.zc-partida-overlay .zc-partida-bar span { display: block; height: 100%; background: var(--zc-rojo); }
.zc-partida-overlay .zc-partida-bar span.medium { background: #e0a83a; }
.zc-partida-overlay .zc-partida-bar span.low { background: #3ddc84; }
.zc-partida-overlay .zc-partida-occ { margin-top: 6px; text-align: right; font-size: 13px; font-weight: 800; color: #fff; }

/* Sponsors */
.zc-sponsors-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.zc-sin-sponsors { grid-column: 1 / -1; padding: 30px; text-align: center; color: #6b7a90; font-style: italic; }
.zc-sponsor-tile {
    height: 92px; border: 1px solid var(--zc-borde); border-radius: 12px;
    background: #fff; display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05); transition: transform .12s, box-shadow .15s;
    padding: 10px;
}
.zc-sponsor-tile:hover { transform: translateY(-2px); box-shadow: 0 10px 20px rgba(0,0,0,0.10); }
.zc-sponsor-tile img { max-width: 100%; max-height: 60px; object-fit: contain; }
.zc-sponsor-tile span { font-size: 15px; font-weight: 900; letter-spacing: 1px; color: #44566e; text-align: center; }

/* ─────────────────────────── Responsive ─────────────────────────── */
@media (max-width: 1180px) {
    .zc-inicio-top, .zc-inicio-bottom { grid-template-columns: 1fr; min-height: 0; }
    .zc-inicio-top .zc-hero, .zc-inicio-top .zc-mapa { grid-column: auto; }
    .zc-partidas-grid { grid-template-columns: repeat(2, 1fr); }
    .zc-hero-title { font-size: 48px; }
}
@media (max-width: 980px) {
    .zc-bar { margin-left: 150px; }
    .zc-logo-img { height: 46px; }
}
@media (max-width: 720px) {
    .zc-nav { display: none; }
    .zc-bar { margin-left: 120px; }
    .zc-logo-img { height: 42px; }
    .zc-partidas-grid, .zc-sponsors-grid { grid-template-columns: 1fr 1fr; }
}
