@charset "utf-8";
/* *************************************************************
	Global
*************************************************************** */

html {
  font-size: 18px;
  line-height: 35px;
}


body {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.7;
  font-optical-sizing: auto;
  font-style: normal;
  color: #333;
  max-width: 100%;
  overflow-x: hidden;
  background-color: #F8F8F5;
}

img {
  max-width: 100%;
  height: auto;
}

.inner {
  max-width: 970px;
  margin: 0 auto;
  padding: 40px;
  overflow: visible;
}

a {
  text-decoration: none;
}

ul {
  list-style-type: none;
}



.pc {
  display: block;
}

.sp {
  display: none;
}

/* 上のアイコン（SVGを画像で配置） */
.section-icon {
  display: inline-block;
  width: auto;
  height: 60px;
  /* 画像サイズは適宜調整 */
  max-width: 38vw;
  margin: 0 auto 20px;
}

.section-icon img {
  width: 100%;
  height: auto;
  display: block;
}

.section-title {
  font-family: "Kaisei Opti", serif;
  font-weight: 500;
  font-size: 36px;
  letter-spacing: .02em;
  margin: 0 0 32px;
  color: #333;
}

/* 続きを見る ボタン（ pill + 右側に矢印の丸） */
.read-more_btn {
  display: inline-flex;
  width: 235px;
  align-items: center;
  justify-content: center;
  gap: 27px;
  /* 文字と矢印の間隔 */
  padding: 8px 0px 8px 33px;
  border: 3px solid #FA35A7;
  /* ピンクの枠線 */
  border-radius: 9999px;
  /* 丸み */
  background-color: #fff;
  /* 背景白 */
  color: #555454;
  /* テキスト色 */
  font-size: 20px;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.3s ease;
}

.read-more_btn img {
  width: 14px;
  height: 14px;
  transition: transform 0.3s ease;
}

/* ホバー時 */
.read-more_btn:hover {
  background-color: #FA35A7;
  color: #fff;
}

.read-more_btn:hover img {
  transform: translateX(3px);
  filter: brightness(0) invert(1);
  /* 白に反転 */
}


.text-center {
  text-align: center;
}

/* **************************************************************
	header
*************************************************************** */

/* ===== Header base ===== */
#header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  /* 手前に表示 */
  padding: 16px 24px;
}

.header-inner {
  max-width: 1200px;
  margin: 30px auto 0;
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 24px;
}

/* ===== Logo (SVG 1枚) ===== */
.header-logo {
  margin: 0;
  line-height: 1;
}

.header-logo a {
  display: inline-block;
}

.header-logo img {
  width: 190px;
  height: auto;
  display: block;
}

/* ===== Nav ===== */
.header-nav ul {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 8px;
  background: #fff;
  border-radius: 999px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, .1);
}

.header-nav li {
  list-style: none;
}

.header-nav a {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 18px;
  /* ← 指定フォントサイズ */
  line-height: 1.2;
  color: #333;
  text-decoration: none;
  transition: background .2s ease, color .2s ease;
}

/* 先頭の丸アイコン＋山括弧 */
.header-nav a::before {
  content: "";
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 27px;
  height: 27px;
  border-radius: 50%;
  border: 1px solid #CECBCB;
  background: #fff;
  position: relative;
}

/* ▶ 矢印線部分 */
.header-nav a::after {
  content: "";
  position: absolute;
  left: 22px;
  width: 8px;
  height: 8px;
  border-top: 1px solid #707070;
  border-right: 1px solid #707070;
  transform: rotate(45deg);
}



/* Hover */
.header-nav a:hover {
  background: #f7f7f7;
}

/* お問い合わせ（ピンクの丸ボタン） */
.header-nav .contact-btn {
  font-weight: 500;
  color: #fff;
  background: #FA35A7;
  padding: 15px 42px;
}

.header-nav .contact-btn::before {
  content: none;
}

.header-nav .contact-btn:hover {
  background: #ff67b1;
}

/* ▼ 矢印を非表示にする指定 */
.header-nav .contact-btn::before,
.header-nav .contact-btn::after {
  content: none !important;
}

.sp-contact,
.hamburger {
  display: none;
}

/* ===== PC表示ではSPメニューを完全非表示 ===== */
@media screen and (min-width: 768px) {
  .sp-menu {
    display: none !important;
  }

  .hamburger,
  .sp-contact {
    display: none !important;
  }
}

/* **************************************************************
	kv
*************************************************************** */

/* ===== Key Visual ===== */
#kv {
  position: relative;
  width: 100%;
  height: 800px;
  /* 背景エリアの高さ */
  background-image: url("../img/kv_bg.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  /* ← 中央基準 */
  background-size: cover;
  /* ← 横幅が広いときは拡大してカバー */
  overflow: hidden;
}

/* === 中央テキスト（SVG） === */
#kv .kv-title {
  position: absolute;
  top: 58%;
  left: 50%;
  transform: translate(-50%, -50%);
  /* 完全中央配置 */
  width: min(90%, 500px);
  text-align: center;
}

#kv .kv-title img {
  width: 100%;
  height: auto;
  display: block;
}




/* **************************************************************
	about
*************************************************************** */

.about-section {
  background: #fff;
  padding: 80px 16px 120px;
}

.about-inner {
  max-width: 990px;
  margin: 0 auto;
  text-align: center;
}

.about-text {
  text-align: left;
  font-weight: 300;
  margin: 0 auto 60px;
}

.about-text p {
  margin: 0 0 10px;
}


/* **************************************************************
	store
*************************************************************** */

.store {
  padding: 90px 20px 64px;
}

.store__inner {
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}

/* 検索バー */
.store-search {
  position: relative;
  max-width: 620px;
  margin: 0 auto 80px;
}

.store-search__label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.store-search__icon {
  position: absolute;
  left: 19px;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
  height: 30px;
  pointer-events: none;
}

.store-search__input {
  width: 100%;
  height: 60px;
  background-color: #fff;
  padding: 0 60px 0 60px; /* 左右余白（左右にアイコン・ボタン） */
  border: 1px solid #ddd;
  border-radius: 30px;
  font-size: 18px;
  outline: none;
}

.store-search__input::placeholder {
  color: #9aa0a6;
}

/* ▼ 右側の送信（検索）ボタン */
.store-search__button {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  background: #fa35a7;
  border: none;
  border-radius: 50%;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: opacity .2s ease;
}

.store-search__button img {
  width: 20px;
  height: 20px;
  filter: brightness(0) invert(1); /* 白アイコン化（必要なら） */
}

.store-search__button:hover {
  opacity: .8;
}

.store-no-item {
  text-align: center;
  font-size: 16px;
  color: #555;
  margin: 0 0 120px; /* ← この余白を調整 */
}

/* グリッド */
.store-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 38px 64px;
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 980px;
  /* 画像の見た目に合わせて中央寄せ */
}

/* カード */

.store-card {
  text-align: center;
}

.store-card a {
  display: inline-block;
  width: 250px;
  text-decoration: none;
  color: inherit;
  transition: transform .15s ease, filter .15s ease;
}

.store-card a:hover,
.store-card a:focus-visible {
  transform: translateY(-2px);
  filter: brightness(1.02);
}

/* 丸画像：250×250 */
.store-card__thumb {
  width: 250px;
  height: 250px;
  margin: 0 auto 12px;
  border-radius: 50%;
  overflow: hidden;
  display: grid;
  place-items: center;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, .06) inset;
}

.store-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ラベル */
.store-card__label {
  font-size: 24px;
  font-weight: 500;
  letter-spacing: .02em;
}

/* **************************************************************
	News・イベント
*************************************************************** */

.news-events {
  padding: 24px 0 140px;
}

.news-events__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 16px;
  text-align: center;
}

/* タイトル・本文左寄せ */
.news-card__title,
.news-card__excerpt,
.news-card__date {
  text-align: left;
}

.news-events__title {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.3;
  margin: 12px 0 16px;
}

/* カードの並び */
.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 345px);
  gap: 20px;
  justify-content: space-between;
  margin-bottom: 80px;
  align-items: stretch;
}

/* カード本体 */
.news-card {
  width: 345px;
  min-height: 556px;
  background: #fff;
  border-radius: 30px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 8px;
}

/* 画像 */
.news-card__image {
  display: block;
  overflow: hidden;
}

.news-card__image img {
  width: 100%;
  height: 240px;
  /* 見た目合わせ（必要なら調整） */
  object-fit: cover;
  display: block;
  border-radius: 25px;
}

/* テキスト部 */
.news-card__body {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  /* ← カード内で縦に伸びる */
  align-items: flex-start;
  /* 左寄せ維持 */
  text-align: left;
}

/* カテゴリピル */
.news-card__cat {
  align-self: flex-start;
  /* 念のため個別にも指定 */
  display: inline-block;
  padding: 6px 20px;
  /* ← ここで長さ調整 */
  border-radius: 999px;
  background: #FDC185;
  color: #fff;
  line-height: 1;
  margin: 18px 0 0;
  width: auto;
  /* 保険 */
}

/* タイトル */
.news-card__title {
  font-size: 20px;
  font-weight: 800;
  line-height: 28px;
  margin: 12px 0 10px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  /* 2行で省略 */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news-card__title a {
  color: #363535;
}

/* 抜粋 */
.news-card__excerpt {
  font-size: 18px;
  line-height: 28px;
  color: #555;
  margin: 0 0 5px;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  /* 行数はお好みで調整 */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* フッタ（左：日付／右：丸ボタン） */
.news-card__foot {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0 11px 7px;
}

.news-card__date {
  font-size: 18px;
  color: #363535;
}

/* 丸ボタン */
.news-card__more {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: grid;
  place-items: center;

  /* Safari 対応：グラデーションを2色指定する */
  background: radial-gradient(circle at 30% 30%, #FA35A7 0%, #FA35A7 100%);

  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}


.news-card__more img {
  width: 21px;
  height: 21px;
  display: block;
}

.news-card__more:hover {
  transform: translateY(-2px);
  filter: brightness(1.05);
}

/* カードのホバー（任意） */
.news-card:hover {
  box-shadow: 0 10px 22px rgba(0, 0, 0, .10);
  transform: translateY(-1px);
  transition: box-shadow .25s ease, transform .25s ease;
}

/* **************************************************************
	recommend
*************************************************************** */

/* ===== Swiper レイアウト ===== */
.recommend .recommend-swiper {
  padding: 8px 16px;
  /* 両端に少し余白 */
  overflow: visible;
  /* 影や丸角のはみ出しを見せる */
  text-align: center;
  margin-bottom: 120px;
}

.recommend .swiper-wrapper {
  align-items: stretch;
  /* 全カードの高さを自然に揃える */
}

.recommend .swiper-slide {
  width: 310px;
  /* 指定：カード幅固定 */
  height: auto;
}

/* ===== カード ===== */
.rec-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  /* body の背景色は未指定（指示どおり） */
  border-radius: 24px;
  overflow: hidden;
  text-align: left;
}

.rec-card__thumb {
  margin: 0;
  line-height: 0;
}

.rec-card__thumb img {
  width: 100%;
  height: 200px;
  /* 好みで調整（例：aspect-ratio: 4/3; でもOK） */
  object-fit: cover;
  display: block;
}

.rec-card__body {
  position: relative;
  padding: 16px 20px 56px;
  /* 右下の丸ボタン分の余白 */
}

.rec-card__badge {
  display: inline-block;
  font-size: 16px;
  line-height: 1;
  color: #fff;
  background: #FDC185;
  /* 画像の例に近い色味 */
  padding: 6px 20px;
  border-radius: 9999px;
}

.rec-card__title {
  margin: 12px 0 6px;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.35;
  color: #363535;
}

.rec-card__text {
  margin: 0;
  font-size: 14px;
  line-height: 1.8;
  color: #444;
}

/* 丸ボタン（矢印SVG対応） */
.rec-card__more {
  position: absolute;
  right: 16px;
  bottom: 16px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #ea4aa0;
  /* ピンクの丸 */
  display: grid;
  place-items: center;
  text-decoration: none;
  transition: transform .2s ease;
}

.rec-card__more:hover {
  transform: translateY(-2px);
}

.rec-card__arrow {
  width: 22px;
  /* SVGのサイズを調整 */
  height: 22px;
  display: block;
}


/* 視覚的に隠す（アクセシビリティ用） */
.sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* モバイル微調整（任意） */
@media (max-width: 480px) {
  .rec-card__thumb img {
    height: 180px;
  }
}


/* **************************************************************
	map
*************************************************************** */

.map-section {
  background: #fff;
  padding: 150px 0 125px;
  text-align: center;
}

/* ボタンエリア */
.map-buttons-area {
  background: #fff;
  padding-top: 50px;
  padding-bottom: 30px;
}

.map-tabs {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 60px;
}

/* ===== ボタン共通 ===== */
.map-tab {
  width: 300px;
  padding: 17px 18px;
  border-radius: 9999px;
  background: #fff;
  font-weight: 500;
  font-size: 20px;
  line-height: 1;
  color: #555454;
  --accent: #999;
  border: 3px solid var(--accent);
  /* ← 枠線はaccent */
  box-shadow: inset 0 0 0 0 var(--accent);
  /* ← 内側もaccent */
  transition: box-shadow .25s ease, transform .12s ease;
}

.map-tab:is(:hover, :focus-visible) {
  transform: translateY(-1px);
}

.map-tab.is-active {
  box-shadow: inset 0 0 0 3px var(--accent);
  /* 内側を太く */
}

/* エリアごとの色指定（ここだけで一元管理） */
.map-tab--suzuran {
  --accent: #FF8D2B;
}

.map-tab--kita {
  --accent: #642BFF;
}

.map-tab--minami {
  --accent: #FF2B7D;
}

/* ===== マップ枠 ===== */
.map-frame {
  width: 100%;
}

.map-frame iframe {
  width: 100vw;
  /* 画面幅いっぱい */
  height: 600px;
  /* 高さはお好みで */
  border: none;
  display: block;
}

/* **************************************************************
	instagram
*************************************************************** */

/* Instagramセクション全体 */
#instagram {
  background-color: #fff;
  /* 背景白 */
  padding: 100px 0 200px;
}

.insta-inner {
  max-width: 1080px;
  margin: 0 auto;
  text-align: center;
}


/* 画像グリッド */
.insta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(245px, 1fr));
  gap: 30px;
  justify-content: center;
  padding-top: 50px;
}

/* 外枠：角丸を保持する役目 */
.insta-item {
  width: 245px;
  height: 245px;
  background-color: #fff;
  border-radius: 16px;
  overflow: hidden;
  margin: 0 auto;

  /* Safariでtransform時に角丸が消えるのを防ぐ */
  -webkit-mask-image: -webkit-radial-gradient(white, black);
}

/* 画像ラッパー：Safariで必須 */
.insta-item .img-wrap {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* 画像 */
.insta-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}

/* hover時に拡大 */
.insta-item:hover img {
  transform: scale(1.05);
}






/* **************************************************************
	footer
*************************************************************** */

#footer {
  background-color: #fff;
  padding: 150px 0 60px;
  color: #555454;
  font-family: "Noto Sans JP", sans-serif;
}

.footer-inner {
  max-width: 1137px;
  margin: 0 auto;
  position: relative;
}

.footer-line {
  border: none;
  border-top: 1px solid #cfcfcf;
  width: 1137px;
  margin: 0 auto 40px;
}

.footer-nav {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
  position: relative;
  padding: 0 120px;
}

.matop-150 {
  margin-top: 150px;
}

.footer-column {
  flex: 1;
}

.footer-column h3 {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 20px;
  color: #333;
}

.footer-column h3 a {
   color: #333; 
}

.footer-column ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-column ul li {
  margin-bottom: 10px;
}

.footer-column ul li a {
  text-decoration: none;
  color: #777;
  font-size: 16px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: opacity 0.3s ease;
}

.footer-column ul li a img {
  width: 14px;
  height: 14px;
  vertical-align: middle;
}

.footer-column ul li a:hover {
  opacity: 0.7;
}

/* ▼SNSアイコンをフッターナビの右下に配置 */
.footer-sns {
  position: absolute;
  right: 0;
  bottom: 45px;
  display: flex;
  gap: 30px;
  padding-right: 150px;
}

.footer-sns img {
  width: 60px;
  height: 60px;
  opacity: 0.6;
  transition: opacity 0.3s ease;
}

.footer-sns img:hover {
  opacity: 1;
}

.footer-bottom {
  text-align: center;
  margin-top: 80px;
  font-size: 18px;
  color: #ADADAD;
}

/* ======================================
   Category Page
====================================== */
.category-page {
  margin: 200px auto 0;
  padding: 0 0;
  box-sizing: border-box;
}

/* パンくず */
.breadcrumb {
  max-width: 1080px; /* サイトの基準幅 */
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}


.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 13px;
  color: #8a8a8a;
  margin: 0 0 18px;
}

/* 各リンク */
.breadcrumb a {
  color: inherit;
  text-decoration: none;
}

.breadcrumb a:hover {
  text-decoration: underline;
}

/* 区切り記号 */
.breadcrumb .separator {
  margin: 0 4px;
  color: #ccc; /* 区切りの色 */
}

/* 現在位置（最後の要素） */
/* 現在位置（最後の要素） */
.breadcrumb li[aria-current="page"] {
  color: #333;
  font-weight: 500;
}


.breadcrumb li+li::before {
  content: "▶︎";
  margin: 0 6px 0 2px;
}

/* タイトル（SVG＋JP） */
.cat-hero {
  text-align: center;
  margin: 10px 0 18px;
}

.cat-hero img {
  display: inline-block;
  height: 60px;
  /* 必要に応じて */
  width: auto;
  max-width: 90%;
}

.cat-hero__jp {
  margin-top: 6px;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: .12em;
  color: #333;
}

/* カテゴリーフィルター（色は currentColor を利用） */
.cat-filter ul {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 10px;
  justify-content: center;
  padding: 22px 0 8px;
  list-style: none;
  margin: 0 0 80px;
}

/* ボタン本体 */
.cat-btn {
  width: 180px;
  --btn-c: #999;
  /* 各色ボタンで上書きする色変数 */
  display: inline-block;
  padding: 16px 22px;
  border: 3px solid var(--btn-c);
  border-radius: 999px;
  background: #fff;
  /* ← 全ボタン未選択時は白背景 */
  color: #555454;
  text-decoration: none;
  font-weight: 500;
  line-height: 1;
  transition: filter .15s ease, transform .15s ease, background-color .15s ease, color .15s ease;
}

.cat-btn:hover,
.cat-btn:focus-visible {
  transform: translateY(-1px);
  filter: brightness(1.02);
}

/* 選択状態：塗りをボーダー色と同じに */
.cat-btn.is-selected {
  background: var(--btn-c);
  color: #fff;
  border-color: var(--btn-c);
}

/* カラーバリエーション（ここで色を設定） */
.cat-btn.color-orange {
  --btn-c: #FE8C2B;
}

.cat-btn.color-green {
  --btn-c: #67F07C;
}

.cat-btn.color-purple {
  --btn-c: #DD94FD;
}

.cat-btn.color-blue {
  --btn-c: #63BCFD;
}

.cat-btn.color-pink {
  --btn-c: #FF96C7;
}

.cat-btn.color-teal {
  --btn-c: #75E2D1;
}



/* 見出し */
.cat-heading {
  margin: 36px auto 18px;
  text-align: center;
  font-size: clamp(22px, 2.4vw, 32px);
  letter-spacing: .16em;
  font-weight: 700;
  color: #333;
}

/* =========================================
   Category Page : cat-card（store-cardから独立）
========================================= */

/* カードリスト */
.cat-list {
  display: grid;
  gap: 28px;
  max-width: 1180px;
  margin: 0 auto 180px;
}

/* カード本体 */
.cat-card {
  background: #fff;
  border-radius: 30px;
  overflow: hidden;
}

/* 横並びレイアウト（画像左 / テキスト右） */
.cat-card__link {
  display: grid;
  grid-template-columns: 360px 1fr; /* 画像固定幅＋残り本文 */
  gap: 28px;
  align-items: stretch;             /* ← 高さをそろえる */
  padding: 20px;
  text-decoration: none;
  color: inherit;
  box-sizing: border-box;
}

/* 画像部分 */
.cat-card__thumb {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 20px;
  overflow: hidden;
  margin: 0;
}

.cat-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* 本文部分 */
.cat-card__body {
  min-width: 0;
  text-align: left;
  white-space: normal;
  display: flex;
  flex-direction: column;
  align-items: flex-start;   /* 子要素のデフォルトは左寄せ */
}

.cat-card__badge {
  display: inline-flex;      /* 中身＋padding の幅だけ */
  align-self: flex-start;
  background: #FDC185;
  color: #fff;
  border-radius: 999px;
  padding: 2px 20px;
  font-size: 16px;
  font-weight: 500;
}


.cat-card__title {
  margin: 10px 0 8px;
  font-size: 25px;
  font-weight: 700;
  line-height: 1.4;
  color: #363535;
}

.cat-card__excerpt {
  color: #666;
  font-size: 18px;
  line-height: 28px;
  margin: 0 0 16px;
}

.cat-card__ado-tel {
  color: #333;
  font-size: 18px;
  line-height: 28px;
  font-weight: 500;
  margin: 0 0;
}

/* タグ・ボタンフッター */
.cat-card__foot {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: auto;        /* 本文の一番下に固定 */
  width: 100%;             /* ★ カードの横幅いっぱいに広げる */
  /* もしくは align-self: stretch; でもOK */
}

.cat-card__tags {
  display: flex;
  gap: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
  flex-wrap: wrap;
}

.cat-card__tags li {
  background: #aeadae;
  color: #fff;
  border-radius: 10px;
  padding: 3px 20px;
  font-size: 16px;
  font-weight: 500;
}

.cat-card__more-btn {
  margin-left: auto;       /* ★ 常に右端へ寄せる */
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;

  background-color: #FA35A7;
  background-image: radial-gradient(
    circle at 30% 30%,
    #FA35A7 0,
    #FA35A7 66%,
    #FA35A7 100%
  );
}

.cat-card__more-btn img {
  width: 21px;
  height: 21px;
  display: block;
}


/* Pagination (丸型72px) */
:root {
  --pagi-color: #FF93D2;
  /* ピンク系の基準色 */
}

.cat-pagination {
  margin: 36px 0 0;
  background-color: #fff;
  padding: 82px 0 130px;
}

.cat-pagination ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* WordPress の page-numbers 共通スタイル（a/span 両方） */
.cat-pagination .page-numbers {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  border-radius: 999px;
  border: 2px solid var(--pagi-color);
  background: #fff;
  color: var(--pagi-color);
  font-weight: 600;
  font-size: 25px;
  line-height: 1;
  text-decoration: none;
  box-sizing: border-box;
  transition: transform .15s ease, filter .15s ease;
}

.cat-pagination a.page-numbers:hover,
.cat-pagination a.page-numbers:focus-visible {
  transform: translateY(-2px);
  filter: brightness(1.02);
  outline: none;
}

/* 数字ボタン（未選択）は塗り＝ピンク、文字＝白 */
.cat-pagination .page-numbers:not(.current):not(.dots):not(.next):not(.prev) {
  background: var(--pagi-color);
  color: #fff;
  border-color: var(--pagi-color);
}

/* 現在ページ（current）は枠のみピンク、白塗り＋ピンク文字 */
.cat-pagination .page-numbers.current {
  background: #fff;
  color: var(--pagi-color);
}

/* 「…」のドットは装飾なしでOK */
.cat-pagination .page-numbers.dots {
  width: auto;
  height: auto;
  border: none;
  background: transparent;
  font-size: 20px;
  color: #FF93D2;
}

/* 「次へ」「前へ」ボタンを楕円形に */
.cat-pagination .page-numbers.next,
.cat-pagination .page-numbers.prev {
  width: 66px;
  height: 40px;
  border-radius: 40px;
  font-size: 28px;
  font-weight: 700;
  background: #fff;
  color: var(--pagi-color);
  border: 2px solid var(--pagi-color);
}

.cat-pagination .page-numbers.next:hover,
.cat-pagination .page-numbers.prev:hover,
.cat-pagination .page-numbers.next:focus-visible,
.cat-pagination .page-numbers.prev:focus-visible {
  transform: translateY(-2px);
  filter: brightness(1.02);
}


/* =========================================
   store-detail Page
========================================= */


/* 外枠 */
.store-detail {
  padding: 200px 40px 100px
}

.store-detail__grid-1 {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  gap: 36px 48px;
  grid-template-columns: 465px 1fr;
  grid-template-areas:
    "gallery info"
    "meta    map";
}

/* 下段：詳細情報 ＋ 地図の2カラム */
.store-detail__grid-2 {
  max-width: 1080px;
  margin: 0 auto 80px;
  display: grid;
  grid-template-columns: minmax(0, 540px) minmax(0, 1fr);
  gap: 32px 48px;
  grid-template-areas: "meta map";
  align-items: start;   /* ★ここがポイント：縦方向に伸ばさない */
}

.store-meta-wrap,
.store-map {
  min-width: 0;
  align-self: start;  /* 念のため：各アイテムも上揃え */
}

/* ギャラリー（上段 左） */
.store-gallery {
  grid-area: gallery
}

/* ギャラリー（上段 左） */
.store-gallery__main {
  background: #fff;
  border-radius: 30px;
  overflow: hidden;
  margin: 0 0 18px;
  aspect-ratio: 4 / 3;
}

.store-gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity .25s ease;
  border-radius: 0;
  /* ←★ ここを追加：プレビュー画像は角丸にしない */
}

.store-gallery__thumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  list-style: none;
  margin: 0;
  padding: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.store-gallery .thumb {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid transparent;
  background: transparent;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.store-gallery .thumb.is-active {
  border-color: #EA4DA0;
  box-shadow: 0 0 0 4px rgba(234, 77, 160, .12) inset;
}

.store-gallery .thumb:hover {
  transform: translateY(-2px);
}

.store-gallery .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 50%;
  /* ←★ サムネイルのみ丸く */
}


/* 概要（上段 右） */
.store-info {
  grid-area: info
}

.store-cat {
  display: inline-block;
  font-size: 16px;
  line-height: 1;
  padding: 5px 20px;
  border-radius: 999px;
  background: #FCA8D1;
  color: #fff;
  margin-bottom: 14px
}

.store-title {
  font-size: 25px;
  margin: 0 0 14px
}

/* 店舗詳細ページのタグ */
.store-tags {
  display: flex;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 10px 0 10px;
  flex-wrap: wrap;
}

.store-tags li {
  background: #aeadae;
  color: #fff;
  border-radius: 10px;
  padding: 3px 20px;
  font-size: 15px;
  font-weight: 500;
}


.store-desc p {
  margin: 0 0 10px;
  color: #555
}

/* 詳細（下段 左） */
.store-meta-wrap {
  grid-area: meta
}

.store-meta {
  margin: 0
}

.store-meta__row {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  align-items: start;
  padding: 12px 0;
}

/* 店舗詳細：公式サイトなど長い文字列を折り返す */
.store-meta__row dd,
.store-meta__row dd a {
  word-break: break-all;       /* 単語の途中でも折り返す */
  overflow-wrap: anywhere;     /* どこでも折り返し可（対応ブラウザ向け） */
  min-width: 0;                /* グリッド内で幅を押し広げないように */
}


.store-meta-wrap,
.store-map {
  min-width: 0;
}



.store-meta dt {
  color: #363535;
  font-weight: 400
}

.store-meta dd {
  margin: 0;
  font-weight: 600;
  color: #363535;
}

.store-meta dd a {
  color: #363535;
}

.store-sns a {
  display: inline-block;
  margin-right: 10px
}

.store-sns img {
  width: 35px;
  height: 35px
}

/* 地図（下段 右） */
.store-map {
  grid-area: map;
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  padding: 0;       /* 念のためパディングもゼロに */
}

/* WYSIWYG で付く <p> の余白を消す */
.store-map p {
  margin: 0;
  line-height: 0;
}

/* iframe 本体 */
.store-map iframe {
  display: block;
  width: 100%;
  height: 320px;
  border: 0;
}



/* =========================================
   About Page
========================================= */

#about-page {
  padding: 200px 20px 100px;
}

.about-page {
  max-width: 776px;
  margin: 0 auto;
  padding: 0 20px 120px;
  text-align: center;
}

/* 写真 */
.about-image {
  margin-top: 40px;
}

.about-image img {
  width: 100%;
  border-radius: 20px;
  display: block;
  height: auto;
}

/* テキストブロック */
.about-page-text {
  background: #fff;
  border-radius: 30px;
  padding: 30px 45px;
  margin-top: 60px;
}

/* 小見出し */
.about-subtitle {
  background-color: #807E7D;
  color: #fff;
  display: inline-block;
  padding: 12px 75px;
  border-radius: 35px;
  font-size: 25px;
  line-height: 1;
  font-weight: 500;
  text-align: center;
  margin-bottom: 28px;
  text-align: center;
}

/* 段落 */
.about-page-text p {
  font-size: 25px;
  line-height: 40px;
  text-align: left;
  font-weight: 300;
  color: #555;
}

/* aboutページ用マップ */
.about-map {
  width: 100%;
  margin-top: 100px;
  /* 高さ指定を親ではなく iframe に任せる */
  overflow: visible; /* ← hiddenを外すことで切れ防止 */
  background-color: #fff;
}

.about-map iframe {
  display: block;
  width: 100%;
  height: 440px; /* ← 高さをこちらで固定 */
  min-height: 440px; /* 念のため保険 */
  border: none;
}



/* =========================================
   News Page
========================================= */

#news-page {
  padding: 200px 0 0;
}

/* aboutページ用マップ */
.news-map {
  width: 100%;
  height: 440px;
  overflow: hidden;
}

.news-map iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

.pabottom-220 {
  padding-bottom: 220px;
}

.news-page-grid {
  display: grid;
  grid-template-columns: repeat(3, 345px);
  gap: 20px;
  justify-content: space-between;
  margin-bottom: 80px;
  align-items: stretch;
}

/* =========================================
   event Page
========================================= */


#event {
  padding: 200px 0 0;
}

.event-detail {
  padding: 80px 20px;            /* 余白（左右は安全マージン） */
}

.event-detail__inner {
  max-width: 900px;
  text-align: center;
  margin: 0 auto;
}

.event-detail__title {
  font-size: 25px;
  font-weight: 700;
  text-align: center;
  letter-spacing: .05em;
  margin: 0 0 28px;
}

/* 画像：幅900px（PC）、SPでは100%で自動縮小 */
.event-detail__figure {
  width: 900px;
  max-width: 100%;
  margin: 0 auto 40px;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}

.event-detail__figure img {
  display: block;
  width: 100%;
  height: auto;
}

/* 本文 */
.event-detail__body {
  max-width: 980px;
  margin: 0 auto 90px;
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 2.2;
  letter-spacing: .02em;
  color: #333;
    text-align: left;
}

.event-detail__body p + p {
  margin-top: 1.2em;
}

/* 余白感微調整（SP） */
@media (max-width: 767px) {
  .event-detail {
    padding: 60px 16px;
  }
  .event-detail__figure {
    margin-bottom: 28px;
    border-width: 4px;
    border-radius: 18px;
  }
}

/* =========================================
   news Page
========================================= */


#news {
  padding: 200px 0 0;
}

.news-detail {
  padding: 80px 20px;            /* 余白（左右は安全マージン） */
}

.news-detail__inner {
  max-width: 900px;
  text-align: center;
  margin: 0 auto;
}

.news-detail__title {
  font-size: 25px;
  font-weight: 700;
  text-align: center;
  letter-spacing: .05em;
  margin: 0 0 28px;
}

/* 画像：幅900px（PC）、SPでは100%で自動縮小 */
.news-detail__figure {
  width: 900px;
  max-width: 100%;
  margin: 0 auto 40px;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}

.news-detail__figure img {
  display: block;
  width: 100%;
  height: auto;
}

/* 本文 */
.news-detail__body {
  max-width: 980px;
  margin: 0 auto 90px;
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 2.2;
  letter-spacing: .02em;
  color: #333;
    text-align: left;
}

.news-detail__body p + p {
  margin-top: 1.2em;
}

/* 余白感微調整（SP） */
@media (max-width: 767px) {
  .news-detail {
    padding: 60px 16px;
  }
  .news-detail__figure {
    margin-bottom: 28px;
    border-width: 4px;
    border-radius: 18px;
  }
}

/* =========================================
   contact Page
========================================= */

/* お問い合わせ */
.contact-section {
  padding: 200px 0 120px;
}

.contact-inner {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
}

.contact-title {
  font-size: 26px;
  text-align: center;
  margin-bottom: 60px;
}

.contact-form {
  background: transparent;
}

/* 行レイアウト（PC 基本） */
.form-row {
  display: grid;
  grid-template-columns: 240px 1fr;
  column-gap: 24px;
  row-gap: 0;
  align-items: center;      /* ★ 基本は中央揃え */
  margin: 0 0 32px;
  font-size: 20px;
  line-height: 1;           /* 行間リセット（余分な高さをなくす） */
}

/* テキストエリアの行だけ上揃えにしたい場合は
   該当行に class="form-row textarea-row" を付ける */
.form-row.textarea-row {
  align-items: flex-start;  /* ★ お問い合わせ内容 だけ上揃え */
}

/* プライバシー行は 1 カラム */
.form-row-privacy {
  grid-template-columns: 1fr;
}

/* 送信ボタン行 */
.form-row-submit {
  grid-template-columns: 1fr;
  text-align: center;
  margin: 0 auto 40px;
}

/* ラベル（項目名 + 必須/任意） */
.form-label {
  font-weight: 600;
  color: #333;
  margin: 0;
  display: flex;
  align-items: center;      /* ★ ラベル内で縦中央 */
  gap: 8px;
  line-height: 1;
  height: 100%;             /* ★ 行の高さに合わせる → きれいに中央揃えになる */
}

/* textarea 行だけはラベルを上揃えに戻す */
.form-row.textarea-row .form-label {
  align-items: flex-start;
  height: auto;
}

/* 必須・任意バッジ */
.badge {
  display: inline-block;
  padding: 6px 8px;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1;
  vertical-align: middle;
}

.badge-required {
  background: #ff4fa0;
  color: #fff;
}

.badge-optional {
  background: #ccc;
  color: #fff;
}

/* フィールド側 */
.form-field {
  line-height: 1;
}

/* インプット共通 */
.form-field input[type="text"],
.form-field input[type="email"],
.form-field input[type="tel"],
.form-field textarea,
.form-field select {
  width: 100%;
  padding: 10px 14px;
  border-radius: 10px;
  border: 2px solid #ff4fa0;
  font-size: 14px;
  line-height: 1.4;          /* 入力文字の行間だけ少し確保 */
  box-sizing: border-box;
  background-color: #fff;
  outline: none;
}

.form-field textarea {
  min-height: 180px;
  resize: vertical;
}

/* セレクトの矢印 */
.select-wrapper {
  position: relative;
}

.select-wrapper select {
  -webkit-appearance: none;
  appearance: none;
  padding-right: 40px;
}

.select-wrapper::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 8px;
  height: 8px;
  border-right: 2px solid #ff4fa0;
  border-bottom: 2px solid #ff4fa0;
  transform: translateY(-60%) rotate(45deg);
  pointer-events: none;
}

/* ファイル */
.form-field-file {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* 実際の file input は見えない場所へ */
.form-field-file .file-input {
  position: absolute;
  left: -9999px;
}

.file-button {
  display: inline-block;
  padding: 10px 24px;
  border-radius: 30px;
  background: #ff6fa6; /* 既存のピンクに合わせて調整してください */
  color: #fff;
  font-size: 14px;
  cursor: pointer;
}

.file-name {
  font-size: 14px;
  color: #555;
}



.file-button {
  position: relative;
  display: inline-block;
  padding: 8px 22px;
  border-radius: 999px;
  background: #ff4fa0;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}

.file-button input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.file-note {
  font-size: 12px;
  color: #666;
}

.file-name {
  width: 100%;
  font-size: 12px;
  color: #333;
}

/* プライバシー */
.privacy-title {
  margin: 0 0 10px;
  font-size: 20px;
  font-weight: 600;
}

.privacy-check {
  margin-top: 4px;
}

/* ==== 利用規約チェックボックス ==== */

.privacy-check {
  margin-top: 4px;
}

/* ラベル全体（ボックス＋文字） */
.checkbox-label {
  position: relative;           /* input をこの中で絶対配置するため */
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 14px;
  margin-bottom: 50px;
}

/* 本物のチェックボックス（見えないけどクリック判定担当） */
.checkbox-label input[type="checkbox"] {
  position: absolute;
  inset: 0;                     /* ラベル全体をクリック範囲にする */
  margin: 0;
  opacity: 0;                   /* 完全に非表示 */
  cursor: pointer;
}

/* 見た目の四角いボックス */
.checkbox-custom {
  width: 18px;
  height: 18px;
  border-radius: 4px;
  border: 2px solid #ff4fa0;
  box-sizing: border-box;
  display: inline-block;
  position: relative;
  flex-shrink: 0;
}

/* チェックされたときのチェックマーク */
.checkbox-label input[type="checkbox"]:checked + .checkbox-custom::after {
  content: "";
  position: absolute;
  top: 1px;
  left: 4px;
  width: 6px;
  height: 10px;
  border-right: 2px solid #ff4fa0;
  border-bottom: 2px solid #ff4fa0;
  transform: rotate(45deg);
}

/* テキストもクリック可能に */
.checkbox-text {
  cursor: pointer;
}

.checkbox-text a {
  color: #0071d4;
  text-decoration: underline;
}

/* 送信ボタン（CF7用） */
.contact-form .wpcf7-form-control.wpcf7-submit.contact-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 260px;                  /* ★ ここが効くようになる */
  padding: 12px 36px;
  border-radius: 999px;
  border: 2px solid #ff4fa0;
  background: #fff;
  font-size: 20px;
  font-weight: 500;
  color: #555454;
  cursor: pointer;
  transition: background .2s ease, color .2s ease, transform .1s ease;
  margin: 0 auto;
}

/* hover も同じクラスで */
.contact-form .wpcf7-form-control.wpcf7-submit.contact-submit:hover {
  background: #ff4fa0;
  color: #fff;
  transform: translateY(-1px);
}


.submit-arrow {
  font-size: 20px;
  color: #ff4fa0;
}

/* モーダル */
.contact-modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}

.contact-modal.is-open {
  display: block;
}

.contact-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.4);
}

.contact-modal__content {
  position: relative;
  max-width: 700px;
  margin: 60px auto;
  background: #fff;
  border-radius: 16px;
  padding: 24px 24px 28px;
  box-sizing: border-box;
}

.contact-modal__title {
  text-align: center;
  font-size: 18px;
  margin-bottom: 16px;
}

.confirm-list {
  margin: 0;
}

.confirm-row {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 6px 16px;
  font-size: 14px;
  padding: 8px 0;
  border-bottom: 1px solid #eee;
}

.confirm-row dt {
  font-weight: 600;
  color: #333;
}

.confirm-row dd {
  margin: 0;
  white-space: pre-wrap;
}

.contact-modal__footer {
  margin-top: 20px;
  display: flex;
  justify-content: center;
  gap: 16px;
}

.modal-button {
  min-width: 140px;
  padding: 8px 20px;
  border-radius: 999px;
  border: 2px solid #ccc;
  background: #fff;
  font-size: 14px;
  cursor: pointer;
}

.modal-button--back {
  border-color: #ccc;
  color: #555;
}

.modal-button--submit {
  border-color: #ff4fa0;
  color: #fff;
  background: #ff4fa0;
}

/* 利用規約エリア */
.terms-wrap {
  width: 100%;
}

/* スクロールボックス */
.terms-box {
  width: 100%;
  max-height: 180px;        /* 高さは好みで調整 */
  padding: 10px 20px;
  border-radius: 15px;
  background: #fff;
  box-sizing: border-box;
  overflow-y: scroll;       /* ここでスクロールさせる */
  margin-bottom: 10px;
}

.terms-box__inner {
  font-size: 13px;
  line-height: 1.6;
  color: #333;
}

.terms-box__inner h3 {
  font-size: 13px;
  margin: 12px 0 4px;
}

.terms-box__inner ul {
  padding-left: 1.2em;
  margin: 0 0 6px;
}

.terms-box__inner li {
  list-style: disc;
}

.terms-last {
  margin-top: 10px;
}

/* 既存のチェックボックス周りと馴染むように少し余白 */
.privacy-check {
  margin-top: 4px;
}

/* Contact Form 7 利用規約チェックボックスを表示させる */
.terms-wrap .checkbox-label input[type="checkbox"] {
  display: inline-block !important;
  width: 16px;
  height: 16px;
  margin-right: 6px;
  vertical-align: middle;
}

/* Contact Form 7 用：ラッパーとフィールド幅だけ調整 */
.contact-form .wpcf7-form-control-wrap {
  display: block;
}

.contact-form .wpcf7-form-control {
  width: 100%;
  box-sizing: border-box;
}

/* セレクト用（念のため） */
.contact-form .wpcf7-form-control.wpcf7-select {
  width: 100%;
}

/* テキストエリアも同様に */
.contact-form textarea.wpcf7-form-control {
  width: 100%;
  resize: vertical;
}

/* ───────────────
   お問い合わせフォーム 最終調整
   ラベルを中央揃えにする
   ─────────────── */

/* 全行：ラベルとフィールドを縦中央に */
.contact-form .form-row {
  align-items: center !important;
}

/* ラベル内のテキスト＋バッジを中央に */
.contact-form .form-row > .form-label {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start;
  margin: 0 !important;
  height: 100%;
  line-height: 1;
}

/* textarea の行だけは「上揃え」に戻す */
.contact-form .form-row.textarea-row {
  align-items: flex-start !important;
}

.contact-form .form-row.textarea-row > .form-label {
  align-items: flex-start !important;
  height: auto;
}


/* =========================================
   thanks Page
========================================= */

/* サンクスページ */

#contact-thanks {
  margin-top: 200px;
}

.contact-thanks-section {
  padding: 20px 0 120px;
}

.contact-thanks-inner {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
  text-align: center;
}

.contact-thanks-title {
  font-size: 26px;
  margin-bottom: 24px;
}

.contact-thanks-lead {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 24px;
}

.contact-thanks-box {
  background: #fff;
  border-radius: 20px;
  padding: 30px 24px 30px;
  box-sizing: border-box;
  font-size: 14px;
  text-align: center;
  margin: 0 auto 32px;
}

.contact-thanks-box p {
  margin: 0 0 12px;
}

.contact-thanks-list {
  margin: 0;
  padding-left: 1.2em;
}

.contact-thanks-list li {
  line-height: 1.8;
}

/* ボタン */
.contact-thanks-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
}

.contact-thanks-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  padding: 10px 28px;
  border-radius: 999px;
  border: 2px solid #ff4fa0;
  background: #ff4fa0;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  box-sizing: border-box;
  transition: background .2s ease, color .2s ease, transform .1s ease;
}

.contact-thanks-btn:hover {
  background: #fff;
  color: #ff4fa0;
  transform: translateY(-1px);
}

.contact-thanks-btn--sub {
  background: #fff;
  color: #ff4fa0;
}

.contact-thanks-btn--sub:hover {
  background: #ff4fa0;
  color: #fff;
}
