/* ============================================================
   Camp Display — Frontend Styles
   Heavy specificity needed to override Divi's global resets
   ============================================================ */

#camp-display,
#camp-display *,
#camp-display *::before,
#camp-display *::after {
  box-sizing: border-box !important;
}

#camp-display {
  --cp: #1D6FA4;
  --ca: #F4A623;
  --cd: #152535;
  --cm: #6b7e8d;
  --cb: #dde4ea;
  --cl: #f4f7fa;
  font-family: 'DM Sans', sans-serif !important;
  color: var(--cd);
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 0 60px;
}

/* Toggle */
#camp-display .cd-toggle {
  display: flex !important;
  background: var(--cl);
  border: 1.5px solid var(--cb);
  border-radius: 40px;
  padding: 4px;
  width: fit-content;
  margin: 0 auto 36px;
  gap: 2px;
  list-style: none !important;
}
#camp-display .cd-toggle button {
  border: none !important;
  background: transparent !important;
  padding: 9px 26px !important;
  border-radius: 40px !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  cursor: pointer;
  color: var(--cm) !important;
  transition: all .18s ease;
  display: flex !important;
  align-items: center;
  gap: 7px;
  line-height: 1 !important;
  box-shadow: none !important;
  outline: none;
  margin: 0 !important;
}
#camp-display .cd-toggle button.on {
  background: var(--cp) !important;
  color: #fff !important;
  box-shadow: 0 2px 10px rgba(29,111,164,.28) !important;
}

/* Month heading */
#camp-display .cd-month {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--cp) !important;
  border: none !important;
  border-bottom: 2px solid var(--cb) !important;
  padding: 0 0 8px 0 !important;
  margin: 36px 0 14px !important;
  background: none !important;
}
#camp-display .cd-month:first-child { margin-top: 0 !important; }

/* ── Card — grid layout guarantees 3 columns ── */
#camp-display .cd-card {
  display: grid !important;
  grid-template-columns: 86px 1fr auto !important;
  align-items: center !important;
  background: #fff !important;
  border: 1.5px solid var(--cb) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  margin: 0 0 12px 0 !important;
  padding: 0 !important;
  text-decoration: none !important;
  color: var(--cd) !important;
  transition: box-shadow .18s, transform .18s, border-color .18s !important;
  min-height: 84px !important;
  width: 100% !important;
  float: none !important;
  position: relative !important;
}
#camp-display .cd-card:hover {
  box-shadow: 0 6px 24px rgba(21,37,53,.13) !important;
  transform: translateY(-2px) !important;
  border-color: var(--cp) !important;
  text-decoration: none !important;
  color: var(--cd) !important;
}
#camp-display .cd-card:visited { color: var(--cd) !important; }

/* Date strip */
#camp-display .cd-strip {
  background: var(--cp) !important;
  color: #fff !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  align-self: stretch !important;
  padding: 14px 8px !important;
  margin: 0 !important;
  text-align: center;
  min-height: 84px !important;
}
#camp-display .cd-strip .dy {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 30px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  color: #fff !important;
}
#camp-display .cd-strip .mo {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  margin: 3px 0 0 !important;
  padding: 0 !important;
  opacity: .85;
  display: block !important;
  color: #fff !important;
}
#camp-display .cd-strip .yr {
  font-size: 10px !important;
  opacity: .6;
  margin: 2px 0 0 !important;
  padding: 0 !important;
  display: block !important;
  color: #fff !important;
}
#camp-display .cd-strip .sep {
  font-size: 13px !important;
  opacity: .4;
  margin: 2px 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
  display: block !important;
  color: #fff !important;
}
#camp-display .cd-strip .dy2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  color: #fff !important;
}

/* Card body */
#camp-display .cd-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  padding: 16px 24px !important;
  margin: 0 !important;
  min-width: 0;
  align-self: center !important;
}
#camp-display .cd-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  color: var(--cd) !important;
  margin: 0 !important;
  padding: 0 !important;
  white-space: normal !important;
}
#camp-display .cd-date-line {
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 13px !important;
  color: var(--cm) !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Card right */
#camp-display .cd-right {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: center !important;
  padding: 16px 20px 16px 12px !important;
  margin: 0 !important;
  gap: 10px !important;
  flex-shrink: 0;
  align-self: stretch !important;
}
#camp-display .cd-price {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--cp) !important;
  white-space: nowrap;
  margin: 0 !important;
  padding: 0 !important;
}
#camp-display .cd-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  background: var(--ca) !important;
  color: var(--cd) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  padding: 9px 18px !important;
  border-radius: 30px !important;
  white-space: nowrap;
  transition: filter .15s;
  text-decoration: none !important;
  border: none !important;
  cursor: pointer;
  line-height: 1 !important;
  margin: 0 !important;
}
#camp-display .cd-card:hover .cd-btn { filter: brightness(.92); }
#camp-display .cd-arr { display: inline-block; transition: transform .15s; }
#camp-display .cd-card:hover .cd-arr { transform: translateX(3px); }

/* ── Calendar ── */
#cd-cal { display: none; }
#cd-cal.on { display: block; }

#camp-display .cd-cal-nav {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 20px !important;
}
#camp-display .cd-cal-nav h2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 26px !important;
  font-weight: 700 !important;
  color: var(--cd) !important;
  margin: 0 !important;
  padding: 0 !important;
}
#camp-display .cd-cal-nav button {
  border: 2px solid var(--cb) !important;
  background: #fff !important;
  width: 40px !important; height: 40px !important;
  border-radius: 50% !important;
  cursor: pointer;
  display: flex !important; align-items: center !important; justify-content: center !important;
  transition: all .15s;
  color: var(--cd) !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
}
#camp-display .cd-cal-nav button:hover {
  border-color: var(--cp) !important;
  background: var(--cp) !important;
  color: #fff !important;
}

#camp-display .cd-grid {
  display: grid !important;
  grid-template-columns: repeat(7,1fr) !important;
  gap: 3px !important;
}
#camp-display .cd-dh {
  text-align: center;
  font-size: 11px !important; font-weight: 700 !important;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--cm) !important; padding: 6px 0 12px !important;
  margin: 0 !important;
}
#camp-display .cd-cell {
  min-height: 86px !important;
  background: #fff !important;
  border-radius: 7px !important;
  border: 1.5px solid var(--cb) !important;
  padding: 7px 6px 5px !important;
  margin: 0 !important;
  position: relative;
  overflow: hidden;
}
#camp-display .cd-cell.empty {
  background: var(--cl) !important;
  border-color: transparent !important;
}
#camp-display .cd-cell.has {
  border-color: var(--cp) !important;
  background: #f0f7fc !important;
  cursor: pointer;
  transition: background .15s;
}
#camp-display .cd-cell.has:hover { background: #d9ecf7 !important; }
#camp-display .cd-cell.today .cd-num {
  background: var(--cp) !important;
  color: #fff !important;
  border-radius: 50% !important;
}
#camp-display .cd-num {
  font-size: 13px !important; font-weight: 600 !important;
  width: 24px !important; height: 24px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  margin-bottom: 4px !important;
  color: var(--cd) !important;
}
#camp-display .cd-dot {
  font-size: 9.5px !important; font-weight: 600 !important;
  background: var(--cp) !important; color: #fff !important;
  border-radius: 3px !important; padding: 2px 4px !important; margin-top: 2px !important;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block !important;
}
#camp-display .cd-dot.alt { background: var(--ca) !important; color: var(--cd) !important; }
#camp-display .cd-dot-more {
  font-size: 9.5px !important; font-weight: 700 !important;
  color: var(--cp) !important; border: 1.5px solid var(--cp) !important;
  border-radius: 3px !important; padding: 1px 4px !important; margin-top: 2px !important;
  display: inline-block !important; background: transparent !important;
}

/* ── Day modal — appended to <body>, outside Divi ── */
.cd-modal-overlay {
  display: none;
  position: fixed !important;
  top: 0 !important; left: 0 !important;
  width: 100% !important; height: 100% !important;
  background: rgba(21,37,53,.6) !important;
  z-index: 9999999 !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
}
.cd-modal-overlay.on { display: flex !important; }

.cd-modal {
  background: #fff !important;
  border-radius: 14px !important;
  width: 100% !important;
  max-width: 560px !important;
  max-height: 85vh !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: 0 20px 60px rgba(21,37,53,.3) !important;
  animation: cdModalIn .2s ease;
  overflow: hidden !important;
  position: relative !important;
  font-family: 'DM Sans', sans-serif !important;
}
@keyframes cdModalIn {
  from { transform: scale(.94) translateY(8px); opacity: 0; }
  to   { transform: scale(1) translateY(0); opacity: 1; }
}
.cd-modal-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 18px 22px 14px !important;
  border-bottom: 1.5px solid #dde4ea !important;
  flex-shrink: 0;
}
.cd-modal-head h3 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 18px !important; font-weight: 700 !important;
  color: #1D6FA4 !important; margin: 0 !important; padding: 0 !important;
}
.cd-modal-close {
  border: none !important;
  background: #f4f7fa !important;
  border-radius: 50% !important;
  width: 34px !important; height: 34px !important;
  cursor: pointer;
  font-size: 16px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  color: #152535 !important;
  transition: background .15s;
  flex-shrink: 0;
  padding: 0 !important;
  box-shadow: none !important;
  line-height: 1 !important;
}
.cd-modal-close:hover { background: #dde4ea !important; }

.cd-modal-body {
  overflow-y: auto !important;
  padding: 16px 18px !important;
  flex: 1;
}
/* Cards inside modal get the same scoped styles via .cd-modal-body */
.cd-modal-body .cd-card {
  display: grid !important;
  grid-template-columns: 72px 1fr auto !important;
  align-items: center !important;
  background: #fff !important;
  border: 1.5px solid #dde4ea !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  margin: 0 0 10px 0 !important;
  padding: 0 !important;
  text-decoration: none !important;
  color: #152535 !important;
  min-height: 72px !important;
  transition: box-shadow .18s, transform .18s, border-color .18s !important;
  width: 100% !important;
}
.cd-modal-body .cd-card:hover {
  box-shadow: 0 4px 18px rgba(21,37,53,.12) !important;
  transform: translateY(-2px) !important;
  text-decoration: none !important;
}
.cd-modal-body .cd-strip { min-height: 72px !important; padding: 10px 8px !important; }
.cd-modal-body .cd-strip .dy  { font-size: 24px !important; }
.cd-modal-body .cd-strip .yr  { display: none !important; }
.cd-modal-body .cd-body  { padding: 12px 16px !important; }
.cd-modal-body .cd-title { font-size: 14px !important; }
.cd-modal-body .cd-right { padding: 12px 14px 12px 8px !important; gap: 8px !important; }
.cd-modal-body .cd-price { font-size: 15px !important; }
.cd-modal-body .cd-btn   { font-size: 12px !important; padding: 7px 14px !important; }

/* Empty */
#camp-display .cd-empty {
  text-align: center !important;
  padding: 50px 20px !important;
  color: #6b7e8d !important;
  font-size: 16px !important;
}

/* Responsive */
@media (max-width: 640px) {
  #camp-display .cd-card { grid-template-columns: 64px 1fr !important; }
  #camp-display .cd-right { grid-column: 1 / -1 !important; flex-direction: row !important; justify-content: space-between !important; padding: 0 14px 14px !important; }
  #camp-display .cd-strip .yr { display: none !important; }
  #camp-display .cd-dot { display: none !important; }
  #camp-display .cd-cell.has { background: #d9ecf7 !important; }
  #camp-display .cd-cell { min-height: 50px !important; }
  #camp-display .cd-cal-nav h2 { font-size: 19px !important; }
}
