:root{
  --tap-border:#c6c6cb; --tap-grid:#d0d1d6; --tap-bg:#f8f8f8;
  --tap-dow-wk:#3e3e43; --tap-dow-sun:#9f5a5a; --tap-dow-sat:#4f6da8;
  --tap-selected:#fff7b0; --tap-footer-wk:#4a4a4f; --tap-footer-sun:#8f5050; --tap-footer-sat:#445f96;
  --tap-other:#9aa0a8; --tap-day:#333333; --tap-sun-bg:#ffe9ea; --tap-sat-bg:#eaf1ff;
  --tap-today-text:#1f5fd0;
}

.tapcal-v39{ max-width:1100px; margin:0 auto; color:#222; }
.tapcal-header{ padding:6px 4px 0; display:flex; align-items:center; justify-content:space-between; }
.tapcal-title{ border:none; background:none; padding:4px 10px; display:flex; gap:8px; align-items:baseline;
  border:1px solid #e3e4e8; background:#fff; border-radius:10px; box-shadow:0 1px 2px rgba(0,0,0,.04); pointer-events:none;
}
/* “がっしり”フォント：見出し・日付・フッター */
.tapcal-v39 .tapcal-title strong,
.tapcal-v39 .tapcal-day .num strong,
.tapcal-v39 .tapcal-footerbar,
.tapcal-v39 .tapcal-footerbar strong{
  font-family: "SF Pro Display","Segoe UI","Inter","Noto Sans JP",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight: 800;
}

.tapcal-y,.tapcal-m{ display:inline-block; font-size:22px; line-height:1.1; margin:0; }
.tapcal-todaybtn{ font-size:13px; padding:2px 10px; min-width:60px; border-radius:6px; border:1px solid var(--tap-grid); background:#fff; cursor:pointer; }

.tapcal-swipehint{ text-align:center; font-size:12px; color:#666; padding:4px 0 2px; }

.tapcal-gridwrap{ position:relative; overflow:hidden; touch-action: pan-y; min-height: 330px; }
.tapcal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:2px; padding:2px 0 4px; user-select:none; position:relative; background:transparent; }
.tapcal-grid, .tapcal-grid.ghost{ will-change: transform; contain: paint; }
.tapcal-grid.anim, .tapcal-grid.ghost.anim{ transition: transform .28s ease, opacity .28s ease; }

.tapcal-cell{ position:relative; text-align:left; padding:6px; border:1px solid var(--tap-grid); background:var(--tap-bg); border-radius:6px; }
.tapcal-dow{ padding:0; height:26px; display:flex; align-items:center; justify-content:center; color:#fff; border:none; border-radius:6px; font-weight:800; }

.tapcal-dow.wk{ background:var(--tap-dow-wk); } .tapcal-dow.sun{ background:var(--tap-dow-sun); } .tapcal-dow.sat{ background:var(--tap-dow-sat); }

.tapcal-day{ height:46px; border-radius:6px; }
.tapcal-day .num{ position:absolute; left:4px; top:3px; font-size:14px; color:#333; }
.tapcal-day .num strong{ display:inline-flex; width:22px; height:22px; align-items:center; justify-content:center; border-radius:50%; line-height:1; }
.tapcal-day.sun:not(.other){ background:var(--tap-sun-bg); } .tapcal-day.sun:not(.other) .num{ color:#d83a3a; }
.tapcal-day.sat:not(.other){ background:var(--tap-sat-bg); } .tapcal-day.sat:not(.other) .num{ color:#2a67d9; }
.tapcal-day.other{ background:#eceef2; border-color:#c8cad0; } .tapcal-day.other .num{ color:var(--tap-other); }
.tapcal-day.selected{ background:var(--tap-selected) !important; outline:none; }
.tapcal-day .mark{ position:absolute; right:4px; bottom:4px; width:6px; height:6px; border-radius:50%; background:#888; opacity:0; }
.tapcal-day.has .mark{ opacity:1; }
.tapcal-day.today .num strong{ box-shadow: inset 0 0 0 2px var(--tap-today-text); color:var(--tap-today-text); background:transparent; }

.tapcal-footerbar{ color:#fff; padding:3px 10px; border-radius:6px; margin:6px 0 0; }
.tapcal-footerbar.wk{ background: #4a4a4f; }
.tapcal-footerbar.sun{ background: #8f5050; }
.tapcal-footerbar.sat{ background: #445f96; }
.tapcal-footerbar__date{ min-height:14px; }

.tapcal-list{ background:#fff; border:1px solid var(--tap-border); border-radius:6px; padding:8px 10px; margin-top:6px; }
.tapcal-item{ padding:8px 0; border-bottom:1px solid #eee; } .tapcal-item:last-child{ border-bottom:none; }
.tapcal-item-meta{ font-size:11.5px; color:#555; margin-top:1px; }
.tapcal-item-title{ font-size:14px; line-height:1.3; margin-top:2px; display:flex; gap:6px; align-items:center; }

/* Grade ラベル */
.tapcal-grade{ display:inline-block; padding:0 6px; height:18px; line-height:18px; border-radius:9px; font-size:12px; font-weight:800; color:#fff; }
.tapcal-grade.g1{ background:#d83a3a; }  /* 赤 */
.tapcal-grade.g2{ background:#2a67d9; }  /* 青 */
.tapcal-grade.g3{ background:#2c9c5d; }  /* 緑 */
.tapcal-grade.l{  background:#6b7280; }  /* グレー */

/* Gラベルの角丸を控えめに */
.tapcal-v39 .tapcal-grade {
  border-radius: 8px;
}

/* タイトル下メモをタイトルと同じ列に揃える */
.tapcal-v39 .tapcal-daynote {
  margin-left: 0;
  margin-right: 0;
}

/* 予定の時間・場所をヘッダー日付と同フォントにし、タイトルより少し小さく */
.tapcal-v39 .tapcal-item-meta,
.tapcal-v39 .tapcal-item-meta time,
.tapcal-v39 .tapcal-item-meta strong {
  font-family: "SF Pro Display","Segoe UI","Inter","Noto Sans JP",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-size: 13px;
  font-weight: 700;
}

/* Gラベルも同フォントで太字、角丸控えめ */
.tapcal-v39 .tapcal-grade {
  font-family: "SF Pro Display","Segoe UI","Inter","Noto Sans JP",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight: 800;
  border-radius: 8px;
}

/* タイトル下メモをタイトルと同じ列に（左右のみ揃える） */
.tapcal-v39 .tapcal-daynote,
.tapcal-v39 .tapcal-list-note {
  margin-left: 0;
  margin-right: 0;
}

/* 年月ヘッダーを34版レイアウトに戻す */
.tapcal-v39 .tapcal-header {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: baseline;
}

.tapcal-v39 .tapcal-title {
  grid-column: 2;
  justify-self: center;
  border: none;
  background: transparent;
  box-shadow: none;
}

/* 数字を大きく、年・月の漢字は一回り小さく */
.tapcal-v39 .tapcal-title .num {
  font-size: 28px;
  line-height: 1;
}

.tapcal-v39 .tapcal-title strong {
  font-size: 18px;
}

/* 予定タイトルとメモの間に点線区切り＋メモの位置調整 */
.tapcal-v39 .tapcal-item-body,
.tapcal-v39 .tapcal-item-note {
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px dashed #e0e0e0;
  margin-left: 0;
}

/* 今月ボタンの幅を少し短くする */
.tapcal-v39 .tapcal-todaybtn {
  min-width: auto;
  padding-left: 8px;
  padding-right: 8px;
}

/* メモ本文は Noto Sans JP に統一 */
.tapcal-v39 .tapcal-item-body,
.tapcal-v39 .tapcal-item-note {
  font-family: "Noto Sans JP", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

/* 今月ボタンの幅を短く（強制上書き） */
.tapcal-v39 .tapcal-todaybtn {
  width: auto !important;
  min-width: 0 !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
  display: inline-block;
}

/* メモ本文フォントを FOT-筑紫A丸ゴシック Std D に変更 */
.tapcal-v39 .tapcal-item-body,
.tapcal-v39 .tapcal-item-note {
  font-family: "FOT-筑紫A丸ゴシック Std D","Noto Sans JP",system-ui,-apple-system,BlinkMacSystemFont,sans-serif !important;
}

/* 今月ボタンは使用しないため完全に非表示 */
.tapcal-v39 .tapcal-todaybtn {
  display: none !important;
}

/* カテゴリUIは使用しないため非表示（念のため） */
.tapcal-v39 .tapcal-catbar,
.tapcal-v39 .tapcal-catbtn {
  display: none !important;
}

/* 月選択ボタン: 押しやすいサイズに調整 */
.tapcal-v39 .tapcal-monthbar{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:6px;
  margin-top:4px;
  margin-bottom:2px;
}
.tapcal-v39 .tapcal-monthbtn{
  padding:5px 12px;
  min-width:40px;
  font-size:13px;
  line-height:1.6;
  border-radius:6px;
  border:1px solid #ddd;
  background:#fff;
  cursor:pointer;
}
.tapcal-v39 .tapcal-monthbtn:hover{
  background:#f5f5f5;
}

/* 月選択ボタン: さらに押しやすく */
.tapcal-v39 .tapcal-monthbtn{
  padding:6px 14px;
  min-width:44px;
  font-size:14px;
}

/* PC向けにスワイプ案内文は非表示 */
.tapcal-v39 .tapcal-note{
  display:none !important;
}

/* 年選択バー */
.tapcal-v39 .tapcal-yearbar{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin-top:4px;
}
.tapcal-v39 .tapcal-yearbtn{
  padding:4px 8px;
  font-size:14px;
  border-radius:6px;
  border:1px solid #ddd;
  background:#fff;
  cursor:pointer;
}
.tapcal-v39 .tapcal-yearlabel{
  font-size:15px;
  font-weight:600;
}
.tapcal-v39 .tapcal-yearbtn:hover{
  background:#f5f5f5;
}

/* 月選択ボタン: シンプルかつ押しやすいサイズ */
.tapcal-v39 .tapcal-monthbar{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  margin:4px 0 2px;
}
.tapcal-v39 .tapcal-monthbtn{
  padding:8px 16px;
  min-width:52px;
  font-size:14px;
  line-height:1.6;
  border-radius:8px;
  border:1px solid #cccccc;
  background:#ffffff;
  cursor:pointer;
}
.tapcal-v39 .tapcal-monthbtn:hover{
  background:#f2f2f2;
}

/* 年選択バーも同系統のデザインに統一 */
.tapcal-v39 .tapcal-yearbar{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  margin:4px 0;
}
.tapcal-v39 .tapcal-yearbtn{
  padding:6px 10px;
  font-size:14px;
  border-radius:8px;
  border:1px solid #cccccc;
  background:#ffffff;
  cursor:pointer;
}
.tapcal-v39 .tapcal-yearbtn:hover{
  background:#f2f2f2;
}
.tapcal-v39 .tapcal-yearlabel{
  font-size:15px;
  font-weight:600;
}

/* --- Refined month/year selector styling to match calendar --- */
.tapcal-v39 .tapcal-monthbar{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:4px;
  margin:8px 0 4px;
}
.tapcal-v39 .tapcal-monthbtn{
  padding:6px 14px;
  min-width:46px;
  font-size:13px;
  line-height:1.5;
  border-radius:4px;
  border:1px solid #d4d4d4;
  background:#f7f7f7;
  color:#333;
  font-weight:500;
  box-shadow:0 1px 2px rgba(0,0,0,0.03);
}
.tapcal-v39 .tapcal-monthbtn:hover{
  background:#ececec;
}

/* Year selector aligned with same visual language */
.tapcal-v39 .tapcal-yearbar{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:6px;
  margin:0 0 2px;
}
.tapcal-v39 .tapcal-yearbtn{
  padding:4px 8px;
  font-size:13px;
  border-radius:4px;
  border:1px solid #d4d4d4;
  background:#f7f7f7;
  color:#555;
  cursor:pointer;
  box-shadow:0 1px 2px rgba(0,0,0,0.03);
}
.tapcal-v39 .tapcal-yearbtn:hover{
  background:#ececec;
}
.tapcal-v39 .tapcal-yearlabel{
  font-size:14px;
  font-weight:500;
  color:#333;
}

/* --- Month / Year selector final tuning --- */
.tapcal-v39 .tapcal-monthbar{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:6px;
  margin:10px 0 6px;
}

.tapcal-v39 .tapcal-monthbtn{
  padding:8px 18px;
  min-width:60px;
  font-size:14px;
  line-height:1.6;
  border-radius:6px;
  border:1px solid #dadada;
  background:#ffffff;
  color:#333333;
  font-weight:500;
}

/* hover onlyわずかに */
.tapcal-v39 .tapcal-monthbtn:hover{
  background:#f3f3f3;
}

/* year bar: same language */
.tapcal-v39 .tapcal-yearbar{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin:0 0 4px;
}

.tapcal-v39 .tapcal-yearbtn{
  padding:6px 10px;
  font-size:14px;
  border-radius:6px;
  border:1px solid #dadada;
  background:#ffffff;
  color:#333333;
  cursor:pointer;
}

.tapcal-v39 .tapcal-yearbtn:hover{
  background:#f3f3f3;
}

.tapcal-v39 .tapcal-yearlabel{
  font-size:15px;
  font-weight:500;
  color:#333333;
}

/* --- Selector styled like header: active in Saturday blue --- */
.tapcal-v39 .tapcal-yearbar{
  display:flex;
  justify-content:center;
  align-items:flex-end;
  gap:0;
  margin:0 0 6px;
  font-family: inherit;
}
.tapcal-v39 .tapcal-yearbtn,
.tapcal-v39 .tapcal-yearlabel{
  padding:10px 32px;
  font-size:16px;
  line-height:1.4;
  border:none;
}
.tapcal-v39 .tapcal-yearbtn{
  background:#f1f1f1;
  color:#555;
  cursor:pointer;
}
.tapcal-v39 .tapcal-yearbtn:hover{
  background:#e5e5e5;
}
.tapcal-v39 .tapcal-yearlabel{
  position:relative;
  background:var(--tap-dow-sat);
  color:#fff;
  font-weight:600;
}
.tapcal-v39 .tapcal-yearlabel::after{
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-6px;
  border-width:6px 6px 0 6px;
  border-style:solid;
  border-color:var(--tap-dow-sat) transparent transparent transparent;
}

/* month buttons as flat segments under year bar */
.tapcal-v39 .tapcal-monthbar{
  display:flex;
  flex-wrap:nowrap;
  justify-content:center;
  gap:0;
  margin:10px auto 6px;
  max-width:960px;
}
.tapcal-v39 .tapcal-monthbtn{
  padding:10px 0;
  flex:1 1 0;
  font-size:14px;
  line-height:1.4;
  border:1px solid #e0e0e0;
  border-left:none;
  border-radius:0;
  background:#fafafa;
  color:#555;
  font-weight:500;
}
.tapcal-v39 .tapcal-monthbtn:first-child{
  border-left:1px solid #e0e0e0;
  border-top-left-radius:4px;
  border-bottom-left-radius:4px;
}
.tapcal-v39 .tapcal-monthbtn:last-child{
  border-top-right-radius:4px;
  border-bottom-right-radius:4px;
}
.tapcal-v39 .tapcal-monthbtn:hover{
  background:#f0f0f0;
}
.tapcal-v39 .tapcal-monthbtn.is-current{
  background:var(--tap-dow-sat);
  color:#fff;
  border-color:var(--tap-dow-sat);
}

/* Month/Year selector refined: same font as dates, bold labels */
.tapcal-v39 .tapcal-monthbtn,
.tapcal-v39 .tapcal-yearlabel{
  font-family: inherit;
  font-weight: 700;
}

/* make '年' label slightly smaller than numbers via relative size */
.tapcal-v39 .tapcal-yearlabel{
  font-size: 0.95em;
}

/* year arrow buttons as minimal triangles */
.tapcal-v39 .tapcal-yearbtn{
  position: relative;
  width: 28px;
  height: 32px;
  padding: 0;
  border-radius: 4px;
  border: 1px solid #dadada;
  background: #ffffff;
}
.tapcal-v39 .tapcal-yearbtn::before{
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -4px;
  margin-left: -4px;
  border-style: solid;
  border-width: 4px 6px;
  border-color: transparent;
}
.tapcal-v39 .tapcal-yearbtn-prev::before{
  border-right-color: #555;
  margin-left: -2px;
}
.tapcal-v39 .tapcal-yearbtn-next::before{
  border-left-color: #555;
  margin-left: -4px;
}

/* Mobile: ensure month buttons wrap without overflow */
@media (max-width: 640px){
  .tapcal-v39 .tapcal-monthbar{
    flex-wrap: wrap;
    justify-content: center;
    gap: 4px;
    margin-top: 6px;
  }
  .tapcal-v39 .tapcal-monthbtn{
    flex: 0 0 calc(100% / 6 - 4px); /* 2段構成で12ヶ月 */
    min-width: auto;
    padding:4px 0;
    font-size:12px;
    border-radius:4px;
  }
  .tapcal-v39 .tapcal-yearbar{
    margin-bottom: 2px;
  }
}
