/* =============================================
   Event Schedule Calendar — Styles

   Fully token-driven. Any Style Studio theme
   (theme-light, theme-dark-purple, theme-dark-brown,
   theme-color-blind, custom) flows through via the
   published `body.theme-{slug}` CSS variables.
   ============================================= */

/* Layout-only container — no visual chrome, so the header and calendar
 * blocks each provide their own card surface. This avoids the wrapper
 * colour diverging from the inner card in dark themes (colorblind mode
 * sets --bg-page near-black while --bg-card stays light, which turned
 * the previous wrapper rule into a mismatched frame). */
.jes-wrapper {
    max-width: 1000px;
    margin: 0 auto;
    padding: 20px;
    color: var(--text-primary, #1a1a2e);
    font-family: inherit;
    background: transparent;
    border: 0;
}

.jes-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 20px;
    background: linear-gradient(135deg, var(--accent-from, #667eea) 0%, var(--accent-to, #764ba2) 100%);
    color: var(--header-text, #fff);
    border-radius: 8px;
    margin-bottom: 20px;
    border: 1px solid transparent;
    gap: 10px;
}

.jes-header-left {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.jes-header-right {
    display: flex;
    gap: 15px;
    align-items: center;
}

.jes-header h1 {
    margin: 0 0 4px;
    font-size: 1.8em;
    color: var(--header-text, #fff);
}

.jes-subtitle {
    color: var(--header-text, #fff);
    opacity: 0.9;
    font-size: 0.9em;
    margin: 0;
}

.jes-user-badge {
    background: color-mix(in srgb, var(--header-text, #fff) 20%, transparent);
    border: 1px solid color-mix(in srgb, var(--header-text, #fff) 35%, transparent);
    color: var(--header-text, #fff);
    padding: 8px 15px;
    border-radius: 20px;
    font-size: 0.9em;
}

/* -- Navigation ------------------------------------------ */

.jes-calendar-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
    gap: 12px;
}

.jes-nav-btn {
    background: var(--bg-page, #f8f9fa);
    border: 1px solid var(--border-card, rgba(0,0,0,0.12));
    color: var(--text-primary, #1a1a2e);
    padding: 8px 18px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 1em;
    font-weight: 600;
    transition: background 0.15s, border-color 0.15s;
}

.jes-nav-btn:hover {
    background: var(--surface-hover, color-mix(in srgb, var(--accent-from, #667eea) 10%, transparent));
    border-color: var(--accent-from, #667eea);
}

.jes-month-label {
    font-size: 1.3em;
    font-weight: 700;
    color: var(--text-primary, #1a1a2e);
    flex: 1;
    text-align: center;
}

/* -- Calendar -------------------------------------------- */

.jes-calendar {
    background: var(--bg-card, #fff);
    border: 1px solid var(--border-card, rgba(0,0,0,0.08));
    border-radius: 10px;
    overflow: hidden;
}

.jes-day-header-row {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: color-mix(in srgb, var(--accent-from, #667eea) 10%, transparent);
    border-bottom: 1px solid var(--border-card, rgba(0,0,0,0.08));
}

.jes-day-header {
    padding: 10px 4px;
    text-align: center;
    font-weight: 700;
    font-size: 0.85em;
    color: var(--accent-from, #667eea);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.jes-days-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--bg-card, #fff);
}

.jes-day {
    min-height: 80px;
    padding: 8px 6px 6px;
    border-right: 1px solid var(--border-card, rgba(0,0,0,0.06));
    border-bottom: 1px solid var(--border-card, rgba(0,0,0,0.06));
    vertical-align: top;
    background: var(--bg-card, #fff);
    color: var(--text-primary, #1a1a2e);
    transition: background 0.1s;
}

.jes-day:nth-child(7n) { border-right: none; }

/* Empty cells: subtle tint of the card bg, NOT --bg-page. In dark
 * themes --bg-page can be near-black while --bg-card stays light, and
 * using --bg-page here produces stark black voids between white day
 * cells. A mix keeps empty cells distinguishable but quiet. */
.jes-day-empty {
    background: color-mix(in srgb, var(--text-primary, #1a1a2e) 5%, var(--bg-card, #fff));
}

.jes-day.jes-has-events {
    cursor: pointer;
    background: color-mix(in srgb, var(--accent-from, #667eea) 5%, var(--bg-card, #fff));
}

.jes-day.jes-has-events:hover {
    background: color-mix(in srgb, var(--accent-from, #667eea) 12%, var(--bg-card, #fff));
}

.jes-today {
    background: color-mix(in srgb, var(--accent-from, #667eea) 10%, var(--bg-card, #fff)) !important;
    outline: 2px solid var(--accent-from, #667eea);
    outline-offset: -2px;
}

.jes-day-num {
    display: block;
    font-size: 0.85em;
    font-weight: 600;
    color: var(--text-muted, #6b6b8a);
    margin-bottom: 4px;
}

.jes-today .jes-day-num { color: var(--accent-from, #667eea); }

/* -- Event dots in calendar cells ----------------------- */

.jes-event-dots {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.jes-event-dot {
    font-size: 0.72em;
    padding: 2px 6px;
    border-radius: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    font-weight: 600;
}

.jes-dot-vb {
    background: color-mix(in srgb, var(--accent-from, #667eea) 20%, transparent);
    color: var(--accent-from, #667eea);
    border-left: 3px solid var(--accent-from, #667eea);
}

.jes-dot-duel {
    background: color-mix(in srgb, var(--accent-to, #764ba2) 18%, transparent);
    color: var(--accent-to, #764ba2);
    border-left: 3px solid var(--accent-to, #764ba2);
}

/* Shop events — distinct from fight bets so admins can tell them apart
 * at a glance. Uses a teal/cyan accent derived from the surface-hover
 * token so it reads as "commerce" rather than "combat". */
.jes-dot-shop {
    background: color-mix(in srgb, #2aa198 22%, transparent);
    color: #2aa198;
    border-left: 3px solid #2aa198;
}

.jes-more-events {
    font-size: 0.72em;
    color: var(--text-muted, #6b6b8a);
    padding: 1px 6px;
}

/* -- Loading -------------------------------------------- */

.jes-loading {
    padding: 40px;
    text-align: center;
    color: var(--text-muted, #6b6b8a);
    grid-column: 1 / -1;
}

/* -- Day Detail Panel ------------------------------------ */

.jes-day-detail {
    margin-top: 20px;
    background: var(--bg-card, #fff);
    border: 1px solid var(--border-card, rgba(0,0,0,0.08));
    border-radius: 10px;
    overflow: hidden;
}

.jes-day-detail-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    background: linear-gradient(135deg, var(--accent-from, #667eea) 0%, var(--accent-to, #764ba2) 100%);
    border-bottom: 1px solid transparent;
    color: var(--header-text, #fff);
}

.jes-day-detail-header h3 {
    margin: 0;
    font-size: 1.1em;
    color: var(--header-text, #fff);
}

.jes-close-day {
    background: none;
    border: none;
    font-size: 1.4em;
    color: var(--header-text, #fff);
    opacity: 0.8;
    cursor: pointer;
    line-height: 1;
    padding: 0;
}

.jes-close-day:hover { opacity: 1; }

.jes-day-detail-events {
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: var(--bg-card, #fff);
}

/* -- Event Cards ---------------------------------------- */

.jes-event-card {
    padding: 14px 16px;
    border-radius: 8px;
    border-left: 4px solid transparent;
    background: var(--bg-page, #f8f9fa);
    color: var(--text-primary, #1a1a2e);
}

.jes-event-vb {
    background: color-mix(in srgb, var(--accent-from, #667eea) 8%, var(--bg-card, #fff));
    border-left-color: var(--accent-from, #667eea);
}

.jes-event-duel {
    background: color-mix(in srgb, var(--accent-to, #764ba2) 10%, var(--bg-card, #fff));
    border-left-color: var(--accent-to, #764ba2);
}

.jes-event-shop {
    background: color-mix(in srgb, #2aa198 10%, var(--bg-card, #fff));
    border-left-color: #2aa198;
}

.jes-event-card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
}

.jes-event-badge {
    font-size: 0.8em;
    font-weight: 700;
    color: var(--text-muted, #6b6b8a);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.jes-event-time {
    font-size: 0.85em;
    color: var(--text-muted, #6b6b8a);
}

.jes-event-title {
    font-weight: 700;
    font-size: 1em;
    color: var(--text-primary, #1a1a2e);
    margin-bottom: 4px;
}

.jes-event-matchup {
    font-size: 0.9em;
    color: var(--text-muted, #6b6b8a);
}

.jes-event-status {
    display: inline-block;
    margin-top: 6px;
    padding: 2px 9px;
    border-radius: 10px;
    font-size: 0.78em;
    font-weight: 600;
    text-transform: uppercase;
}

.jes-event-status-upcoming  { background: color-mix(in srgb, #e0a500 18%, transparent); color: #b8881e; border: 1px solid color-mix(in srgb, #e0a500 40%, transparent); }
.jes-event-status-active    { background: color-mix(in srgb, #2f7d4f 18%, transparent); color: #2f7d4f; border: 1px solid color-mix(in srgb, #2f7d4f 40%, transparent); }
.jes-event-status-scheduled { background: color-mix(in srgb, var(--accent-to, #764ba2) 18%, transparent); color: var(--accent-to, #764ba2); border: 1px solid color-mix(in srgb, var(--accent-to, #764ba2) 40%, transparent); }

/* -- Responsive ----------------------------------------- */

@media (max-width: 600px) {
    .jes-day-header,
    .jes-day-num { font-size: 0.75em; }
    .jes-day { min-height: 55px; padding: 4px; }
    .jes-event-dot { display: none; }
    .jes-day.jes-has-events::after {
        content: '•';
        display: block;
        text-align: center;
        color: var(--accent-from, #667eea);
        font-size: 1.2em;
    }
}
