/* ═══════════════════════════════════════════
   FJPS - Events – Frontend Styles
   All colors come from CSS variables set
   by PHP inline style (design settings).
═══════════════════════════════════════════ */

/* ── Wrapper ── */
.fjpse-wrapper { width: 100%; box-sizing: border-box; }
.fjpse-section-title {
    font-family: var(--fjpse-font-title, inherit);
    font-size: calc(var(--fjpse-font-size-title, 1.4rem) * 1.3);
    color: var(--fjpse-title-color, #1A1A2E);
    margin: 0 0 24px; font-weight: 700;
}

/* ── Controls: search + filter ── */
.fjpse-controls {
    display: flex; flex-wrap: wrap; gap: 12px;
    margin-bottom: 24px; align-items: center;
}
.fjpse-search-wrap {
    position: relative; flex: 1; min-width: 200px;
}
.fjpse-search-icon {
    position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
    width: 18px; height: 18px; color: #9CA3AF; pointer-events: none;
}
.fjpse-search {
    width: 100%; padding: 10px 12px 10px 38px;
    border: 2px solid var(--fjpse-card-border, #E8E8E8);
    border-radius: var(--fjpse-radius, 12px);
    font-size: .9rem; color: var(--fjpse-body-color, #374151);
    background: var(--fjpse-card-bg, #fff);
    transition: border-color .2s; box-sizing: border-box;
}
.fjpse-search:focus { outline: none; border-color: var(--fjpse-accent, #E63946); }

.fjpse-filter-wrap { display: flex; gap: 6px; flex-wrap: wrap; }
.fjpse-filter-btn {
    padding: 8px 14px; border: 2px solid var(--fjpse-card-border, #E8E8E8);
    border-radius: 20px; background: var(--fjpse-card-bg, #fff);
    color: var(--fjpse-meta-color, #6B7280); font-size: .82rem; font-weight: 600;
    cursor: pointer; transition: all .2s;
}
.fjpse-filter-btn:hover,
.fjpse-filter-btn.active {
    border-color: var(--fjpse-accent, #E63946);
    background: var(--fjpse-accent, #E63946);
    color: var(--fjpse-btn-text, #fff);
}

/* ── Grid ── */
.fjpse-grid {
    display: grid;
    grid-template-columns: repeat(var(--fjpse-cols-desktop, 3), 1fr);
    gap: var(--fjpse-gap, 24px);
}
@media (max-width: 1023px) {
    .fjpse-grid { grid-template-columns: repeat(var(--fjpse-cols-tablet, 2), 1fr); }
}
@media (max-width: 767px) {
    .fjpse-grid { grid-template-columns: repeat(var(--fjpse-cols-mobile, 1), 1fr); }
}

/* ── Card ── */
.fjpse-card {
    background: var(--fjpse-card-bg, #fff);
    border: 1px solid var(--fjpse-card-border, #E8E8E8);
    border-radius: var(--fjpse-radius, 12px);
    box-shadow: var(--fjpse-card-shadow, 0 4px 20px rgba(0,0,0,.08));
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .2s, box-shadow .2s;
}
.fjpse-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(0,0,0,.14);
}
.fjpse-card--past { opacity: .85; }
.fjpse-card--featured { border-color: var(--fjpse-accent, #E63946); }
.fjpse-card--horizontal { flex-direction: row; }
.fjpse-card--horizontal .fjpse-card__image {
    width: 200px; flex-shrink: 0; height: auto; min-height: 160px;
}
@media (max-width: 600px) {
    .fjpse-card--horizontal { flex-direction: column; }
    .fjpse-card--horizontal .fjpse-card__image { width: 100%; }
}

/* ── Card image ── */
.fjpse-card__image {
    position: relative;
    height: var(--fjpse-img-height, 220px);
    background-size: cover; background-position: center;
    background-color: #F3F4F6;
    flex-shrink: 0;
}

/* ── Badge ── */
.fjpse-badge {
    position: absolute; top: 12px; left: 12px;
    padding: 4px 10px; border-radius: 20px;
    font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
    background: var(--fjpse-badge-bg, #E63946); color: var(--fjpse-badge-text, #fff);
}
.fjpse-badge--past { background: rgba(0,0,0,.55); }
.fjpse-badge--featured { background: var(--fjpse-badge-bg, #E63946); }

/* ── Card body ── */
.fjpse-card__body {
    padding: var(--fjpse-padding, 20px);
    display: flex; flex-direction: column; gap: 10px; flex: 1;
}
.fjpse-card__title {
    margin: 0;
    font-family: var(--fjpse-font-title, inherit);
    font-size: var(--fjpse-font-size-title, 1.4rem);
    font-weight: var(--fjpse-font-weight-title, 700);
    color: var(--fjpse-title-color, #1A1A2E);
    line-height: 1.3;
}

/* ── Meta ── */
.fjpse-card__meta { display: flex; flex-wrap: wrap; gap: 8px; }
.fjpse-meta-item {
    display: flex; align-items: center; gap: 5px;
    font-size: var(--fjpse-font-size-meta, .85rem);
    color: var(--fjpse-meta-color, #6B7280);
    font-family: var(--fjpse-font-body, inherit);
}
.fjpse-meta-item a { color: var(--fjpse-accent, #E63946); text-decoration: none; }
.fjpse-meta-item a:hover { text-decoration: underline; }
.fjpse-icon { width: 1em; height: 1em; flex-shrink: 0; }

/* ── Desc ── */
.fjpse-card__desc {
    font-size: var(--fjpse-font-size-body, 1rem);
    font-family: var(--fjpse-font-body, inherit);
    color: var(--fjpse-body-color, #374151);
    line-height: 1.6;
    margin: 0;
}

/* ── Card actions ── */
.fjpse-card__actions {
    display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; padding-top: 6px;
}

/* ── Buttons ── */
.fjpse-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 7px 14px; border-radius: 8px; font-size: .82rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all .2s;
    background: var(--fjpse-btn-bg, #E63946); color: var(--fjpse-btn-text, #fff); border: none;
}
.fjpse-btn:hover { opacity: .88; transform: translateY(-1px); }
.fjpse-btn--outline {
    background: transparent;
    color: var(--fjpse-accent, #E63946);
    border: 2px solid var(--fjpse-accent, #E63946);
}
.fjpse-btn--outline:hover {
    background: var(--fjpse-accent, #E63946);
    color: #fff;
}

/* ── Empty state ── */
.fjpse-empty {
    text-align: center; padding: 60px 20px;
    color: var(--fjpse-meta-color, #6B7280);
}
.fjpse-empty-icon { font-size: 3rem; display: block; margin-bottom: 12px; }
.fjpse-empty p { margin: 0; font-size: 1rem; }

/* ═══════════════════════════════════════════
   POPUP – SPONSORS
═══════════════════════════════════════════ */

.fjpse-popup-overlay {
    position: fixed; inset: 0;
    background: var(--fjpse-popup-overlay, rgba(0,0,0,.7));
    z-index: 99999;
    display: flex; align-items: center; justify-content: center;
    padding: 20px; box-sizing: border-box;
    opacity: 0; visibility: hidden; transition: all .25s;
}
.fjpse-popup-overlay.open { opacity: 1; visibility: visible; }

.fjpse-popup {
    background: var(--fjpse-popup-bg, #fff);
    border-radius: calc(var(--fjpse-radius, 12px) + 4px);
    width: 100%; max-width: 560px; max-height: 80vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0,0,0,.3);
    transform: translateY(20px); transition: transform .25s;
}
.fjpse-popup-overlay.open .fjpse-popup { transform: translateY(0); }

.fjpse-popup__header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 20px 24px 16px; border-bottom: 1px solid rgba(0,0,0,.08);
    position: sticky; top: 0; background: var(--fjpse-popup-bg, #fff); z-index: 1;
}
.fjpse-popup__title {
    margin: 0; font-size: 1.2rem; font-weight: 700;
    font-family: var(--fjpse-font-title, inherit);
    color: var(--fjpse-title-color, #1A1A2E);
}
.fjpse-popup__close {
    background: none; border: none; font-size: 1.3rem; cursor: pointer;
    color: var(--fjpse-meta-color, #6B7280); padding: 4px 8px; border-radius: 6px;
    transition: background .2s;
}
.fjpse-popup__close:hover { background: rgba(0,0,0,.06); }
.fjpse-popup__body { padding: 20px 24px 24px; }

/* ── Sponsor item ── */
.fjpse-sponsor-item {
    display: flex; gap: 16px; align-items: flex-start;
    padding: 16px 0; border-bottom: 1px solid rgba(0,0,0,.07);
}
.fjpse-sponsor-item:last-child { border-bottom: none; padding-bottom: 0; }
.fjpse-sponsor-logo {
    width: 56px; height: 56px; border-radius: 8px;
    object-fit: contain; flex-shrink: 0;
    background: #F3F4F6; padding: 4px; box-sizing: border-box;
}
.fjpse-sponsor-logo-placeholder {
    width: 56px; height: 56px; border-radius: 8px;
    background: linear-gradient(135deg, var(--fjpse-accent, #E63946), var(--fjpse-accent-hover, #c1121f));
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 1.3rem; font-weight: 800; flex-shrink: 0;
}
.fjpse-sponsor-info { flex: 1; }
.fjpse-sponsor-name {
    margin: 0 0 4px; font-weight: 700;
    font-family: var(--fjpse-font-title, inherit);
    color: var(--fjpse-title-color, #1A1A2E);
}
.fjpse-sponsor-desc {
    margin: 0 0 6px; font-size: .88rem;
    color: var(--fjpse-body-color, #374151);
    line-height: 1.5;
}
.fjpse-sponsor-link {
    font-size: .82rem; color: var(--fjpse-accent, #E63946);
    text-decoration: none; font-weight: 600;
}
.fjpse-sponsor-link:hover { text-decoration: underline; }

/* ═══════════════════════════════════════════
   CALENDAR
═══════════════════════════════════════════ */

.fjpse-cal-wrapper { display: grid; grid-template-columns: auto 1fr; gap: 24px; }
@media (max-width: 767px) { .fjpse-cal-wrapper { grid-template-columns: 1fr; } }

.fjpse-calendar {
    background: var(--fjpse-card-bg, #fff);
    border-radius: var(--fjpse-radius, 12px);
    box-shadow: var(--fjpse-card-shadow, 0 4px 20px rgba(0,0,0,.08));
    overflow: hidden; min-width: 300px;
}

.fjpse-cal__nav {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 20px;
    background: var(--fjpse-cal-header-bg, #1A1A2E);
    color: var(--fjpse-cal-header-text, #fff);
}
.fjpse-cal__nav-btn {
    background: rgba(255,255,255,.15); border: none;
    color: var(--fjpse-cal-header-text, #fff); font-size: 1.4rem;
    width: 36px; height: 36px; border-radius: 8px; cursor: pointer;
    display: flex; align-items: center; justify-content: center; transition: background .2s;
}
.fjpse-cal__nav-btn:hover { background: rgba(255,255,255,.3); }
.fjpse-cal__month-label { margin: 0; font-size: 1rem; font-weight: 700; }

.fjpse-cal__weekdays {
    display: grid; grid-template-columns: repeat(7, 1fr);
    background: rgba(0,0,0,.04); padding: 0 4px;
}
.fjpse-cal__weekdays span {
    text-align: center; padding: 8px 0;
    font-size: .75rem; font-weight: 800; text-transform: uppercase;
    letter-spacing: .05em; color: var(--fjpse-meta-color, #6B7280);
}

.fjpse-cal__days {
    display: grid; grid-template-columns: repeat(7, 1fr);
    padding: 8px; gap: 4px;
}
.fjpse-cal__day {
    aspect-ratio: 1; display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    border-radius: 8px; cursor: pointer; transition: all .15s;
    position: relative; font-size: .88rem;
    color: var(--fjpse-body-color, #374151);
}
.fjpse-cal__day:hover { background: rgba(0,0,0,.05); }
.fjpse-cal__day--empty { cursor: default; }
.fjpse-cal__day--today { background: var(--fjpse-cal-today-bg, #FFF3F3); font-weight: 700; }
.fjpse-cal__day--selected { background: var(--fjpse-cal-sel-bg, #E63946) !important; color: var(--fjpse-cal-sel-text, #fff) !important; }
.fjpse-cal__day--has-events { font-weight: 700; }
.fjpse-cal__day-dot {
    width: 5px; height: 5px; border-radius: 50%;
    background: var(--fjpse-cal-dot, #E63946);
    position: absolute; bottom: 4px;
}
.fjpse-cal__day--selected .fjpse-cal__day-dot { background: rgba(255,255,255,.8); }

/* ── Calendar event list ── */
.fjpse-cal-events {
    background: var(--fjpse-card-bg, #fff);
    border-radius: var(--fjpse-radius, 12px);
    box-shadow: var(--fjpse-card-shadow, 0 4px 20px rgba(0,0,0,.08));
    padding: 20px; align-self: start;
}
.fjpse-cal-events__title {
    margin: 0 0 16px; font-size: .85rem; font-weight: 800;
    text-transform: uppercase; letter-spacing: .07em;
    color: var(--fjpse-meta-color, #6B7280);
    border-bottom: 2px solid rgba(0,0,0,.07); padding-bottom: 10px;
}
.fjpse-cal-event-row {
    display: flex; gap: 12px; align-items: flex-start;
    padding: 10px 0; border-bottom: 1px solid rgba(0,0,0,.06); cursor: pointer;
}
.fjpse-cal-event-row:last-child { border-bottom: none; }
.fjpse-cal-event-row:hover .fjpse-cal-event-name { color: var(--fjpse-accent, #E63946); }
.fjpse-cal-event-date-badge {
    text-align: center; background: var(--fjpse-accent, #E63946); color: #fff;
    border-radius: 8px; padding: 4px 8px; min-width: 40px; flex-shrink: 0;
    line-height: 1.2;
}
.fjpse-cal-event-date-badge .day { font-size: 1.2rem; font-weight: 800; }
.fjpse-cal-event-date-badge .mon { font-size: .65rem; text-transform: uppercase; }
.fjpse-cal-event-info { flex: 1; }
.fjpse-cal-event-name { font-weight: 700; color: var(--fjpse-title-color, #1A1A2E); font-size: .9rem; margin-bottom: 2px; }
.fjpse-cal-event-meta { font-size: .78rem; color: var(--fjpse-meta-color, #6B7280); }

/* ── Loading state ── */
.fjpse-cal-loading { text-align: center; padding: 24px; color: var(--fjpse-meta-color, #6B7280); }
.fjpse-skeleton {
    background: linear-gradient(90deg, #F0F0F0 25%, #E0E0E0 50%, #F0F0F0 75%);
    background-size: 200% 100%; animation: fjpse-shimmer 1.4s infinite;
    border-radius: 6px;
}
@keyframes fjpse-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ── Error ── */
.fjpse-error { padding: 12px; background: #FEE2E2; color: #991B1B; border-radius: 8px; }

/* ── Compact calendar ── */
.fjpse-cal--compact .fjpse-calendar { min-width: 260px; }
.fjpse-cal--compact .fjpse-cal__day { font-size: .8rem; }

/* ── Print ── */
@media print {
    .fjpse-card:hover { transform: none; box-shadow: none; }
    .fjpse-popup-overlay { display: none !important; }
    .fjpse-filter-wrap, .fjpse-search-wrap { display: none; }
}
