/* =============================================================================
   JMA Events Manager — Public Stylesheet  v1.1.1
   ============================================================================= */

/* ── Design Tokens ─────────────────────────────────────────────────────────── */
:root {
  --jma-bg:           #0a0e1a;
  --jma-surface:      #111827;
  --jma-surface-2:    #1c2434;
  --jma-border:       #1e2d45;
  --jma-accent:       #0072ce;
  --jma-accent-light: #338ef7;
  --jma-accent-hover: #005ba5;
  --jma-red:          #e63329;
  --jma-text:         #f0f4ff;
  --jma-text-muted:   #8da3c0;
  --jma-text-dim:     #4a6080;
  --jma-radius:       6px;
  --jma-radius-lg:    12px;
  --jma-shadow:       0 4px 24px rgba(0,0,0,.45);
  --jma-font:         'Inter', 'Helvetica Neue', Arial, sans-serif;
  --jma-transition:   0.22s ease;
}

/* ── Wrapper ────────────────────────────────────────────────────────────────── */
.jma-events-wrap {
  font-family: var(--jma-font);
  color:        var(--jma-text);
  margin:       2rem 0;
}

/* ── Card Grid ──────────────────────────────────────────────────────────────── */
.jma-events-grid {
  display:               grid;
  gap:                   1.5rem;
  grid-template-columns: 1fr;
}
.jma-cols-2 { grid-template-columns: repeat(2, 1fr); }
.jma-cols-3 { grid-template-columns: repeat(3, 1fr); }
.jma-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
  .jma-cols-3, .jma-cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 580px) {
  .jma-cols-2, .jma-cols-3, .jma-cols-4 { grid-template-columns: 1fr; }
}

/* ── Event Card ─────────────────────────────────────────────────────────────── */
.jma-event-card {
  background:     var(--jma-surface);
  border:         1px solid var(--jma-border);
  border-radius:  var(--jma-radius-lg);
  overflow:       hidden;
  cursor:         pointer;
  transition:     transform var(--jma-transition),
                  box-shadow var(--jma-transition),
                  border-color var(--jma-transition);
  display:        flex;
  flex-direction: column;
}
.jma-event-card:hover,
.jma-event-card:focus {
  transform:    translateY(-4px);
  box-shadow:   var(--jma-shadow), 0 0 0 2px var(--jma-accent);
  border-color: var(--jma-accent);
  outline:      none;
}
.jma-event-card.jma-event-past { opacity: .65; }

/* Thumbnail */
.jma-event-thumb { overflow: hidden; height: 180px; }
.jma-event-thumb img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.4s ease;
}
.jma-event-card:hover .jma-event-thumb img { transform: scale(1.04); }

/* Card body */
.jma-event-card-body {
  padding:        1.25rem 1.25rem 1.5rem;
  flex:           1;
  display:        flex;
  flex-direction: column;
  gap:            .65rem;
}

/* ── Type badges — IN FLOW (v1.1.1 fix, was position:absolute) ────────────── */
/* Badges now live inside .jma-event-card-body as the first child.
   They wrap naturally and never overlap the date badge or title. */
.jma-event-types {
  display:    flex;
  flex-wrap:  wrap;
  gap:        5px;
  /* No position:absolute, no top/left — purely in-flow */
}
.jma-event-type-badge {
  background:     var(--jma-accent);
  color:          #fff;
  font-size:      0.67rem;
  font-weight:    700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding:        3px 9px;
  border-radius:  3px;
  white-space:    nowrap;
  line-height:    1.4;
}

/* Date badge */
.jma-event-date-badge {
  display:        inline-flex;
  flex-direction: column;
  align-items:    center;
  background:     var(--jma-accent);
  color:          #fff;
  border-radius:  var(--jma-radius);
  padding:        6px 14px;
  line-height:    1;
  align-self:     flex-start;
}
.jma-date-month {
  font-size:      0.65rem;
  font-weight:    700;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.jma-date-day {
  font-size:   1.6rem;
  font-weight: 800;
  margin-top:  2px;
}

/* Title */
.jma-event-title {
  font-size:   1.05rem;
  font-weight: 700;
  color:       var(--jma-text);
  margin:      0;
  line-height: 1.3;
}

/* Meta row */
.jma-event-meta-row {
  display:        flex;
  flex-direction: column;
  gap:            .35rem;
}
.jma-meta-item {
  display:     flex;
  align-items: center;
  gap:         6px;
  font-size:   .8rem;
  color:       var(--jma-text-muted);
}
.jma-meta-item svg {
  width: 13px; height: 13px;
  fill:  var(--jma-accent-light);
  flex-shrink: 0;
}

/* Excerpt */
.jma-event-excerpt {
  font-size:          .85rem;
  color:              var(--jma-text-muted);
  margin:             0;
  line-height:        1.55;
  flex:               1;
  display:            -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:           hidden;
}

/* Actions */
.jma-event-actions {
  display:    flex;
  gap:        .75rem;
  flex-wrap:  wrap;
  margin-top: auto;
  padding-top: .25rem;
}

/* ── Buttons ────────────────────────────────────────────────────────────────── */
.jma-btn {
  display:        inline-flex;
  align-items:    center;
  gap:            6px;
  font-family:    var(--jma-font);
  font-size:      .78rem;
  font-weight:    700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding:        9px 20px;
  border-radius:  var(--jma-radius);
  border:         none;
  cursor:         pointer;
  transition:     background var(--jma-transition), transform var(--jma-transition);
  text-decoration: none;
  white-space:    nowrap;
}
.jma-btn:focus  { outline: 2px solid var(--jma-accent-light); outline-offset: 2px; }
.jma-btn:active { transform: scale(.97); }

.jma-btn-details {
  background: var(--jma-surface-2);
  color:      var(--jma-text);
  border:     1px solid var(--jma-border);
}
.jma-btn-details:hover { background: var(--jma-border); color: var(--jma-text); }

.jma-btn-register {
  background: var(--jma-accent);
  color:      #fff;
}
.jma-btn-register:hover { background: var(--jma-accent-hover); color: #fff; }

.jma-btn-close {
  background: transparent;
  color:      var(--jma-text-muted);
  border:     1px solid var(--jma-border);
  padding:    6px 14px;
  font-size:  .75rem;
}
.jma-btn-close:hover { background: var(--jma-surface-2); color: var(--jma-text); }

/* ── No-events message ──────────────────────────────────────────────────────── */
.jma-no-events {
  padding:       2rem;
  text-align:    center;
  color:         var(--jma-text-muted);
  background:    var(--jma-surface);
  border:        1px solid var(--jma-border);
  border-radius: var(--jma-radius-lg);
}

/* ── Modal ──────────────────────────────────────────────────────────────────── */
.jma-modal-overlay {
  position:        fixed;
  inset:           0;
  background:      rgba(5,10,20,.82);
  backdrop-filter: blur(6px);
  z-index:         99990;
  display:         flex;
  align-items:     center;
  justify-content: center;
  padding:         1rem;
  opacity:         0;
  transition:      opacity .25s ease;
  pointer-events:  none;
}
.jma-modal-overlay.jma-modal-open {
  opacity:        1;
  pointer-events: all;
}
.jma-modal {
  background:    var(--jma-surface);
  border:        1px solid var(--jma-border);
  border-radius: var(--jma-radius-lg);
  max-width:     720px;
  width:         100%;
  max-height:    90vh;
  overflow-y:    auto;
  box-shadow:    var(--jma-shadow);
  transform:     translateY(30px) scale(.97);
  transition:    transform .28s cubic-bezier(.22,.68,0,1.2);
}
.jma-modal-overlay.jma-modal-open .jma-modal { transform: translateY(0) scale(1); }

.jma-modal-header {
  position:      relative;
  background:    var(--jma-surface-2);
  border-bottom: 1px solid var(--jma-border);
  overflow:      hidden;
}
.jma-modal-thumb  { width:100%; max-height:240px; object-fit:cover; display:block; }
.jma-modal-header-inner { padding: 1.5rem 1.75rem 1.25rem; }
.jma-modal-types  { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:.75rem; }
.jma-modal-title  { font-size:1.5rem; font-weight:800; color:var(--jma-text); margin:0; line-height:1.25; }

.jma-modal-close {
  position:      absolute; top:14px; right:14px;
  background:    rgba(10,14,26,.7);
  border:        1px solid var(--jma-border);
  border-radius: 50%;
  color:         var(--jma-text);
  width:34px; height:34px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:1.1rem;
  transition: background var(--jma-transition);
}
.jma-modal-close:hover { background: var(--jma-red); }

.jma-modal-body {
  padding:        1.5rem 1.75rem 2rem;
  display:        flex;
  flex-direction: column;
  gap:            1.25rem;
}
.jma-modal-meta {
  display:       flex;
  flex-wrap:     wrap;
  gap:           .85rem 2rem;
  padding:       1rem 1.25rem;
  background:    var(--jma-surface-2);
  border:        1px solid var(--jma-border);
  border-radius: var(--jma-radius);
}
.jma-modal-meta-item {
  display:     flex;
  align-items: center;
  gap:         8px;
  font-size:   .85rem;
  color:       var(--jma-text-muted);
}
.jma-modal-meta-item svg  { width:15px; height:15px; fill:var(--jma-accent-light); flex-shrink:0; }
.jma-modal-meta-item strong { color:var(--jma-text); font-weight:600; }
.jma-modal-content { font-size:.9rem; line-height:1.7; color:var(--jma-text-muted); }
.jma-modal-content p { margin:0 0 .75rem; }
.jma-modal-content a { color:var(--jma-accent-light); }
.jma-modal-footer {
  display:     flex;
  gap:         .75rem;
  flex-wrap:   wrap;
  padding-top: .5rem;
  border-top:  1px solid var(--jma-border);
}
.jma-modal-loading { text-align:center; padding:3rem; color:var(--jma-text-muted); }

/* ── Spinner ────────────────────────────────────────────────────────────────── */
.jma-spinner {
  display:        inline-block;
  width:          36px; height: 36px;
  border:         3px solid var(--jma-border);
  border-top-color: var(--jma-accent);
  border-radius:  50%;
  animation:      jma-spin .7s linear infinite;
  margin-bottom:  1rem;
}
@keyframes jma-spin { to { transform: rotate(360deg); } }

/* ── Calendar ───────────────────────────────────────────────────────────────── */
.jma-calendar-wrap {
  background:    var(--jma-surface);
  border:        1px solid var(--jma-border);
  border-radius: var(--jma-radius-lg);
  overflow:      hidden;
}
.jma-calendar-nav {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         1rem 1.5rem;
  background:      var(--jma-surface-2);
  border-bottom:   1px solid var(--jma-border);
}
.jma-cal-title    { font-size:1.1rem; font-weight:700; color:var(--jma-text); margin:0; }
.jma-cal-nav-btn  { color:var(--jma-accent-light); text-decoration:none; font-size:1.3rem; padding:4px 12px; border-radius:var(--jma-radius); transition:background var(--jma-transition); }
.jma-cal-nav-btn:hover { background:var(--jma-border); }
.jma-calendar-grid { display:grid; grid-template-columns:repeat(7,1fr); border-left:1px solid var(--jma-border); border-top:1px solid var(--jma-border); }
.jma-cal-header-cell { padding:.6rem .4rem; text-align:center; font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--jma-text-muted); background:var(--jma-surface-2); border-right:1px solid var(--jma-border); border-bottom:1px solid var(--jma-border); }
.jma-cal-cell { min-height:90px; padding:.5rem .4rem; border-right:1px solid var(--jma-border); border-bottom:1px solid var(--jma-border); }
.jma-cal-cell.jma-cal-empty  { background:rgba(0,0,0,.15); }
.jma-cal-cell.jma-cal-today  { background:rgba(0,114,206,.08); }
.jma-cal-cell.jma-cal-today .jma-cal-day-num { background:var(--jma-accent); color:#fff; border-radius:50%; width:24px; height:24px; display:flex; align-items:center; justify-content:center; }
.jma-cal-day-num  { font-size:.8rem; font-weight:600; color:var(--jma-text-muted); display:block; margin-bottom:.3rem; }
.jma-cal-events   { display:flex; flex-direction:column; gap:3px; }
.jma-cal-event-pill { background:var(--jma-accent); color:#fff; border:none; border-radius:3px; font-size:.68rem; font-weight:600; padding:2px 6px; cursor:pointer; text-align:left; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; width:100%; transition:background var(--jma-transition); }
.jma-cal-event-pill:hover { background:var(--jma-accent-hover); }

/* ── Filter Bar ─────────────────────────────────────────────────────────────── */
.jma-events-filtered-wrap { display:flex; flex-direction:column; gap:1.5rem; }

.jma-filter-bar {
  display:       flex;
  flex-wrap:     wrap;
  align-items:   center;
  gap:           .85rem;
  padding:       1rem 1.25rem;
  background:    var(--jma-surface);
  border:        1px solid var(--jma-border);
  border-radius: var(--jma-radius-lg);
}

/* Search */
.jma-filter-search-wrap { position:relative; flex:1 1 200px; min-width:160px; max-width:320px; }
.jma-filter-search {
  width:100%; background:var(--jma-surface-2); border:1px solid var(--jma-border);
  border-radius:var(--jma-radius); color:var(--jma-text); font-family:var(--jma-font);
  font-size:.85rem; padding:8px 14px 8px 36px; outline:none; box-sizing:border-box;
  transition:border-color var(--jma-transition), box-shadow var(--jma-transition);
}
.jma-filter-search::placeholder { color:var(--jma-text-dim); }
.jma-filter-search:focus { border-color:var(--jma-accent); box-shadow:0 0 0 3px rgba(0,114,206,.2); }
.jma-search-icon { position:absolute; left:10px; top:50%; transform:translateY(-50%); width:14px; height:14px; fill:var(--jma-text-dim); pointer-events:none; }

/* Filter buttons */
.jma-filter-buttons { display:flex; flex-wrap:wrap; gap:.5rem; flex:1 1 auto; }

.jma-filter-btn {
  display:        inline-flex;
  align-items:    center;
  gap:            6px;
  font-family:    var(--jma-font);
  font-size:      .78rem;
  font-weight:    700;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding:        7px 16px;
  border-radius:  var(--jma-radius);
  border:         1px solid var(--jma-border);
  background:     var(--jma-surface-2);
  color:          var(--jma-text-muted);
  cursor:         pointer;
  white-space:    nowrap;
  transition:     background var(--jma-transition), color var(--jma-transition),
                  border-color var(--jma-transition), box-shadow var(--jma-transition),
                  transform .12s ease;
}
.jma-filter-btn:hover  { background:var(--jma-border); color:var(--jma-text); border-color:var(--jma-accent); }
.jma-filter-btn:active { transform:scale(.96); }
.jma-filter-btn:focus  { outline:2px solid var(--jma-accent-light); outline-offset:2px; }

.jma-filter-btn.jma-filter-active {
  background:   var(--jma-accent);
  color:        #fff;
  border-color: var(--jma-accent);
  box-shadow:   0 0 0 3px rgba(0,114,206,.25);
}
.jma-filter-btn.jma-filter-active:hover { background:var(--jma-accent-hover); border-color:var(--jma-accent-hover); }

.jma-filter-count {
  background:    rgba(255,255,255,.18);
  color:         inherit;
  font-size:     .68rem;
  font-weight:   800;
  padding:       1px 6px;
  border-radius: 20px;
  line-height:   1.4;
  min-width:     18px;
  text-align:    center;
}
.jma-filter-btn:not(.jma-filter-active) .jma-filter-count { background:var(--jma-border); color:var(--jma-text-dim); }

/* Results + loading */
.jma-filter-results { position:relative; min-height:200px; }
.jma-filter-spinner {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(10,14,26,.55); backdrop-filter:blur(3px);
  border-radius:var(--jma-radius-lg);
  opacity:0; pointer-events:none; transition:opacity .2s ease; z-index:10;
}
.jma-filter-results.jma-loading .jma-filter-spinner { opacity:1; pointer-events:all; }
.jma-filter-results-inner { transition:opacity .2s ease; }
.jma-filter-results.jma-loading .jma-filter-results-inner { opacity:.3; }

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width:640px) {
  .jma-filter-bar    { padding:.75rem; gap:.6rem; }
  .jma-filter-btn    { font-size:.72rem; padding:6px 12px; }
  .jma-filter-search-wrap { max-width:100%; }
  .jma-cal-cell      { min-height:56px; padding:.3rem .2rem; }
  .jma-cal-event-pill{ font-size:.6rem; padding:1px 4px; }
  .jma-cal-header-cell{ font-size:.6rem; padding:.4rem .2rem; }
}
