/*
 * ofj26.css
 * Mini-sitio OFJ — Orquesta Filarmónica de Jalisco Segunda Temporada 2026
 *
 * SISTEMA DE VARIABLES: para adaptar a otro evento solo cambia este bloque.
 */

:root {
    --f-primary:     #CD3736;   /* rojo principal */
    --f-primary-dk:  #a82b2a;   /* hover */
    --f-primary-lt:  #fdf0f0;   /* fondo suave */
    --f-accent:      #111111;   /* negro — detalles y badges */
    --f-accent-lt:   #f2f2f2;   /* fondo negro suave */
    --f-dark:        #0d0d0d;   /* hero, textos oscuros */
    --f-grey:        #5a6472;   /* texto secundario */
    --f-border:      #e0d0d0;   /* bordes suaves */
}


/* ═══════════════════════════════════════════
   HERO
══════════════════════════════════════════════ */
#ofj26 {
    background: var(--f-primary-lt);
    overflow-x: hidden;
}

.ofj-hero {
    position: relative;
    background: var(--f-dark);
    overflow: hidden;
    min-height: 340px;
    display: flex;
    align-items: center;
}

.ofj-hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center center;
    opacity: .35;
}

.ofj-hero__overlay {
    position: relative;
    z-index: 1;
    width: 100%;
}

.ofj-hero__edition {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: rgba(255,255,255,.75);
}

.ofj-hero__title {
    font-size: clamp(1.7rem, 4.5vw, 3rem);
    font-weight: 800;
    line-height: 1.15;
    color: #fff;
    letter-spacing: -.01em;
}

.ofj-hero__divider {
    width: 56px;
    height: 3px;
    background: var(--f-accent);
    border-radius: 2px;
}

.ofj-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    color: rgba(255,255,255,.85);
    border-radius: 100px;
    padding: .35rem .9rem;
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .02em;
}


/* ═══════════════════════════════════════════
   SECCIÓN HEADERS
══════════════════════════════════════════════ */
.ofj-section-eyebrow {
    display: block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .25em;
    text-transform: uppercase;
    color: var(--f-primary);
    margin-bottom: .4rem;
}

.ofj-section-title {
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 800;
    color: var(--f-dark);
    margin: 0 0 .75rem;
}

.ofj-section-line {
    width: 48px;
    height: 3px;
    background: var(--f-accent);
    border-radius: 2px;
}


/* ═══════════════════════════════════════════
   DESCRIPCIÓN
══════════════════════════════════════════════ */
.ofj-descripcion-wrap {
    background: #fff;
    border-bottom: 1px solid var(--f-border);
}

.ofj-descripcion {
    font-size: 1rem;
    color: var(--f-grey);
    line-height: 1.7;
    max-width: 780px;
    margin: 0 auto;
    text-align: center;
}


/* ═══════════════════════════════════════════
   PROMOCIONES
══════════════════════════════════════════════ */
.ofj-promos-wrap {
    background: #fff;
    border-bottom: 1px solid var(--f-border);
    border-top: 1px solid var(--f-border);
}

.ofj-promo-card {
    background: var(--f-accent-lt);
    border: 1px solid #d0d0d0;
    border-radius: 12px;
    padding: 1.75rem;
    position: relative;
    overflow: hidden;
}

.ofj-promo-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: var(--f-accent);
    border-radius: 4px 0 0 4px;
}

.ofj-promo-card__icon {
    font-size: 1.4rem;
    color: var(--f-accent);
    margin-bottom: .75rem;
}

.ofj-promo-card__badge {
    display: inline-block;
    background: var(--f-accent);
    color: #fff;
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
    border-radius: 4px;
    padding: .25rem .65rem;
    margin-bottom: .75rem;
}

.ofj-promo-card__title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--f-dark);
    margin-bottom: .5rem;
}

.ofj-promo-card__text {
    font-size: .88rem;
    color: var(--f-grey);
    margin-bottom: 0;
    line-height: 1.6;
}

.ofj-promo-card__list {
    font-size: .85rem;
    color: var(--f-grey);
    padding-left: 1.1rem;
    margin-bottom: .5rem;
    line-height: 1.8;
}

.ofj-promo-card__nota {
    font-size: .75rem;
    color: #777;
    margin-bottom: 0;
    font-style: italic;
}


/* ═══════════════════════════════════════════
   PATROCINADORES
══════════════════════════════════════════════ */
.ofj-patrocinadores-wrap {
    background: #fff;
    border-top: 1px solid var(--f-border);
}

.ofj-patrocinadores__img {
    max-width: 100%;
    width: 1200px;
    height: auto;
    display: block;
    margin: 0 auto;
}


/* ═══════════════════════════════════════════
   PROGRAMACIÓN
══════════════════════════════════════════════ */
.ofj-programa-wrap {
    background: var(--f-primary-lt);
}


/* ═══════════════════════════════════════════
   CARDS DE EVENTO
══════════════════════════════════════════════ */
.ofj-card.card {
    border: none;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
    overflow: hidden;
    transition: box-shadow .2s ease, transform .2s ease;
}

.ofj-card.card:hover {
    box-shadow: 0 8px 28px rgba(27,63,107,.15);
    transform: translateY(-2px);
}

/* Imagen */
.ofj-card__img-wrap {
    position: relative;
    background: var(--f-primary-lt);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 220px;
}

.ofj-card__img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    padding: .75rem;
}

/* Badge "Clausura" sobre imagen */
.ofj-card__clausura-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--f-accent);
    color: #fff;
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    border-radius: 4px;
    padding: .3rem .8rem;
}

/* Body */
.ofj-card__body {
    padding: 1.5rem;
}

/* Badge Programa N */
.ofj-badge-programa {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    background: var(--f-primary-lt);
    color: var(--f-primary);
    border: 1px solid #b8cfe0;
    border-radius: 4px;
    padding: .25rem .65rem;
}

/* Título */
.ofj-card__title {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--f-dark);
    line-height: 1.25;
    margin-bottom: .5rem;
}

/* Meta (fecha, sala, duración) */
.ofj-card__meta {
    font-size: .8rem;
    color: var(--f-grey);
    line-height: 1.5;
}

.ofj-card__meta i {
    color: var(--f-primary);
    opacity: .7;
}

/* Sinopsis */
.ofj-card__sinopsis {
    font-size: .88rem;
    color: var(--f-grey);
    line-height: 1.65;
    margin-bottom: 0;
}


/* ═══════════════════════════════════════════
   LISTA DE PROGRAMA MUSICAL
══════════════════════════════════════════════ */
.ofj-programa-musical {
    background: var(--f-primary-lt);
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--f-border);
}

.ofj-programa-musical__header {
    background: var(--f-primary);
    color: #fff;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .5rem 1rem;
}

.ofj-programa-musical__list {
    list-style: none;
    margin: 0;
    padding: .25rem 0;
}

.ofj-programa-musical__list li {
    display: flex;
    flex-direction: column;
    padding: .4rem 1rem;
    border-bottom: 1px solid var(--f-border);
    font-size: .83rem;
}

.ofj-programa-musical__list li:last-child {
    border-bottom: none;
}

.ofj-compositor {
    font-weight: 700;
    color: var(--f-dark);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.ofj-programa-musical__list em {
    color: var(--f-grey);
    font-style: italic;
}

.ofj-precio-rango {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--f-accent);
    color: #fff;
    padding: .55rem 1rem;
}

.ofj-precio-rango__label {
    font-size: .65rem;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: #fff;
}

.ofj-precio-rango__valor {
    font-size: .88rem;
    font-weight: 700;
    letter-spacing: .01em;
}


/* ═══════════════════════════════════════════
   TABLA DE PRECIOS
══════════════════════════════════════════════ */
.ofj-precios {
    background: var(--f-primary-lt);
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--f-border);
}

.ofj-precios__header {
    background: var(--f-primary);
    color: #fff;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .5rem 1rem;
}

.ofj-precios__table {
    margin-bottom: 0 !important;
    font-size: .82rem;
}

.ofj-precios__table thead th {
    background: rgba(27,63,107,.08);
    color: var(--f-primary);
    font-weight: 700;
    font-size: .75rem;
    letter-spacing: .04em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--f-border);
    padding: .4rem 1rem;
}

.ofj-precios__table tbody td {
    padding: .35rem 1rem;
    color: var(--f-grey);
    border-color: var(--f-border);
}

.ofj-precios__table tbody tr:hover td {
    background: rgba(27,63,107,.04);
}

.ofj-precios__nota {
    font-size: .72rem;
    color: #8a95a0;
    padding: .5rem 1rem;
    margin: 0;
    font-style: italic;
    background: #fff;
    border-top: 1px solid var(--f-border);
}


/* ═══════════════════════════════════════════
   BOTÓN TICKETS
══════════════════════════════════════════════ */
.ofj-btn-ticket {
    background: var(--f-primary);
    color: #fff !important;
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .04em;
    border-radius: 8px;
    padding: .5rem 1.25rem;
    border: none;
    white-space: nowrap;
    transition: background .2s ease;
}

.ofj-btn-ticket:hover,
.ofj-btn-ticket:focus {
    background: var(--f-primary-dk);
    color: #fff !important;
}

.ofj-btn-ticket--outline {
    background: transparent;
    border: 2px solid var(--f-primary);
    color: var(--f-primary) !important;
}

.ofj-btn-ticket--outline:hover {
    background: var(--f-primary);
    color: #fff !important;
}


/* ═══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media (max-width: 767px) {
    .ofj-card__img-wrap {
        min-height: 200px;
        max-height: 240px;
    }

    .ofj-card__body {
        padding: 1.1rem;
    }

    .ofj-card__title {
        font-size: 1rem;
    }

    .ofj-btn-ticket {
        width: 100%;
        text-align: center;
    }

    .ofj-btn-ticket--outline {
        width: 100%;
        text-align: center;
    }
}

@media (max-width: 575px) {
    .ofj-hero .d-flex.gap-3 {
        flex-direction: column;
        align-items: center;
    }

    .ofj-card__meta {
        flex-direction: column;
        gap: .4rem !important;
    }

    .ofj-precios__table {
        font-size: .78rem;
    }
}
