
.mbc-table {
  border-collapse: collapse;
  margin: 10px;
  width: 100%;
  max-width: 700px;
  table-layout: fixed;
  font-size: 1.1em;
}
.admin .mbc-table {
  width: 350px;
}
.mbc-table th, .mbc-table td {
  border: 1px solid #ccc;
  text-align: center;
  height: 80px;
  vertical-align: top;
  overflow-wrap: break-word;
  padding: 3px;
}
.mbc-table th {
  background: #eee;
  height: 30px;
  font-size: 1em;
}
.mbc-table caption {
  font-weight: bold;
  margin-bottom: 5px;
  font-size: 1.2em;
}
.label {
  display: inline-block;
  margin-top: 8px;
  padding: 4px 8px;
  border-radius: 6px;
  font-size: 0.8em;
  font-weight: bold;
}
.label-today {
  background-color: #f0c000;
  color: #000;
}
.label-alert {
  background-color: #c00000;
  color: #fff;
}
.label-day {
  background: none;
  color: #007acc;
}
.label-holiday {
  background-color: #aaa;
  color: #fff;
}
.calendar-row {
  display: flex;
  gap: 10px;
  justify-content: center;
}
.bg-today {
  background-color: #fff5c2 !important;
}
.bg-alert {
  background-color: #ffe2e2 !important;
}

.bg-day {
  background-color: #e6f4ff !important;
}

.bg-holiday {
  background-color: #f2f2f2 !important;
}

.mbc-plan-title { font-size: 1.5em; text-align: center; margin-bottom: 10px; }
@media screen and (max-width: 641px) {
  .calendar-row {
    flex-wrap: wrap;
  }
  .mbc-table {
    flex-basis: 100%;
  }
  #plan-select {
    width: 100%;
  }
}
