/* =====================================
   Front Page – Business Calendar
   トップページ営業日カレンダー
   ===================================== */

.top-business-calendar {
  margin: 24px 0 20px;
}

.top-business-calendar .inner {
  max-width: 1200px;
  padding-top: 36px;
}

/* 上部の見出し・説明 */
.top-business-calendar__head {
  margin-bottom: 10px;
}

.top-business-calendar__title {
  font-weight: 600;
  letter-spacing: 0.05em;
  margin-bottom: 4px;
  text-align: center;
}

/* 説明文を中央＆読みやすい行幅に */
.top-business-calendar__note {
  font-size: 14px;
  line-height: 1.6;
  opacity: 0.85;
  max-width: 920px;
  margin: 0 auto;
  padding: 0 16px;
  text-align: center;
}

.top-business-calendar__body {
  margin: 12px 0 8px;
}

/* ショートコード側（kinmata-bc）の余白をトップ用に調整 */
.top-business-calendar .kinmata-bc {
  width: 100%;
  max-width: 820px !important;
  margin: 0 auto;
}

/* トップではショートコード側の注記は使わない */
.top-business-calendar .kinmata-bc__note {
  display: none !important;
}

.top-business-calendar__footnote {
  margin-top: 6px;
  font-size: 12px;
  opacity: 0.75;
  text-align: center;
}


/* -------------------------------------------------
   Ajax版カレンダーのレイアウト崩れ対策
   - タイトル/ナビ/テーブルを縦積み
   - 中央寄せ
   ------------------------------------------------- */

/* 右寄せの原因だった flex を無効化して縦積みに */
.top-business-calendar .kinmata-bc__head {
  display: block !important;
  margin-bottom: 10px;
}

/* トップに大見出しがあるので、ショートコード内タイトルは隠す */
.top-business-calendar .kinmata-bc__title {
  display: none !important;
}

/* Ajax差し替え部分は幅100% */
.top-business-calendar .kinmata-bc__inner {
  width: 100%;
}

/* 月ナビを中央寄せ */
.top-business-calendar .kinmata-bc__nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin: 0 0 10px;
}

/* ボタン（a/buttonの見た目差を吸収） */
.top-business-calendar .kinmata-bc__btn {
  display: inline-block;
  padding: 6px 10px;
  border: 1px solid rgba(0,0,0,.2);
  border-radius: 8px;
  text-decoration: none;
  background: #fff;
  line-height: 1.2;

  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
}

.top-business-calendar .kinmata-bc__btn.is-disabled {
  opacity: .35;
  cursor: not-allowed;
}

.top-business-calendar .kinmata-bc__month {
  min-width: 8em;
  text-align: center;
  font-weight: 600;
  opacity: .85;
}


/* =====================================
   Calendar table
   ===================================== */

/* テーブルを中央寄せ。ラベル短縮後なのでPC幅は控えめ */
.top-business-calendar .kinmata-bc__table {
  width: 100%;
  max-width: 760px !important;
  margin: 0 auto;
  border-collapse: collapse;
  table-layout: fixed;
}

/* カレンダーの列幅を7等分で固定 */
.kinmata-bc__table {
  table-layout: fixed;
}

.kinmata-bc__table th,
.kinmata-bc__table td {
  width: calc(100% / 7);
}

.top-business-calendar .kinmata-bc__table th,
.top-business-calendar .kinmata-bc__table td {
  border: 1px solid rgba(0,0,0,.12);
  vertical-align: top;
  padding: 8px;
}

.top-business-calendar .kinmata-bc__table th {
  font-weight: 600;
}

.top-business-calendar .kinmata-bc__cell {
  height: 74px;
}

.top-business-calendar .kinmata-bc__day {
  font-weight: 600;
}

/* 通常ステータス */
.top-business-calendar .kinmata-bc__status {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.35;
  opacity: .88;
  white-space: nowrap;
  letter-spacing: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: clip;
}

/* 2段表示時の詰め */
.top-business-calendar .kinmata-bc__status + .kinmata-bc__status {
  margin-top: 2px;
}

/* 空セル */
.top-business-calendar .kinmata-bc__table td.is-empty {
  background: rgba(0,0,0,.02);
}

/* ローディング中 */
.top-business-calendar .kinmata-bc.is-loading {
  opacity: .65;
  pointer-events: none;
}


/* =====================================
   Calendar status colors
   休館日・料理教室・特別営業など
   ===================================== */

/* 休館日セル */
.top-business-calendar .kinmata-bc__cell.is-closed {
  background-color: #dcdcdc !important;
  border-color: #bfbfbf !important;
}

/* 休館日の文字 */
.top-business-calendar .kinmata-bc__cell.is-closed .kinmata-bc__status,
.top-business-calendar .kinmata-bc__status--closed {
  color: #444 !important;
  font-weight: 700;
}

/* 営業 */
.top-business-calendar .kinmata-bc__status--open {
  color: inherit;
}

/* 料理教室 */
.top-business-calendar .kinmata-bc__cell.has-cookingclass {
  background: rgba(160, 120, 40, .08);
}

.top-business-calendar .kinmata-bc__status--cookingclass {
  font-size: 12px;
  font-weight: 600;
  opacity: .95;
  color: #9a4f00 !important;
}

/* 正月営業 */
.top-business-calendar .kinmata-bc__cell.has-newyear {
  background: rgba(160, 40, 40, .08);
}

.top-business-calendar .kinmata-bc__status--newyear {
  font-weight: 700;
}

/* 昼のみ・夜のみ */
.top-business-calendar .kinmata-bc__cell.has-lunch_only,
.top-business-calendar .kinmata-bc__cell.has-dinner_only {
  background: rgba(40, 80, 140, .06);
}

.top-business-calendar .kinmata-bc__status--lunch_only,
.top-business-calendar .kinmata-bc__status--dinner_only {
  font-weight: 700;
}


/* -----------------------------------------
   セレクタが効かない場合の保険（トップ限定）
   ※ショートコードが .top-business-calendar の外に出た時でも効く
   ----------------------------------------- */

.home .kinmata-bc__title,
.home .kinmata-bc__note {
  display: none !important;
}


/* =====================================
   Mobile adjustment
   ===================================== */

@media (max-width: 768px) {
  .top-business-calendar {
    margin: 18px 0 16px;
  }

  .top-business-calendar .inner {
    padding-top: 28px;
  }

  .top-business-calendar__note {
    font-size: 13px;
  }

  .top-business-calendar__footnote {
    font-size: 11px;
  }

  .top-business-calendar .kinmata-bc,
  .km-mtop .top-business-calendar .kinmata-bc {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
  }

  .top-business-calendar .kinmata-bc__nav,
  .km-mtop .top-business-calendar .kinmata-bc__nav {
    gap: 8px;
    margin-bottom: 10px;
  }

  .top-business-calendar .kinmata-bc__btn,
  .km-mtop .top-business-calendar .kinmata-bc__btn {
    padding: 6px 8px;
    font-size: 12px;
  }

  .top-business-calendar .kinmata-bc__month,
  .km-mtop .top-business-calendar .kinmata-bc__month {
    min-width: 7em;
    font-size: 14px;
  }

  .top-business-calendar .kinmata-bc__table,
  .km-mtop .top-business-calendar .kinmata-bc__table {
    width: 100% !important;
    max-width: 100% !important;
    table-layout: fixed !important;
    border-collapse: collapse !important;
  }

  .top-business-calendar .kinmata-bc__table th,
  .top-business-calendar .kinmata-bc__table td,
  .km-mtop .top-business-calendar .kinmata-bc__table th,
  .km-mtop .top-business-calendar .kinmata-bc__table td {
    width: calc(100% / 7) !important;
    padding: 5px 3px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  .top-business-calendar .kinmata-bc__cell,
  .km-mtop .top-business-calendar .kinmata-bc__cell {
    height: 74px !important;
    vertical-align: top !important;
  }

  .top-business-calendar .kinmata-bc__table th,
  .km-mtop .top-business-calendar .kinmata-bc__table th {
    font-size: 15px !important;
    line-height: 1.2 !important;
    text-align: center !important;
  }

  .top-business-calendar .kinmata-bc__day,
  .km-mtop .top-business-calendar .kinmata-bc__day {
    font-size: 14px !important;
    line-height: 1.1 !important;
    font-weight: 700 !important;
    margin-bottom: 2px !important;
  }

  .top-business-calendar .kinmata-bc__status,
  .km-mtop .top-business-calendar .kinmata-bc__status {
    display: block !important;
    clear: both !important;

    margin-top: 1px !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
    font-weight: 500 !important;
    letter-spacing: -0.02em !important;

    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    max-width: 100% !important;
  }

  .top-business-calendar .kinmata-bc__status + .kinmata-bc__status,
  .km-mtop .top-business-calendar .kinmata-bc__status + .kinmata-bc__status {
    margin-top: 1px !important;
  }

.top-business-calendar .kinmata-bc__status--cookingclass,
.km-mtop .top-business-calendar .kinmata-bc__status--cookingclass {
  font-size: 10px !important;
  line-height: 1.2 !important;
  font-weight: 600 !important;
  letter-spacing: -0.03em !important;
  white-space: nowrap !important;
  color: #9a4f00 !important;
}

.top-business-calendar .kinmata-bc__status--newyear,
.top-business-calendar .kinmata-bc__status--lunch_only,
.top-business-calendar .kinmata-bc__status--dinner_only,
.km-mtop .top-business-calendar .kinmata-bc__status--newyear,
.km-mtop .top-business-calendar .kinmata-bc__status--lunch_only,
.km-mtop .top-business-calendar .kinmata-bc__status--dinner_only {
  font-size: 10px !important;
  line-height: 1.2 !important;
  font-weight: 600 !important;
  letter-spacing: -0.03em !important;
  white-space: nowrap !important;
}
}


/* =========================================
   Floating Calendar Box
   右下に浮く「営業日はこちら」
   ========================================= */

:root {
  --recaptcha-safe-bottom: 86px;
}

.floating-calendar-box {
  position: fixed;
  right: 18px;
  bottom: var(--recaptcha-safe-bottom) !important;
  z-index: 2147483647;

  display: inline-flex;
  align-items: center;

  padding: 14px 44px 14px 18px;
  border-radius: 14px;

  background: rgba(153, 51, 0, 0.88);
  color: #fff;
  text-decoration: none;

  box-shadow: 0 14px 30px rgba(0,0,0,0.22);
  border: 1px solid rgba(255,255,255,0.22);

  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  transform: translate3d(0,0,0);
  will-change: transform;

  opacity: 0;
  visibility: hidden;
  transition: opacity .18s ease, visibility .18s ease, filter .18s ease;
}

/* 文字ではなく線で作る矢印 */
.floating-calendar-box::after {
  content: "";
  position: absolute;
  right: 19px;
  top: 50%;

  width: 8px;
  height: 8px;
  border-top: 1.6px solid #fff;
  border-right: 1.6px solid #fff;

  transform: translateY(-50%) rotate(45deg);
  pointer-events: none;
  opacity: 0.9;
}

.floating-calendar-box.is-visible {
  opacity: 1;
  visibility: visible;
}

.floating-calendar-box__text {
  font-size: 15px;
  letter-spacing: 0.10em;
  white-space: nowrap;
  line-height: 1.1;
}

.floating-calendar-box:hover {
  filter: brightness(1.3);
  color: #fff;
}


/* ===== Mobile: bigger + safe area + avoid reCAPTCHA ===== */

@media (max-width: 900px) {
  body a.floating-calendar-box {
    right: 14px !important;
    bottom: calc(140px + env(safe-area-inset-bottom)) !important;

    padding: 18px 48px 18px 22px !important;
    border-radius: 18px !important;

    min-height: 52px !important;
  }

  body a.floating-calendar-box::after {
    right: 20px !important;
    top: 50% !important;
    width: 9px !important;
    height: 9px !important;
    border-top-width: 1.8px !important;
    border-right-width: 1.8px !important;
  }

  body a.floating-calendar-box .floating-calendar-box__text {
    font-size: 18px !important;
    letter-spacing: 0.10em !important;
    line-height: 1.1 !important;
    font-weight: 500 !important;
  }
}


/* =========================================
   Mobile test: calendar range + month label
   km-mtop用
   ========================================= */

/* 期間表示：営業日カレンダー（2026年2月〜2026年7月） */
.km-mtop .top-business-calendar__body .kinmata-bc__range,
.km-mtop .top-business-calendar__body .business-calendar__range,
.km-mtop .top-business-calendar__body .kinmata-bc__caption,
.km-mtop .top-business-calendar__body .business-calendar__caption {
  display: block !important;
  text-align: center !important;
  font-size: 18px !important;
  line-height: 1.45 !important;
  letter-spacing: .06em !important;
  margin: 12px auto 14px !important;
}

/* 月表示：「2026年2月」 */
.km-mtop .top-business-calendar__body .kinmata-bc__month,
.km-mtop .top-business-calendar__body .business-calendar__month,
.km-mtop .top-business-calendar__body .kinmata-bc__month-label,
.km-mtop .top-business-calendar__body .business-calendar__month-label {
  display: block !important;
  text-align: center !important;
  font-size: 30px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  margin: 6px auto 18px !important;
}

/* 内側が span 等でもセンター維持 */
.km-mtop .top-business-calendar__body .kinmata-bc__month *,
.km-mtop .top-business-calendar__body .business-calendar__month * {
  text-align: inherit !important;
  font-size: inherit !important;
}

