@charset "utf-8";
/*
Theme Name: crepeandespresso_fc
Theme URI: http://enmusubi426.wp.xdomain.jp/
Description: クレープとエスプレッソとFCオリジナルテーマ
Version: 2.0
Author: Hisae Komatsu
Author URI: http://enmusubi426.wp.xdomain.jp/
*/
/*------------------- headerレイアウト ------------------------------*/
.sp-br {
  display: none;
}
/* コンテンツ内の<p>タグ非表示 
p {
  display: none;
} */
#header {
  width: 100%;
  left: 0;
  top: 0;
  z-index: 9999;
  transition: .3s;
  height: 105px;
  padding-bottom: 0;
  position: fixed;
}
/* 親コンテナ */
#flex1 {
  width: 1180px;
  max-width: 96%;
  height: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between; /* ロゴは左、ナビは右に振り分ける */
  align-items: center; /* 上下中央揃え */
}
/* ロゴの設定 */
h1#logo {
  width: 120px; /* 少し大きくして視認性をアップ */
  height: auto;
  margin: 0;
  flex-shrink: 0; /* ロゴが潰れないように固定 */
}
h1#logo img {
  width: 80%;
  height: auto;
  display: block;
}
.clearfix {
  content: "";
  clear: both;
}
/*------------------- ナビレイアウト ------------------------------*/
/* ナビゲーションのボックス */
#nav_box {
  display: flex;
  align-items: center;
  justify-content: flex-end; /* 右寄せ */
  flex-grow: 1; /* 余ったスペースをナビ側で確保 */
}
#nav_box ul {
  display: flex;
  gap: 15px; /* メニュー項目間の距離を適度に空ける */
  margin: 0;
  padding: 0;
  list-style-type: none;
}
#nav_box li {
  display: block;
  padding-left: 15px;
  padding-right: 15px;
  letter-spacing: 0.1em;
  font-weight: bold;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
  box-sizing: border-box;
}
#nav_box a {
  display: block;
  width: 100%;
  color: #f3eacd;
  font-size: 15px;
  text-decoration: none;
  position: relative;
  padding-bottom: 5px;
  font-weight: bold;
}
#nav_box li.line a::after {
  border-bottom: 2px solid #e3857b;
  bottom: 0;
  content: "";
  display: block;
  position: absolute;
  right: 0;
  transition: all .3s ease;
  -webkit-transition: all .3s ease;
  width: 0;
  margin-bottom: -3px;
}
#nav_box li.line a:hover::after {
  width: 100%;
}
a.contact_btn {
  margin-left: auto;
  margin-right: 0;
  padding: .3em .3em;
  background: #ca3636;
  font-size: 14px;
}
.contact_btn img {
  position: relative;
  top: 0.6vw;
  left: 0vw;
}
.contact_btn p {
  padding-bottom: 6px;
  position: relative;
  top: 0vw;
  color: #fff;
}
a.contact_btn:hover {
  animation: shine 1s;
}
@keyframes shine {
  0% {
    background: #6c0707;
  }
  10% {
    background: #ccc;
  }
  100% {
    background: #6c0707;
  }
}
/*ナビに配置しているお問い合わせボタンのレイアウト*/
.f_item a {
  color: #00B0F0;
  border-bottom: 3px solid #00B0F0;
}
/*------------------- モーダル仮 ------------------------------*/
.modal {
  display: none; /* jQueryからfadeIn対象 */
  position: fixed;
  z-index: 9999; /* モーダルが前面にくるように */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6); /* 背景半透明 */
}
.modal .modal-content {
  background: #fff;
  padding: 2rem;
  max-width: 600px;
  margin: 10% auto;
  border-radius: 5px;
  position: relative;
  z-index: 10000;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
  border: 9px #dfcda6 double;
}
.close {
  font-size: 24px;
  color: #998a3b;
  background-color: #f0ead4;
  border: 2px solid #dfcda5;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  position: absolute;
  position: absolute;
  top: -5px;
  left: 6px;
}
.close:hover {
  background-color: #f9ffe3;
  color: #a0cab5;
  border-color: #a0cab5;
}
.modal-content h3 {
  font-size: 17px;
  margin: 10px 0;
  color: #484848;
  font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;  
}
.modal-content strong {
  font-size: 18px;
  margin: 10px auto;
  color: #484848;
  font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;  
}
.modal-content p {
  font-size: 15px;
  font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;  
}
.info-table {
  width: 100%;
  border-collapse: collapse;
}
.info-table th {
  text-align: left;
  vertical-align: top;
  padding: 4px 8px;
  white-space: nowrap;
  width: 80px;
  color: #484848;
  font-size: 15px;
  font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;  
}
.info-table td {
  padding: 4px 8px;
  color: #484848;
  font-size: 15px;
  font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;  
}
/*------------------- モーダル仮 ------------------------------*/
/*------------------- mv背景レイアウト ------------------------------*/
#top_mv {
  width: 100%;
  height: 850px;
}
.fv_sp {
  display: none;
}
#txt_img_pc img {
  width: 100%;
  height: auto;
}
#namibatabg {
  width: 100%;
  height: 97px;
  background-image: url(../images/namigatabg.png);
  position: relative;
  top: -6rem;
  background-repeat: no-repeat; /* 画像を繰り返さない */
}
#main-box {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  max-width: 100vw; /* 横揺れ防止 */
}
.contentbox {
  width: 100%;
  max-width: 1180px;
  height: auto;
  margin: 0 auto;
}
/* ページ全体の幅 */
.mainContents {
  width: 100%;
  height: auto;
  margin: 0 auto;
  max-width: 1180px;
  padding: 0; /* 余計なpaddingを防ぐ */
}
/* ページ全体のh1見出しのレイアウト*/
h1.pagetitle_1 {
  width: 100%;
  max-width: 980px;
  height: 60px;
  position: relative;
  top: -12vw;
  left: 23vw;
  font-size: 38px;
  color: white;
  letter-spacing: 0.1em;
  font-weight: 700;
}
h1.pagetitle_2 {
  width: 100%;
  max-width: 980px;
  height: 60px;
  position: relative;
  top: -11vw;
  left: 12vw;
  font-size: 38px;
  color: white;
  letter-spacing: 0.1em;
  font-weight: 700;
}
.cont-header {
  background-color: #f1eee7;
  width: 100%;
  height: auto;
}
.trim-h {
  width: 100%;
  height: auto;
}
/* パンくずリスト全体のスタイル */
.pankuzu {
  width: 100%;
  height: auto;
  background: #f1eee7;
  padding: 1.8rem 11rem 1rem;
}
.breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  color: #333;
  position: relative;
  top: -1vw;
}
/* 各リンクのスタイル */
.breadcrumbs a {
  color: #682b2b;
  text-decoration: none;
  padding: 0 5px;
  transition: color 0.3s ease;
}
/* リンクにホバー時の効果 */
.breadcrumbs a:hover {
  color: #bf4d4d;
  text-decoration: underline;
}
/* 区切り文字のスタイル */
.breadcrumbs span::after {
  content: ">";
  margin: 0 5px;
  color: #aaa;
}
/* 最後の要素には区切りを表示しない */
.breadcrumbs span:last-child::after {
  content: "";
}
/*.col-md-9 {
  margin-top: 50px;
} */
/*------------------- sectionレイアウト ------------------------------*/
#section1 {
  width: 100%;
  height: auto;
  min-height: 100vh;
  background-image: url(../images/con1_2bg.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  background-color: white;
  margin-bottom: -3vw;
}
#section2 {
  width: 100%;
  height: 100%;
  background-color: #f1eee7;
  padding: 40px 0;
  background-image: url(../images/con2_1bg.png);
  background-repeat: no-repeat;
}
#section3 {
  width: 100%;
  height: 100%;
}
#section4 {
  width: 100%;
  height: 100%;
  background-color: #f1eee7;
}
#section5 {
  width: 100%;
  height: 100%;
}
#section6 {
  width: 100%;
  height: 100%;
  background-color: #f1eee7;
}
#section7 {
  width: 100%;
  height: 100%;
  background-color: #f1eee7;
}
#section8 {
  margin-top: 50px;
  margin-bottom: 50px;
}
/*-----------------------------------------------------  */
/* content						*/
/*-----------------------------------------------------	*/
.inner {
  width: 100%;
  max-width: 100%; /* 親要素を超えないようにする */
}
/* パンくずリスト全体のスタイル */
.breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  color: #333;
  position: relative;
  top: -0.8vw;
}
/* パンくずリストcontactページのみスタイル */
.breadcrumbs-contact {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  color: #333;
  position: relative;
  top: -0.8vw;
}
/* 各リンクのスタイル */
.breadcrumbs a {
  color: #682b2b;
  text-decoration: none;
  padding: 0 5px;
  transition: color 0.3s ease;
}
/* リンクにホバー時の効果 */
.breadcrumbs a:hover {
  color: #bf4d4d;
  text-decoration: underline;
}
/* 区切り文字のスタイル */
.breadcrumbs span::after {
  content: ">";
  margin: 0 5px;
  color: #aaa;
}
/* 最後の要素には区切りを表示しない */
.breadcrumbs span:last-child::after {
  content: "";
}
/*.col-md-9 {
  margin-top: 50px;
} */
/* Shop投稿ページのみのレイアウト */
h1.single-Shop {
  width: 100%;
  height: auto;
  max-width: 980px;
  margin: 20px auto 40px;
  font-size: 1.5em;
  position: relative;
  text-align: center;
  padding: 1.2rem;
}
h1.single-Shop::before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 30px);
  width: 60px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background: #ca1b1d;
}
.single-page {
  height: 127px;
}
/*.breadcrumbs-2 {
  position: absolute;
  top: 5vw;
}*/
/* パンくずリスト全体のスタイル */
.breadcrumbs-2 {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  color: #333;
  position: relative;
  top: 3.2vw;
}
/* 各リンクのスタイル */
.breadcrumbs-2 a {
  color: #682b2b;
  text-decoration: none;
  padding: 0 5px;
  transition: color 0.3s ease;
}
/* リンクにホバー時の効果 */
.breadcrumbs-2 a:hover {
  color: #bf4d4d;
  text-decoration: underline;
}
/* 区切り文字のスタイル */
.breadcrumbs-2 span::after {
  content: ">";
  margin: 0 5px;
  color: #aaa;
}
/* 最後の要素には区切りを表示しない */
.breadcrumbs-2 span:last-child::after {
  content: "";
}
/*-----------------------------------------------------  */
/* section1 レイアウト						*/
/*-----------------------------------------------------	*/
h3 {
  width: 60%;
  height: auto;
  margin: auto auto 13px auto;
}
#concept {
  text-align: center;
  margin-bottom: 30px;
  margin-top: 30px;
}
#concept_flex {
  width: 100%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  height: auto;
  padding-bottom: 30px;
}
#co_txt {
  width: 50%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 3%;
}
#co_txt p {
  color: #2B2222;
  font-size: 15px;
  line-height: 1.8em;
  display: block;
}
h3#about {
  width: 350px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 15px;
  font-size: 20px;
  margin: 10px auto;
}
#co_img {
  width: 45%;
  height: auto;
  margin-left: 3px;
  position: relative;
  top: -1vw;
}
*#co_img img {
  width: 100%;
  height: auto;
  border-radius: 10px; /* 角を丸くする */
  box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.2); /* 影をつける */
}
.an2-fadeup {
  animation-name: fadeup;
  animation-duration: 2s;
  animation-iteration-count: 1;
}
@keyframes fadeup {
  from {
    opacity: 0;
    transform: translateY(50px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/*-----------------------------------------------------  */
/* section2 レイアウト						*/
/*-----------------------------------------------------	*/
#section2 {
  width: 100%;
  height: 100%;
  background-image: url(../images/con2_1bg.png);
  background-repeat: no-repeat;
  background-color: #f1eee7;
  padding: 40px 0;
}
#miryoku_box {
  margin-bottom: 35px;
}
/* SP用テキストPC表示時は非表示 */
.textsp-on {
  display: none;
}
.miryokuimg {
  width: 100%;
  margin: 0 auto;
  text-align: center;
  margin-top: 40px;
  margin-bottom: 40px;
}
#miryoku_txt p {
  display: block;
}
#miryoku_txt {
  font-size: 14px;
  line-height: 1.6em;
  padding: 0 10px;
  box-sizing: border-box;
  width: 100%;
  max-width: 90%; /* 画面幅に応じて自動調整 */
  margin: 0 auto;
  overflow-wrap: break-word; /* 確実に折り返す */
  white-space: normal; /* 通常の折り返しを維持 */
  overflow: hidden; /* はみ出しを防ぐ */
}
#miryoku {
  margin: 0 auto 60px;
  text-align: center; /* 中の要素を中央寄せ */
}
#miryoku h1 {
  font-size: 28px;
}
#miryoku h1 span {
  font-size: 36px;
  color: #dd2929;
  font-weight: bold;
}
h1.miryoku {
  margin: 0 auto; /* 左右のマージンを自動で均等にする */
  text-align: center; /* テキストを中央揃え */
  font-size: 29px;
  height: 45px;
  display: flex;
  justify-content: center; /* Flexboxで中身を中央に配置 */
  align-items: center; /* 縦方向の中央寄せ */
}
.miryoku span {
  color: #d31c1c;
  font-size: 55px;
  position: relative;
  top: -9%;
  left: -1%;
  font-family: "Hiragino Mincho Pro", "Yu Mincho", "MS PMincho", "MS Mincho", serif;
}
.miryoku .txt {
  border-left-style: solid;
  border-left-width: 1px;
  padding: 15px 3px 5px 13px;
  border-left-color: #df2525;
  height: 40px;
}
/*-----------------------------------------------------  */
/* section3 レイアウト						*/
/*-----------------------------------------------------	*/
#section3 {
  width: 100%;
  height: 100%;
  background-image: url(../images/con4_01bg.png);
  background-repeat: no-repeat;
  padding: 25px 0;
  background-position: 90% 2%;
}
#fcbusiness {
  width: 100%;
  height: auto;
}
/* 見出しを中央揃え */
.heading {
  text-align: left;
  font-size: 21px;
  font-weight: bold;
  color: #c00; /* 赤系のカラー */
  margin-bottom: 20px;
}
/* コンテナ設定 */
.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 20px;
  width: 100%;
}
/* フッターを下に押し下げるための指定 */
.main-wrapper {
  min-height: 60vh; /* 画面の高さの60%を最低限確保する（相対指定） */
  padding-bottom: 50px; /* フッターとの間の余白 */
}
/* ついでにタイトル周りの余白も整えます */
.pagetitle_1 {
  margin-bottom: 30px;
  font-weight: bold;
}
/* コンテンツの左右配置 */
.content {
  display: flex;
  align-items: center;
  gap: 20px; /* ボックス間の余白 */
}
/* 画像ボックス */
.image-box {
  flex: 1;
}
.image-box img {
  width: 100%;
  height: auto; /* 画像のアスペクト比を保つ */
  display: block;
}
/* テキストボックス */
.text-box {
  flex: 1;
  font-size: 16px;
  line-height: 1.8;
}
/*-----------------------------------------------------  */
/* section4 レイアウト						*/
/*-----------------------------------------------------	*/
#titlebg {
  width: 100%;
  height: 350px;
  background-image: url(../images/puro_tibg.png);
}
#titlebox {
  width: 100%;
  height: 50vh; /* 高さを画面全体に設定 */
  margin: 0 auto;
  text-align: center;
  overflow-x: hidden;
  display: flex; /* Flexboxを適用 */
  justify-content: center; /* 横方向で中央に配置 */
  align-items: center; /* 縦方向で中央に配置 */
}
h1#puro {
  font-size: 40px;
  color: white;
}
/***ステップバーデザイン１***/
.step-wrap1 {
  counter-reset: count;
  /*margin: 2em 0;*/
  position: relative;
  width: 750px;
  margin: 50px auto 30px auto;
}
.step-content1 {
  padding: 0 0 1.3em 2em;
  margin: 0;
  position: relative;
}
.step-content1::before {
  content: "";
  display: block;
  width: 14px;
  height: 14px;
  background: #dd3232;
  border-radius: 50%;
  position: absolute;
  top: 3px;
  left: 3px;
}
.step-content1::after {
  content: "";
  display: block;
  /*height: calc(100% - 35px);*/ /*default*/
  height: calc(100% - 14px);
  border-left: solid 2px #e42121;
  position: absolute;
  /*top: 30px;*/ /*default*/
  top: 17px;
  left: 10px;
}
.step-title1 {
  font-weight: bold;
  font-size: 105%;
}
.step-label1 {
  color: #454848;
  font-weight: bold;
}
.step-label1::after {
  counter-increment: count;
  content: counter(count);
  position: relative;
  left: .4em;
  display: block;
  color: #b92020;
  font-size: 35px;
  font-family: "Hiragino Mincho Pro", "Yu Mincho", "MS PMincho", "MS Mincho", serif;
}
.step-body1 {
  margin-top: .5em;
  padding: 0 0 1em;
  border-bottom: dotted 2px #ddd;
}
.step-wrap1 > :last-of-type::after {
  display: none;
}
.step-body1 {
  margin-top: .5em;
  padding: 0 0 1em;
  border-bottom: dotted 2px #ddd;
  font-size: 16px;
}
.step-title1 span {
  color: #cc1515;
  font-size: 25px;
}
/***ステップバーデザイン１***/
/*-----------------------------------------------------  */
/* section5					*/
/*-----------------------------------------------------	*/
h1#shop_news {
  width: 200px;
  height: auto;
  margin: 0 auto;
  font-size: 35px;
  color: #353534;
  letter-spacing: 0.1em;
}
h1#shop_news {
  position: relative;
  margin-bottom: 1em;
  text-align: center;
}
h1#shop_news:before {
  position: absolute;
  display: inline-block;
  content: '';
  bottom: -15px;
  width: 60px;
  height: 5px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: #bf1212;
  border-radius: 2px;
}
#list-box {
  max-width: 1180px;
  height: auto;
  margin: 0 auto;
  position: relative;
  left: 4rem;
}
.store-cards {
  display: flex;
  gap: 20px;
  flex-wrap: nowrap; /* 横並びを固定 */
  justify-content: space-between;
  margin-top: 40px;
}
.store-card {
  border: 1px solid #ddd;
  border-radius: 8px;
  overflow: hidden;
  width: 30%; /* 横に3件並べるために30%に設定 */
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease;
}
.store-card:hover {
  transform: translateY(-5px);
}
.store-photo {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.store-details {
  padding: 15px;
}
.store-name {
  font-size: 1.5em;
  margin-bottom: 10px;
  color: #333;
}
.store-address, .store-hours, .store-holiday {
  font-size: 0.9em;
  color: #666;
  margin: 5px 0;
}
/* 店舗一覧btnのレイアウトここから */
#store_btnbox {
  width: 600px;
  height: auto;
  margin: 55px auto;
}
.storebtn a {
  background: #fff;
  border-radius: 3px;
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  margin: auto;
  max-width: 350px;
  padding: 10px 25px;
  font-family: "Noto Sans Japanese";
  text-decoration: none;
  color: #d71e1e;
  line-height: 1.8;
  transition: 0.3s ease-in-out;
  font-weight: 900;
  border: #d71e1e solid 1px;
  font-size: 16px;
  letter-spacing: 0.1em;
}
.storebtn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}
.storebtn a:hover {
  background: #d71e1e;
  color: #fff;
}
.storebtn a:hover:after {
  right: 1.4rem;
}
/* 店舗一覧btnのレイアウトここまで */
/*-----------------------------------------------------  */
/* section6 レイアウト						*/
/*-----------------------------------------------------	*/
.news-list {
  max-width: 1000px;
  margin: 0 auto;
  padding: 20px;
}
.news-item {
  padding: 15px 0;
  border-bottom: 1px solid #df1a1a;
  position: relative;
  transition: background-color 0.3s ease;
}
.news-item:hover {
  background-color: #f9f9f9; /* ホバー時に背景色を少し変更 */
}
.news-date {
  font-size: 0.8em;
  color: #666;
  font-style: italic;
  margin-bottom: 5px;
}
.news-title {
  font-size: 18px;
  font-weight: bold;
  color: #333;
  margin: 5px 0;
  transition: color 0.4s ease;
}
.news-title:hover {
  color: #8A7C71;
}
.news-summary {
  font-size: 0.9em;
  color: #555;
  line-height: 1.6;
  margin: 10px 0;
}
.news-link {
  font-size: 0.8em;
  color: #BF1212;
  text-decoration: none;
  font-weight: bold;
  transition: color 0.4s ease;
  display: inline-block;
}
.news-link:hover {
  color: #8A7C71;
  text-decoration: underline;
  transition: color 0.4s ease;
}
/* 新着情報btnのレイアウトここから */
#news_btnbox {
  width: 600px;
  height: auto;
  margin: 55px auto;
}
.newsbtn a {
  background: #fff;
  border-radius: 3px;
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  margin: auto;
  max-width: 350px;
  padding: 10px 25px;
  font-family: "Noto Sans Japanese";
  text-decoration: none;
  color: #d71e1e;
  line-height: 1.8;
  transition: 0.3s ease-in-out;
  font-weight: 900;
  border: #d71e1e solid 1px;
  font-size: 16px;
  letter-spacing: 0.1em;
}
.newsbtn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}
.newsbtn a:hover {
  background: #d71e1e;
  color: #fff;
}
.newsbtn a:hover:after {
  right: 1.4rem;
}
/* 新着情報btnのレイアウトここまで */
/*-----------------------------------------------------  */
/* section7 レイアウト						*/
/*-----------------------------------------------------	*/
#btn_box {
  max-width: 100%; /* 画面幅に収まるように */
  width: 750px; /* PCでは750px */
  margin: 0 auto;
  height: auto;
}
#contact_btnbox {
  margin-bottom: 25px;
}
/* section7のお問い合わせbtnのレイアウトここから */
.contactbtn {
  text-align: center; /* ボタンを中央に配置 */
}
.contactbtn a {
  background: #d71e1e;
  border-radius: 3px;
  position: relative;
  display: inline-block; /* flex の必要がなければ inline-block */
  width: 100%; /* 画面幅いっぱいにする */
  max-width: 350px;
  padding: 10px 25px;
  font-family: "Noto Sans Japanese", sans-serif;
  text-decoration: none;
  color: #fff;
  line-height: 1.8;
  transition: 0.3s ease-in-out;
  font-weight: 900;
  border: #d71e1e solid 1px;
  font-size: 16px;
  letter-spacing: 0.1em;
}
.contactbtn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}
.contactbtn a:hover {
  background: #835748;
  color: #fff;
  border: #835748 solid 1px;
}
.contactbtn a:hover:after {
  right: 1.4rem;
}
/* section7のお問い合わせbtnのレイアウトここまで */
/* section7の資料請求btnのレイアウトここから */
#sriyou_btnbox {
  padding-bottom: 30px;
  text-align: center; /* 親要素でボタンを中央配置 */
}
.siryoubtn {
  text-align: center; /* ボタンを確実に中央寄せ */
}
.siryoubtn a {
  background: #ffc619;
  border-radius: 3px;
  position: relative;
  display: inline-block; /* flex の必要がなければ inline-block */
  width: 100%; /* 画面幅いっぱいにする */
  max-width: 350px;
  padding: 10px 25px;
  font-family: "Noto Sans Japanese", sans-serif;
  text-decoration: none;
  color: #191919;
  line-height: 1.8;
  transition: 0.3s ease-in-out;
  font-weight: 900;
  border: #ffc619 solid 1px;
  font-size: 16px;
  letter-spacing: 0.1em;
}
.siryoubtn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}
.siryoubtn a:hover {
  background: #835748;
  border: #835748 solid 1px;
  color: #fff;
}
.siryoubtn a:hover:after {
  right: 1.4rem;
}
/* section7の資料請求btnのレイアウトここまで */
/*-----------------------------------------------------  */
/* お問い合わせボタンのレイアウト						*/
/*-----------------------------------------------------	*/
#contact-button {
  display: none;
}
#back-to-top-button {
  display: none;
}
.button-container-box {
  width: 100%;
  max-width: 100%;
}
.button-container {
  position: fixed;
  bottom: 20px; /* `-20px` だと下にずれるので調整 */
  right: 20px;
  display: flex;
  gap: 10px;
  z-index: 1000;
  transform: translateZ(0); /* 横揺れ防止 */
}
.button-container {
  will-change: transform;
}
.contact-button {
  padding: 14px 6vw; /* 縦横のパディング */
  background-color: #d71e1e; /* ボタンの背景色 */
  color: white; /* ボタンの文字色 */
  border-radius: 3px; /* ボタンの角を丸く */
  cursor: pointer; /* カーソルをポインターに */
  font-size: 16px;
  position: absolute;
  left: -58vw;
  top: -4vw;
}
.contact-button a {
  color: #FFFFFF;
  text-decoration: none;
}
.back-to-top-button {
  width: 50px; /* トップに戻るボタンの幅 */
  height: 50px; /* トップに戻るボタンの高さ */
  background-color: #b38a7d; /* ボタンの背景色 */
  border-radius: 50%; /* ボタンを丸く */
  color: white; /* ボタンの文字色 */
  display: none; /* 初期状態は非表示 */
  align-items: center;
  justify-content: center;
  display: flex; /* フレックスボックスで表示 */
  position: absolute;
  left: -25vw;
  top: -4vw;
}
/*-----------------------------------------------------  */
/* お問い合わせフォームレイアウト						*/
/*-----------------------------------------------------	*/
.wpcf7-form {
  background-color: #f1eee7;
  padding: 50px;
  width: 100%; /* 横幅を100%に設定 */
  max-width: 980px; /* 最大幅980pxに設定 */
  border-radius: 10px;
  margin: 0 auto; /* 中央揃え */
}
.table_form {
  width: 100%;
  max-width: 100%;
  margin: 30px auto;
  font-family: inherit;
  letter-spacing: 0.1em;
  overflow-x: auto; /* 横スクロールを許可 */
  display: block; /* 親要素の幅を超えないようにする */
}
.table_form th, .table_form td {
  padding: 20px;
  font-size: 16px;
}
/* ----- ヘッダーのスタイル設定 ----- */
.table_form th {
  color: #684327;
  text-align: right;
  border-bottom: 1px dotted #684327;
  font-weight: bold;
  width: 30%;
  vertical-align: top;
}
/* ----- 必須マークのスタイル ----- */
span.required {
  display: inline-block;
  margin-left: 5px;
  color: #FFF;
  background-color: #FF5B33;
  font-size: 12px;
  line-height: 24px;
  padding: 0 5px;
}
/* ----- フォーム入力エリアの設定 ----- */
.table_form td {
  border-bottom: 1px dotted #684327;
}
.table_form input[type="text"], .table_form input[type="email"], .table_form input[type="tel"], .table_form textarea, .table_form select {
  background-color: #fff;
  color: #333;
  width: 100%;
  border: 1px solid #ddd;
  font-size: 16px;
  padding: 0.5em;
  border-radius: 4px;
  box-shadow: 1px 1px 3px rgba(0, 0, 0, .1) inset;
  font-family: inherit;
  letter-spacing: 0.1em;
}
.table_form input[type="checkbox"], .table_form input[type="radio"] {
  margin-right: 5px;
}
/* ----- ボタンのスタイル ----- */
.form-buttons {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 20px;
}
.btn-reset, .btn-submit {
  padding: 10px 20px;
  font-size: 1rem;
  color: #fff;
  border: none;
  border-radius: 3px;
  cursor: pointer;
}
.btn-reset {
  background-color: #ccc;
}
.btn-submit {
  background-color: #d33;
}
.btn-reset:hover, .btn-submit:hover {
  opacity: 0.9;
}
/* ----- 送信ボタン（Contact Form 7用） ----- */
form input.wpcf7-form-control[type="submit"] {
  background-color: #d71e1e;
  color: #FFF;
  padding: 10px 25px;
  border-radius: 6px;
  border: 2px solid #EEE;
  transition: 0.2s linear;
  font-size: 18px;
  width: 300px;
  margin: 15px auto; /* これで中央に配置される */
  display: block;
}
form input.wpcf7-form-control[type="submit"]:hover {
  background-color: #FFF;
  color: #d71e1e;
  border-color: #d71e1e;
  cursor: pointer;
}
/*------------ Thanks-pageレイアウト -------------*/
/* サンクスページ全体のスタイル */
.thanks-box {
  background-color: #f1eee7;
  padding: 50px;
  width: 100%;
  max-width: 880px;
  border-radius: 10px;
  margin: 0 auto;
}
.thanks-box p {
  font-size: 16px;
  text-align: left;
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  line-height: 2rem;
}
/* トップページリンク */
.button-box {
  width: 100%;
  max-width: 240px;
  margin: 20px auto;
}
.back-to-home {
  font-size: 18px;
  color: #fff;
  background-color: #b33333;
  padding: 15px 30px; /* ボタンのサイズを大きく */
  border-radius: 50px; /* 丸みのある角 */
  text-decoration: none;
  display: inline-block;
  font-weight: bold; /* フォントを太くして強調 */
  text-transform: uppercase; /* 文字を大文字に */
  letter-spacing: 2px; /* 文字間隔を広げて、デザイン性を追加 */
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* 微妙な影をつけて浮き上がるように */
  transition: all 0.3s ease; /* すべての変化を滑らかに */
}
/* ホバー時の効果 */
.back-to-home:hover {
  background-color: #b35858;
  box-shadow: 0 6px 10px rgba(0, 0, 0, 0.2); /* ホバー時に影を強くして立体感を出す */
  transform: translateY(-3px); /* ボタンが浮き上がるように */
}
/* フォーカス時の効果（キーボード操作時に目立つように） */
.back-to-home:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.5); /* 目立つアウトラインを追加 */
}
/*-----------------------------------------------------  */
/* プライバシーポリシーレイアウト						*/
/*-----------------------------------------------------	*/
/*------------ プライバシーポリシー見出しレイアウト -------------*/
h2#pri-tt {
  width: 100%;
  height: auto;
  max-width: 980px;
  margin: 30px auto 30px;
  font-size: 1.5em;
  position: relative;
  padding: 1.5rem;
  text-align: center;
}
h2#pri-tt:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 30px);
  width: 60px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background: #ca1b1d;
}
h3.pri-tt2 {
  padding: 0.5rem 0.5rem;
  border-bottom: 1px solid #ca1b1d;
  width: 100%;
  font-size: 1.3em;
  margin-bottom: 25px;
}
h4.pri-tt2 {
  font-size: 1em;
  color: #f23c3c;
  margin-bottom: 15px;
}
h5.pri-tt2 {
  font-size: 0.9em;
  margin-bottom: 20px;
}
/*------------ プライバシーポリシー見出しレイアウト -------------*/
.pri-contents {
  max-width: 980px;
  height: auto;
  margin: 0 auto;
}
.pri-contents p {
  font-size: 17px;
  line-height: 1.8em;
  margin-bottom: 15px;
}
.pri-list li {
  list-style: decimal outside;
  font-size: 16px;
  font-weight: 300;
  margin-bottom: 15px;
  margin-left: 1.5em;
  line-height: 1.5;
}
.pri-list span {
  font-weight: bold;
}
/*-----------------------------------------------------  */
/* 店舗一覧ページのレイアウト					*/
/*-----------------------------------------------------	*/
/* 店舗一覧ページh2のレイアウト */
Section#shop-list {
  width: 100%;
  height: 100%;
  padding-top: 50px;
}
#shop-list p {
  font-size: 16px;
  line-height: 27px;
}
.store-list h2 {
  width: 100%;
  height: auto;
  max-width: 980px;
  margin: 30px auto 30px;
  font-size: 1.5em;
  position: relative;
  padding: 1.5rem;
  text-align: center;
}
.store-list h2:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 30px);
  width: 60px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background: #ca1b1d;
}
/* 店舗情報のレイアウト */
/* 店舗リスト */
/* 全体のスタイル */
.store-list {
  margin: 20px 0;
  padding: 0;
}
.store-list h2 {
  font-size: 24px;
  margin-bottom: 15px;
  color: #333;
  text-align: center;
}
/* 店舗リスト */
.store-list {
  display: flex;
  flex-wrap: wrap; /* 横3列の後に自動的に改行 */
  gap: 16px; /* ボックス間の隙間 */
  justify-content: center; /* コンテンツを中央に揃える */
}
.store-item {
  flex: 1 1 calc(33.333% - 16px); /* 3列の幅に調整 */
  box-sizing: border-box; /* パディング込みの幅を設定 */
  max-width: calc(33.333% - 16px); /* 各アイテムの最大幅を設定 */
  margin-bottom: 16px; /* 下に少し余白を追加 */
  border: 1px #d72929 solid;
  padding: 20px;
  text-align: left;
  background-color: #f1eee7;
}
.store-item img {
  width: 100%;
  height: auto;
  margin-bottom: 10px;
}
.store-details p {
  font-size: 0.9em;
  margin-bottom: 5px;
}
.store-name {
  display: flex;
  align-items: center;
  font-size: 1.1em;
  font-weight: bold;
  margin-bottom: 10px;
}
.store-icon {
  width: 20px; /* アイコンのサイズを指定 */
  height: 20px; /* アイコンのサイズを指定 */
  margin-right: 8px; /* テキストとの間にスペースを追加 */
}
.store-item button {
  display: inline-block;
  width: 250px;
  text-align: center;
  line-height: 40px;
  background-color: #d71e1e;
  -webkit-transition: all .3s;
  transition: all .3s;
}
.store-item button a {
  text-decoration: none;
  outline: none;
  color: white;
}
/* ボタンをクリックしたときのエフェクト */
.store-item button:hover {
  color: #fff;
  background-color: #deb887;
  opacity: 0.7;
}
/*-----------------------------------------------------  */
/* 固定ページmenu レイアウト						*/
/*-----------------------------------------------------	*/
section.menu-contents {
  width: 100%;
  height: auto;
}
/* ページ内コンテンツナビレイアウト */
/* メニュー全体のスタイル */
#menu_box {
  background-color: #f8f8f8;
  padding: 20px 0;
  text-align: center;
}
/* ナビゲーションリストの横並び設定 */
.menu-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  flex-wrap: wrap; /* 画面が狭い場合は折り返し */
  gap: 20px;
}
/* 各リストアイテムのリンクスタイル */
.menu-nav-list li a {
  display: inline-block;
  text-decoration: none;
  padding: 15px 20px;
  background-color: #dfcda5;
  color: #553939;
  border-radius: 8px;
  font-weight: bold;
  font-family: 'Shippori Mincho', serif;
  transition: background-color 0.3s ease, color 0.3s ease;
}
/* リンク内の日本語テキスト（span） */
.menu-nav-list li a span {
  display: block;
  font-size: 0.7em;
  font-weight: normal;
  color: #553939;
}
/* ホバー時のスタイル変更 */
.menu-nav-list li a:hover {
  background-color: #ff7f50; /* コーラルオレンジ */
  color: #fff;
}
.menu-nav-list li a:hover span {
  color: #fff;
}
h1.menu-title {
  width: 100%;
  height: auto;
  text-align: center;
  margin-top: 30px;
  color: #4a2a1d;
  font-size: 2.7rem;
}
/*パリパリ系のコンテンツのタイトルと説明文 */
.category-box {
  width: 1100px;
  height: auto;
  max-width: 100%;
  margin: 50px auto 20px;
  display: inline-flex;
  flex-wrap: nowrap;
  gap: 10px;
}
.category-inner {
  display: flex;
  flex-wrap: wrap; /* スマホ対応 */
  gap: 30px;
  align-items: center;
  justify-content: center;
}
.titlebg-box-beige {
  background-image: url("../images/menu_titlebg_1.png");
  background-position: center;
  background-repeat: no-repeat;
  width: 57%;
  height: 278px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.titlebg-box-pink {
  background-image: url("../images/menu_titlebg_2.png");
  background-position: center;
  background-repeat: no-repeat;
  width: 57%;
  height: 278px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.category-title {
  font-family: 'Shippori Mincho', serif;
  font-size: 1.8rem; /* 少し大きくしても綺麗です */
  color: #715c4c;
  line-height: 1.5;
  letter-spacing: 0.1em; /* 字間を少し空けるとプロっぽくなります */
}
.category-title span {
  font-size: 1rem;
  font-weight: normal;
}
.category-comment {
  max-width: 522px;
  padding: 20px;
  background-color: #fffbf3;
  border-radius: 5px;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
}
.category-comment p {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 300; /* 細めにすると一気にオシャレになります */
  font-size: 1rem;
  line-height: 1.9; /* 行間を少し広げて余白を意識 */
  color: #444; /* 真っ黒より少しだけグレーに */
  margin: 0;
  letter-spacing: 0.03em;
  display: block;
}
.crepe-menubox {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  justify-content: center;
  width: 1100px;
  height: auto;
  max-width: 100%;
  margin: 0 auto;
}
.crepe-menubox > div {
  /*width: calc(50% - 10px); /* 2列分割（gapに合わせて調整） */
  box-sizing: border-box;
}
/* 店舗限定のレイアウト */
/* グリッドコンテナの設定 */
.crepe-menubox-exclusive {
  display: grid;
  grid-template-columns: repeat(2, 1fr); /* 2列 */
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}
/* 各メニューアイテムの枠 */
.crepe-item {
  width: 100%;
}
/* 画像コンテナ */
/* スマホ対応：768px以下で1列にする */
@media (max-width: 768px) {
  .crepe-menubox-exclusive {
    grid-template-columns: 1fr; /* 1列 */
    gap: 20px;
  }
}
/*-----------------------------------------------------  */
/* footerレイアウト						*/
/*-----------------------------------------------------	*/
.footer {
  background-color: #fff;
  color: #fff;
  margin-top: auto; /* フッターがページの一番下に来るように */
  border-top: 1px solid #d71e1e;
}
.footer-content {
  display: flex;
  justify-content: space-around;
  max-width: 1000px;
  margin: 0 auto;
  width: 100%;
}
.footer-section {
  /* flex: 1;*/
  padding: 10px;
}
.footer-section h2, .footer-section h3 {
  color: #ffcc00;
  margin-bottom: 10px;
}
.footer-section p, .footer-section ul, .footer-section li, .footer-bottom {
  font-size: 14px;
  color: #ccc;
  margin: 0;
}
.footer-section ul {
  list-style-type: none;
  padding: 0;
}
.footer-section ul li a {
  color: #424040;
  text-decoration: none;
  margin-bottom: 8px;
  display: block;
}
.footer-section ul li a:hover {
  color: #ca1b1d;
}
.footer-section ul {
  list-style-type: none;
  padding: 0;
  display: flex;
  gap: 15px; /* 各リンクの間にスペースを追加 */
}
.footer-bottom {
  text-align: center;
  padding: 10px 0 10px;
  font-size: 12px;
  border-top: 1px solid #fff;
  margin-top: 20px;
  color: #fff;
  background-color: #ca1b1d;
}
/*-----------------------------------------------------  */
/* カスタム投稿 店舗情報アーカイブページ カテゴリPickup共通レイアウト			*/
/*-----------------------------------------------------	*/
/* カテゴリpickupページSectionレイアウト */
Section#pickup-list {
  width: 100%;
  height: 100%;
  padding-top: 70px;
}
h2#pickup-title {
  width: 100%;
  height: auto;
  max-width: 980px;
  margin: 30px auto 30px;
  font-size: 1.5em;
  position: relative;
  text-align: center;
  padding: 1rem;
}
h2#pickup-title:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 30px);
  width: 60px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background: #ca1b1d;
}
h2#archive-title {
  width: 100%;
  height: auto;
  max-width: 980px;
  margin: 30px auto 30px;
  font-size: 1.5em;
  position: relative;
  text-align: center;
  padding: 1.5rem;
}
h2#archive-title:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 30px);
  width: 60px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background: #ca1b1d;
}
/* カテゴリごとのタイトル */
#shop-list h3 {
  font-size: 1.5rem;
  position: relative;
  padding: 3.5rem 1rem;
  width: 100%;
}
#shop-list h3:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #714c4c, #714c4c 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #714c4c, #714c4c 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
/* 店舗リスト */
.shoplist-items {
  list-style: none;
  padding: 0;
  margin: 20px 0;
  display: flex;
  gap: 10px;
}
.shoplist-item {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 20px;
  border: 1px solid #ae1111;
  border-radius: 8px;
  padding: 10px;
  background: #f1eee7;
  transition: box-shadow 0.3s;
  justify-content: space-between;
  align-items: stretch;
  min-height: 150px;
  width: 100%;
}
.shoplist-item a {
  text-decoration: none;
  width: 100%;
}
.shoplist-item:hover {
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}
.shoplist-thumbnail {
  flex: 0 0 150px; /* 幅を120pxから150pxに変更 */
  max-width: 150px; /* 最大幅を設定 */
  margin-right: 20px;
}
.shoplist-thumbnail img {
  width: 100%; /* 親要素に合わせて幅を調整 */
  height: auto; /* アスペクト比を維持 */
  border-radius: 8px; /* 角を少し丸める */
}
.shoplist-item h4 {
  font-size: 1.2rem;
  margin: 0 0 10px;
  color: #ae1111;
}
.shop-address, .shop-phone, .shop-hours, .shop-holiday {
  font-size: 0.9rem;
  color: #212121;
  margin: 5px 0;
}
.shop-instagram a {
  /* display: inline-flex;*/
  /* align-items: center;*/
  font-size: 0.9rem;
  color: #212121;
  text-decoration: none;
  transition: color 0.3s, background-color 0.3s; /* スムーズな変化 */
}
.shop-instagram a:hover {
  color: #ff6347; /* マウスオーバー時の文字色 */
  /* background-color: #f0f0f0; /* マウスオーバー時の背景色 */
  text-decoration: underline; /* マウスオーバー時の装飾 */
}
.instagram-icon {
  width: 16px;
  height: 16px;
  margin-right: 5px;
}
.shoplist-excerpt {
  font-size: 0.9rem;
  color: #444;
  margin-top: 10px;
}
/*-----------------------------------------------------  */
/* カスタム投稿 メディア情報・各カテゴリ共通CSS					*/
/*-----------------------------------------------------	*/
h1.media-title {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
  position: absolute;
  top: 29%;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  font-size: 35px;
  color: white;
}
.media-container {
  width: 800px;
  max-width: 100%;
  margin: 15% auto 0px;
}
.media-featured-img {
  width: 100%;
  height: auto;
  max-width: 100%;
  margin: 0 auto;
  text-align: center;
}
.post-meta {
  font-size: 15px;
}
.media-featured-img img {
  width: 70%;
  height: auto;
  max-width: 600px;
  border-radius: 16px; /* 角丸 */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15); /* やわらかい影 */
}
/*-----------------------------------------------------  */
/* カスタム投稿アーカイブ メディア情報・各カテゴリ共通CSS					*/
/*-----------------------------------------------------	*/
/* 全体のアーカイブセクション */
/* メディアアイテム1つずつ */
.media-card {
  width: calc(33.333% - 20px);
  background: #f1eee7;
  border: 2px solid #714c4c;
  border-radius: 8px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
}
.media-card a {
  /* display: flex;
  flex-direction: column;*/
  text-decoration: none;
  padding: 15px;
}
.media-card h4 {
  font-size: 1.2rem;
  margin: 0px 0px 10px;
  color: rgb(87, 63, 53);
}
.media-card p {
  font-size: 14px;
  color: rgb(85, 85, 85);
}
.media-item {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
  margin-bottom: 40px;
  padding: 24px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.media-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.1);
}
/* タイトル */
.media-title {
  font-size: 1.5em;
  margin-bottom: 10px;
  color: #2c2c2c;
}
.media-title a {
  text-decoration: none;
  color: #cc0000;
}
.media-title a:hover {
  text-decoration: underline;
}
/* サブタイトル・日付など */
.media-subtitle, .media-date, .media-link {
  font-size: 0.95em;
  color: #555;
  margin-bottom: 6px;
}
.media-link a {
  color: #cc0000;
  text-decoration: none;
}
.media-link a:hover {
  text-decoration: underline;
}
/* サムネイル */
.media-thumbnail {
  margin-top: 15px;
}
.media-thumbnail img {
  max-width: 100%;
  height: auto;
  border-radius: 6px;
}
/* 説明文 */
.media-description {
  margin-top: 12px;
  font-size: 0.95em;
  line-height: 1.7;
  color: #444;
}
/* ページネーション */
.media-pagination {
  margin-top: 40px;
  text-align: center;
}
.media-pagination a, .media-pagination span {
  display: inline-block;
  margin: 0 4px;
  padding: 8px 14px;
  border-radius: 4px;
  color: #fff;
  background-color: #cc0000;
  text-decoration: none;
  transition: background-color 0.3s ease;
}
.media-pagination a:hover {
  background-color: #a30000;
}
.media-pagination .current {
  background-color: #555;
}
/*-----------------------------------------------------  */
/* カスタム投稿 店舗情報ページレイアウト					*/
/*-----------------------------------------------------	*/
h2.shop_ti {
  position: relative;
  padding-bottom: 10px;
  /*font-size: 26px;*/
  font-size: 1.5rem;
  margin-bottom: 15px;
  color: #714c4c;
}
h2.shop_ti::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 8px;
  background-image: repeating-linear-gradient(45deg, #714c4c 0px, #714c4c 1px, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 50%);
  background-size: 8px 8px;
}
/* 全体のコンテナ */
.shop-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px; /* 要素間のスペース */
}
.pickup-section {
  margin-top: 20px;
  width: 1100px;
  margin: 20px auto 0;
  max-width: 100%;
}
.pickup-item.d-flex a {
  text-decoration: none;
}
.pickup-item {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  background: #f1eee7;
  border: 1px solid #ae1111;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  margin-bottom: 20px;
}
.pickup-thumbnail {
  width: 100%;
  padding-right: 20px;
}
.pickup-details {
  width: 60%;
}
.pickup-thumbnail img {
  width: 100%; /* 画像を親要素いっぱいにする */
  height: auto; /* アスペクト比を保持したまま調整 */
  display: block; /* 余白が発生しないようにする */
  border-right: 1px solid #ddd;
  position: relative; /* absoluteを使わず、意図したレイアウトに */
  top: 0;
}
.pickup-details h4 {
  font-weight: bold;
  font-size: 1.2rem;
  margin: 0 0 10px;
  color: #ae1111;
}
.pickup-details p {
  font-size: 14px;
  color: #555;
  margin-bottom: 5px;
}
.othershops-section {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  width: 1100px;
  margin: 20px auto auto;
  max-width: 100%;
}
.shop-area-section {
  display: flex;
  flex-wrap: wrap; /* 複数行に折り返す */
  gap: 15px; /* カード間のスペース */
  margin-top: 10px;
}
.othershop-card {
  width: calc(33.333% - 20px); /* 3列レイアウト */
  background: #f1eee7;
  border: 2px solid #714c4c;
  border-radius: 8px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
}
.shop-thumbnail {
  width: 100%;
  height: auto;
}
.shop-thumbnail img {
  width: 100%;
  height: auto;
  border-bottom: 1px solid #ddd;
}
.othershop-card a {
  /*display: flex;
  flex-direction: column;*/
  padding: 15px;
  text-decoration: none;
}
.othershop-card h4 {
  font-size: 1.2rem;
  margin: 0 0 10px;
  color: #714c4c;
}
.othershop-card p {
  font-size: 14px;
  color: #555;
}
@media (max-width: 767px) {
  .pickup-item, .shop-card {
    width: 100%;
  }
}
/* 画像要素 */
.shop-container-2 {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: flex-start;
  width: 800px;
  max-width: 100%;
  margin: 25px auto 0px;
  gap: 15px;
}
/* 左側：ロゴ（小さめで縦並び） */
.shop-logos-vertical {
  display: flex;
  flex-direction: column;
  width: 30%; /* 左をやや小さめに */
  flex-shrink: 0;
}
.shop-logo {
  width: 100%;
}
.shop-logo-2 {
  width: 100%;
}
.shop-logo img {
  width: 100%;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  padding: 5px;
  position: relative;
  top: 30px;
}
/* 右側：ギャラリー（大きめに表示） */
.shop-fade-gallery {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-height: 420px;
  margin: 0;
  overflow: hidden;
}
.shop-fade-gallery .fade-image {
  display: inline-block;
  padding: 10px; /* フレームの内側余白 */
  background-color: #fff; /* 写真の背景、額縁風 */
  border: 1px solid #ccc; /* やや柔らかい色に変更 */
  border-radius: 5px; /* 角を少し丸めて柔らかい印象に */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2); /* 影をやや強めにして立体感をアップ */
  transition: box-shadow 0.3s ease;
}
.shop-fade-gallery .fade-image:hover {
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3); /* ホバー時にさらに浮かせる */
}
.shop-fade-gallery .fade-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  opacity: 1;
  transition: opacity 2s ease-in-out; /* フェードの滑らかさ */
  object-fit: cover;
  z-index: 1; /* 他の画像の下に表示 */
}
/*.shop-fade-gallery .fade-image.active {
  display: block;
  opacity: 1;
  position: relative;
  z-index: 2;
} */
.shop-fade-gallery .fade-image.active img {
  opacity: 1; /* activeクラスがついた時に画像を表示 */
  z-index: 1; /* 最前面に配置 */
}
.shop-info {
  margin: 20px auto;
  padding: 20px;
  border: 1px solid #714c4c;
  border-radius: 5px;
  background-color: #f1eee7;
  max-width: 800px;
}
.shop-info ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
.shop-info li {
  margin-bottom: 10px;
  font-size: 18px;
}
a.shop-instagram {
  color: #333; /* 通常時の文字色 */
  text-decoration: none; /* 通常時の装飾をなしにする */
  transition: color 0.3s, background-color 0.3s; /* スムーズな変化 */
}
a.shop-instagram:hover {
  color: #ff6347; /* マウスオーバー時の文字色 */
  background-color: #f0f0f0; /* マウスオーバー時の背景色 */
  text-decoration: underline; /* マウスオーバー時の装飾 */
}
a.shop-tel {
  color: #333; /* 通常時の文字色 */
  text-decoration: none; /* 通常時の装飾をなしにする */
  transition: color 0.3s, background-color 0.3s; /* スムーズな変化 */
}
a.shop-tel:hover {
  color: #ff6347; /* マウスオーバー時の文字色 */
  background-color: #f0f0f0; /* マウスオーバー時の背景色 */
  text-decoration: underline; /* マウスオーバー時の装飾 */
}
.shop-info li strong {
  color: #555;
}
.instagram-icon {
  width: 24px; /* アイコンの幅 */
  height: 24px; /* アイコンの高さ */
}
.gallery {
  margin: 30px auto;
  max-width: 800px;
  text-align: center;
}
.gallery h2 {
  font-size: 1.8rem;
  margin-bottom: 15px;
}
.slider {
  display: flex;
  gap: 15px;
  overflow-x: scroll;
  padding: 10px;
  scroll-snap-type: x mandatory;
}
.slider-item {
  flex: 0 0 auto;
  width: 200px;
  scroll-snap-align: center;
}
.slider-item img {
  width: 100%;
  height: auto;
  border-radius: 5px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}
.slider-item .caption {
  margin-top: 5px;
  font-size: 0.9rem;
  color: #666;
}
.features {
  margin: 30px auto;
  padding: 20px;
  max-width: 800px;
  border: 1px solid #714c4c;
  border-radius: 5px;
  background-color: #f1eee7;
}
.features h2 {
  font-size: 1.5rem;
  margin-bottom: 15px;
}
.features p {
  line-height: 1.6;
  color: #333;
  font-size: 17px;
  letter-spacing: 1px;
}
.access {
  margin: 30px auto;
  max-width: 800px;
}
.access h2 {
  font-size: 1.5rem;
  margin-bottom: 15px;
}
.map {
  margin-top: 10px;
}
.map iframe {
  width: 100%;
  height: 400px;
  border: none;
  border-radius: 5px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}
/*-----------------------------------------------------  */
/* アーカイブ 新店情報ページレイアウト					*/
/*-----------------------------------------------------	*/
.new_shop-section {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  width: 1100px;
  margin: 10% auto 25px auto;
  max-width: 100%;
}
.new_shop-card {
  width: calc(33.333% - 20px);
  background: #f1eee7;
  border: 2px solid #714c4c;
  border-radius: 8px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
}
.new_shop-card h4 {
  font-size: 1.2rem;
  margin: 0 0 10px;
  color: #573f35;
}
.shop-thumbnail {
  width: 100%;
  height: auto;
}
.shop-thumbnail img {
  width: 100%;
  height: auto;
  border-bottom: 1px solid #ddd;
}
.new_shop-card a {
  /*display: flex;
  flex-direction: column;*/
  padding: 15px;
  text-decoration: none;
}
.new_shop-card p {
  font-size: 14px;
  color: #555;
}
/*-----------------------------------------------------  */
/* 投稿 新店情報ページレイアウト					*/
/*-----------------------------------------------------	*/
.newshop-info {
  margin: 20px auto;
  padding: 20px;
  border: 1px solid #714c4c;
  ;
  border-radius: 5px;
  background-color: #f1eee7;
  max-width: 800px;
}
h2.newshop-info-ti {
  position: relative;
  padding-bottom: 10px;
  font-size: 26px;
  font-size: 1.5rem;
  margin-bottom: 15px;
  color: #714c4c;
}
h2.newshop-info-ti::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 8px;
  background-image: repeating-linear-gradient(45deg, #714c4c 0px, #714c4c 1px, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 50%);
  background-size: 8px 8px;
}
.newshop-info ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
.newshop-info li {
  margin-bottom: 10px;
  font-size: 18px;
}
.newshop-info li strong {
  color: #555;
}
.features-newshop-info {
  margin: 30px auto;
  padding: 20px;
  max-width: 800px;
  border: 1px solid #714c4c;
  border-radius: 5px;
  background-color: #f1eee7;
}
.access-newshop-info {
  margin: 30px auto;
  padding: 20px;
  max-width: 800px;
  border: 1px solid #714c4c;
  border-radius: 5px;
  background-color: #f1eee7;
}
/* PC用スタイル */
@media (min-width: 768px) {
  /* PC用のヘッダーのスタイル */
  #sp_nav {
    display: none;
  }
  /* SP用のFV非表示 */
  /* SP用のmiryokuimg非表示 */
  .mi_sp {
    display: none;
  }
}
/* ====== 中間ゾーン（1025px〜1280px） ====== */
@media screen and (min-width: 1025px) and (max-width: 1280px) {
  /* ノートPCやブラウザ縮小時の調整 */
  #namibatabg {
    top: -6rem;
  }
  .cont-header {
    background-color: #f1eee7;
    width: 100%;
    height: auto;
  }
  .trim-h {
    width: 100%;
    height: auto;
  }
  .single-page {
    height: 126px;
  }
  .breadcrumbs-2 {
    top: -2.8vw;
  }
  .container {
    position: relative;
    top: 86%;
  }
}
/*------------------- タブレットサイズ以下のスタイル変更 ------------------------------*/
/* タブレット用（1024px以下） */
@media screen and (max-width: 1024px) {
  /* トップページ全体のレイアウト */
  /* 全体的なオーバーフローの制御 */
  body, html {
    overflow-x: hidden; /* 横スクロールを防ぐ */
  }
  .sp-br {
    display: none;
  }
  #header {
    width: 100%;
  }
  #nav_box ul {
    gap: 9px;
  }
  /* #flex1 {
    width: 100%; 
    max-width: 100%;
    top: -4%;
    left: 1%;
  } */
  h1#logo {
    padding-left: 30px;
    padding-top: 10px;
  }
  #nav_box {
    left: 50%;
  }
  #nav_box a {
    font-size: 13px;
  }
  #top_mv {
    height: 400px;
  }
  .fv_sp {
    display: none;
  }
  #namibatabg {
    top: -4rem;
    background-size: cover;
    position: relative;
  }
  /* .mainContents {
    width: 100%;
    max-width: 100%; 
  } */
  .contentbox {
    width: 95%;
  }
  #concept img {
    width: 100%;
    height: auto;
  }
  /* Section1タイトルとコンテンツ全体のレイアウト */
  #h1 img {
    width: 98%;
    height: auto;
  }
  /* Section2FC4つの魅力コンテンツ タイトルとコンテンツ全体のレイアウト */
  #miryoku_box {
    width: 90%;
    margin: 0 auto 35px auto;
  }
  h1.miryoku {
    width: 90%;
    font-size: 25px;
  }
  .miryoku span {
    font-size: 43px;
    top: -13%;
    left: -1%;
  }
  .miryoku .txt {
    padding: 4px 3px 12px 14px;
    height: 43px;
  }
  #miryoku h1 {
    font-size: 28px;
  }
  #miryoku h1 span {
    font-size: 35px;
  }
  .miryoku .txt {
    height: 63px;
  }
  .mi_pc {
    width: 100%;
    height: auto;
  }
  /* Section3 タイトルとコンテンツ全体のレイアウト */
  .container {
    max-width: 90%; /* 横幅を90%に設定 */
    padding: 10px; /* パディングも少し調整 */
  }
  .heading {
    font-size: 19px;
  }
  .text-box {
    font-size: 15px;
  }
  /* Section4 タイトルとコンテンツ全体のレイアウト */
  #titlebg {
    height: 215px;
    background-size: contain;
    background-repeat: no-repeat;
  }
  #titlebox {
    width: 100%;
    text-align: center;
    height: 27vh;
  }
  h1#puro {
    font-size: 33px;
  }
  .step-wrap1 {
    width: 95%;
  }
  /* Section5 タイトルとコンテンツ全体のレイアウト */
  #list-box {
    max-width: 950px;
    left: 0;
  }
  .shoplist-item h4 {
    font-size: 0.9rem;
  }
  /* 店舗一覧btnのレイアウト */
  #store_btnbox {
    width: 100%;
  }
  .contact-button {
    top: -9vw;
  }
  .back-to-top-button {
    top: -9vw;
  }
  /* 下層ページ全体ヘッダーボックスレイアウト */
  .cont-header {
    height: auto;
  }
  .trim-h {
    width: 100%;
    height: auto;
  }
  .trim-h img {
    width: 100%;
    height: 300px;
    object-fit: cover;
  }
  .pankuzu {
    padding-left: 8rem;
  }
  /* single-Shopページのレイアウト */
  .single-page {
    height: 120px;
  }
  .breadcrumbs-2 {
    top: -0.8vw;
  }
  h1.pagetitle_2 {
    display: none;
  }
  /* FC募集固定ALLページのレイアウト */
  h1.pagetitle_1 {
    top: -8vw;
    left: 33vw;
    font-size: 30px;
  }
  /* カスタム投稿ページのレイアウト */
  h1.pagetitle_2 {
    top: -8vw;
    left: 18vw;
    font-size: 27px;
  }
  /* Contactページのレイアウト */
  .wpcf7-form {
    width: 100%; /* 横幅を100%に設定 */
    max-width: 100%; /* 最大幅を100%に設定 */
    padding: 30px; /* パディングを調整 */
  }
  .table_form {
    width: auto;
  }
  /* プライバシー・ポリシーページのレイアウト */
  h3.pri-tt2 {
    width: 98%;
  }
  /* 店舗情報一覧ページのレイアウト */
  h2#archive-title {
    margin: 120px auto 30px;
  }
  /* pickupアーカイブページのレイアウト */
  h2#pickup-title {
    margin: 120px auto 30px;
  }
}
/* 1023px 以下 770px 以上（タブレット中間サイズ） */
@media screen and (max-width: 1023px) and (min-width: 770px) {
  /* コンテンツ幅を少し狭くする */
  .container {
    max-width: 90%;
  }
  .cont-header {
    height: auto;
  }
  .fv_sp {
    display: none;
  }
  /* ナビの位置を調整 */
  #nav_box {
    left: 44%;
  }
  /* ナビゲーションのフォントサイズを調整 */
  nav a {
    font-size: 14px;
  }
  /* サイドバーを非表示にする */
  .sidebar {
    display: none;
  }
  /* shop投稿ページのヘッダーの高さを調整 */
  .single-page {
    height: 120px;
  }
  /* クレープメニューページレイアウト */
  .menu-nav-list li a {
    font-size: 0.9rem;
  }
  .category-box {
    display: flex; /* inline-flex → flex */
    justify-content: center;
    gap: 15px;
  }
  .titlebg-box-beige, .titlebg-box-pink, .category-comment {
    width: 60rem;
    background-size: contain;
    height: auto;
    box-sizing: border-box;
  }
  .category-comment p {
    font-size: 0.8rem;
  }
}
/* スマートフォン用（768px以下） */
@media screen and (max-width: 768px) {
  /* 横スクロールバーの非表示 */
  body, html {
    overflow-x: hidden; /* 横スクロールを隠す */
    margin: 0; /* 余白をなくして右にずれないようにする */
  }
  .sp-br {
    display: block;
  }
  header#header {
    display: none;
  }
  #sp_nav {
    display: block;
  }
  #header {
    height: auto;
    padding-bottom: 5px;
  }
  #flex1 {
    width: 90%;
    flex-direction: column;
    align-items: center;
    top: 5%;
    margin-left: auto;
    margin-right: auto;
  }
  h1#logo {
    width: 80px;
    padding-top: 5px;
    margin: 0 auto;
  }
  #nav_box {
    flex-direction: column;
    left: 0;
    top: 0;
    text-align: center;
  }
  #nav_box ul {
    top: 0;
  }
  #nav_box li {
    padding-right: 5px;
    font-size: 14px;
  }
  #sp_nav {
    position: absolute;
    top: 0;
    width: 100%;
    left: 0;
    height: 115px;
    z-index: 9999;
    /* background-color: #f1eee7;
    border-bottom: 1px solid #ce612c;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1); /* 影を追加 */
  }
  #sp_logo {
    width: 30%;
    height: auto;
    margin: -1px auto auto;
  }
  #sp_logo img {
    width: 45%;
    height: auto;
  }
  .menu {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    -webkit-transition: ease .5s;
    transition: ease .5s;
    z-index: 1000;
    background-color: rgba(238, 219, 199, 0.65);
    margin-top: 0px;
    position: absolute;
    left: 0%;
    width: 100%;
    top: 100%;
  }
  .menu a {
    color: #573636; /* 通常のリンク色 */
    text-decoration: none;
    transition: color 0.3s ease, transform 0.3s ease;
    font-weight: bold;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
  }
  .menu a:hover {
    color: #8d551d; /* ホバー時の色 */
  }
  .menu a:active {
    transform: scale(1.1); /* クリック時に少し大きく */
    color: #6a4015; /* クリック時に少し濃いオレンジ色 */
  }
  .menu ul li {
    padding: 1em;
    background-color: #ceb0884f;
    text-align: center;
    list-style: none;
    box-sizing: border-box; /* パディングを含めた幅計算 */
    max-width: 100%; /* 幅を親要素以内に収める */
    overflow: hidden; /* はみ出し防止 */
  }
  /*OPEN時の動き*/
  .menu.open {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  /**/
  /*開閉ボタン*/
  .navbar_toggle p {
    font-size: 15px;
    margin-top: 5px;
    position: relative;
    left: -11%;
    color: #fff;
  }
  .navbar_toggle {
    position: absolute;
    left: 83%;
    top: 32%;
  }
  .navbar_toggle_icon {
    position: relative;
    display: block;
    height: 2px;
    width: 30px;
    background-color: #fff;
    -webkit-transition: ease .5s;
    transition: ease .5s;
  }
  .navbar_toggle_icon:nth-child(1) {
    top: 0;
  }
  .navbar_toggle_icon:nth-child(2) {
    margin: 8px 0;
  }
  .navbar_toggle_icon:nth-child(3) {
    top: 0;
  }
  /*OPEN時の動き*/
  .navbar_toggle.open .navbar_toggle_icon:nth-child(1) {
    top: 12px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .navbar_toggle.open .navbar_toggle_icon:nth-child(2) {
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    opacity: 0;
    top: auto;
  }
  .navbar_toggle.open .navbar_toggle_icon:nth-child(3) {
    top: -9px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  /* PCのファーストビュー非表示 */
  .fv_pc {
    display: none;
  }
  .fv_sp {
    display: block;
  }
  /* single-Shop投稿ページのレイアウト */
  .single-page {
    height: 170px !important;
  }
  .breadcrumbs-2 {
    top: 2.2vw;
  }
  /* single-Shop投稿ページ改行タグ非表示 */
  .shop-container-2 {
    flex-direction: column; /* 縦並びに変更 */
    width: 100%;
    gap: 10px;
  }
  .shop-logos-vertical {
    width: 100%; /* 横幅100%にして1列で表示 */
    flex-direction: row; /* ロゴを横並びに */
    justify-content: center;
    gap: 10px;
  }
  .shop-logo {
    width: 100%; /* 画像が並ぶように調整（2個なら45%くらい） */
  }
  .shop-logo-2 {
    width: 100%;
  }
  .shop-logo img {
    height: auto;
    object-fit: contain;
  }
  .shop-logo-2 img {
    height: auto;
    position: absolute;
    top: 19rem;
    left: 37%;
    max-width: 50%;
  }
  /* .shop-fade-gallery {
    position: relative;
    width: 100%;
    height: auto;
    margin-bottom: 68vw;  
  } */
  .shop-fade-gallery {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3; /* 画像比率に合わせて調整 */
    overflow: hidden;
    min-height: 525px;
  }
  .shop-fade-gallery .fade-image img {
    position: static;
    width: 100%;
    height: auto;
    object-fit: cover;
  }
  .cont-header {
    height: auto;
  }
  .trim-h {
    width: 100%;
    height: auto;
  }
  .trim-h img {
    width: 100%;
    height: 190px;
  }
  .pankuzu {
    padding-left: 2rem;
    padding-bottom: 1rem;
    padding-top: 1rem;
  }
  #top_mv {
    height: 540px;
    box-sizing: border-box;
  }
  #txt_img_pc img {
    width: 100%;
    height: 540px;
  }
  .fv_sp {
    object-fit: cover;
  }
  #namibatabg {
    width: 100%;
    height: 98px;
    background-size: cover; /* 背景画像を要素内に収める */
    background-position: center; /* 中央に配置 */
    background-repeat: no-repeat; /* 繰り返しを防ぐ */
  }
  #main-box {
    width: 100%; /* 横幅を画面サイズに近づける */
  }
  .mainContents {
    width: 98%;
    max-width: none; /* max-widthを解除してレスポンシブ対応 */
  }
  /* 見出しのレイアウト調整 */
  h1.pagetitle_1, h1.pagetitle_2 {
    width: 90%; /* 横幅を調整 */
    font-size: 24px; /* フォントサイズを縮小 */
    left: 1%;
    top: -5vw;
    text-align: center;
  }
  .trim-h {
    height: auto;
  }
  /* パンくずリストの調整 */
  .breadcrumbs {
    font-size: 12px; /* フォントサイズ縮小 */
    top: 0; /* 上下位置を調整 */
  }
  .breadcrumbs a {
    padding: 0 3px; /* パディングを縮小 */
  }
  /* セクションごとの調整 */
  #section1, #section2, #section3, #section4, #section5, #section6, #section7 {
    background-size: cover; /* 背景画像をカバーで表示 */
    padding: 7px; /* 内側余白を調整 */
  }
  /* コンテンツボックスの調整 */
  .contentbox {
    width: 100%; /* 横幅を調整 */
    margin-top: 20px; /* 上部マージンを縮小 */
  }
  .col-md-9 {
    margin-top: 20px; /* 上部マージンを縮小 */
  }
  /* トップページ「あなたは…」コンテンツボックスのレイアウト */
  #concept_flex {
    width: 100%;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    display: block;
    height: auto;
    padding-bottom: 30px;
  }
  /* 4つの魅力タイトルレイアウト */
  h1.miryoku {
    width: 100%;
    font-size: 20px;
    text-align: left;
    padding-bottom: 10px;
  }
  .miryoku span {
    font-size: 35px;
    top: 0%;
    left: -1%;
  }
  .miryoku .txt {
    height: 43px;
  }
  .txt-l {
    font-size: 1.5rem;
    /* padding-left: 1px; */
    border-left: 1px solid #df3636;
    /* margin-left: 1px; */
  }
  #co_img {
    width: 100%;
    height: auto;
    /* margin-left: 3px; */
    /* position: relative; */
    /* top: -1vw; */
  }
  #co_txt {
    width: 100%;
    height: auto;
    /* margin-left: auto; */
    /* margin-right: auto; */
    /* padding-bottom: 3%; */
  }
  /* 4つの魅力sp用イメージ非表示 */
  img.mi_sp {
    display: none;
  }
  #section4 {
    padding: 0;
  }
  #miryoku h1 {
    word-break: break-word;
    white-space: normal;
  }
  #miryoku h1 span {
    font-size: 30px;
  }
  #miryoku_txt {
    max-width: 95%; /* スマホでは95%に調整 */
    font-size: 15px;
  }
  /* FC加入までのプロセスタイトルレイアウト */
  #titlebox {
    width: 100%;
    text-align: center;
    height: 15vh;
    padding: 20px;
  }
  /* お問い合わせフォームレイアウト&下層ページのコンテンツのboxレイアウト */
  .container {
    padding: 10px;
    width: 95%;
    padding: 0;
  }
  #btn_box {
    width: 90%; /* 画面幅に対して適切なサイズ */
  }
  /* Shop Listページの店舗情報のレイアウト */
  .pickup-thumbnail {
    width: 100%;
    height: fit-content;
  }
  .pickup-thumbnail img {
    width: 100%;
    height: auto;
    display: block;
    border-right: 1px solid #ddd;
    position: relative;
    top: 0;
  }
  /* クレープメニューページレイアウト */
  .menu-nav-list li a {
    font-size: 0.9rem;
  }
  .category-box {
    display: block;
  }
  .titlebg-box-beige {
    width: 100%;
  }
  .titlebg-box-pink {
    width: 100%;
  }
  .category-comment {
    width: 80%;
    margin: 0 auto;
  }
}
/* タブレット未満（740px以下） */
@media (max-width: 740px) {
  .shop-logo-2 img {
    height: auto;
    position: absolute;
    top: 82%;
    left: 37%;
    max-width: 50%;
  }
  .shop-fade-gallery {
    min-height: 500px;
  }
  .features br {
    display: none;
  }
}
/* Surface Duo 横（740px以下） */
@media (max-width: 720px) {
  .shop-logo-2 img {
    top: 54%;
  }
}
/* iPhone SE横向きなど（667px以下） */
@media (max-width: 667px) {
  h1.single-Shop {
    margin: 20px auto 20px;
  }
  .shop-logo img {
    top: 6%;
  }
  .shop-logo-2 img {
    top: 16rem;
  }
  .shop-fade-gallery {
    min-height: 460px;
  }
}
/* Surface Duo 縦（550px以下） */
@media (max-width: 550px) {
  .shop-logo-2 img {
    top: 35%;
  }
}
/* 480px 以下（スマホ） */
@media screen and (max-width: 480px) {
  /* 全体的なオーバーフローの制御 */
  body, html {
    overflow-x: hidden; /* 横スクロールを防ぐ */
  }
  .sp-br {
    display: block;
  }
  #section1, #section2, #section3, #section4, #section5, #section6, #section7 {
    background-size: contain;
    padding: 7px;
    background-position: top;
  }
  .cont-header {
    height: auto;
  }
  h1.pagetitle_1, h1.pagetitle_2 {
    top: 5vw;
    text-align: center;
  }
  #sp_logo {
    width: 100%;
    height: auto;
    position: absolute;
    left: 50%; /* 中央揃え */
    transform: translateX(-50%); /* 左右中央揃え */
  }
  #sp_logo img {
    width: 24%;
    height: auto;
  }
  #titlebg {
    background-size: cover;
    background-repeat: no-repeat;
  }
  #titlebox {
    width: 100%;
    text-align: center;
    height: 20vh;
  }
  #miryoku h1 {
    word-break: break-word;
    white-space: normal;
    font-size: 1.9rem;
  }
  #miryoku h1 span {
    font-size: 2rem;
  }
  /* 4つの魅力のタイトルレイアウト */
  /* PCのテキストSP時は非表示 */
  .sp-off {
    display: none;
  }
  /* sp用のテキストSP時は表示 */
  .textsp-on {
    display: block;
  }
  .textsp-on p {
    font-size: 15px;
    line-height: 1.6rem;
  }
  .miryoku span {
    font-size: 25px;
    top: 0%;
    left: -1%;
  }
  h1.miryoku {
    font-size: 1.1rem;
    text-align: left;
    padding-bottom: 0px;
  }
  h1#puro {
    font-size: 25px;
  }
  .button-container {
    display: block;
  }
  .button-container {
    display: block;
  }
  .contact-button {
    top: -14vh;
    left: 50%;
    margin-left: -100px;
    transform: translateX(-50%);
    width: 150px;
  }
  .back-to-top-button {
    top: -7vh;
    left: 50%;
    transform: translateX(-50%);
    margin-left: -100px;
  }
  /* テーブルの調整 */
  .table_form {
    overflow-x: auto;
  }
  .table_form table {
    width: 100%;
    min-width: 400px; /* テーブルが小さくなりすぎない */
  }
  .table_form th {
    text-align: left;
    font-weight: bold;
    width: 100%;
    max-width: 95%;
    display: block;
    font-size: 15px;
    border: 0;
  }
  .table_form td {
    padding: 20px;
    font-size: 15px;
    display: block;
    border: 0;
  }
  .table_form input[type="text"], .table_form input[type="email"], .table_form input[type="tel"], .table_form textarea, .table_form select {
    background-color: #fff;
    color: #333;
    width: 100%;
    border: 1px solid #ddd;
    font-size: 16px;
    padding: 0.5em;
    border-radius: 4px;
    box-shadow: 1px 1px 3px rgba(0, 0, 0, .1) inset;
    font-family: inherit;
    letter-spacing: 0.1em;
  }
  form input.wpcf7-form-control[type="submit"] {
    width: 100%;
  }
  /* フッター調整 */
  .footer-content {
    display: flex;
    justify-content: space-around;
    max-width: 100%;
    margin: 0 auto;
    width: 100%;
  }
  .footer-section ul {
    display: block;
  }
  h1.single-Shop {
    font-size: 20px;
  }
  .shop-container-2 {
    flex-direction: column;
    width: 100%;
    gap: 10px;
  }
  .shop-logos-vertical {
    width: 100%;
    /* flex-direction: column; /* ロゴを縦並びに戻す */
    /* align-items: center; */
    gap: 10px;
  }
  .shop-logo {
    width: 80%; /* スマホでは1つずつ大きく表示 */
  }
  .shop-logo img {
    width: 100%;
    height: auto;
    object-fit: contain;
    top: 1%;
  }
  .shop-logo-2 img {
    top: 25%;
  }
  .shop-fade-gallery {
    width: 100%;
    height: auto;
    min-height: 300px;
  }
  .shop-fade-gallery .fade-image img {
    position: static;
    width: 100%;
    height: auto;
    object-fit: cover;
  }
  /* Shop Listページ ピックアップコンテンツ部分のレイアウト */
  #shop-list h3 {
    font-size: 1.3rem;
    padding: 1.3rem 1rem;
  }
  .pickup-item {
    display: block;
  }
  .pickup-thumbnail {
    width: 100%;
    padding-right: 0;
    margin-bottom: 10px;
  }
  .pickup-thumbnai img {
    width: 100% !important;
    height: auto;
    display: block;
  }
  .pickup-details {
    width: 100%;
  }
  /* クレープメニューページ コンテンツ部分のレイアウト */
  .titlebg-box-beige {
    width: 100%; /* 画面幅にフィット */
    height: auto; /* 高さは画像比率で自然に調整 */
    aspect-ratio: 2 / 1; /* 必要に応じて比率調整 */
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    padding: 1.5rem; /* テキスト余白が必要なら */
  }
  .titlebg-box-pink {
    width: 100%; /* 画面幅にフィット */
    height: auto; /* 高さは画像比率で自然に調整 */
    aspect-ratio: 2 / 1; /* 必要に応じて比率調整 */
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    padding: 1.5rem; /* テキスト余白が必要なら */
  }
  .category-comment {
    width: 100%;
    margin: 10px auto;
  }
  .crepe-menubox > div {
    width: calc(100% - 10px);
    box-sizing: border-box;
  }
  /* メディア紹介-TV・新店情報カテゴリページレイアウト */
  .new_shop-section {
    margin: 15% auto 25px auto; /* メディア・新店情報共通 */
  }
  .new_shop-card {
    width: 100%;
  }
  .media-container {
    margin: 40% auto 0px;
  }
  .media-card {
    width: 100%;
  }
  h1.media-title {
    top: 35vw;
    left: 50%;
    font-size: 20px;
  }
}
@media (max-width: 375px) {
  /* スマホの中でも特に小さい画面対応 */
  /* Shop投稿ページのレイアウト */
  h1.single-Shop {
    margin: 20px auto 25px;
    font-size: 1.2em;
  }
  .shop-logos-vertical {
    flex-direction: row;
  }
  .shop-logo img {
    top: 7%;
  }
  .shop-logo-2 img {
    top: 34%;
  }
  .shop-fade-gallery {
    min-height: 266px;
  }
  .shop-info li {
    margin-bottom: 10px;
    font-size: 16px;
  }
  .features p {
    font-size: 16px;
  }
  .features br {
    display: none;
  }
}