/* WCIS OpenDays — Phase 5A Calendar Engine (rebuild)
   Scoped to .wcis-od-calwrap so themes don’t break the layout.
*/

.wcis-od-calwrap{max-width:1180px;margin:0 auto;padding:18px 14px;}
.wcis-od-calwrap, .wcis-od-calwrap *{box-sizing:border-box;}
.wcis-od-calwrap a{text-decoration:none;}

.wcis-od-calwrap .wcis-od__h1{font-size:46px;line-height:1.1;margin:0 0 10px;}
.wcis-od-calwrap .wcis-od__sub{color:#64748b;margin:0 0 14px;font-size:14px;}

.wcis-od-calwrap .wcis-od__tabs{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 16px;}
.wcis-od-calwrap .wcis-od__tab{display:inline-flex;align-items:center;gap:8px;border:1px solid #cbd5e1;background:#fff;border-radius:999px;padding:8px 12px;font-weight:600;color:#0f172a;}
.wcis-od-calwrap .wcis-od__tab.is-active{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.15);}

.wcis-od-calwrap .wcis-od__panel{border:1px solid #e2e8f0;background:#fff;border-radius:14px;padding:14px;box-shadow:0 8px 24px rgba(2,6,23,.06);}

/* Filter bar (public calendar) — matches the “beautiful” horizontal layout */
.wcis-od-calwrap .wcis-od__filters{margin:10px 0 14px;}
/* Date range row (Agenda/Week/Day) */
.wcis-od-calwrap .wcis-od__daterow{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin:0 0 12px;}
.wcis-od-calwrap .wcis-od__datefield{display:flex;flex-direction:column;gap:4px;}
.wcis-od-calwrap .wcis-od__datefield label{font-size:12px;color:#64748b;font-weight:700;}
.wcis-od-calwrap .wcis-od__datefield input{height:44px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px;background:#fff;min-width:170px;}
.wcis-od-calwrap .wcis-od__datefield input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.15);}
.wcis-od-calwrap .wcis-od__filterrow{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.wcis-od-calwrap .wcis-od__filterrow input,
.wcis-od-calwrap .wcis-od__filterrow select{height:44px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px;background:#fff;min-width:140px;}
.wcis-od-calwrap .wcis-od__filterrow input:focus,
.wcis-od-calwrap .wcis-od__filterrow select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.15);}

/* sizes */
.wcis-od-calwrap .wcis-od__filterrow input[name="q"]{flex:1 1 320px;min-width:260px;}
.wcis-od-calwrap .wcis-od__filterrow select[name="school"]{flex:0 0 200px;}
.wcis-od-calwrap .wcis-od__filterrow input[name="location"]{flex:0 0 180px;}
.wcis-od-calwrap .wcis-od__filterrow input[name="course"]{flex:0 0 200px;}
.wcis-od-calwrap .wcis-od__filterrow select[name="format"]{flex:0 0 170px;}
.wcis-od-calwrap .wcis-od__filterrow select[name="level"]{flex:0 0 160px;}

/* Autocomplete dropdown (dark list like the previous working build) */
.wcis-od-calwrap .wcis-od__acwrap{position:relative;flex:0 0 auto;}
.wcis-od-calwrap .wcis-od__acwrap.is-location{flex:0 0 180px;}
.wcis-od-calwrap .wcis-od__acwrap.is-course{flex:0 0 200px;}
.wcis-od-calwrap .wcis-od__acwrap input{width:100%;}
.wcis-od-calwrap .wcis-od__acmenu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#111827;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:6px;box-shadow:0 14px 38px rgba(2,6,23,.25);z-index:9999;max-height:260px;overflow:auto;}
.wcis-od-calwrap .wcis-od__acitem{display:block;width:100%;text-align:left;border:0;background:transparent;color:#fff;padding:6px 8px;border-radius:10px;cursor:pointer;font-size:13px;line-height:1.25;}
.wcis-od-calwrap .wcis-od__acitem:hover{background:rgba(255,255,255,.10);}

.wcis-od-calwrap .wcis-od__btn{display:inline-flex;align-items:center;justify-content:center;height:42px;padding:0 14px;border-radius:10px;border:1px solid #cbd5e1;background:#0f172a;color:#fff;font-weight:700;cursor:pointer;}
.wcis-od-calwrap .wcis-od__btn.secondary{background:#fff;color:#0f172a;}
.wcis-od-calwrap .wcis-od__btn:disabled{opacity:.55;cursor:not-allowed;}

.wcis-od-calwrap .wcis-od__toolbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:12px 0 10px;flex-wrap:wrap;}
.wcis-od-calwrap .wcis-od__title{font-size:18px;font-weight:800;}
.wcis-od-calwrap .wcis-od__nav{display:flex;gap:10px;align-items:center;}

/* Month nav (Monthly view)
   Keep Prev and Next on the edges with the month title centered.
   This prevents the arrows/buttons from squeezing or pushing the title on any screen size. */
.wcis-od-calwrap .wcis-od__monthnav{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;margin:10px 0 16px;}
.wcis-od-calwrap .wcis-od__monthtitle{justify-self:center;text-align:center;font-weight:900;font-size:22px;line-height:1.1;}
.wcis-od-calwrap .wcis-od__monthnav .wcis-od__smallbtn{white-space:nowrap;}

.wcis-od-calwrap .wcis-od__monthgrid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;}
.wcis-od-calwrap .wcis-od__dow{font-size:12px;color:#64748b;text-align:center;padding:8px 0;}
.wcis-od-calwrap .wcis-od__day{min-height:110px;border:1px solid #e2e8f0;border-radius:12px;padding:8px;background:#fff;display:flex;flex-direction:column;gap:6px;}
.wcis-od-calwrap .wcis-od__day.is-other{opacity:.45;}
.wcis-od-calwrap .wcis-od__daynum{font-size:12px;font-weight:800;color:#0f172a;}
.wcis-od-calwrap .wcis-od__event{display:block;border-left:3px solid #2563eb;padding:6px 8px;border-radius:8px;background:#f8fafc;color:#0f172a;font-size:12px;line-height:1.25;}
.wcis-od-calwrap .wcis-od__event small{display:block;color:#64748b;margin-top:2px;}

.wcis-od-calwrap .wcis-od__list{display:flex;flex-direction:column;gap:10px;margin-top:8px;}
.wcis-od-calwrap .wcis-od__listitem{display:flex;justify-content:space-between;gap:14px;border:1px solid #e2e8f0;border-radius:14px;padding:12px;background:#fff;}
.wcis-od-calwrap .wcis-od__listitem .meta{color:#64748b;font-size:12px;margin-top:4px;}
.wcis-od-calwrap .wcis-od__listitem .title{font-weight:800;font-size:14px;color:#0f172a;}
.wcis-od-calwrap .wcis-od__badge{display:inline-flex;align-items:center;gap:6px;border:1px solid #cbd5e1;border-radius:999px;padding:6px 10px;font-size:12px;color:#0f172a;background:#fff;white-space:nowrap;height:30px;}

/* Card pagination (Agenda / Weekly / Daily) */
.wcis-od-calwrap .wcis-od__pager{display:flex;align-items:center;justify-content:center;gap:12px;margin:18px 0 6px;}
.wcis-od-calwrap .wcis-od__pagerinfo{font-size:13px;color:#64748b;font-weight:700;}
.wcis-od-calwrap .wcis-od__pagerbtn{display:inline-flex;align-items:center;justify-content:center;height:38px;padding:0 12px;border-radius:10px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;font-weight:800;}
.wcis-od-calwrap .wcis-od__pagerbtn:hover{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12);}
.wcis-od-calwrap .wcis-od__pagerbtn.is-disabled{opacity:.45;pointer-events:none;}

/* Hover preview card (Monthly view) */
.wcis-od-hovercard{position:fixed;left:0;top:0;z-index:999999;display:none;width:320px;max-width:calc(100vw - 24px);background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 18px 50px rgba(15,23,42,.18);overflow:hidden;}
.wcis-od-hovercard.is-open{display:block;}
.wcis-od-hovercard .hc-media{height:170px;background:#f1f5f9;overflow:hidden;}
.wcis-od-hovercard .hc-media img{display:block;width:100%;height:100%;object-fit:cover;}
.wcis-od-hovercard .hc-body{padding:12px 14px;}
.wcis-od-hovercard .hc-dt{font-weight:800;font-size:12px;color:#0f172a;margin:0 0 6px 0;}
.wcis-od-hovercard .hc-title{font-weight:900;font-size:15px;line-height:1.25;color:#0f172a;margin:0 0 6px 0;}
.wcis-od-hovercard .hc-ex{font-size:12px;line-height:1.35;color:#475569;margin:0 0 10px 0;}
.wcis-od-hovercard .hc-meta{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 10px 0;}
.wcis-od-hovercard .hc-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid #e2e8f0;border-radius:999px;padding:5px 9px;font-size:11px;color:#0f172a;background:#fff;}
.wcis-od-hovercard .hc-actions{display:flex;align-items:center;justify-content:flex-start;gap:10px;}
.wcis-od-hovercard .hc-link{display:inline-flex;align-items:center;justify-content:center;height:36px;padding:0 12px;border-radius:12px;background:#2563eb;color:#fff;font-weight:900;font-size:12px;text-decoration:none;}
.wcis-od-hovercard .hc-link:hover{filter:brightness(.95);}

/* Make chips look interactive */
.wcis-od-calwrap a.wcis-od__eventchip{cursor:pointer;}

/* Monthly chips: two-line label (Title / Date • Time) */
.wcis-od-calwrap a.wcis-od__eventchip{display:block;}
.wcis-od-calwrap a.wcis-od__eventchip .wcis-od__chip-title{display:block;font-weight:800;line-height:1.2;}
.wcis-od-calwrap a.wcis-od__eventchip .wcis-od__chip-meta{display:block;margin-top:4px;font-size:12px;font-weight:700;color:#64748b;line-height:1.15;}

@media (max-width: 980px){
  .wcis-od-calwrap .wcis-od__acwrap.is-location,
  .wcis-od-calwrap .wcis-od__acwrap.is-course,
  .wcis-od-calwrap .wcis-od__filterrow input[name="location"],
  .wcis-od-calwrap .wcis-od__filterrow input[name="course"],
  .wcis-od-calwrap .wcis-od__filterrow select[name="school"],
  .wcis-od-calwrap .wcis-od__filterrow select[name="format"],
  .wcis-od-calwrap .wcis-od__filterrow select[name="level"]{flex:1 1 180px;}
}
@media (max-width: 560px){
  .wcis-od-calwrap{padding:14px 10px;}
  .wcis-od-calwrap .wcis-od__h1{font-size:34px;}
  .wcis-od-calwrap .wcis-od__filterrow{gap:10px;}
  .wcis-od-calwrap .wcis-od__filterrow input,
  .wcis-od-calwrap .wcis-od__filterrow select{flex:1 1 100%;min-width:0;}

  /* Month header: keep date on one side and arrows together on the other.
     Prevent wrapping which currently makes Prev/Next stack and "press" the date. */
  .wcis-od-calwrap .wcis-od__toolbar{
    flex-wrap:nowrap;
    align-items:center;
  }
  .wcis-od-calwrap .wcis-od__title{
    flex:1 1 auto;
    min-width:0;
  }
  .wcis-od-calwrap .wcis-od__nav{
    flex:0 0 auto;
    flex-wrap:nowrap;
    gap:8px;
  }
  .wcis-od-calwrap .wcis-od__nav a,
  .wcis-od-calwrap .wcis-od__nav button{
    white-space:nowrap;
  }

  .wcis-od-calwrap .wcis-od__monthgrid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .wcis-od-calwrap .wcis-od__dow{display:none;}
}


.wcis-od-calwrap{--wcis-od-card-img-h:170px;}
