#reservation-window {
  align-items: flex-start !important;
  padding-top: 1vh;
}

#reservation-window .modal-content::before {
  content: "非公式";
  position: absolute;
  top: 6px;
  left: 8px;
  font-size: 10px;
  color: #aaaaaa;
  opacity: 0.8;
  pointer-events: none;
  font-weight: 600;
}

.title {
  text-align: center;
  font-weight: 700;
  font-size: 22px;
  margin-bottom: 12px;
}

.pavilion-box {
  width: 100%;
  border: 2px solid #000;
  background: #fff;
  padding: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  margin-bottom: 0;
}

.symbol {
  margin-left: 10px;   /* 枠とのマージン */
  margin-right: 10px; /* ← これはパビリオン名との間 */
  font-weight: 700;
  font-size: 22px;
}

.red {
  color: red;
}
.orange {
  color: orange;
}
.blue {
  color: blue;
}
.pavilion-name {
  flex: 1;
  font-size: 14px;
  font-weight: 500;
}

.dummy-dot {
  font-size: 22px;
  color: red;
  margin-left: auto;
  margin-right: 4px;
}
.dummy-dot .dummy-icon {
  width: 20px;
  height: 20px;
  display: block;
}
.symbol svg,
.dummy-dot svg {
  vertical-align: middle;
}

.detail-link {
  display: block;        /* ← 隙間を詰めるために必要 */
  width: fit-content;    /* ← 背景を文字幅に戻す */
  margin: 0 0 14px 0; /* 上 右 下 左 */
  padding: 0 10px; /* 上下 左右 */
  font-size: 10px;
  background: #ddd;
  border-radius: 9999px;
  text-decoration: underline;
  color: #333;
}

.close-btn {
  display: block;
  margin: 28px auto 0;
  padding: 12px 28px;
  font-size: 16px;
  background: #666;
  color: #fff;
  border: none;
  border-radius: 9999px;
}

/* 時間セルとボタンの間に余白を追加 */
.schedule-wrapper {
  margin-bottom: 8px; /* ← 下に余白を追加してボタンとの距離を確保 */
}

