/* =============================================
   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: 1500px;
    margin: 0 auto;
    padding: 20px;
    color: var(--text-primary, #1a1a2e);
    font-family: inherit;
    background: transparent;
    border: 0;
}

/* Side-by-side layout: calendar on the left, day-detail on the right
 * when there's room. Below the breakpoint the detail panel turns into
 * a modal (see .jes-day-detail rules at the breakpoint). */
.jes-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.jes-layout-main {
    min-width: 0;
}

@media (min-width: 1100px) {
    .jes-layout {
        grid-template-columns: minmax(0, 1fr) 400px;
    }
}

.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;
}

/* Past events kept on the calendar as history: dimmed so they read as
 * "done" without disappearing. Cancelled additionally gets a strike. */
.jes-event-dot.jes-dot-done {
    opacity: 0.5;
    filter: grayscale(0.4);
}
.jes-event-dot.jes-dot-cancelled {
    text-decoration: line-through;
}

.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 ------------------------------------ */

/* Wide screens: side panel that stays in flow inside the grid column.
 * Sticky so it remains visible while scrolling a long calendar/event list. */
.jes-day-detail {
    background: var(--bg-card, #fff);
    border: 1px solid var(--border-card, rgba(0,0,0,0.08));
    border-radius: 10px;
    overflow: hidden;
}

@media (min-width: 1100px) {
    .jes-day-detail {
        position: sticky;
        top: 20px;
        max-height: calc(100vh - 40px);
        display: flex;
        flex-direction: column;
    }
    .jes-day-detail-events {
        overflow-y: auto;
        flex: 1;
    }
}

/* Narrow screens: turn the day-detail into a modal so users don't have
 * to scroll past the calendar to see the events for the day they tapped. */
.jes-day-detail-backdrop {
    display: none;
}
@media (max-width: 1099px) {
    .jes-day-detail-backdrop {
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,0.55);
        z-index: 99998;
    }
    .jes-day-detail {
        position: fixed;
        top: 5vh;
        left: 50%;
        transform: translateX(-50%);
        width: min(92vw, 640px);
        max-height: 90vh;
        z-index: 99999;
        display: flex;
        flex-direction: column;
        box-shadow: 0 20px 60px rgba(0,0,0,0.4);
    }
    .jes-day-detail-events {
        overflow-y: auto;
        flex: 1;
    }
}

body.jes-modal-open { overflow: hidden; }

/* -- Inline "Upcoming" stack (below calendar at narrow widths) ----------
 * Wide screens (>=1100px) keep the upcoming list in the sticky side panel.
 * Below the breakpoint the side panel hides and this stack takes over so
 * the calendar can claim the full width and the upcoming events stay
 * visible without requiring a click. */
.jes-upcoming-inline {
    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-upcoming-inline-header {
    padding: 14px 18px;
    background: linear-gradient(135deg, var(--accent-from, #667eea) 0%, var(--accent-to, #764ba2) 100%);
    color: var(--header-text, #fff);
}
.jes-upcoming-inline-header h3 {
    margin: 0;
    color: var(--header-text, #fff);
    font-size: 1.05em;
}
.jes-upcoming-inline-events {
    padding: 12px 16px 16px;
}
/* At wide widths the side panel handles the upcoming list; this inline
 * container would just duplicate it. Hide forcefully (the !important is
 * because the JS uses .show() which sets inline `display: block`). */
@media (min-width: 1100px) {
    .jes-upcoming-inline { display: none !important; }
}

/* -- Event Details modal -------------------------------------------------
 * Independent of .jes-day-detail because it can be opened from anywhere on
 * the schedule page (calendar tile, side panel, mobile day-modal) and
 * shouldn't replace whatever's already showing in the day panel. */
.jes-event-details-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.55);
    z-index: 100000;
}
.jes-event-details-modal {
    position: fixed;
    top: 5vh;
    left: 50%;
    transform: translateX(-50%);
    width: min(92vw, 640px);
    max-height: 90vh;
    z-index: 100001;
    display: flex;
    flex-direction: column;
    background: var(--bg-card, #ffffff);
    color: var(--text-primary, #1a1a2e);
    border: 1px solid var(--border-card, rgba(0,0,0,0.18));
    border-radius: 10px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.4);
    overflow: hidden;
}
.jes-event-details-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: #fff;
}
.jes-event-details-header h3 {
    margin: 0;
    font-size: 1.05em;
    color: #fff;
}
.jes-event-details-body {
    padding: 16px 18px;
    overflow-y: auto;
    flex: 1;
    line-height: 1.5;
    font-size: 0.95em;
    white-space: normal;
}
.jes-event-details-body a {
    color: var(--accent-from, #667eea);
    text-decoration: underline;
    word-break: break-word;
}
.jes-event-details-body strong { font-weight: 700; }
.jes-event-details-body em { font-style: italic; }
.jes-discord-mention {
    background: rgba(102, 126, 234, 0.15);
    color: var(--accent-from, #667eea);
    padding: 1px 6px;
    border-radius: 4px;
    font-weight: 600;
    font-size: 0.92em;
}

/* "Event Details" button on each event card. */
.jes-event-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.jes-event-details-btn {
    cursor: pointer;
    border: 1px solid var(--border-card, rgba(0,0,0,0.18));
    background: var(--bg-page, #f8f9fa);
    color: var(--text-primary, #1a1a2e);
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 0.85em;
    font-weight: 600;
    transition: background 120ms ease, border-color 120ms ease, transform 80ms ease;
}
.jes-event-details-btn:hover {
    background: var(--surface-hover, #eef1fb);
    border-color: var(--accent-from, #667eea);
}
.jes-event-details-btn:active { transform: translateY(1px); }

/* "Place a Bet" sits next to "Event Details" when betting is open. Styled
 * primary (gradient) so the call-to-action reads ahead of the secondary
 * Event Details button. */
.jes-event-actions .jes-place-bets-btn {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
    text-decoration: none;
    padding: 5px 12px;
    border-radius: 4px;
    font-size: 0.85em;
    font-weight: 700;
    background: linear-gradient(135deg, var(--accent-from, #667eea) 0%, var(--accent-to, #764ba2) 100%);
    color: var(--header-text, #fff);
    border: 1px solid transparent;
    transition: filter 120ms ease, transform 80ms ease, box-shadow 120ms ease;
}
.jes-event-actions .jes-place-bets-btn:hover {
    filter: brightness(1.1);
    box-shadow: 0 2px 8px rgba(102, 126, 234, 0.35);
}
.jes-event-actions .jes-place-bets-btn:active { transform: translateY(1px); }

/* -- Signup controls (calendar event card) --------------- */
.jes-event-signup { margin-top: 10px; }
.jes-signup-controls {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}
.jes-signup-controls button {
    cursor: pointer;
    border: 1px solid var(--border-card, rgba(0,0,0,0.18));
    background: var(--bg-page, #f8f9fa);
    color: var(--text-primary, #1a1a2e);
    border-radius: 6px;
    padding: 6px 12px;
    font-size: 0.88em;
    font-weight: 600;
    line-height: 1;
}
.jes-signup-controls button:hover:not(:disabled) {
    border-color: var(--accent-from, #667eea);
}
.jes-signup-controls button:disabled {
    opacity: 0.55;
    cursor: progress;
}
.jes-signup-controls .jes-btn-primary {
    background: var(--accent-from, #667eea);
    border-color: var(--accent-from, #667eea);
    color: #fff;
}
.jes-signup-status {
    display: inline-block;
    font-weight: 700;
    font-size: 0.82em;
    padding: 3px 9px;
    border-radius: 11px;
    letter-spacing: 0.02em;
}
.jes-signup-confirmed {
    background: color-mix(in srgb, #2ecc71 18%, transparent);
    color: #1f8a4d;
}
.jes-signup-standby {
    background: color-mix(in srgb, #f39c12 22%, transparent);
    color: #b9770e;
}
.jes-signup-counts {
    color: var(--text-muted, #6b6b8a);
    font-size: 0.85em;
    margin-left: 4px;
}

.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); }
.jes-event-status-signup        { background: color-mix(in srgb, #e0a500 18%, transparent); color: #b8881e; border: 1px solid color-mix(in srgb, #e0a500 40%, transparent); }
.jes-event-status-signup_closed { background: color-mix(in srgb, #c77d2e 18%, transparent); color: #c77d2e; border: 1px solid color-mix(in srgb, #c77d2e 40%, transparent); }
.jes-event-status-completed     { background: color-mix(in srgb, #6b6b8a 18%, transparent); color: #6b6b8a; border: 1px solid color-mix(in srgb, #6b6b8a 40%, transparent); }
.jes-event-status-cancelled     { background: color-mix(in srgb, #b14b4b 18%, transparent); color: #b14b4b; border: 1px solid color-mix(in srgb, #b14b4b 40%, transparent); text-decoration: line-through; }

/* -- 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;
    }
}
