/* Viva Class Calendar — calendar.css v1.2.0 */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&family=Jost:wght@300;400;500;600&display=swap');

.vcc-wrap {
  --ink:      #1c1814;
  --mid:      #6b6259;
  --muted:    #a09890;
  --cream:    #faf7f3;
  --paper:    #fff;
  --border:   #ebe4dc;
  --rust:     #c45c3a;
  --rust-bg:  #fdf1ed;
  --sage:     #4a7c6b;
  --sage-bg:  #eef5f2;
  --gold:     #b8832a;
  --plum:     #6b4a82;
  --plum-bg:  #f5f0fa;
  --blue:     #3a6aaa;
  --blue-bg:  #eef3fa;
  --teal:     #2e7a8a;
  --teal-bg:  #eaf5f7;
  --pink:     #b84a6e;
  font-family: 'Jost', sans-serif;
  background: var(--cream);
  color: var(--ink);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 40px rgba(28,24,20,0.10);
  max-width: 1100px;
  margin: 0 auto;
}
.vcc-wrap * { box-sizing: border-box; }

/* ── Header ── */
.vcc-header {
  background: #852b33;
  padding: 22px 28px;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 14px;
}
.vcc-brand h2 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.7rem !important; font-weight: 600 !important;
  color: var(--cream) !important; margin: 0 !important; padding: 0 !important; border: none !important;
}
.vcc-brand p { font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.7); margin: 4px 0 0; }
.vcc-note { color: rgba(255,255,255,0.8); font-size: 0.78rem; background: rgba(255,255,255,0.12); padding: 9px 14px; border-radius: 8px; max-width: 280px; line-height: 1.5; }

/* ── Controls ── */
.vcc-controls {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 28px; background: var(--paper); border-bottom: 1px solid var(--border);
  flex-wrap: wrap; gap: 12px;
}
.vcc-nav { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.vcc-nav-btn {
  background: none !important; border: 1.5px solid var(--border) !important;
  border-radius: 8px !important; padding: 6px 12px !important;
  font-family: 'Jost', sans-serif !important; font-size: 0.82rem !important;
  cursor: pointer !important; color: var(--ink) !important;
  transition: all 0.15s !important; box-shadow: none !important;
}
.vcc-nav-btn:hover { border-color: var(--rust) !important; color: var(--rust) !important; }
.vcc-today-btn { border-color: var(--rust) !important; color: var(--rust) !important; }
.vcc-period {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem; font-weight: 600; min-width: 170px; text-align: center;
}
.vcc-toggle-group { display: flex; background: var(--border); border-radius: 9px; padding: 3px; gap: 2px; }
.vcc-toggle {
  padding: 6px 16px; border: none !important; border-radius: 7px !important;
  font-family: 'Jost', sans-serif !important; font-size: 0.82rem !important; font-weight: 500 !important;
  cursor: pointer !important; background: transparent !important; color: var(--mid) !important;
  transition: all 0.15s !important; box-shadow: none !important;
}
.vcc-toggle.active { background: var(--ink) !important; color: var(--cream) !important; }

/* ── Legend ── */
.vcc-legend { display: flex; gap: 14px; flex-wrap: wrap; padding: 10px 28px; border-bottom: 1px solid var(--border); background: var(--cream); }
.vcc-leg-item { display: flex; align-items: center; gap: 6px; font-size: 0.74rem; color: var(--mid); }
.vcc-leg-dot { width: 9px; height: 9px; border-radius: 3px; display: inline-block; }

/* ── Monthly grid ── */
.vcc-monthly-view { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.vcc-month-grid { display: grid; grid-template-columns: repeat(7, 1fr); min-width: 560px; }
.vcc-month-hdr {
  background: var(--cream); border-right: 1px solid var(--border);
  border-bottom: 2px solid var(--ink); padding: 8px;
  text-align: center; font-size: 0.68rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted);
}
.vcc-month-cell {
  border-right: 1px solid var(--border); border-bottom: 1px solid var(--border);
  min-height: 110px; padding: 7px 5px 5px; background: var(--paper);
  transition: background 0.12s;
}
.vcc-month-cell:hover { background: #fffcf9; }
.vcc-other-month { background: var(--cream); opacity: 0.6; }
.vcc-today-cell { border-top: 3px solid var(--rust); padding-top: 4px; }
.vcc-mdate {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem; font-weight: 600; line-height: 1; margin-bottom: 4px;
}
.vcc-today-num { color: var(--rust); }
.vcc-month-pill {
  display: block; border-radius: 4px; padding: 3px 5px;
  margin-bottom: 2px; font-size: 0.65rem; font-weight: 500;
  line-height: 1.3; text-decoration: none !important;
  transition: all 0.12s; cursor: pointer; overflow: hidden;
  white-space: nowrap; text-overflow: ellipsis;
}
.vcc-month-pill:hover { filter: brightness(0.92); transform: translateX(1px); }
.pill-t { font-weight: 600; font-size: 0.62rem; letter-spacing: 0.03em; }
.vcc-more { font-size: 0.64rem; color: #fff !important; font-weight: 600; padding: 2px 5px; background: #2e5490 !important; border: none; border-radius: 3px; width: 100%; text-align: left; cursor: pointer; margin-top: 1px; }
.vcc-more:hover { background: #1e3a6e !important; }

/* ── Weekly grid ── */
.vcc-scroll-wrap { overflow-x: auto; }
.vcc-week-grid { display: grid; grid-template-columns: 56px repeat(7,1fr); border-left: 1px solid var(--border); min-width: 560px; }
.vcc-corner { background: var(--cream); border-right: 1px solid var(--border); border-bottom: 2px solid var(--ink); }
.vcc-day-hdr { background: var(--cream); border-right: 1px solid var(--border); border-bottom: 2px solid var(--ink); padding: 10px 6px; text-align: center; }
.vcc-day-name { font-size: 0.68rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); }
.vcc-day-num { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 600; margin-top: 3px; }
.vcc-time-label { font-size: 0.68rem; color: var(--muted); padding: 4px 5px 0; text-align: right; border-right: 1px solid var(--border); border-bottom: 1px solid rgba(235,228,220,0.6); min-height: 50px; background: var(--cream); }
.vcc-time-cell { border-right: 1px solid var(--border); border-bottom: 1px solid rgba(235,228,220,0.6); min-height: 50px; padding: 2px; background: var(--paper); }
.vcc-pill {
  display: block; border-radius: 5px; padding: 4px 7px; font-size: 0.7rem;
  font-weight: 500; cursor: pointer; transition: all 0.14s; margin: 1px;
  text-decoration: none !important; line-height: 1.3;
}
.vcc-pill:hover { transform: translateY(-1px); box-shadow: 0 3px 12px rgba(0,0,0,0.14); }
.pill-name { font-weight: 600; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pill-time { font-size: 0.64rem; opacity: 0.8; display: block; }

/* ── Category colours ── */
.c-strength { background:#fdeee9; color:#8a3520; border-left:3px solid #c45c3a; }
.c-hiit     { background:#fdf5e6; color:#7a540a; border-left:3px solid #b8832a; }
.c-yoga     { background:#eaf4f0; color:#2e5447; border-left:3px solid #4a7c6b; }
.c-pilates  { background:#f3eef8; color:#4a2c62; border-left:3px solid #6b4a82; }
.c-pound    { background:#edf2fb; color:#1e4478; border-left:3px solid #3a6aaa; }
.c-rom      { background:#eaf5f7; color:#1a5060; border-left:3px solid #2e7a8a; }
.c-kids     { background:#faeef3; color:#7a1e42; border-left:3px solid #b84a6e; }
.c-express  { background:#fff0e8; color:#7a3010; border-left:3px solid #c06830; }

/* ── Footer ── */
.vcc-footer { text-align: center; padding: 16px 28px; border-top: 1px solid var(--border); font-size: 0.76rem; color: var(--muted); background: var(--cream); }
.vcc-footer a { color: var(--rust); text-decoration: none; }

/* ── Loading / Error ── */
.vcc-loading { padding: 48px; text-align: center; color: var(--muted); font-size: 0.9rem; background: var(--paper); }
.vcc-loading::before { content: ''; display: block; width: 32px; height: 32px; border: 3px solid var(--border); border-top-color: var(--rust); border-radius: 50%; margin: 0 auto 16px; animation: vcc-spin 0.8s linear infinite; }
@keyframes vcc-spin { to { transform: rotate(360deg); } }
.vcc-error { padding: 32px; text-align: center; color: var(--rust); font-size: 0.88rem; background: var(--rust-bg); }

/* ── Modal ── */
.vcc-modal-overlay {
  position: fixed; inset: 0; background: rgba(10,8,6,0.82);
  z-index: 99999; display: flex; align-items: center; justify-content: center;
  padding: 20px; opacity: 0; pointer-events: none;
  transition: opacity 0.2s; backdrop-filter: blur(8px);
}
.vcc-modal-overlay.open { opacity: 1; pointer-events: all; }
.vcc-modal {
  background: #ffffff; border-radius: 14px;
  max-width: 450px; width: 100%;
  box-shadow: 0 32px 100px rgba(0,0,0,0.55); overflow: hidden;
  transform: translateY(16px) scale(0.97); transition: transform 0.2s;
}
.vcc-modal-overlay.open .vcc-modal { transform: translateY(0) scale(1); }
.vcc-modal-stripe { height: 5px; background: var(--rust); }
.vcc-modal-inner { padding: 20px 24px 22px; position: relative; background: #ffffff; }
.vcc-modal-cat { font-size: 0.67rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--rust); margin-bottom: 5px; }
.vcc-modal-title { font-family: 'Cormorant Garamond', serif !important; font-size: 1.55rem !important; font-weight: 600 !important; color: var(--ink) !important; margin: 0 0 12px !important; padding: 0 !important; border: none !important; line-height: 1.1 !important; }
.vcc-modal-close { position: absolute; top: 14px; right: 16px; background: var(--cream) !important; border: none !important; border-radius: 50% !important; width: 28px; height: 28px; font-size: 0.88rem !important; cursor: pointer !important; color: var(--mid) !important; transition: all 0.14s !important; display: flex !important; align-items: center; justify-content: center; box-shadow: none !important; }
.vcc-modal-close:hover { background: var(--rust-bg) !important; color: var(--rust) !important; }
.vcc-modal-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 12px; }
.vcc-chip { font-size: 0.78rem; color: #6b6259; background: #f5f2ee; border-radius: 20px; padding: 4px 12px; }
.vcc-modal-desc { font-size: 0.85rem; line-height: 1.65; color: #6b6259; margin-bottom: 18px; min-height: 0; }
.vcc-modal-btns { display: flex; gap: 8px; }
.vcc-btn-book { flex: 1; background: #852b33 !important; color: #fff !important; border: none !important; border-radius: 9px !important; padding: 14px 18px !important; font-family: 'Jost', sans-serif !important; font-size: 0.92rem !important; font-weight: 600 !important; cursor: pointer !important; text-decoration: none !important; text-align: center !important; transition: all 0.17s !important; display: block !important; letter-spacing: 0.03em; }
.vcc-btn-book:hover { background: #6b1f27 !important; transform: translateY(-1px) !important; }
.vcc-btn-member { flex: 1; background: var(--sage-bg) !important; color: var(--sage) !important; border: 1.5px solid #a0c8b8 !important; border-radius: 9px !important; padding: 12px 14px !important; font-family: 'Jost', sans-serif !important; font-size: 0.88rem !important; font-weight: 600 !important; cursor: pointer !important; text-decoration: none !important; text-align: center !important; transition: all 0.17s !important; display: block !important; }

@media (max-width: 640px) {
  .vcc-header, .vcc-controls, .vcc-legend, .vcc-footer { padding-left: 16px; padding-right: 16px; }
  .vcc-month-cell { min-height: 80px; padding: 5px 3px; }
  .vcc-month-hdr { font-size: 0.58rem; padding: 6px 3px; letter-spacing: 0.06em; }
  .vcc-mdate { font-size: 0.85rem; }
  .pill-t { display: none; }
  .vcc-modal-btns { flex-direction: column; }
  .vcc-period { min-width: 120px; font-size: 0.95rem; }
}

/* ── Status overlay (separate from grid containers) ── */
.vcc-status { padding: 48px 28px; background: var(--paper); }

/* ── Active member banner ── */
.vcc-member-banner {
  background: var(--sage-bg);
  border-left: 4px solid var(--sage);
  color: var(--ink);
  padding: 14px 20px;
  margin: 0 0 4px;
  font-family: 'Jost', sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
  border-radius: 0 6px 6px 0;
}
