/* === KSC Jr. components.css === */

/* ── Admin bar ── */
.admin-bar-ksc {
  background: #1a1a2e; display: flex; align-items: center;
  gap: 2px; padding: 0 12px; height: 32px; font-size: 11px; overflow-x: auto;
}
.admin-bar-ksc__label { color: rgba(255,255,255,.5); margin-right: 6px; white-space: nowrap; }
.admin-bar-ksc a {
  color: rgba(255,255,255,.82); text-decoration: none;
  padding: 3px 9px; border-radius: 3px; white-space: nowrap; transition: background .15s;
}
.admin-bar-ksc a:hover { background: rgba(255,255,255,.15); }

/* ── Header ── */
.site-header {
  background: var(--color-primary);
  height: 80px;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
  position: sticky; top: 0; z-index: 100;
  width: 100%;
}
/* ヘッダー内コンテンツを1200pxに制限 */
.site-header__inner {
  width: 100%;
  max-width: 1200px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px;
  height: 100%;
}
.site-header__logo { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.site-header__logo-img {
  width: 52px; height: 52px; border-radius: 50%; object-fit: cover;
  border: 2px solid rgba(255,255,255,.3); flex-shrink: 0;
}
.site-header__logo-text { color: #fff; line-height: 1.25; }
.site-header__logo-text strong { display: block; font-size: 40px; font-weight: 500; letter-spacing: .01em; }
.site-header__logo-text small  { font-size: 10px; opacity: .72; font-weight: 400; letter-spacing: .08em; }

/* PC ナビ */
.site-header__nav { display: flex; align-items: center; }
.nav-list { display: flex; align-items: center; gap: 2px; list-style: none; }

/* nav-list 内の li — 直書きフォールバック & WordPress wp_nav_menu 両対応 */
.nav-list > li { position: relative; }

/* nav-list 内の a — 両対応 */
.nav-list > li > a,
.nav-list__link {
  display: block; color: rgba(255,255,255,.9); font-size: 13px;
  padding: 8px 13px; border-radius: 5px; white-space: nowrap;
  transition: background .15s;
}
.nav-list > li > a:hover,
.nav-list > li.current-menu-item > a,
.nav-list > li.current_page_item > a,
.nav-list__link:hover,
.nav-list__item.current-menu-item .nav-list__link {
  background: rgba(255,255,255,.18);
}
.nav-list > li.current-menu-item > a,
.nav-list > li.current_page_item > a { font-weight: 500; }

/* ドロップダウン (wp_nav_menu の子メニュー .sub-menu) */
.nav-list > li:hover > .sub-menu,
.nav-list > li:focus-within > .sub-menu { display: block; }
.nav-list .sub-menu {
  display: none; position: absolute; top: calc(100% + 6px); left: 0;
  min-width: 160px; background: #fff; border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0,0,0,.14); overflow: hidden; z-index: 200; list-style: none;
}
.nav-list .sub-menu li a {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; font-size: 13px; color: #1a1a1a;
  border-bottom: 0.5px solid rgba(0,0,0,.06); transition: background .12s;
  background: none; border-radius: 0; font-weight: 400;
}
.nav-list .sub-menu li:last-child a { border-bottom: none; }
.nav-list .sub-menu li a:hover { background: #FFF0F0 !important; color: var(--color-primary); }
.nav-list .sub-menu li a::before {
  content: ''; width: 3px; height: 3px; border-radius: 50%;
  background: var(--color-primary); flex-shrink: 0;
}

/* お問い合わせボタン — 直書き & WordPress menu-item-object-page 対応 */
.nav-list__link--contact,
.nav-list > li.menu-item-contact > a,
.nav-list > li:last-child > a {
  background: #fff !important; color: var(--color-primary) !important;
  font-weight: 500; border-radius: 20px; margin-left: 6px;
  padding: 7px 16px !important; transition: opacity .15s, transform .15s !important;
}
.nav-list__link--contact:hover,
.nav-list > li.menu-item-contact > a:hover,
.nav-list > li:last-child > a:hover {
  background: #fff !important; opacity: .88; transform: scale(1.03);
}

/* ハンバーガーボタン */
.nav-burger {
  display: none; flex-direction: column; justify-content: center; gap: 5px;
  width: 36px; height: 36px; padding: 6px; border: none; background: transparent;
  cursor: pointer; border-radius: 5px; transition: background .15s; flex-shrink: 0;
}
.nav-burger:hover { background: rgba(255,255,255,.15); }
.nav-burger span { display: block; height: 2px; background: #fff; border-radius: 1px; transition: all .25s; }
.nav-burger span:nth-child(2) { width: 75%; }
.nav-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger.is-open span:nth-child(2) { opacity: 0; transform: translateX(-6px); }
.nav-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* SP メニュー */
.sp-menu {
  background: #B31010; overflow: hidden;
  max-height: 0; transition: max-height .32s ease;
}
.sp-menu.is-open { max-height: 700px; }
.sp-menu__list { list-style: none; padding: 8px 0; }
.sp-menu__list li a,
.sp-menu__item > a {
  display: block; padding: 13px 20px;
  color: rgba(255,255,255,.92); font-size: 14px;
  border-bottom: 0.5px solid rgba(255,255,255,.1);
  transition: background .12s, padding-left .15s;
}
.sp-menu__list li a:hover,
.sp-menu__item > a:hover { background: rgba(255,255,255,.1); padding-left: 26px; }
.sp-menu__list .sub-menu { list-style: none; }
.sp-menu__item--sub > a,
.sp-menu__sublink {
  padding-left: 36px !important; font-size: 13px;
  opacity: .85; background: rgba(0,0,0,.1);
}
.sp-menu__item--sub > a:hover,
.sp-menu__sublink:hover { padding-left: 42px !important; }
.sp-menu__contact > a {
  display: block; margin: 10px 16px 6px;
  background: #fff; color: var(--color-primary) !important;
  text-align: center; border-radius: 6px; font-weight: 500;
  border-bottom: none !important; padding: 11px 20px !important;
  transition: opacity .15s !important;
}
.sp-menu__contact > a:hover { opacity: .88; padding-left: 20px !important; background: #fff; }

/* WordPress 管理バー表示時のオフセット調整 */
.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}

@media (max-width: 767px) {
  .site-header { height: 56px; padding: 0 14px; }
  .site-header__logo-img { width: 40px; height: 40px; }
  .site-header__logo-text strong { font-size: 14px; }
  .site-header__nav { display: none; }
  .nav-burger { display: flex; }
}

/* ── Hero slider ── */
.hero { position: relative; height: 420px; overflow: hidden; background: #111; }
.hero__slides { position: absolute; inset: 0; }
.hero__slide {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0; transition: opacity 1.1s cubic-bezier(.4,0,.2,1); will-change: opacity;
}
.hero__slide.is-active { opacity: 1; }
.hero__overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(135deg, rgba(196,20,20,.72) 0%, rgba(0,0,0,.45) 100%);
}
.hero__inner {
  position: relative; z-index: 2; height: 100%;
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 8px; padding: 20px; text-align: center;
}
.hero__tag {
  background: var(--color-primary); color: #fff;
  font-size: 11px; font-weight: 500; padding: 3px 10px; border-radius: 2px; letter-spacing: .06em;
}
.hero__title { color: #fff; font-size: 28px; font-weight: 500; line-height: 1.25; text-shadow: 0 2px 14px rgba(0,0,0,.4); }
.hero__sub   { color: rgba(255,255,255,.82); font-size: 13px; }
.hero__btn {
  margin-top: 4px; background: #fff; color: var(--color-primary);
  font-size: 13px; font-weight: 500; padding: 9px 22px; border-radius: 5px;
  display: inline-block; animation: pulse 2.5s infinite; transition: transform .15s;
}
.hero__btn:hover { transform: scale(1.04); }
.hero__dots { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); display: flex; gap: 7px; z-index: 3; }
.hero__dot {
  width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,.38);
  border: none; padding: 0; cursor: pointer; transition: background .25s, transform .25s;
}
.hero__dot.is-active { background: #fff; transform: scale(1.35); }
.hero__progress { position: absolute; bottom: 0; left: 0; height: 2px; background: rgba(255,255,255,.55); z-index: 4; transition: none; }
.hero__arr {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 32px; height: 32px; border-radius: 50%; background: rgba(0,0,0,.35);
  border: 0.5px solid rgba(255,255,255,.25); color: #fff; font-size: 18px;
  display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 3;
  transition: background .15s;
}
.hero__arr:hover { background: rgba(0,0,0,.6); }
.hero__arr--prev { left: 10px; }
.hero__arr--next { right: 10px; }
@media (max-width: 767px) { .hero { height: 280px; } }

/* ── Ticker ── */
.ticker { background: var(--color-primary); height: 30px; display: flex; align-items: center; overflow: hidden; }
.ticker__label {
  background: var(--color-primary-dark); color: #fff;
  font-size: 10px; font-weight: 500; padding: 0 10px;
  height: 100%; display: flex; align-items: center; white-space: nowrap; flex-shrink: 0;
}
.ticker__track { flex: 1; overflow: hidden; }
.ticker__inner { display: flex; gap: 40px; animation: ticker 22s linear infinite; width: max-content; }
.ticker__item  { color: #fff; font-size: 11px; white-space: nowrap; }
.ticker__item span { opacity: .6; margin-right: 5px; }

/* ── News ── */
.news-list { display: flex; flex-direction: column; gap: 8px; }
.news-item {
  display: flex; gap: 9px; align-items: flex-start;
  padding: 10px 12px; background: var(--color-bg-secondary);
  border-radius: 8px; border-left: 3px solid var(--color-primary);
}
.news-item__date  { font-size: 11px; color: var(--color-text-muted); white-space: nowrap; margin-top: 1px; }
.news-item__badge { font-size: 9px; background: var(--color-primary); color: #fff; padding: 2px 6px; border-radius: 2px; white-space: nowrap; flex-shrink: 0; }
.news-item__text  { font-size: 13px; line-height: 1.5; }

/* ── Post grid ── */
.posts-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 10px; }
.post-card {
  background: var(--color-bg-secondary); border-radius: 10px;
  overflow: hidden; border: 0.5px solid var(--color-border); cursor: pointer; transition: transform .15s;
}
.post-card:hover { transform: translateY(-2px); }
.post-card__thumb { height: 90px; display: flex; align-items: center; justify-content: center; font-size: 28px; }
.post-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.post-card__link { display: block; text-decoration: none; color: inherit; height: 100%; }
.post-card__link:hover .post-card__title { color: var(--color-primary); }
.post-card__body  { padding: 8px 10px; }
.post-card__date  { font-size: 10px; color: var(--color-text-muted); }
.post-card__title { font-size: 13px; font-weight: 500; margin-top: 3px; line-height: 1.4; }
.post-card__content { font-size: 12px; color: var(--color-text-muted); margin-top: 5px; line-height: 1.6; }

/* ── Calendar event list ── */
.cal-month { margin-bottom: 16px; }
.cal-month__title {
  font-size: 12px; font-weight: 500; color: var(--color-text-muted);
  padding: 3px 0 6px; border-bottom: 0.5px solid var(--color-border); margin-bottom: 7px;
}
.cal-events { display: flex; flex-direction: column; gap: 6px; }
.cal-event {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; border-radius: 8px;
  background: var(--color-bg-secondary); border-left: 3px solid #ccc;
}
.cal-event--thu   { border-left-color: var(--cal-thu); }
.cal-event--sat   { border-left-color: var(--cal-sat); }
.cal-event--sun,
.cal-event--holi  { border-left-color: var(--cal-sun); }
.cal-event--extra { border-left-color: var(--cal-extra); }
.cal-event--cancel {
  border-left-color: #7C3AED;
  background: #F5F3FF;
}
.cal-event--cancel .cal-event__badge { background: #7C3AED; color: #fff; }
.cal-event--cancel .cal-event__dow   { color: #7C3AED; }
.cal-event__day--cancel { opacity: .6; }
.cal-event__time--cancel,
.cal-event__place--cancel {
  text-decoration: line-through;
  color: var(--color-text-muted);
  opacity: .6;
}
.cal-event__cancel-note {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--cal-cancel);
  margin-top: 2px;
}
.cal-event__date  { min-width: 38px; text-align: center; }
.cal-event__day   { font-size: 17px; font-weight: 500; display: block; line-height: 1; }
.cal-event__dow   { font-size: 9px; display: block; }
.cal-event--thu .cal-event__dow   { color: var(--cal-thu); }
.cal-event--sat .cal-event__dow   { color: var(--cal-sat); }
.cal-event--sun .cal-event__dow,
.cal-event--holi .cal-event__dow  { color: var(--cal-sun); }
.cal-event--extra .cal-event__dow { color: var(--cal-extra); }
.cal-event--cancel .cal-event__dow { color: var(--cal-cancel); }
.cal-event__badge { font-size: 9px; padding: 1px 5px; border-radius: 2px; color: #fff; display: inline-block; margin-top: 2px; }
.cal-event--thu .cal-event__badge   { background: var(--cal-thu); }
.cal-event--sat .cal-event__badge   { background: var(--cal-sat); }
.cal-event--sun .cal-event__badge,
.cal-event--holi .cal-event__badge  { background: var(--cal-sun); }
.cal-event--extra .cal-event__badge { background: var(--cal-extra); }
.cal-event--cancel .cal-event__badge { background: #DC2626; color: #fff; }

/* cal-event__dow は非表示（バッジに統合） */
.cal-event__dow { display: none; }
.cal-event__detail { flex: 1; min-width: 0; }
.cal-event__time  { font-size: 12px; font-weight: 500; display: block; }
.cal-event__place { font-size: 11px; color: var(--color-text-muted); display: block; }
.cal-event__note  { font-size: 10px; color: var(--color-text-muted); display: block; margin-top: 2px; }
.cal-legend { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 8px; }
.cal-legend__item { display: flex; align-items: center; gap: 4px; font-size: 11px; color: var(--color-text-muted); }
.cal-legend__dot  { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* ── Map section ── */
.map-section__label { font-size: 12px; color: var(--color-text-muted); margin-bottom: 8px; display: flex; align-items: center; gap: 5px; }
.map-section__embed { border-radius: 12px; overflow: hidden; height: 220px; }
.map-section__embed iframe { width: 100%; height: 100%; border: 0; }
.map-section__link { display: inline-block; font-size: 12px; color: #4285F4; margin-top: 6px; }

/* ── SNS cards ── */
.sns-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.sns-card {
  display: flex; align-items: center; gap: 9px; padding: 10px 12px;
  background: var(--color-bg-secondary); border-radius: 9px;
  border: 0.5px solid var(--color-border); text-decoration: none; color: var(--color-text); transition: transform .15s;
}
.sns-card:hover { transform: translateY(-2px); }
.sns-card__icon { width: 34px; height: 34px; border-radius: 7px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 16px; }
.sns-card--line .sns-card__icon  { background: #06C755; color: #fff; }
.sns-card--insta .sns-card__icon { background: radial-gradient(circle at 30% 110%,#fdf497 0,#fd5949 45%,#d6249f 70%,#285AEB 100%); color: #fff; }
.sns-card__name { font-size: 12px; font-weight: 500; display: block; }
.sns-card__desc { font-size: 10px; color: var(--color-text-muted); display: block; }

/* ── External links ── */
.ext-links__list { display: flex; flex-direction: column; gap: 5px; }
.ext-links__item a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 11px; background: var(--color-bg-secondary); border-radius: 7px;
  border: 0.5px solid var(--color-border); font-size: 12px; transition: border-color .15s, transform .12s;
}
.ext-links__item a:hover { border-color: var(--color-primary); transform: translateX(2px); }
.ext-links__name { font-weight: 500; display: block; }
.ext-links__desc { font-size: 10px; color: var(--color-text-muted); display: block; }
.ext-links__arrow { color: var(--color-primary); font-size: 13px; flex-shrink: 0; }

/* ── Join banner ── */
.join-banner {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  border-radius: 10px; padding: 18px 16px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.join-banner__title { color: #fff; font-size: 15px; font-weight: 500; }
.join-banner__desc  { color: rgba(255,255,255,.85); font-size: 12px; margin-top: 4px; line-height: 1.5; }
.join-banner__btn {
  background: #fff; color: var(--color-primary);
  font-size: 12px; font-weight: 500; padding: 8px 16px;
  border-radius: 6px; white-space: nowrap; flex-shrink: 0; transition: transform .15s;
}
.join-banner__btn:hover { transform: scale(1.04); }

/* ── Sidebar ── */
.sidebar { border-left: 0.5px solid var(--color-border); padding-left: 20px; }
.sb-widget { margin-bottom: 20px; }
.sb-widget__title { font-size: 13px; font-weight: 500; margin-bottom: 10px; padding-bottom: 6px; border-bottom: 0.5px solid var(--color-border); }
.sb-news { display: flex; flex-direction: column; gap: 8px; }
.sb-news__item { font-size: 12px; line-height: 1.5; }
.sb-news__date { display: block; font-size: 10px; color: var(--color-text-muted); }
.sb-news__item a:hover { color: var(--color-primary); }
.sb-cats { display: flex; flex-wrap: wrap; gap: 5px; }
.sb-cats a {
  font-size: 11px; padding: 3px 9px; border-radius: 3px;
  background: var(--color-bg-secondary); border: 0.5px solid var(--color-border);
  color: var(--color-text-muted); transition: border-color .15s, color .15s;
}
.sb-cats a:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ── Single post ── */
.single-post__hero { border-radius: 8px; overflow: hidden; height: 200px; margin-bottom: 16px; background: var(--color-bg-secondary); position: relative; }
.single-post__hero img { width: 100%; height: 100%; object-fit: cover; }
.post-cat-badge { position: absolute; top: 10px; left: 10px; background: var(--color-primary); color: #fff; font-size: 10px; padding: 2px 8px; border-radius: 2px; }
.post-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.post-meta__date { font-size: 11px; color: var(--color-text-muted); }
.post-meta__cat  { font-size: 11px; background: var(--color-primary-light); color: var(--color-primary); padding: 2px 7px; border-radius: 2px; }
.single-post__title { font-size: 22px; font-weight: 500; line-height: 1.35; margin-bottom: 16px; }
.single-post__body  { font-size: 14px; line-height: 1.85; }
.single-post__body p { margin-bottom: 14px; }
.single-post__body strong { font-weight: 500; }
.no-comment-note {
  background: var(--color-bg-secondary); border: 0.5px solid var(--color-border);
  border-radius: 8px; padding: 10px 14px; font-size: 12px; color: var(--color-text-muted);
  margin-top: 20px;
}
.no-comment-note a { color: var(--color-primary); }
.post-navigation { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 20px; border-top: 0.5px solid var(--color-border); padding-top: 16px; }
.post-navigation a { background: var(--color-bg-secondary); border-radius: 8px; padding: 10px 12px; display: block; border: 0.5px solid var(--color-border); transition: border-color .15s; font-size: 12px; }
.post-navigation a:hover { border-color: var(--color-primary); }
.post-navigation__label { font-size: 10px; color: var(--color-text-muted); display: block; margin-bottom: 3px; }
.post-navigation .next { text-align: right; }

/* ── Archive ── */
.archive-header { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%); padding: 20px 16px; color: #fff; }
.archive-header__title { font-size: 18px; font-weight: 500; }
.archive-header__count { font-size: 12px; opacity: .8; margin-top: 4px; }
.filter-bar { padding: 10px 16px; background: var(--color-bg-secondary); border-bottom: 0.5px solid var(--color-border); display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.filter-bar__label { font-size: 11px; color: var(--color-text-muted); }
.filter-btn {
  font-size: 11px; padding: 3px 10px; border-radius: 3px;
  border: 0.5px solid var(--color-border); background: var(--color-bg);
  color: var(--color-text-muted); cursor: pointer; transition: all .12s;
}
.filter-btn.is-active,
.filter-btn:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.archive-list { display: flex; flex-direction: column; }
.archive-item { display: flex; gap: 12px; padding: 14px 16px; border-bottom: 0.5px solid var(--color-border); text-decoration: none; color: var(--color-text); transition: background .12s; align-items: flex-start; }
.archive-item:hover { background: var(--color-bg-secondary); }
.archive-item__thumb { width: 80px; height: 60px; border-radius: 6px; flex-shrink: 0; overflow: hidden; background: var(--color-bg-secondary); display: flex; align-items: center; justify-content: center; font-size: 24px; }
.archive-item__thumb img { width: 100%; height: 100%; object-fit: cover; }
.archive-item__meta  { display: flex; gap: 6px; align-items: center; margin-bottom: 4px; }
.archive-item__date  { font-size: 10px; color: var(--color-text-muted); }
.archive-item__cat   { font-size: 10px; background: var(--color-primary-light); color: var(--color-primary); padding: 1px 6px; border-radius: 2px; }
.archive-item__title   { font-size: 14px; font-weight: 500; line-height: 1.4; margin-bottom: 4px; }
.archive-item__excerpt { font-size: 12px; color: var(--color-text-muted); line-height: 1.55; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.wp-pagenavi,
.navigation.pagination { padding: 16px; display: flex; gap: 4px; justify-content: center; }
.wp-pagenavi a, .wp-pagenavi span,
.page-numbers { min-width: 32px; height: 32px; border-radius: 5px; border: 0.5px solid var(--color-border); display: inline-flex; align-items: center; justify-content: center; font-size: 12px; }
.wp-pagenavi .current,
.page-numbers.current { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

/* ── Contact page ── */
.contact-header { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%); padding: 20px 16px; color: #fff; }
.contact-header h1 { font-size: 18px; font-weight: 500; }
.contact-header p  { font-size: 12px; opacity: .82; margin-top: 4px; }
.contact-form { display: flex; flex-direction: column; gap: 14px; }
.form-fieldset { border: none; padding: 0; }
.form-legend  { font-size: 12px; color: var(--color-text-muted); margin-bottom: 8px; font-weight: 500; }
.radio-group  { display: flex; gap: 12px; flex-wrap: wrap; }
.radio-label  { display: flex; align-items: center; gap: 5px; font-size: 13px; cursor: pointer; }
.radio-label input { accent-color: var(--color-primary); }
.form-group   { display: flex; flex-direction: column; gap: 4px; }
.form-label   { font-size: 12px; color: var(--color-text-muted); display: flex; align-items: center; gap: 4px; }
.form-req     { font-size: 9px; background: var(--color-primary); color: #fff; padding: 1px 4px; border-radius: 2px; }
.form-opt     { font-size: 9px; background: var(--color-border); color: var(--color-text-muted); padding: 1px 4px; border-radius: 2px; }
.form-input, .form-select, .form-textarea {
  border: 0.5px solid #ccc; border-radius: 6px; padding: 9px 11px;
  font-size: 13px; font-family: inherit; background: var(--color-bg);
  color: var(--color-text); outline: none; transition: border-color .15s; width: 100%;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color: var(--color-primary); }
.form-textarea { min-height: 110px; resize: vertical; }
.form-grid     { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 600px) { .form-grid { grid-template-columns: 1fr; } }
.privacy-note {
  background: var(--color-bg-secondary); border-radius: 7px; padding: 10px 13px;
  font-size: 11px; color: var(--color-text-muted); line-height: 1.6;
  border: 0.5px solid var(--color-border);
}
.agree-label { display: flex; align-items: center; gap: 7px; font-size: 13px; cursor: pointer; }
.agree-label input { accent-color: var(--color-primary); }
.btn-primary {
  background: var(--color-primary); color: #fff; border: none;
  padding: 11px 28px; border-radius: 6px; font-size: 14px; font-weight: 500;
  cursor: pointer; font-family: inherit; transition: opacity .15s; align-self: flex-start;
}
.btn-primary:hover { opacity: .85; }
.btn-danger  { background: #DC2626; color: #fff; border: none; padding: 5px 10px; border-radius: 4px; font-size: 11px; cursor: pointer; font-family: inherit; }
.alert { border-radius: 7px; padding: 12px 14px; font-size: 13px; margin-bottom: 12px; }
.alert--success { background: #f0fdf4; border: 0.5px solid #16A34A; color: #166534; }
.alert--error   { background: #fef2f2; border: 0.5px solid #DC2626; color: #991b1b; }
.alert ul { padding-left: 16px; list-style: disc; }
.contact-thanks { text-align: center; padding: 40px 20px; }
.contact-thanks .thanks-icon { font-size: 48px; margin-bottom: 16px; }
.contact-thanks h2 { font-size: 18px; font-weight: 500; margin-bottom: 8px; }
.contact-thanks p  { font-size: 13px; color: var(--color-text-muted); line-height: 1.7; margin-bottom: 20px; }

/* ── Calendar edit page ── */
.cal-edit-section { margin-bottom: 24px; border: 0.5px solid var(--color-border); border-radius: 9px; padding: 16px; background: var(--color-bg-secondary); }
.cal-edit-section h2 { font-size: 14px; font-weight: 500; margin-bottom: 8px; }
.cal-edit-note { font-size: 12px; color: var(--color-text-muted); margin-bottom: 12px; }
.cal-override-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.cal-override-table th, .cal-override-table td { padding: 6px 10px; border-bottom: 0.5px solid var(--color-border); text-align: left; }
.cal-override-table th { background: var(--color-bg); font-weight: 500; font-size: 11px; color: var(--color-text-muted); }

/* ── News post page ── */
.news-post-page .container { max-width: 680px; margin: 0 auto; padding: 24px 16px; }
.page-title { font-size: 20px; font-weight: 500; margin-bottom: 20px; }
.news-post-form { display: flex; flex-direction: column; gap: 14px; }
.draft-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; cursor: pointer;
  padding: 10px 14px; border-radius: 7px;
  background: var(--color-bg-secondary); border: 0.5px solid var(--color-border);
}
.draft-label input { accent-color: var(--color-primary); width: 16px; height: 16px; flex-shrink: 0; }

/* ── Footer ── */
.site-footer { background: #1a1a1a; color: rgba(255,255,255,.55); text-align: center; padding: 20px 16px; font-size: 11px; }
.site-footer__name { color: #fff; display: block; font-size: 13px; margin-bottom: 4px; }
.site-footer__copy { margin-top: 8px; font-size: 10px; }

@keyframes pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(196,20,20,.4); }
  70%      { box-shadow: 0 0 0 8px rgba(196,20,20,0); }
}
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
