@charset "utf-8";

/* ==========================================================================
   サイトヘッダー（堺市公園協会）
   ========================================================================== */
/*
<header class="l-header">
  <div class="l-header__top">
    <div class="l-header__top-inner">
      <a class="l-header__logo">...</a>
      <div class="l-header__utility">...</div>         ← PC用
      <div class="l-header__mobile-controls">...</div> ← SP用
    </div>
  </div>
  <nav class="l-global-nav">...</nav>
</header>
*/
.l-header {
  width: 100%;
  background-color: #fff;
}
	
.l-header--fixed {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
}
	
/* ---- 上段 ---- */
.l-header__top {
  background-color: #fff;
}
.l-header__top-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--s-15); /* 60px */
  padding: 0 0 0 var(--s-4);
}

/* ---- ロゴ ---- */
.l-header__logo {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  z-index: 130;
  text-decoration: none;
  /*flex-shrink: 0;*/
  min-width: 0;
}
.l-header__logo:hover {
  opacity: 0.85;
}
.l-header__logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  color: var(--color-accent);
  flex-shrink: 0;
}
.l-header__logo-mark svg {
  width: 100%;
  height: 100%;
  display: block;
}
.l-header__logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1.15;
  min-width: 0;
}
.l-header__logo-en {
	font-family: var(--font-eng);
  font-size: var(--text-10); /* 10px */
  color: #666;
  font-weight: 600;
}
.l-header__logo-ja {
  font-size: 0.875rem; /* 14px */
  font-weight: 800;
  /*white-space: nowrap;*/
	white-space: normal; 
	overflow-wrap: anywhere;
}

/* ---- デスクトップ用ユーティリティ（PCで表示） ---- */
.l-header__utility {
  display: none;
  align-items: center;
  gap: var(--s-5);
}

/* 閲覧補助（背景色・文字サイズ） */
.l-a11y-group {
  display: flex;
  align-items: center;
  gap: var(--s-2);
	font-size: var(--text-14);
}
.l-a11y-group__label {
  font-weight: 500;
  white-space: nowrap;
}
.l-a11y-group__btns {
  display: flex;
  gap: var(--s-1);
}
.l-a11y-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 1.875rem; /* 30px */
  padding: 0 var(--s-2);
  border: 1px solid #cfcfcf;
  background-color: #fff;
  font-size: var(--text-14);
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  line-height: 1;
  border-radius: 2px;
}
.l-a11y-btn:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
/* 背景色ボタン（黒） */
.l-a11y-btn--bg-black {
  background-color: #111;
  border-color: #111;
  color: #fff;
}
.l-a11y-btn--bg-black:hover {
  background-color: #000;
  border-color: #000;
  color: #fff;
}
/* 背景色ボタン（青） */
.l-a11y-btn--bg-blue {
  background-color: #0034a1;
  border-color: #0034a1;
  color: #ffff00;
}
.l-a11y-btn--bg-blue:hover {
  background-color: #00277a;
  border-color: #00277a;
  color: #ffff00;
}
/* 文字サイズ：アクティブ */
.l-a11y-btn--size.is-active {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}
.l-a11y-btn--size {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.l-a11y-btn--size:hover {
  background-color: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
  color: #fff;
}

/* 検索フォーム */
.l-header__search {
  display: flex;
  align-items: stretch;
  height: 2.25rem; /* 36px */
}
.l-header__search-input {
  height: 100%;
  padding: 0 var(--s-3);
  border: 1px solid #cfcfcf;
  border-right: none;
  background-color: #fff;
  font-size: var(--text-14);
  width: 100%;
  outline: none;
  border-radius: 2px 0 0 2px;
}
.l-header__search-input:focus {
  border-color: var(--color-accent);
}
.l-header__search-btn {
  height: 100%;
  padding: 0 var(--s-4);
  border: 1px solid var(--color-accent);
  background-color: var(--color-accent);
  color: #fff;
  font-size: var(--text-14);
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
  white-space: nowrap;
  border-radius: 0 2px 2px 0;
}
.l-header__search-btn:hover {
  background-color: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
}

/* SNSアイコン */
.l-header__sns {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  list-style: none;
  margin: 0;
  padding: 0;
}
.l-header__sns-item {
  list-style: none;
}
.l-header__sns-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
	font-size: var(--text-14);
  color: #fff;
  text-decoration: none;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.l-header__sns-link:hover {
  transform: translateY(-2px);
  opacity: 0.9;
}
.l-header__sns-link--instagram {
  background: radial-gradient(circle at 30% 110%, #ffd870 0%, #f96e46 25%, #d53d95 55%, #8f2cc4 80%, #4d5bff 100%);
}
.l-header__sns-link--facebook {
  background-color: #1877f2;
}
.l-header__sns-link--x {
  background-color: #000;
}

/* ---- モバイル用コントロール ---- */
.l-header__mobile-controls {
  display: flex;
  align-items: stretch;
  height: var(--s-15); /* 60px */
  margin-left: auto;
}
.l-a11y-toggle {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
	width: var(--s-15);
	height: var(--s-15);
  background-color: #fff;
	border-left:1px solid #eee;
  cursor: pointer;
  font-weight: 700;
  line-height: 1;
  transition: background-color 0.2s ease;
}
.l-a11y-toggle:hover {
  background-color: var(--color-accent-light);
}
.l-a11y-toggle i {
  font-size: var(--text-18);
	color: var(--color-accent);
}
.l-a11y-toggle__label {
	font-size: var(--text-10);
}

/* ==========================================================================
   ハンバーガーメニュー
   ========================================================================== */
.l-hamburger-btn {
  position: relative;
  z-index: 150;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  width: var(--s-15);
  height: var(--s-15);
  padding: var(--s-4);
  background-color: var(--color-accent);
  cursor: pointer;
  transition: background-color 0.2s ease;
  border: none;
}
.l-hamburger-btn:hover {
  background-color: var(--color-accent-dark);
}
.l-hamburger-btn__bar {
  display: block;
  width: 100%;
  height: 2px;
  background-color: #fff;
  transition: transform 0.4s ease;
}
.l-hamburger-btn.is-active .l-hamburger-btn__bar:nth-of-type(1) {
  transform: translateY(10px) rotate(45deg);
}
.l-hamburger-btn.is-active .l-hamburger-btn__bar:nth-of-type(2) {
  transform: scaleX(0);
}
.l-hamburger-btn.is-active .l-hamburger-btn__bar:nth-of-type(3) {
  transform: translateY(-10px) rotate(-45deg);
}

/* ==========================================================================
   グローバルナビ
   ========================================================================== */
.l-global-nav {
  position: fixed;
  top: var(--s-15);
  right: 0;
  z-index: 120;
  width: 100%;
  height: calc(100% - var(--s-15));
  padding: 0 0 var(--s-15);
  background-color: rgba(255, 255, 255, 0.98);
  overflow-y: auto;
  backdrop-filter: blur(5px);
  transform: translateX(100%);
  transition: transform 0.4s ease;
}
.l-global-nav.is-active {
  transform: translateX(0);
}
.l-global-nav__list {
  margin: 0;
  padding: 0;
  list-style: none;
  text-align: center;
  border-top: 1px solid var(--color-border);
}
.l-global-nav__item {
  border-bottom: 1px solid var(--color-border);
  list-style: none;
}
.l-global-nav__link {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-4);
  font-size: var(--text-16);
  font-weight: 700;
  line-height: 1.2;
  transition: color 0.2s ease;
  text-align: left;
  text-decoration: none;
}
.l-global-nav__link:hover {
  color: var(--color-primary-dark);
  opacity: 1;
}
.l-global-nav__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  color: var(--color-primary);
  font-size: var(--text-16);
  flex-shrink: 0;
}
.l-global-nav__icon svg{
	width:20px;
	height:20px;
	}

/* ---- SP時のみ：ナビ内SNSアイコン（お問合せの下に中央配置） ---- */
.l-global-nav__sns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--s-4);
  list-style: none;
  margin: 0;
  padding: var(--s-8) var(--s-4);
}
.l-global-nav__sns-item {
  list-style: none;
}
.l-global-nav__sns .l-header__sns-link {
  width: 2.75rem;
  height: 2.75rem;
  font-size: 1.125rem;
}

/* ==========================================================================
   ドロップダウンメニュー
   ========================================================================== */
.l-global-nav__item.has-submenu {
  position: relative;
}
.l-global-nav__item-main {
  position: relative;
}
.l-global-nav__item-main > .l-global-nav__link {
  display: flex;
  width: 100%;
  text-align: left;
}
.l-submenu {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s ease-in-out;
  list-style: none;
  margin: 0;
  padding: 0;
}
.l-submenu__item {
  list-style: none;
}
.l-submenu__link {
  display: block;
  padding: var(--s-4) var(--s-4);
  border-top: 1px solid #eee;
  background-color: var(--color-accent-light);
  font-size: var(--text-14);
  line-height: 1.2;
  text-align: left;
  text-decoration: none;
}
.l-submenu__item:first-child .l-submenu__link {
    border-top: none;
}
.l-submenu__link:hover {
  color: var(--color-accent);
  opacity: 1;
}
.l-submenu__link i{
	color:#666;
	font-size: var(--text-12);
	}
.l-submenu-toggle {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  background-color: var(--color-accent);
  border: none;
  cursor: pointer;
}
.l-submenu-toggle:hover {
  background-color: var(--color-accent-dark);
}
.l-submenu-toggle::before,
.l-submenu-toggle::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 10px;
  height: 2px;
  background-color: #fff;
  transition: transform 0.3s ease;
}
.l-submenu-toggle::before { transform: translate(-50%, -50%); }
.l-submenu-toggle::after  { transform: translate(-50%, -50%) rotate(90deg); }
.l-global-nav__item.has-submenu.is-open .l-submenu-toggle::after {
  display: none;
}

/* ==========================================================================
   PC（1024px以上）
   ========================================================================== */
@media (min-width: 1024px) {
	.l-header--fixed {
		position:static;
	}
  /* ---- 上段レイアウト ---- */
  .l-header__top {
  }
  .l-header__top-inner {
    /*max-width: 90rem;*/
    margin: 0 auto;
    height: 6.25rem; /* 100px */
    padding: 0 var(--s-10);
    gap: var(--s-5);
  }
  .l-header__logo {
    gap: var(--s-5);
  }
  .l-header__logo-mark {
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-header__logo-en {
    font-size: var(--text-12);
		margin-bottom:var(--s-1);
  }
  .l-header__logo-ja {
    font-size: 1.375rem;
  }

  .l-header__utility {
    display: flex;
  }
  .l-header__mobile-controls {
    display: none;
  }
  /* SP用のナビ内SNSはPCで非表示 */
  .l-global-nav__sns {
    display: none;
  }

  /* ---- 下段：ナビ横並び ---- */
  .l-global-nav {
    position: static;
    display: flex;
    align-items: stretch;
    justify-content: center;
    width: 100%;
    height: auto;
    padding: 0;
		background-color: #fff;
    backdrop-filter: none;
    overflow-y: visible;
    transform: none;
  }
	.l-header--fixed .l-global-nav{
		background-color: rgba(255,255,255,0.9);
		position: fixed;
		top: 0;
		left: 0;
		z-index: 100;
		}
  .l-global-nav__list {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: space-between;
    /*max-width: 90rem;*/
    width: 100%;
    height: 100%;
    margin: 0;
    /*padding: 0 var(--s-6);*/
    border-top: none;
    /*gap: var(--s-2);*/
  }
  .l-global-nav__item {
    display: flex;
    align-items: stretch;
    border-bottom: none;
    position: relative;
    flex: 1;
		border-left: 1px solid #eeeeee;
  }
	.l-global-nav__item:first-child {
		border-left: none;
	}
  .l-global-nav__item-main {
    display: flex;
    align-items: stretch;
    height: 100%;
    width: 100%;
  }
  .l-global-nav__link {
		width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-2);
    padding: var(--s-4) var(--s-3);
    height: 100%;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    /*font-size: var(--text-15);*/
    border-bottom: 3px solid transparent;
    transition: color 0.2s ease, border-color 0.2s ease;
  }
  .l-global-nav__item-main > .l-global-nav__link {
    width: 100%;
  }
  .l-global-nav__link:hover {
    color: var(--color-primary-dark);
    border-bottom-color: var(--color-primary-dark);
    opacity: 1;
  }
  .l-global-nav__icon {
    width: auto;
    height: auto;
    font-size: 1.125rem;
    color: var(--color-primary);
  }

  /* ---- サブメニュー矢印 ---- */
  .has-submenu .l-global-nav__item-main > .l-global-nav__link::after {
    content: '';
    display: inline-block;
    width: 0.45rem;
    height: 0.45rem;
    margin-left: 0.var(--text-16);
    border-right: 1px solid #aaa;
    border-bottom: 1px solid #aaa;
    transform: translateY(-0.18rem) rotate(45deg);
    flex-shrink: 0;
  }

  /* ---- ドロップダウン（PC） ---- */
  .l-submenu-toggle {
    display: none;
  }
  .l-submenu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    /*transform: translateX(-50%) translateY(-6px);*/
    transition: opacity 0.25s ease, transform 0.25s ease;
		width: 100%;
    /*width: max-content;
		min-width: 100%;
    max-width: min(20rem, calc(100vw - 2rem));*/
		max-height: calc(100vh - 175px);
    overflow-y: auto;
    overflow-x: hidden;
    background-color: #fff;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
    opacity: 0;
    z-index: 200;
    pointer-events: none;
  }
	.l-header--fixed .l-submenu {
		max-height: calc(100vh - 75px);
	}
  .l-global-nav__item.has-submenu:hover .l-submenu,
  .l-global-nav__item.has-submenu:focus-within .l-submenu {
    opacity: 1;
    pointer-events: auto;
		transform: translateX(-50%);
    /*transform: translateX(-50%) translateY(0);*/
  }
  .l-submenu__link {
    display: block;
    background-color: #fff;
		font-size: var(--text-15);
  }
  .l-submenu__link:hover {
    background-color: var(--color-accent-light);
    color: var(--color-accent);
    opacity: 1;
  }
}

/* 中間サイズ（タブレット）向け微調整 */
@media (min-width: 1024px) and (max-width: 1199px) {
  .l-header__top-inner {
    gap: var(--s-3);
    padding: 0 var(--s-4);
  }
  .l-header__utility {
    gap: var(--s-3);
  }
  .l-header__search-input {
    width: 8rem;
  }
  .l-global-nav__link {
    padding: var(--s-4) var(--s-2);
    font-size: var(--text-14);
  }
}

/* ==========================================================================
   閲覧補助 モーダル（SP）
   ========================================================================== */
.l-a11y-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--s-4);
}
.l-a11y-modal.is-open {
  display: flex;
}
.l-a11y-modal__overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(3px);
  cursor: pointer;
}
.l-a11y-modal__content {
  position: relative;
  width: 100%;
  max-width: 28rem;
  padding: var(--s-5);
  background-color: #fff;
  border-radius: 12px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.2);
  animation: l-a11y-modal-in 0.25s ease-out;
  overflow: visible;
}
@keyframes l-a11y-modal-in {
  from { opacity: 0; transform: translateY(10px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.l-a11y-modal__title {
  font-size: var(--text-20);
  font-weight: 700;
  text-align: center;
  color: var(--color-primary);
  margin: 0 0 var(--s-5);
  letter-spacing: 0.05em;
}
.l-a11y-modal__group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-3) 0;
}
.l-a11y-modal__label {
  font-size: var(--text-16);
  font-weight: 600;
}
.l-a11y-modal__btns {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  flex-wrap: wrap;
}
/* 丸ボタン（背景色） */
.l-a11y-circle-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border: 2px solid #ccc;
  border-radius: 50%;
  background-color: #fff;
  color: #333;
  font-size: 0.875rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  line-height: 1;
}
.l-a11y-circle-btn:hover {
  transform: translateY(-1px);
  border-color: #999;
}
.l-a11y-circle-btn.is-active {
  box-shadow: 0 0 0 3px var(--color-accent, #4a8f1e);
  border-color: #fff;
}
.l-a11y-circle-btn--white {
  background-color: #fff;
  color: #333;
}
.l-a11y-circle-btn--black {
  background-color: #111;
  border-color: #111;
  color: #fff;
}
.l-a11y-circle-btn--black.is-active {
  border-color: #fff;
}
.l-a11y-circle-btn--blue {
  background-color: #0034a1;
  border-color: #0034a1;
  color: #ffff00;
}
.l-a11y-circle-btn--blue.is-active {
  border-color: #fff;
}
/* ピルボタン（文字サイズ） */
.l-a11y-pill-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 5rem;
  height: 2.75rem;
  padding: 0 var(--s-5);
  border: 2px solid #4a8f1e;
  border-radius: 999px;
  background-color: #fff;
  color: #2a6612;
  font-size: var(--text-16);
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
  line-height: 1;
}
.l-a11y-pill-btn:hover {
  background-color: #eaf4dd;
}
.l-a11y-pill-btn.is-active {
  background-color: #4a8f1e;
  color: #fff;
}
/* 閉じるボタン */
.l-a11y-modal__close {
  position: absolute;
  right: var(--s-5);
  top: var(--s-4);
  bottom: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border: none;
  border-radius: 50%;
  background-color: var(--color-red);
  color: #fff;
  cursor: pointer;
  font-size: var(--text-16);
  transition: background-color 0.2s ease;
}
.l-a11y-modal__close:hover {
  background-color: var(--color-red-dark);
}
/* モーダル内サジェストボックス */
.l-a11y-modal .l-header__search {
  position: relative;
  width: 100%;
}
.l-a11y-modal #suggest-box-modal {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  width: 100%;
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 999999;
  overflow-y: auto;
  max-height: 200px;
}
/* PCでは閲覧補助モーダルは常に不要（上段にインライン表示済み） */
@media (min-width: 1024px) {
  .l-a11y-modal,
  .l-a11y-modal.is-open {
    display: none;
  }
}

/* ==========================================================================
   サイト内検索
   ========================================================================== */

/* ヘッダー・フッター共通 */
.l-header__search {
  position: relative;
}

/* ヘッダーサジェスト */
#suggest-box {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  width: 100%;
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: 0 4px 12px rgba(0,0,0,.15);
  z-index: 99999;
  overflow-y: auto;
  max-height: 200px;
}

/* フッターサジェスト */
#suggest-box-modal {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  width: 100%;
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: 0 4px 12px rgba(0,0,0,.15);
  z-index: 99999;
  overflow-y: auto;
  max-height: 200px;
}

/* サジェスト共通 */
.suggest-item a {
  display: block;
  padding: 10px 14px;
  color: #333;
  text-decoration: none;
  font-size: 14px;
  line-height: 1.4;
}
.suggest-item a:hover {
  background: #f3f7ed;
  color: #4b7f1e;
}
.suggest-empty {
  font-size: 0.8em;
  padding: 3px 3px 3px 6px;
}

/* モーダル内（現在は未使用・念のため残す） */
.l-a11y-modal .l-header__search {
  position: relative;
}
.l-a11y-modal #suggest-box-modal {
  z-index: 999999;
}

/* ==========================================================================
   背景色変更 ／ 文字サイズ変更（body/html モディファイア）
   ========================================================================== */
/* 文字サイズ：拡大（ルートフォントを拡大 → rem が連動してスケール） */
html.is-text-large {
  font-size: 112.5%; /* 18px */
}

/* ==========================================================================
   背景色：黒（黒背景＋白文字／リンク・強調は黄色 #ffff00）
   ==========================================================================
   方針：
   - 背景はすべて #000、文字は #fff、リンク・ボタン・強調は #ffff00
   - 装飾背景画像・カラーグラデーションは無効化
   - ボタン／タグは黒地＋黄色枠＋黄色文字、hover で反転（黄地＋黒文字）
   - a11y モーダル内のテーマ切替ボタンは視認性維持のため別途上書き
========================================================================== */

/* --- ベース --- */
body.is-bg-black {
	background-color: #000 !important;
	color: #fff !important;
}

/* --- セクション／コンテナ系の背景・文字を一括統一 --- */
body.is-bg-black main,
body.is-bg-black section,
body.is-bg-black .l-section,
body.is-bg-black .l-header,
body.is-bg-black .l-header--fixed,
body.is-bg-black .l-header__top,
body.is-bg-black .l-global-nav,
body.is-bg-black .l-submenu,
body.is-bg-black .l-a11y-modal__content,
body.is-bg-black .l-footer,
body.is-bg-black .intro,
body.is-bg-black .news,
body.is-bg-black .activities,
body.is-bg-black .about,
body.is-bg-black .insta,
body.is-bg-black .c-page-hero,
body.is-bg-black .c-card,
body.is-bg-black .c-accordion,
body.is-bg-black .c-accordion__body,
body.is-bg-black .c-tabs__panel,
body.is-bg-black .c-table-stacked,
body.is-bg-black .c-history,
body.is-bg-black .c-process,
body.is-bg-black .c-media {
	background-color: #000 !important;
	background-image: none !important;
	color: #fff !important;
}

/* --- リンクは黄色 --- */
body.is-bg-black a,
body.is-bg-black a:link,
body.is-bg-black a:visited,
body.is-bg-black a:hover,
body.is-bg-black a:focus,
body.is-bg-black a:active {
	color: #ffff00 !important;
}

/* --- 見出し・本文テキストはすべて白（色指定を持つ要素を上書き） --- */
body.is-bg-black h1,
body.is-bg-black h2,
body.is-bg-black h3,
body.is-bg-black h4,
body.is-bg-black h5,
body.is-bg-black h6,
body.is-bg-black p,
body.is-bg-black li,
body.is-bg-black dt,
body.is-bg-black dd,
body.is-bg-black th,
body.is-bg-black td,
body.is-bg-black figcaption,
body.is-bg-black time,
body.is-bg-black small,
body.is-bg-black .c-heading-lg,
body.is-bg-black .c-heading-md,
body.is-bg-black .c-heading-sm,
body.is-bg-black .c-heading-xs,
body.is-bg-black .c-page-hero__title,
body.is-bg-black .c-page-hero__title span,
body.is-bg-black .sec-head,
body.is-bg-black .sec-head__sub,
body.is-bg-black .sec-head__title,
body.is-bg-black .intro__title,
body.is-bg-black .intro__title-accent,
body.is-bg-black .intro__text,
body.is-bg-black .news-card__date,
body.is-bg-black .news-card__title,
body.is-bg-black .c-card__title,
body.is-bg-black .c-card__text,
body.is-bg-black .c-card__label,
body.is-bg-black .l-header__logo-ja,
body.is-bg-black .l-header__logo-en,
body.is-bg-black .l-footer__logo-ja,
body.is-bg-black .l-footer__logo-en,
body.is-bg-black .l-footer__address,
body.is-bg-black .l-footer__address span,
body.is-bg-black .l-footer__open,
body.is-bg-black .l-footer__tel,
body.is-bg-black .l-footer__copy,
body.is-bg-black .l-global-nav__link,
body.is-bg-black .l-submenu__link {
	color: #fff !important;
}

/* --- ボタン共通：黒地＋黄色枠＋黄色文字、hover で反転 --- */
body.is-bg-black .c-btn,
body.is-bg-black .c-btn--primary,
body.is-bg-black .btn-leaf,
body.is-bg-black .btn-leaf--lg,
body.is-bg-black .news__more-link {
	background-color: #000 !important;
	background-image: none !important;
	color: #ffff00 !important;
}
body.is-bg-black .c-btn:hover,
body.is-bg-black .c-btn--primary:hover,
body.is-bg-black .btn-leaf:hover,
body.is-bg-black .btn-leaf--lg:hover,
body.is-bg-black .news__more-link:hover {
	background-color: #ffff00 !important;
	color: #000 !important;
	border-color: #ffff00 !important;
}
body.is-bg-black .c-btn::before {
	background-color: transparent !important;
}
/* ボタン内の矢印擬似要素（CSSボーダー三角）は currentColor 継承でOK */
body.is-bg-black .news__more-link::after,
body.is-bg-black .btn-leaf::after,
body.is-bg-black .c-btn::after {
	border-color: currentColor !important;
}

/* --- カテゴリラベル（news-card__cat など） --- */
body.is-bg-black .news-card__cat,
body.is-bg-black .news-card__cat--info,
body.is-bg-black .news-card__cat--event {
	background-color: #000 !important;
	color: #ffff00 !important;
	border: 1px solid #ffff00 !important;
}

/* --- ボーダー／区切り線の色統一 --- */
body.is-bg-black .l-header,
body.is-bg-black .l-footer,
body.is-bg-black .l-footer__col,
body.is-bg-black .c-accordion,
body.is-bg-black .c-anchor-nav__link,
body.is-bg-black .c-breadcrumb,
body.is-bg-black .c-tabs,
body.is-bg-black .c-tabs__btn,
body.is-bg-black .c-news-list__item,
body.is-bg-black hr,
body.is-bg-black table,
body.is-bg-black th,
body.is-bg-black td {
	border-color: #fff !important;
}

/* --- パンくず --- */
body.is-bg-black .c-breadcrumb__link,
body.is-bg-black .c-breadcrumb__item,
body.is-bg-black .c-breadcrumb__item[aria-current="page"] {
	color: #fff !important;
}
body.is-bg-black .c-breadcrumb__item:not(:first-child)::before {
	color: #fff !important;
}

/* --- アンカーナビ／タブ／アコーディオン --- */
body.is-bg-black .c-anchor-nav__link,
body.is-bg-black .c-tabs__btn,
body.is-bg-black .c-accordion__head {
	background-color: #000 !important;
	color: #fff !important;
	border: 1px solid #ffff00 !important;
}
body.is-bg-black .c-anchor-nav__link:hover,
body.is-bg-black .c-anchor-nav__link:focus,
body.is-bg-black .c-tabs__btn.is-active,
body.is-bg-black .c-accordion.is-open .c-accordion__head {
	background-color: #ffff00 !important;
	color: #000 !important;
	border-color: #ffff00 !important;
}
body.is-bg-black .c-accordion.is-open .c-accordion__title,
body.is-bg-black .c-accordion.is-open .c-accordion__q {
	color: #000 !important;
}
body.is-bg-black .c-accordion__head::before,
body.is-bg-black .c-accordion__head::after {
	background-color: currentColor !important;
}

/* --- ページネーション --- */
body.is-bg-black .c-pagination__link {
	background-color: #000 !important;
	color: #ffff00 !important;
	border: 1px solid #ffff00 !important;
}
body.is-bg-black .c-pagination__link--current,
body.is-bg-black a.c-pagination__link:hover {
	background-color: #ffff00 !important;
	color: #000 !important;
	border-color: #ffff00 !important;
}

/* --- ハンバーガーボタン --- */
body.is-bg-black .l-hamburger-btn {
	background-color: transparent !important;
}
body.is-bg-black .l-hamburger-btn__bar {
	background-color: #fff !important;
}

/* --- ヘッダー検索／SNS --- */
body.is-bg-black .l-header__search-input {
	background-color: #000 !important;
	color: #fff !important;
	border: 1px solid #fff !important;
}
body.is-bg-black .l-header__search-input::placeholder {
	color: #bbb !important;
}
body.is-bg-black .l-header__search-btn,
body.is-bg-black .l-header__sns-link {
	background-color: #000 !important;
	color: #ffff00 !important;
	border: 1px solid #ffff00 !important;
	background-image:none !important;
}
body.is-bg-black .l-header__search-btn:hover,
body.is-bg-black .l-header__sns-link:hover {
	background-color: #ffff00 !important;
	color: #000 !important;
}

/* --- ロゴマーク（SVG の fill/stroke を白に） --- */
body.is-bg-black .l-header__logo-mark svg,
body.is-bg-black .l-footer__logo-mark svg,
body.is-bg-black .l-header__logo-mark svg *,
body.is-bg-black .l-footer__logo-mark svg * {
	fill: #fff !important;
}

/* --- フッター詳細 --- */
body.is-bg-black .l-footer {
	border-top-color: #fff !important;
}
body.is-bg-black .l-footer__col-title::after {
	background-color: #fff !important;
	color: #fff !important;
}
body.is-bg-black .l-footer__col-title a,
body.is-bg-black .l-footer__col-list a {
	color: #ffff00 !important;
}

/* --- Swiper ページネーション／ナビゲーション --- */
body.is-bg-black .swiper-pagination-bullet {
	background-color: #fff !important;
	opacity: 0.4;
}
body.is-bg-black .swiper-pagination-bullet-active {
	background-color: #ffff00 !important;
	opacity: 1;
}
body.is-bg-black .swiper-button-prev,
body.is-bg-black .swiper-button-next,
body.is-bg-black .news__arrow {
	background-color: #000 !important;
	color: #ffff00 !important;
	border: 1px solid #ffff00 !important;
}
body.is-bg-black .swiper-button-prev::after,
body.is-bg-black .swiper-button-next::after,
body.is-bg-black .news__arrow::before,
body.is-bg-black .news__arrow::after {
	color: #ffff00 !important;
	border-color: currentColor !important;
}

/* --- フォーム要素 --- */
body.is-bg-black input[type="text"],
body.is-bg-black input[type="email"],
body.is-bg-black input[type="tel"],
body.is-bg-black input[type="search"],
body.is-bg-black input[type="password"],
body.is-bg-black input[type="number"],
body.is-bg-black input[type="url"],
body.is-bg-black textarea,
body.is-bg-black select {
	background-color: #000 !important;
	color: #fff !important;
	border: 1px solid #fff !important;
}
body.is-bg-black input::placeholder,
body.is-bg-black textarea::placeholder {
	color: #bbb !important;
}
body.is-bg-black button[type="submit"],
body.is-bg-black input[type="submit"],
body.is-bg-black input[type="button"] {
	background-color: #000 !important;
	color: #ffff00 !important;
	border: 1px solid #ffff00 !important;
}

/* --- 固定 UI（ページトップ・フロートバー） --- */
body.is-bg-black .c-page-top {
	background-color: #000 !important;
	color: #ffff00 !important;
	border: 1px solid #ffff00 !important;
}
body.is-bg-black .c-float-bar {
	background-color: #000 !important;
	color: #fff !important;
	border-top: 1px solid #fff !important;
}

/* --- 装飾背景画像の無効化 --- */
body.is-bg-black .intro__decor,
body.is-bg-black .intro__decor--tree {
	display: none !important;
}
body.is-bg-black .activities,
body.is-bg-black .about,
body.is-bg-black .insta,
body.is-bg-black .c-page-hero {
	background-image: none !important;
}

/* --- 区切り罫 --- */
body.is-bg-black hr {
	border-color: #fff !important;
	background-color: #fff !important;
}

/* --- a11y モーダル内テーマ切替ボタンは視認性のため固有色を維持 --- */
body.is-bg-black .l-a11y-modal__title {
	color: #fff !important;
}
body.is-bg-black .l-a11y-modal__label {
	color: #fff !important;
}
body.is-bg-black .l-a11y-circle-btn--white {
	background-color: #fff !important;
	color: #333 !important;
	border-color: #ccc !important;
}
body.is-bg-black .l-a11y-circle-btn--black {
	background-color: #111 !important;
	color: #fff !important;
	border-color: #111 !important;
}
body.is-bg-black .l-a11y-circle-btn--black.is-active {
	border-color: #fff !important;
}
body.is-bg-black .l-a11y-circle-btn--blue {
	background-color: #0034a1 !important;
	color: #ffff00 !important;
	border-color: #0034a1 !important;
}
body.is-bg-black .l-a11y-pill-btn {
	background-color: #fff !important;
	color: #000 !important;
	border-color: #ffff00 !important;
}
body.is-bg-black .l-a11y-pill-btn.is-active {
	background-color: #ffff00 !important;
	color: #000 !important;
}
body.is-bg-black .l-a11y-modal__close {
	background-color: #fff !important;
	color: #000 !important;
}

/* 背景色：青（紺色背景＋黄色文字） */
body.is-bg-blue {
  background-color: #0034a1 !important;
  color: #ffff00 !important;
}
body.is-bg-blue a,
body.is-bg-blue a:hover {
  color: #ffffff !important;
}
body.is-bg-blue .l-header,
body.is-bg-blue .l-header__top,
body.is-bg-blue .l-a11y-modal__content,
body.is-bg-blue .l-global-nav,
body.is-bg-blue .c-card,
body.is-bg-blue section {
  background-color: #0034a1 !important;
  color: #ffff00 !important;
}
body.is-bg-blue .l-header__logo-ja,
body.is-bg-blue .l-header__logo-en,
body.is-bg-blue .l-global-nav__link,
body.is-bg-blue .l-submenu__link {
  color: #ffff00 !important;
}


body.is-bg-black .l-a11y-btn--bg-white{
	color:#000 !important;
	}
body.is-bg-black .l-submenu__link{
	background-color:#111 !important;
	}
body.is-bg-black .l-header--fixed .l-global-nav{
	background-color: rgba(000, 000, 000, 0.9) !important;
	}

body.is-bg-black .activity-wrap{
	background-color:#000 !important;
	background-image:none !important;
	}
body.is-bg-black .activity-card {
	background-color:#000 !important;
}
body.is-bg-black .activity-wrap::after{
	display:none; !important;
	}
body.is-bg-black .news__tab {
	border: 1px solid #ffff00 !important;
	background-color:#000 !important;
	color: #ffff00 !important;
}
body.is-bg-black .news__tab:hover {
	color: #000 !important;
	background-color: #ffff00 !important;
}
body.is-bg-black .news__tab.is-active {
	color: #000 !important;
	background-color: #ffff00 !important;
}
body.is-bg-black .btn-leaf{
	border:1px solid #ffff00 !important;
	}
body.is-bg-black .activity-card{
	border:1px solid #ffff00 !important;
	}
body.is-bg-black .activity-card__title,
body.is-bg-black .activity-card__text{
	color: #ffff00 !important;
	}
body.is-bg-black .activity-card:hover{
	background-color: #ffff00 !important;
	}
body.is-bg-black .activity-card:hover .activity-card__title,
body.is-bg-black .activity-card:hover .activity-card__text{
	color: #000 !important;
	}
body.is-bg-black .insta__account{
	border:1px solid #ffff00 !important;
	}
body.is-bg-black .insta__account:hover{
	color: #000 !important;
	background-color: #ffff00 !important;
	}
body.is-bg-black .l-a11y-btn--size.is-active {
  background-color: #ffff00 !important;
  border-color: #ffff00 !important;
  color: #000 !important;
}
body.is-bg-black .l-a11y-btn--size {
  border-color: #ffff00 !important;
  color: #ffff00 !important;
	background-color:transparent !important;
}
body.is-bg-black .l-a11y-btn--size:hover {
  background-color: #ffff00 !important;
  border-color: #ffff00 !important;
  color: #000 !important;
}
body.is-bg-black .l-footer__copy{
	background-color: #000 !important;
	}
body.is-bg-black .l-global-nav__icon svg{
	color: #ffff00 !important;
	}
body.is-bg-black .has-submenu .l-global-nav__item-main > .l-global-nav__link::after {
	border-right: 1px solid #fff !important
	border-bottom: 1px solid #fff !important
}
body.is-bg-black .l-global-nav__link:hover{
	border-bottom-color: #ffff00 !important;
	}
/*body.is-bg-black .l-submenu__item{
	border-top:1px solid #fff !important;
	}*/
body.is-bg-black .l-a11y-btn--bg-black{
	border-color: #ffff00 !important;
	}
body.is-bg-black .l-a11y-btn--bg-white{
	border-color: #ffff00 !important;
	}
body.is-bg-black .l-submenu-toggle{
	background-color: #ffff00 !important;
	}
body.is-bg-black .l-submenu-toggle::before,
body.is-bg-black .l-submenu-toggle::after {
  background-color: #000 !important;
}
body.is-bg-black .l-a11y-toggle {
  color: #ffff00 !important;
	background-color: #000 !important;
	border:1px solid #ffff00  !important;
}
body.is-bg-black .l-a11y-toggle i{
	color: #ffff00 !important;
	}
body.is-bg-black .l-a11y-circle-btn.is-active{
  box-shadow: 0 0 0 3px #ffff00 !important;
  border-color: #fff;
	}
body.is-bg-black .activity-wrap,
body.is-bg-black .news{
	background-color:#111 !important;
	}
body.is-bg-black .l-hamburger-btn {
  background-color: var(--color-accent);
  cursor: pointer;
}
body.is-bg-black .l-hamburger-btn:hover {
  background-color: var(--color-accent-dark);
}
body.is-bg-black .l-hamburger-btn__bar {
  background-color: #ffff00 !important;
}

body.is-bg-black .otayori-card{
	background-color:#000 !important;
	}
body.is-bg-black .c-page-hero{
	background-color:#111 !important;
	}
body.is-bg-black .c-page-hero::before{
	display:none !important;
	}
body.is-bg-black .c-page-hero::after{
	display:none !important;
	}
body.is-bg-black .c-news-list {
  border-top: 1px solid #fff !important;
  border-bottom: 1px solid #fff !important;
}
body.is-bg-black .c-news-list__item:not(:first-child) {
  border-top: 1px solid #fff !important;
}
body.is-bg-black .c-news-list__date,
body.is-bg-black .c-news-list__title {
	color: #ffff00 !important;
}
body.is-bg-black .c-news-list__link:hover .c-news-list__date,
body.is-bg-black .c-news-list__link:hover .c-news-list__title{
	color:#000 !important;
	}
body.is-bg-black .c-news-list__link[href]::after {
  color: #fff !important;
}
body.is-bg-black .c-news-list__link[href]:hover {
	background-color: #ffff00 !important;
	}
body.is-bg-black .c-news-list__link[href]:hover::after { color: #000 !important; }

body.is-bg-black .c-anchor-nav__link i {
  color: #ffff00 !important;
}
body.is-bg-black .c-anchor-nav__link:hover i {
	color: #000 !important;
}

body.is-bg-black .c-card {
  border:1px solid #ffff00 !important;
}
body.is-bg-black .c-card__title {
  color: #ffff00 !important;
}
body.is-bg-black .c-card__text {
  color: #ffff00 !important;
}
body.is-bg-black a.c-card:hover{
	background-color:#ffff00 !important;
	}
body.is-bg-black a.c-card:hover *{
	color:#000 !important;
	}
body.is-bg-black a.c-card:hover .c-card__title,
body.is-bg-black a.c-card:hover .c-card__text{
	color: #000 !important;
	}
	
body.is-bg-black .otayori-card__title{
	background-color:#000 !important;
	}
body.is-bg-black .otayori-card__button{
	background-color: #000 !important;
	border:1px solid #ffff00 !important;
	}
body.is-bg-black .otayori-card__button:hover{
	color:#000 !important;
	border:1px solid #ffff00 !important;
	background-color:#ffff00 !important;
	}
body.is-bg-black .flower-box{
	color:#fff !important;
	background-color:#111 !important;
	}
body.is-bg-black #suggest-box {
	background: #000 !important;
}
body.is-bg-black .suggest-item a:hover {
	background: #ffff00 !important;
	color: #000 !important;
}

body.is-bg-black .form-intro {
	background: #111 !important;
}
body.is-bg-black .c-table-stacked th {
	background-color: #111 !important;
}
body.is-bg-black .c-table-stacked td{
	background-color: #000 !important;
	}
body.is-bg-black .c-table-stacked tr {
  border: 1px solid rgba(221, 221, 221, 0.2) !important;
}
body.is-bg-black .form-reset-btn {
	color:#fff !important;
	background-color:transparent !important;
}
body.is-bg-black .pagenation li a {
  background-color: #000 !important;
}
body.is-bg-black .pagenation li span {
  color:  #000 !important;
  background-color:  #ffff00 !important;
}
body.is-bg-black .pagenation li a:hover {
  color: #ffff00 !important;
  border:1px solid #ffff00 !important;
}
body.is-bg-black a.pdf-link::after {
	color: #ffff00 !important;
}

/* セクション共通
===========================================================================*/
/*
<section class="l-section">
  <div class="inner">
    <!-- コンテンツ -->
  </div>
</section>
<section class="section section--bg">
  <div class="inner">
    <!-- 背景あり -->
  </div>
</section>
*/
.l-section {
  padding-top: var(--s-12); /* 48px */
  padding-bottom: var(--s-12); /* 48px */
}
.l-section--sm {
  padding-top: var(--s-10); /* 40px */
  padding-bottom: var(--s-10); /* 40px */
}
.l-section--lg {
  padding-top: var(--s-25); /* 100px */
  padding-bottom: var(--s-25); /* 100px */
}
@media (min-width: 768px) {
  .l-section {
    padding-top: var(--s-25); /* 100px */
    padding-bottom: var(--s-25); /* 100px */
  }
  .l-section--sm {
    padding-top: var(--s-15); /* 60px */
    padding-bottom: var(--s-15); /* 60px */
  }
  .l-section--lg {
    padding-top: var(--s-30); /* 120px */
    padding-bottom: var(--s-30); /* 120px */
  }
}


/* フッターレイアウト
===========================================================================*/
.l-footer {
	background-color: #fcfcfc;
	position: relative;
	border-top: 1px solid var(--color-border);
}
.l-footer__inner {
	display: flex;
	flex-direction: column;
	gap: var(--s-10);
	padding-top: var(--s-12);
	padding-bottom: var(--s-12);
}
.l-footer__brand {
	display: flex;
	flex-direction: column;
	gap: var(--s-6);
}
.l-footer__logo {
	display: flex;
	align-items: center;
	gap: var(--s-3);
	text-decoration: none;
}
.l-footer__logo-mark {
	width: var(--s-10);
	height: var(--s-10);
	flex-shrink: 0;
}
.l-footer__logo-text {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}
.l-footer__logo-en {
	font-family: var(--font-eng);
	font-size: var(--text-10);
	color: #666;
	font-weight: 600;
	margin-bottom:var(--s-1);
}
.l-footer__logo-ja {
	font-size: var(--text-18);
	font-weight: 800;
}
.l-footer__address {
	font-size: var(--text-14);
}
.l-footer__address span {
	/*display: block;*/
}
.l-footer__open {
	margin-top: var(--s-2);
	margin-bottom: var(--s-1);
}
.l-footer__tel {
}
.l-footer__sns {
	display: flex;
	justify-content: center;
	gap: var(--s-2);
}
.l-footer__sns li {
}
.l-footer__map{
	}
.l-footer__map iframe{
	border:1px solid var(--color-bg-light);
	}
/* フッターナビ */
.l-footer__nav {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--s-4);
}
.l-footer__col {
	min-width: 0;
}
.l-footer__col-title {
	font-size: var(--text-15);
	font-weight: 700;
	margin-bottom: var(--s-3);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--color-border);
	position: relative;
}
.l-footer__col-title::after {
	content: "";
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 30%;
	height: 1px;
	background-color: var(--color-primary);
}
.l-footer__col-title a {
	transition: color 0.2s ease;
}
.l-footer__col-title a:hover {
	color: var(--color-primary);
	opacity: 1;
}
.l-footer__col-list {
	display: flex;
	flex-direction: column;
}
.l-footer__col-list li {
}
.l-footer__col-list a {
	display: inline-block;
	font-size: var(--text-14);
	transition: color 0.2s ease;
}
.l-footer__col-list a:hover {
	color: var(--color-primary);
	opacity: 1;
}
.l-footer__col-list a i{
	color:#666;
	font-size: var(--text-12);
	}
/* コピーライト */
.l-footer__copy {
	text-align: center;
	padding: var(--s-4) 0;
	background-color: var(--color-primary);
	color: #fff;
	font-size: var(--text-12);
	font-weight:700;
}
@media (min-width: 768px) {
	.l-footer {
	}
	.l-footer__inner {
		gap: var(--s-10);
		padding-top: var(--s-25);
		padding-bottom: var(--s-25);
	}
	.l-footer__brand {
		grid-column: 1 / 2;
		gap: var(--s-8);
	}
	.l-footer__logo {
		gap: var(--s-5);
	}
	.l-footer__logo-mark {
		width: var(--s-15);
		height: var(--s-15);
	}
	.l-footer__logo-en {
		font-size: var(--text-12);
	}
	.l-footer__logo-ja {
		font-size: var(--text-20);
	}
	.l-footer__address{
		font-size: var(--text-15);
	}
	.l-footer__open {
		margin-top: var(--s-3);
		margin-bottom: var(--s-3);
	}
	.l-footer__sns {
		justify-content:flex-start;
	}
	/* フッターナビ */
	.l-footer__nav {
		grid-column: 2 / 3;
		grid-template-columns: repeat(3, 1fr);
		gap: var(--s-5) var(--s-5);
	}
	.l-footer__col-title {
		font-size: var(--text-16);
		margin-bottom: var(--s-4);
    padding-bottom: var(--s-4);
	}
	/* コピーライト */
	.l-footer__copy {
		padding: var(--s-5) 0;
		font-size: var(--text-14);
	}
}
@media (min-width: 1024px) {
	.l-footer__inner {
		/*display: grid;
		grid-template-columns: minmax(280px, 400px) 1fr;*/
		flex-direction: row;
		justify-content: space-between;
		gap: 0;
	}
	.l-footer__brand{
		width:30%;
		}
	.l-footer__nav{
		width:65%;
		}
	/* フッターナビ */
	.l-footer__nav {
		grid-template-columns: repeat(4, 1fr);
	}
}
/*----------------------------------------------------------------------------------------------------

ページネーション

----------------------------------------------------------------------------------------------------*/
/* コンテナ（ol） */
.pagenation {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--s-2);
  list-style: none;
  padding: 0;
  margin-top: var(--s-10);
}

/* 共通の形状（aとspan） */
.pagenation li a,
.pagenation li span {
  display: grid;
  place-items: center;
  min-width: var(--s-10);
  height: var(--s-10);
  padding: 0 0.5rem;
  font-size: var(--text-16);
  font-weight: bold;
  text-decoration: none;
  border-radius: 9999px;
  border: 1px solid var(--color-border);
  transition: background-color 0.3s, color 0.3s;
	box-shadow:0 2px 8px rgba(0, 0, 0, .05);
}

/* 通常のリンク */
.pagenation li a {
  color: var(--color-accent);
  background-color: #fff;
}

/* hover */
.pagenation li a:hover {
  color: #fff;
  background-color: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
	box-shadow:0 6px 16px rgba(45, 107, 47, .18);
}

/* 現在ページ（span） */
.pagenation li span {
  color: #fff;
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  cursor: default;
	box-shadow:0 6px 16px rgba(45, 107, 47, .18);
}

/* 前へ・次への微調整（必要であれば幅を広げる） */
.pagenation li:first-child a,
.pagenation li:last-child a {
  padding: 0 var(--s-2);
}

/* レスポンシブ */
@media (min-width: 768px) {
  .pagenation {
		margin-top: var(--s-10);
    gap: var(--s-3);
  }
  .pagenation li a,
  .pagenation li span {
		min-width: var(--s-12);
		height: var(--s-12);
    padding: 0 var(--s-3);
  }
}