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

/* v3.1 Open Days Calendar search/filter redesign */
.wcis-od-calwrap{max-width:1220px;}
.wcis-od-calwrap .wcis-od__titlebar{display:flex;flex-direction:column;align-items:flex-start;gap:16px;margin:0 0 18px;}
.wcis-od-calwrap .wcis-od__h2{font-size:42px;line-height:1.08;margin:0;color:#0f172a;font-weight:900;letter-spacing:-.035em;}
.wcis-od-calwrap .wcis-od__tabs{display:inline-flex;gap:0;flex-wrap:nowrap;margin:0;border:1px solid #dbe5f1;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 8px 24px rgba(15,23,42,.04);}
.wcis-od-calwrap .wcis-od__tab{border:0;border-right:1px solid #dbe5f1;border-radius:0;padding:13px 24px;font-size:15px;font-weight:800;background:#fff;color:#1e293b;box-shadow:none;min-width:116px;justify-content:center;}
.wcis-od-calwrap .wcis-od__tab:last-child{border-right:0;}
.wcis-od-calwrap .wcis-od__tab.is-active{background:#f8fbff;color:#0b5be7;border-color:#dbe5f1;box-shadow:inset 0 0 0 1.5px #2563eb;}
.wcis-od-calwrap .wcis-od-modern-search{margin:0 0 18px;padding:24px 0 0;border-top:1px solid #e5eaf2;}
.wcis-od-calwrap .wcis-od__searchbar-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center;margin:0 0 14px;}
.wcis-od-calwrap .wcis-od__searchbox{position:relative;display:flex;align-items:center;min-height:58px;border:1px solid #d9e2ef;border-radius:999px;background:#fff;box-shadow:0 8px 22px rgba(15,23,42,.04);padding:0 86px 0 56px;}
.wcis-od-calwrap .wcis-od__searchbox .wcis-od__search-ico{position:absolute;left:24px;top:50%;transform:translateY(-50%);font-size:27px;line-height:1;color:#0f172a;opacity:.9;}
.wcis-od-calwrap .wcis-od__searchbox input[name="q"]{width:100%;height:56px;border:0!important;background:transparent!important;padding:0!important;font-size:17px;box-shadow:none!important;color:#0f172a;min-width:0;}
.wcis-od-calwrap .wcis-od__searchbox input[name="q"]::placeholder{color:#7c8798;opacity:1;}
.wcis-od-calwrap .wcis-od__search-submit{position:absolute;right:5px;top:50%;transform:translateY(-50%);height:48px;min-width:48px;border:0;border-radius:999px;background:#075ee8;color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 17px;font-weight:900;box-shadow:0 10px 20px rgba(7,94,232,.24);cursor:pointer;}
.wcis-od-calwrap .wcis-od__search-submit span{font-size:25px;line-height:1;}
.wcis-od-calwrap .wcis-od__search-submit strong{font-size:14px;}
.wcis-od-calwrap .wcis-od__filter-toggle{height:58px;border:1px solid #d9e2ef;border-radius:16px;background:#fff;color:#0f172a;padding:0 22px;display:inline-flex;align-items:center;gap:12px;font-weight:900;font-size:15px;box-shadow:0 8px 22px rgba(15,23,42,.04);cursor:pointer;}
.wcis-od-calwrap .wcis-od__filter-toggle span{font-size:20px;transform:rotate(90deg);display:inline-block;}
.wcis-od-calwrap .wcis-od__filter-toggle i{font-style:normal;font-size:16px;transition:transform .18s ease;}
.wcis-od-calwrap .wcis-od__filter-toggle.is-open i{transform:rotate(180deg);}
.wcis-od-calwrap .wcis-od__advanced-panel{display:none;border:1px solid #dfe7f2;border-radius:16px;background:#fff;box-shadow:0 14px 36px rgba(15,23,42,.08);overflow:visible;margin-top:14px;position:relative;z-index:20;}
.wcis-od-calwrap .wcis-od__advanced-panel.is-open{display:block;}
.wcis-od-calwrap .wcis-od__advanced-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 24px 8px;}
.wcis-od-calwrap .wcis-od__advanced-title{display:flex;align-items:center;gap:14px;color:#0f172a;font-size:16px;font-weight:900;}
.wcis-od-calwrap .wcis-od__advanced-title span{font-size:20px;transform:rotate(90deg);display:inline-block;}
.wcis-od-calwrap .wcis-od__advanced-actions{display:flex;align-items:center;gap:18px;}
.wcis-od-calwrap .wcis-od__advanced-actions a{color:#075ee8;font-weight:800;font-size:14px;}
.wcis-od-calwrap .wcis-od__advanced-actions button{border:0;background:transparent;color:#0f172a;font-size:20px;cursor:pointer;}
.wcis-od-calwrap .wcis-od__advanced-date-row{display:flex;align-items:flex-end;gap:22px;flex-wrap:wrap;padding:18px 24px 6px;}
.wcis-od-calwrap .wcis-od__datefield-wide{min-width:360px;}
.wcis-od-calwrap .wcis-od__datepair{display:flex;align-items:center;gap:10px;border:1px solid #d9e2ef;border-radius:12px;height:46px;padding:0 12px;background:#fff;}
.wcis-od-calwrap .wcis-od__datepair input{border:0!important;min-width:130px;height:44px;padding:0!important;box-shadow:none!important;background:transparent;}
.wcis-od-calwrap .wcis-od__range-pills{display:inline-flex;align-items:center;border:1px solid #d9e2ef;border-radius:12px;overflow:hidden;background:#fff;height:46px;}
.wcis-od-calwrap .wcis-od__range-pills a,.wcis-od-calwrap .wcis-od__range-pills span{display:inline-flex;align-items:center;height:100%;padding:0 18px;font-weight:800;color:#334155;border-right:1px solid #eef2f7;font-size:14px;}
.wcis-od-calwrap .wcis-od__range-pills a:last-child,.wcis-od-calwrap .wcis-od__range-pills span:last-child{border-right:0;}
.wcis-od-calwrap .wcis-od__range-pills .is-active{background:#eef4ff;color:#075ee8;}
.wcis-od-calwrap .wcis-od__advanced-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px 24px;padding:22px 24px 28px;}
.wcis-od-calwrap .wcis-od__field{display:flex;flex-direction:column;gap:8px;position:relative;}
.wcis-od-calwrap .wcis-od__field span{font-size:13px;font-weight:900;color:#0f172a;}
.wcis-od-calwrap .wcis-od__field input,.wcis-od-calwrap .wcis-od__field select{height:46px;width:100%;border:1px solid #d9e2ef;border-radius:12px;background:#fff;padding:0 14px;color:#0f172a;font-size:14px;box-shadow:none;min-width:0;}
.wcis-od-calwrap .wcis-od__field input:focus,.wcis-od-calwrap .wcis-od__field select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.13);}
.wcis-od-calwrap .wcis-od__advanced-footer{display:flex;justify-content:flex-end;gap:14px;border-top:1px solid #eef2f7;padding:20px 24px 22px;background:#fff;}
.wcis-od-calwrap .wcis-od__apply{background:#075ee8;border-color:#075ee8;border-radius:10px;height:44px;padding:0 28px;}
.wcis-od-calwrap .wcis-od__btn.secondary{border-radius:10px;height:44px;padding:0 24px;}
.wcis-od-calwrap .wcis-od__acwrap.is-main-search{flex:1 1 auto;}
.wcis-od-calwrap .wcis-od__acwrap.is-main-search .wcis-od__acmenu{left:18px;right:18px;top:calc(100% + 8px);background:#fff;border:1px solid #dbe5f1;color:#0f172a;box-shadow:0 18px 42px rgba(15,23,42,.14);padding:8px;border-radius:16px;}
.wcis-od-calwrap .wcis-od__acwrap.is-main-search .wcis-od__acitem{color:#0f172a;background:transparent;font-weight:700;padding:10px 12px;}
.wcis-od-calwrap .wcis-od__acwrap.is-main-search .wcis-od__acitem:hover{background:#eef4ff;color:#075ee8;}
.wcis-od-calwrap .wcis-od__field.wcis-od__acwrap{flex:unset;}
.wcis-od-calwrap .wcis-od__field.wcis-od__acwrap .wcis-od__acmenu{background:#fff;border:1px solid #dbe5f1;box-shadow:0 14px 34px rgba(15,23,42,.14);}
.wcis-od-calwrap .wcis-od__field.wcis-od__acwrap .wcis-od__acitem{color:#0f172a;font-weight:700;}
.wcis-od-calwrap .wcis-od__field.wcis-od__acwrap .wcis-od__acitem:hover{background:#eef4ff;color:#075ee8;}

/* WCIS dropdown overflow fix: keep autocomplete menus free-flowing above the filter card/footer. */
.wcis-od-calwrap .wcis-od-modern-search,
.wcis-od-calwrap .wcis-od-modern-search form,
.wcis-od-calwrap .wcis-od__advanced-panel,
.wcis-od-calwrap .wcis-od__advanced-grid{overflow:visible!important;}
.wcis-od-calwrap .wcis-od__field.wcis-od__acwrap{position:relative;z-index:30;}
.wcis-od-calwrap .wcis-od__field.wcis-od__acwrap:focus-within{z-index:99999;}
.wcis-od-calwrap .wcis-od__field.wcis-od__acwrap .wcis-od__acmenu{position:absolute!important;top:calc(100% + 8px)!important;left:0!important;right:0!important;z-index:999999!important;max-height:320px;overflow-y:auto;overflow-x:hidden;}
.wcis-od-calwrap .wcis-od__advanced-footer{position:relative;z-index:1;}
@media (max-width: 900px){
  .wcis-od-calwrap .wcis-od__tabs{width:100%;overflow-x:auto;}
  .wcis-od-calwrap .wcis-od__tab{min-width:100px;padding:12px 18px;}
  .wcis-od-calwrap .wcis-od__searchbar-row{grid-template-columns:1fr;gap:12px;}
  .wcis-od-calwrap .wcis-od__filter-toggle{width:100%;justify-content:center;}
  .wcis-od-calwrap .wcis-od__advanced-grid{grid-template-columns:1fr;}
  .wcis-od-calwrap .wcis-od__datefield-wide{min-width:0;width:100%;}
  .wcis-od-calwrap .wcis-od__datepair{height:auto;min-height:46px;flex-wrap:wrap;padding:6px 12px;}
  .wcis-od-calwrap .wcis-od__range-pills{width:100%;overflow-x:auto;}
}
@media (max-width:560px){
  .wcis-od-calwrap .wcis-od__h2{font-size:34px;}
  .wcis-od-calwrap .wcis-od__searchbox{padding-left:48px;padding-right:62px;}
  .wcis-od-calwrap .wcis-od__search-submit strong{display:none;}
  .wcis-od-calwrap .wcis-od__advanced-head,.wcis-od-calwrap .wcis-od__advanced-date-row,.wcis-od-calwrap .wcis-od__advanced-grid,.wcis-od-calwrap .wcis-od__advanced-footer{padding-left:16px;padding-right:16px;}
}


/* v3.2 compact active pill rebuild */


/* Compact sizing + pill active state rebuild */
.wcis-od-calwrap{max-width:1180px!important;padding:18px 18px!important;}
.wcis-od-calwrap .wcis-od__titlebar{gap:12px!important;margin-bottom:14px!important;}
.wcis-od-calwrap .wcis-od__h2{font-size:36px!important;line-height:1.06!important;letter-spacing:-.04em!important;}
.wcis-od-calwrap .wcis-od__tabs{border:0!important;background:transparent!important;box-shadow:none!important;gap:10px!important;overflow:visible!important;border-radius:0!important;}
.wcis-od-calwrap .wcis-od__tab{min-width:0!important;height:42px!important;padding:0 18px!important;border:1px solid #d7e2f0!important;border-radius:999px!important;background:#fff!important;color:#0f172a!important;font-size:14px!important;font-weight:850!important;box-shadow:none!important;line-height:1!important;}
.wcis-od-calwrap .wcis-od__tab:last-child{border-right:1px solid #d7e2f0!important;}
.wcis-od-calwrap .wcis-od__tab.is-active{background:#fff!important;color:#0f172a!important;border-color:#2f6bff!important;box-shadow:0 0 0 3px rgba(37,99,235,.18), 0 6px 14px rgba(15,23,42,.06)!important;}
.wcis-od-calwrap .wcis-od-modern-search{padding-top:18px!important;margin-bottom:16px!important;}
.wcis-od-calwrap .wcis-od__searchbar-row{gap:12px!important;margin-bottom:12px!important;}
.wcis-od-calwrap .wcis-od__searchbox{min-height:50px!important;height:50px!important;padding:0 80px 0 46px!important;box-shadow:0 6px 18px rgba(15,23,42,.035)!important;}
.wcis-od-calwrap .wcis-od__searchbox .wcis-od__search-ico{left:19px!important;font-size:20px!important;}
.wcis-od-calwrap .wcis-od__searchbox input[name="q"]{height:48px!important;font-size:15px!important;}
.wcis-od-calwrap .wcis-od__search-submit{height:40px!important;right:5px!important;padding:0 15px!important;gap:7px!important;box-shadow:0 8px 16px rgba(7,94,232,.20)!important;}
.wcis-od-calwrap .wcis-od__search-submit span{font-size:19px!important;}
.wcis-od-calwrap .wcis-od__search-submit strong{font-size:13px!important;}
.wcis-od-calwrap .wcis-od__filter-toggle{height:50px!important;border-radius:14px!important;padding:0 18px!important;gap:10px!important;font-size:14px!important;box-shadow:0 6px 18px rgba(15,23,42,.035)!important;}
.wcis-od-calwrap .wcis-od__filter-toggle svg,.wcis-od-calwrap .wcis-od__advanced-title svg{width:18px!important;height:18px!important;}
.wcis-od-calwrap .wcis-od__advanced-panel{border-radius:15px!important;box-shadow:0 10px 28px rgba(15,23,42,.06)!important;margin-top:12px!important;}
.wcis-od-calwrap .wcis-od__advanced-head{padding:20px 22px 6px!important;}
.wcis-od-calwrap .wcis-od__advanced-title{font-size:15px!important;gap:11px!important;}
.wcis-od-calwrap .wcis-od__advanced-date-row{padding:14px 22px 4px!important;gap:18px!important;}
.wcis-od-calwrap .wcis-od__datefield label,.wcis-od-calwrap .wcis-od__field span{font-size:12.5px!important;}
.wcis-od-calwrap .wcis-od__datefield-wide{min-width:340px!important;}
.wcis-od-calwrap .wcis-od__datepair{height:42px!important;border-radius:11px!important;}
.wcis-od-calwrap .wcis-od__datepair input{height:40px!important;font-size:14px!important;min-width:120px!important;}
.wcis-od-calwrap .wcis-od__range-pills{height:42px!important;border:0!important;background:transparent!important;gap:9px!important;overflow:visible!important;}
.wcis-od-calwrap .wcis-od__range-pills a,.wcis-od-calwrap .wcis-od__range-pills span{height:42px!important;padding:0 16px!important;border:1px solid #d7e2f0!important;border-radius:999px!important;background:#fff!important;color:#334155!important;font-size:13.5px!important;font-weight:850!important;text-decoration:none!important;box-shadow:none!important;}
.wcis-od-calwrap .wcis-od__range-pills .is-active{background:#fff!important;color:#0f172a!important;border-color:#2f6bff!important;box-shadow:0 0 0 3px rgba(37,99,235,.16), 0 5px 12px rgba(15,23,42,.055)!important;}
.wcis-od-calwrap .wcis-od__advanced-grid{gap:18px 22px!important;padding:18px 22px 24px!important;}
.wcis-od-calwrap .wcis-od__field{gap:7px!important;}
.wcis-od-calwrap .wcis-od__field input,.wcis-od-calwrap .wcis-od__field select{height:42px!important;border-radius:11px!important;font-size:13.5px!important;padding:0 13px!important;}
.wcis-od-calwrap .wcis-od__advanced-footer{padding:16px 22px 18px!important;gap:12px!important;}
.wcis-od-calwrap .wcis-od__btn,.wcis-od-calwrap .wcis-od__apply,.wcis-od-calwrap .wcis-od__btn.secondary{height:40px!important;border-radius:10px!important;padding:0 22px!important;font-size:13.5px!important;}
.wcis-od-calwrap .wcis-od__results-head{padding:18px 22px!important;border-radius:15px!important;}
.wcis-od-calwrap .wcis-od__results-head strong{font-size:18px!important;}
.wcis-od-calwrap .wcis-od__results-head span{font-size:13px!important;}
.wcis-od-calwrap .wcis-od__sort select{height:42px!important;border-radius:11px!important;font-size:13.5px!important;}
@media (max-width:900px){.wcis-od-calwrap .wcis-od__tabs{width:auto!important;max-width:100%!important;overflow-x:auto!important}.wcis-od-calwrap .wcis-od__tab{white-space:nowrap!important}.wcis-od-calwrap .wcis-od__datefield-wide{min-width:0!important;width:100%!important}.wcis-od-calwrap .wcis-od__range-pills{width:100%!important;overflow-x:auto!important;justify-content:flex-start!important}}
@media (max-width:560px){.wcis-od-calwrap .wcis-od__h2{font-size:30px!important}.wcis-od-calwrap .wcis-od__range-pills a,.wcis-od-calwrap .wcis-od__range-pills span{white-space:nowrap!important}}


/* WCIS Open Days: strict conditional location controls */
.wcis-od-location-hidden,
.wcis-od__field[hidden],
.wcis-od__advanced-grid [hidden] {
  display: none !important;
}


/* WCIS Open Days: ONE conditional location control only. */
.wcis-od-calwrap [data-wcis-city-filter],
.wcis-od-calwrap [data-wcis-borough-filter],
.wcis-od-calwrap .wcis-od-location-hidden,
.wcis-od-calwrap .wcis-od__field[hidden],
.wcis-od-calwrap .wcis-od__advanced-grid [hidden]{display:none!important;}

/* Smart location control */
.wcis-od-calwrap .wcis-od__geo-row{display:flex!important;align-items:center!important;gap:10px!important;margin:10px 0 0!important;flex-wrap:wrap!important}
.wcis-od-calwrap .wcis-od__geo-btn{height:38px!important;border:1px solid #d9e2ef!important;border-radius:999px!important;background:#fff!important;color:#0f172a!important;padding:0 14px!important;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important;font-size:13px!important;font-weight:750!important;display:inline-flex!important;align-items:center!important;gap:8px!important;box-shadow:0 8px 20px rgba(15,23,42,.04)!important;cursor:pointer!important}
.wcis-od-calwrap .wcis-od__geo-btn:hover,.wcis-od-calwrap .wcis-od__geo-btn.is-loading{border-color:#93c5fd!important;box-shadow:0 0 0 3px rgba(59,130,246,.12),0 8px 20px rgba(15,23,42,.04)!important;color:#075ee8!important}
.wcis-od-calwrap .wcis-od__geo-status{font-size:12.5px!important;font-weight:700!important;color:#64748b!important}
@media (max-width:560px){.wcis-od-calwrap .wcis-od__geo-btn{width:100%!important;justify-content:center!important}.wcis-od-calwrap .wcis-od__geo-status{width:100%!important;text-align:center!important}}

/* WCIS Open Days v3: body-level autocomplete layer.
   This fixes Course/Subject suggestions being clipped/covered by the filter card footer. */
body .wcis-od__acmenu.wcis-od__acmenu--floating{
  position:fixed!important;
  left:auto;
  right:auto;
  top:auto;
  z-index:2147483000!important;
  display:none;
  background:#fff!important;
  color:#0f172a!important;
  border:1px solid #dbe5f1!important;
  border-radius:16px!important;
  box-shadow:0 24px 60px rgba(15,23,42,.22)!important;
  padding:8px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  overscroll-behavior:contain;
}
body .wcis-od__acmenu.wcis-od__acmenu--floating .wcis-od__acitem{
  width:100%!important;
  display:block!important;
  text-align:left!important;
  border:0!important;
  background:transparent!important;
  color:#0f172a!important;
  font:800 14px/1.25 Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important;
  padding:12px 14px!important;
  border-radius:11px!important;
  cursor:pointer!important;
}
body .wcis-od__acmenu.wcis-od__acmenu--floating .wcis-od__acitem:hover,
body .wcis-od__acmenu.wcis-od__acmenu--floating .wcis-od__acitem:focus{
  background:#eef4ff!important;
  color:#075ee8!important;
  outline:none!important;
}
.wcis-od-calwrap .wcis-od__advanced-grid{position:relative!important;z-index:20!important;}
.wcis-od-calwrap .wcis-od__advanced-footer{position:relative!important;z-index:1!important;}


/* WCIS Open Days v3.3: fixed body autocomplete final layer.
   Menu is appended to <body>, can open upward near the panel footer, and is
   deliberately kept outside all filter-card overflow/stacking contexts. */
body > .wcis-od__acmenu.wcis-od__acmenu--floating{
  position:fixed!important;
  z-index:2147483647!important;
  min-height:0!important;
  max-width:min(520px,calc(100vw - 24px))!important;
  pointer-events:auto!important;
  transform:translateZ(0)!important;
}
body > .wcis-od__acmenu.wcis-od__acmenu--floating.is-upward{
  box-shadow:0 -24px 60px rgba(15,23,42,.18)!important;
}
.wcis-od-calwrap .wcis-od__advanced-footer{
  z-index:0!important;
}
.wcis-od-calwrap .wcis-od__field.wcis-od__acwrap:focus-within{
  z-index:2147483000!important;
}
