/* KS学校アップデート v1.0.0 */
:root {
  --ksup-primary: #1a5276;
  --ksup-accent:  #2980b9;
  --ksup-border:  #dce1e7;
  --ksup-bg:      #f4f6f9;
  --ksup-text:    #2c3e50;
  --ksup-sub:     #5d6d7e;
  --ksup-radius:  6px;
}

/* ── 1カラム強制 ──
   GeneratePressはno-sidebarクラスがbodyにあれば
   .site-content .content-areaを100%にする設定を持つ。
   念のためCSSでも上書き */
body.ks-update-page .site-content {
  display: block !important;
}
body.ks-update-page .widget-area,
body.ks-update-page #secondary {
  display: none !important;
}

/* ── パンくず ── */
.ksup-breadcrumb {
  font-size: 0.8rem;
  color: var(--ksup-sub);
  margin-bottom: 16px;
}
.ksup-breadcrumb a { color: var(--ksup-accent); text-decoration: none; }
.ksup-breadcrumb a:hover { text-decoration: underline; }

/* ── アーカイブ ── */
.ksup-archive {
  padding: 20px 0 60px;
}
.ksup-header {
  border-left: 4px solid var(--ksup-primary);
  padding-left: 14px;
  margin-bottom: 24px;
}
.ksup-header__title { font-size: 1.4rem; color: var(--ksup-primary); margin: 0 0 4px; }
.ksup-header__desc  { font-size: 0.9rem; color: var(--ksup-sub); margin: 0; }

/* ── フィルター ── */
.ksup-filter-wrap {
  border: 1px solid var(--ksup-border);
  border-radius: var(--ksup-radius);
  background: #fff;
  margin-bottom: 20px;
  overflow: hidden;
}
.ksup-filter-toggle {
  width: 100%; text-align: left; padding: 12px 16px;
  background: var(--ksup-bg); border: none; cursor: pointer;
  font-size: 0.9rem; font-weight: bold; color: var(--ksup-primary);
  display: flex; align-items: center; gap: 8px;
}
.ksup-toggle-icon { display: inline-block; transition: transform 0.2s; }
.ksup-filter-panel { display: none; padding: 16px; border-top: 1px solid var(--ksup-border); }
.ksup-filter-panel.is-open { display: block; }
.ksup-filter-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px; margin-bottom: 12px;
}
.ksup-filter-item label {
  display: block; font-size: 0.78rem; font-weight: bold;
  color: var(--ksup-sub); margin-bottom: 4px;
}
.ksup-select {
  width: 100%; padding: 6px 10px;
  border: 1px solid var(--ksup-border);
  border-radius: var(--ksup-radius);
  font-size: 0.85rem; color: var(--ksup-text);
  background: #fff; cursor: pointer;
}
.ksup-filter-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.ksup-btn {
  padding: 7px 20px; border-radius: var(--ksup-radius);
  font-size: 0.88rem; cursor: pointer; text-decoration: none;
  display: inline-block; border: none;
}
.ksup-btn--apply { background: var(--ksup-primary); color: #fff; }
.ksup-btn--apply:hover { background: #154360; color: #fff; }
.ksup-btn--reset { background: #fff; color: var(--ksup-sub); border: 1px solid var(--ksup-border); }

/* ── 件数 ── */
.ksup-count { font-size: 0.85rem; color: var(--ksup-sub); margin-bottom: 14px; }
.ksup-count span { font-weight: bold; color: var(--ksup-primary); font-size: 1.1rem; }

/* ── リスト ── */
.ksup-list { display: flex; flex-direction: column; gap: 10px; }

/* ── カード ── */
.ksup-card {
  background: #fff; border: 1px solid var(--ksup-border);
  border-radius: var(--ksup-radius);
  transition: box-shadow 0.15s, transform 0.15s;
}
.ksup-card:hover { box-shadow: 0 2px 10px rgba(26,82,118,.1); transform: translateY(-1px); }
.ksup-card__inner { padding: 12px 14px; }
.ksup-badges { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 6px; }
.ksup-badge {
  display: inline-block; font-size: 0.72rem; font-weight: bold;
  padding: 2px 8px; border-radius: 20px; color: #fff; white-space: nowrap;
}
.ksup-badge--chu { background: #566573; }
.ksup-badge--gak { background: #6c5ce7; }
.ksup-badge--kub { background: #00b894; }
.ksup-badge--chi { background: #e17055; }
.ksup-card__school { font-size: 0.78rem; color: var(--ksup-sub); margin: 0 0 2px; font-weight: bold; }
.ksup-card__title  { font-size: 1.1rem; margin: 0 0 8px; line-height: 1.5; }
.ksup-card__title a { color: var(--ksup-text); text-decoration: none; }
.ksup-card__title a:hover { color: var(--ksup-accent); text-decoration: underline; }
.ksup-card__footer {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 6px;
  border-top: 1px solid var(--ksup-border); padding-top: 8px;
}
.ksup-card__date  { font-size: 0.78rem; color: var(--ksup-sub); }
.ksup-card__links { display: flex; gap: 6px; flex-wrap: wrap; }
.ksup-link {
  font-size: 0.8rem; padding: 3px 10px; border-radius: 4px;
  text-decoration: none; font-weight: bold; white-space: nowrap;
}
.ksup-link--off { background: #fef9e7; color: #b7950b; border: 1px solid #f9e79f; }
.ksup-link--off:hover { background: #fdebd0; color: #9a7d0a; }
.ksup-link--ks  { background: #eaf4fb; color: var(--ksup-accent); border: 1px solid #aed6f1; }
.ksup-link--ks:hover  { background: #d6eaf8; color: var(--ksup-primary); }

/* ── 個別ページ ── */
.ksup-single { padding: 20px 0 60px; }
.ksup-single__article {
  background: #fff; border: 1px solid var(--ksup-border);
  border-radius: var(--ksup-radius); padding: 24px;
}
.ksup-single__title { font-size: 1.3rem; color: var(--ksup-text); margin: 10px 0 18px; line-height: 1.6; }
.ksup-single__info { width: 100%; border-collapse: collapse; margin-bottom: 20px; font-size: 0.9rem; }
.ksup-single__info th,
.ksup-single__info td { padding: 9px 12px; border: 1px solid var(--ksup-border); text-align: left; vertical-align: top; }
.ksup-single__info th { width: 110px; background: var(--ksup-bg); font-weight: bold; color: var(--ksup-sub); white-space: nowrap; }
.ksup-single__body { border-top: 1px solid var(--ksup-border); padding-top: 18px; font-size: 0.95rem; line-height: 1.8; }
.ksup-back { margin-top: 28px; text-align: center; }
.ksup-btn-back {
  display: inline-block; padding: 10px 24px;
  border: 2px solid var(--ksup-primary); border-radius: var(--ksup-radius);
  color: var(--ksup-primary); text-decoration: none; font-size: 0.9rem; font-weight: bold;
  transition: background 0.15s, color 0.15s;
}
.ksup-btn-back:hover { background: var(--ksup-primary); color: #fff; }

/* ── ページネーション ── */
.ksup-pagination { margin-top: 28px; text-align: center; }
.ksup-pagination .page-numbers {
  display: inline-block; padding: 6px 12px; margin: 2px;
  border: 1px solid var(--ksup-border); border-radius: 4px;
  text-decoration: none; color: var(--ksup-text); font-size: 0.9rem;
}
.ksup-pagination .page-numbers.current { background: var(--ksup-primary); color: #fff; border-color: var(--ksup-primary); }

/* ── 空 ── */
.ksup-empty { text-align: center; padding: 40px; color: var(--ksup-sub); border: 1px dashed var(--ksup-border); border-radius: var(--ksup-radius); }

/* ── モバイル ── */
@media (max-width: 600px) {
  .ksup-card__footer { flex-direction: column; align-items: flex-start; }
  .ksup-filter-row   { grid-template-columns: 1fr; }
  .ksup-single__article { padding: 14px; }
  .ksup-single__info th { width: 80px; }
}
