﻿@charset "utf-8";
/* ===================================
   共通設定（SP: max-width 600px）
=================================== */




body{
	font-family: "Jost", sans-serif;
	font-weight: 400;
	font-style: normal;
	color: #462408;
	background-color: #F4F3EE;
}

a{
	color: #462408;
}

li{
	list-style: none;
}

.logo a{
	display: inline-block;
}

.title{
	font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-weight: 800!important;
  font-style: normal;
}

@media screen and (max-width: 767px) {

  .fv_pc,.footer--pc,.top-newpostpc{
    display: none !important;
  }

  .max-width{
		max-width: 1180px;
		margin: 0 auto;
	  padding: 0 10px;
	}
	
	.article_body .max-width{
		padding: 0;
	}
	
	.pc{
		display: none;
	}
	
	

  /* ---------- Header ---------- */

  .header_wrapper {
    position: fixed;
    width: 100vw;
    background-color: #FBE673;
    z-index: 1000;
  }

  .header_inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
	  max-width: 1180px;
	  margin: 0 auto;
	  padding: 0 15px;
	  height: 60px;
  }
	
	.logo{
		width: 87px;
		height: 35px;
	}
	
	.logo a{
		display: inline-block;
	}

  .logo img { display: inline-block; width: 100%; height: auto;}
	

  .header_search_wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
	  padding: 5px 0;
	  gap: 15px;
  }

  .header_search {
    display: flex;
    align-items: center;
    border: solid 1px #DB4813;
	  border-radius: 35px;
	  background-color: white;
    padding: 12px 9px;
    gap: 15px;
	  width: 50px;
	  height: 50px;
	  justify-content: center;
  }

  .header_search a,
  .search_shop a,
  .search_keyword a {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 25px;
    font-weight: 400;
	  width: 100%;
	  justify-content: space-between;
  }
	
	.search_txt_sp{
		display: none;
	}
	
	.search_shop a{
		color: #FFA641
	}
	
	.search_keyword a{
		color: #FEA9C3;
	}

  .search_txt { color: #DB4813; }
  .search_icon { 
	  padding-top: 10px; 
	}
  .search_icon img { 
	  width: 100%;
	  height: auto;
	  object-fit: cover;
	}

  /* ---------- TOP ---------- */
  /*#top { padding-top: 80px !important; }*/

	
	.topMainTitle img{
		width: 100%;
		height: auto;
	}

  .top-wrapperNew {
  background-image: url("../img/main-fv-ad.jpg"); /* 画像パス */
  background-size: cover;               /* 縦横比を保って全画面にフィット */
  background-position: center;          /* 中央配置 */
  background-repeat: no-repeat;
  width: 100%;
  height: 105vh;                        /* 画面の高さと同じ */
  display: flex;                        /* 中央寄せ用 */
  justify-content: center;              /* 横方向中央 */
  color: #fff;                          /* テキストを見やすく白に */
  text-align: center;
}
	.topSubTitle{
		margin-top: 70px;
		margin-bottom: 30px;
		color: #FBE673;
		background-color: #DB4813;
		border-radius: 24px;
		display: inline-flex;
		justify-content: center;
		padding: 8px 50px;
		font-size: 14px;
		font-weight: bold;
	}
	
	/* ===== 検索フォームエリア ===== */
.topSearch form.hero-search {
  width: min(820px, 92vw);
  height: 56px;
  display: flex;
  align-items: center;
  gap: 12px;

  margin: 20px auto 0; /* 上に余白をあける */
  padding: 0 16px 0 12px;
  border-radius: 9999px;

  /* ガラス風の背景 */
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.35);
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.topSearch form.hero-search:focus-within {
  outline: 2px solid rgba(255,255,255,0.7);
  outline-offset: 2px;
}

/* ===== 虫眼鏡アイコンボタン ===== */
.topSearch .hero-search__icon {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  flex: 0 0 40px;

  border: transparent;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}
.topSearch .hero-search__icon img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

/* ===== 入力フィールド ===== */
.topSearch .hero-search__field {
  flex: 1 1 auto;
  height: 100%;
  border: none;
  background: transparent;
  color: #fff;
  font-size: 12px!important;
  letter-spacing: 0.02em;
}
.topSearch .hero-search__field::placeholder {
  color: rgba(255,255,255,0.85);
}
.topSearch .hero-search__field:focus {
  outline: none;
}
	
	.topPlugin{
		margin-top: 50px;
		padding: 0 8%;
	}
	
	#splw-location-weather-12394.splw-main-wrapper{
		margin-left: 0!important;
	}
	
	.topUnderbar{
		margin-top: -4px;
	}
	
/* ===== キービジュアル ===== */
.kv {
  --kv-max: 1100px;
  position: relative;
  padding: 20px 16px 40px;
  background-color: #F4F3EE;
	margin-top: -10px;
	margin-bottom: 60px;
}

.kv__grid {
  max-width: var(--kv-max);
  margin: 0 auto;
}

/* 左テキスト */
.kv__eyebrow {
  color: #0abdc6;
  font-size: clamp(12px, 1.8vw, 14px);
  line-height: 1.5;
  margin: 0 0 10px;
}

.kv__headline {
  font-size: 36px;
  line-height: 1.2;
  margin: 0 0 16px;
}

/* ▼▼ ここから “帯アニメ” 用の修正 ▼▼ */
/* 行ラッパー（帯の器） */
.kv__headline .bgextend{
  display: inline-block;
  margin-bottom: 10px;
  overflow: hidden;
  position: relative;
  opacity: 0;                /* 初期は非表示（IOで is-inview を付与） */
}

/* 文字本体：固定背景は消す／帯より前面に */
.kv__headline .hl{
  background: none;          /* ←固定ピンク背景を無効化 */
  position: relative;
  z-index: 1;
  padding: .05em .25em;
  color: #3a1d00;
  line-height: 1.2;
}

/* 帯は .bgLRextend が付いたときに ::before を伸ばす */
.kv__headline .bgLRextend::before{
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  height: 1.1em;               /* 帯の厚み */
  background-color: #FEA9C3;   /* 帯色 */
  animation: bgLRextendAnime 1s forwards;
}

/* 文字の初期状態と発火 */
.bgappearTrigger{ opacity: 0; }
.bgextend.is-inview{ animation: bgextendAnimeBase 1s forwards; }
.bgappearTrigger.bgappear{ animation: bgextendAnimeSecond 1s .6s forwards; }

/* キーフレーム（必要なら） */
@keyframes bgextendAnimeBase { from{opacity:0;} to{opacity:1;} }
@keyframes bgextendAnimeSecond { from{opacity:0;} to{opacity:1;} }
@keyframes bgLRextendAnime{
  0%   { transform-origin:left;  transform: translateY(-50%) scaleX(0); }
  80%  { transform-origin:left;  transform: translateY(-50%) scaleX(1.05); } /* 少しオーバー */
  100% { transform-origin:left;  transform: translateY(-50%) scaleX(1); }    /* 戻して落ち着く */
}
/* ▲▲ 帯アニメの修正 ここまで ▲▲ */

/* リード（左下に背景画像） */
.kv__lead {
  font-size: clamp(14px, 2vw, 16px);
  line-height: 1.9;
  color: #333;
  margin: 16px 0 0;
  background-image: url("../img/kvBgimage.png");
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: contain;
	position: relative;
	z-index: 4;
}

/* 右側のサムネイル画像 */
.kv__right img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 70vh;
  object-fit: contain;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.18));
}

/* グアム地形の固定（右寄せ基準） */
/*.kvGuam{
  position: absolute;
  transform: translateX(54px);
  top: 350px;
  right: auto;
  z-index: 2;
  pointer-events: none;
	margin-top: 40px;
}
.kvGuam img{
  width: clamp(245px, 30vw, 500px);
  height: auto;
  display: block;
}*/
	 .kvGuam{
    transform: translateX(0);
    margin-top: 20px;
    top: auto;
    right: auto;
    left: 50%;
    transform: translateX(-35%);
    pointer-events: none;
    position: relative; /* スマホでは relative にする方が安定 */
    z-index: 2;
  }

  .kvGuam img{
    width: 245px;   /* スマホは固定 */
    height: auto;
    display: block;
    margin: 0 auto;
  }


	
  .item-relative {
    position: relative;
    height: 50vh;
    overflow: hidden;
  }
  .item-relative img { width: 100%; height: 100%; object-fit: cover; }

  .plugin_absolute { position: absolute; top: 30%; left: 20%; }

  .top_title_wrapper { display: flex; flex-direction: column; align-items: center; justify-content: space-between; padding-right: 80px; }
  .top_txt   { color: #3AAA8A; font-size: 1.5vw; font-weight: 400; }
  .top_title { color: #DB4814; font-size: 4rem; text-align: center; font-weight: 600; margin: 20px 0; }
  .title_ocean, .title_guamu { font-size: 7rem; line-height: 1; }

  /* ---------- HeaderNav（検索/メニュー中身） ---------- */
  .headerNav_wrapper { height: 100%; }
  .headerNav_inner   { display: flex; justify-content: space-around; height: 100%; padding: 2%; }

  .headerNav_right {
    border-left: 3px solid #DB4813;
    padding-left: 2%;
    margin-bottom: 2%;
    width: 30%;
  }
	
	.headerNav_logo a{
		display: flex;
		justify-content: center;
	}

  .headerNav_logo a img { 
	  width: 200px; 
	  height: auto;
	}
	
	.headerNav_right_lib{
		color: #00C3C5;
	}

  .search_genre_title,
  .search_genre_title {
  width: 175px;
  margin: 0 0 10px;
  font-weight: 400;
  line-height: 24px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_genre.png")no-repeat left;
  background-size: contain; /* 画像を枠内に収める */
  color: white; /* 文字色（必要なら調整） */
	  font-size: 14px;
	  padding: 10px 20px;
}
	
	.search_genre_icon_wrapper{
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
		padding: 0 10px;
		flex-direction: column;
	}
	
	.search_genre_icon_list{
		display: flex;
		gap: 20px;
	}
	
	.search_genre_top_icon--div{
		display: flex;
		align-items: center;
		flex-direction: column;
	}
	
	.search_genre_icon_header a{
		display: flex;
		align-items: center;
		gap: 10px;
		flex-direction: column;
		width: 63px;
		height: 82px;
	}
	
	.search_genre_icon_header a img{
		width: 100%;
		height: auto;
		object-fit: cover;
	}

	.search_area_wrapper{
		display: flex;
		gap: 10px;
		margin: 15px 0;
		padding: 0 10px;
		flex-direction: column;
	}

  .search_area_title { 
	  width: 175px;
  font-weight: 400;
  line-height: 24px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_area.png")no-repeat left;
  background-size: contain; /* 画像を枠内に収める */
  color: white; /* 文字色（必要なら調整） */
	  font-size: 14px;
	  padding: 10px 20px;
	}

  .search_shopkeyword { display: flex; flex-direction: column; gap: 10px; margin: 50px 0 15px; padding: 0 10px;}

  .search_shop,
  .search_keyword {
    width: 100%;
    background: #fff;
    padding: 10px 20px;
    border-radius: 10px;
  }

  .search_shop    { border: 2px solid #FFA641; }
  .search_keyword { border: 2px solid #FEA9C3; }

  .search_shop img, .search_keyword img { width: 24px; height: 24px; }

  .keyword_readmore a { display: flex; align-items: baseline; justify-content: flex-end; gap: 20px; }
  .shoplist_readmore a { margin-top: 10px; }
  .shoplist_readmore a p { color: #00C3C5; }

  .search_area_content { display: flex; flex-wrap: wrap; gap: 10px;}
	
	.search_area_content a{
		font-size: 14px;
	}

  .search_area_tumon, .search_area_agat,
  .search_area_hagania, .search_area_merizo,
  .search_area_tarofofo, .search_area_inalahan {
    background-color: #F3C8FF;
    padding: 5px 10px;
    border-radius: 50px;
    text-align: center;
  }
  .search_area_tumon, .search_area_agat { width: 160px; }
  .search_area_hagania, .search_area_merizo { width: 150px; }
  .search_area_tarofofo { width: 190px; }
  .search_area_inalahan { width: 180px; }

  .search_flee_wrapper { 
	  display: flex;
	  align-items: flex-start;
	  gap: 5px;
	  padding: 0 10px 280px;
	  flex-direction: column;
	}
  .search_flee_title   { 
	    width: 200px;
  height: 50px;
  font-weight: 400;
  text-align: center;
  line-height: 24px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_free.png")no-repeat left;
	  padding: 10px 20px;
  background-size: contain; /* 画像を枠内に収める */
	}

  .search1 { display: flex; align-items: center; gap: 10px; }
  .search_flee_icon { background-color: #FBE673; padding: 5px 10px; box-sizing: border-box; border-radius: 10px; width: 70px; display: flex; justify-content: center; }
  .search_image { width: 30px; height: 30px; }
  .search-text { width: 70vw; padding: 5px; border-radius: 13px; border: 2px solid #FBE673; }

  .headerNav_menu { 
	  height: 100%; display: grid;
	  margin-top: 30px;
	}
  .headerNav_menu_list { 
	  max-width: 400px;
	}
	.headerNav_menu_list ul{
		display: flex;
		flex-direction: column;
		align-items: flex-end;
	}
	.sns_link_wrapper{
		max-width: 400px;
		margin: 40px 0;
	}
	.headerNav_left{
		max-width: 868px;
		margin: 0 auto;
	}
	
  .headerNav_menu_list li { list-style: none; margin-bottom: 10px;  text-align: right;}
/* liの枠組み */
.headerNav_menu_list li {
  list-style: none;
  margin-bottom: 20px;

  display: inline-flex;       /* 中身にフィットさせる */
  flex-direction: column;     /* 縦並び */
  align-items: flex-end;      /* 右端を基準に揃える */
  width: max-content;
}

/* 日本語ラベル */
.headerNav_right_lib {
  margin: 0 0 6px 0;
  font-size: 14px;
  line-height: 1;
  color: #00C3C5;
}

/* 英字リンク */
.headerNav_right_link {
  position: relative;
  display: inline-block;
  font-size: 24px;
  line-height: 1.3;
  text-decoration: none; /* デフォルトの下線は消す */
  color: #3a1d00;        /* 好きな文字色に */
  white-space: nowrap;   /* 改行させない */
	padding-right: 0.5em;
	font-weight: 700;
}

/* afterで下線を描画 */
.headerNav_right_link::after {
  content: "";
  position: absolute;
  right: 0;                /* 日本語の右端と揃える */
  bottom: -6px;            /* 文字との距離 */
  width: 100%;             /* 文字幅に合わせたいなら100% */
  height: 2px;
  background-color: #00C3C5;
}


  .sns_link_up { 
	  display: flex; 
	  gap: 20px; 
	  margin-bottom: 30px; 
	  justify-content: flex-end;
	}
	.sns_link_down{
		text-align: right;
	}
  .sns_link_down a, .sns_link_q a { color: #462408; border-bottom: 1px solid #462408; font-weight: normal; }
  .sns_link_down a { font-size: 15px; }
	
	 /* ---------- SLIDE UNDER IMAGE---------- */
	/*.under-slide{
		width: 100vw;
		height: 120px;
	}
	
	.under-slide img{
		width: 100%;
		height: 100%;
		object-fit: cover;
	}*/
	
	.infinity-slide {
  width: 100vw;
  height: 100px;
  overflow: hidden;
  position: relative;
		border-bottom: solid 2px #462408;
}

.infinity-track {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 40px;
  white-space: nowrap;

  /* ここを変える */
  --scroll-distance: 0px;
  animation: infinityScroll 15s linear infinite;
}

.banner {
  font-size: 28px;
  white-space: nowrap;
  padding: 0 40px;
  display: flex;
  align-items: center;
  border-radius: 6px;
  text-decoration: none;
	font-weight: 600!important;
}

/* 無限スクロール */
@keyframes infinityScroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-1 * var(--scroll-distance)));
  }
}

/* スマホだけ速くしたいならオマケで */
@media screen and (max-width: 768px) {
  .infinity-track {
    animation-duration: 24s;
  }
}





	
	.banner:hover{
		opacity: 0.6;
	}

/* ========== NEW POST / SHOP INFO (CSS, keep .newpost_contents_tag as-is) ========== */
	
	.newpost_wrapper{
		background-color: #F4F3EE;
		margin-top: -10px;
	}
	
	.new-post__sp .readmore_btn{
		padding-bottom: 20px;
	}

/* ラッパー */
.newpost_inner{
  gap: 28px;
  margin: 0 auto;
	padding: 80px 38px 0;
}

/* --- 左カラム（吹き出し / 見出し / ボタン） --- */
.newpost-titleWrap{ position: relative; }
.newpost_fukidashi, .Fukidashi{ display: block; margin-bottom: 25px; text-align: center;}

/* 見出し（画像見出しをそのまま使用） */
.newpost_title, .Title{ margin: 0 0 10px; text-align: center; font-size: 27px; font-weight: 400}
.newpost_title img, .Title img{ height: auto; display: block; }
.newpost_title::after,.Title::after {
  content: "";
  display: block;
  width: 46px;
  height: 6px;
  background: #2cd5c4;
  margin: 20px auto 0;   /* ← auto で左右中央寄せ */
}

/* 一覧ボタン（ミントのピル / 左寄せ） */
.newpost_more{ width:auto; margin:30px 0 0; padding:0; background:transparent; text-align:center; border-radius:0; }
.newpost_more a{
  display:inline-block; padding:10px 50px; border-radius:999px;
  background:#2cd5c4; color:#fff; font-weight:700; text-decoration:none;
  box-shadow:0 2px 0 #15b7a8;
}
.newpost_more a:hover{ opacity:.9; }

/* --- 右カラム：横並びカード --- */
.np-card{
  position:relative;
  background:#fff;
  border:1px solid #E8F6F5;          /* 淡いミント枠 */
  border-radius:12px;
  overflow:hidden;
  margin-bottom: 14px;
	box-shadow: 4px 4px 0 #2cd5c4;
}


.np-link{
  display:flex; align-items:center; gap:14px;flex-direction: column;
  padding:15px; text-decoration:none;
}

/* サムネイル */
.np-thumb{
  flex:0 0 150px;                     /* 画像の横幅 */
  aspect-ratio:16/9;
  border-radius:10px; overflow:hidden;
}
.np-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.np-noimg{
  display:grid; place-items:center; width:100%; height:100%;
  background:#f2f5f5; color:#8aa; font-size:12px;
}

/* テキスト側 */
.np-body{ width: 100%; }
.np-meta{ display:flex; align-items:center; gap:70px; margin:2px 0 6px; justify-content: flex-start;}
.np-date{ font-size:12px; color:#7f8a8a; letter-spacing:.02em; }

/* ※カテゴリ表示は newpost_contents_tag をそのまま利用（ここでは触らない） */
/* もし日付の横に余白が欲しければ、ラッパーだけ軽く整える（見た目は変えない） */
.newpost_contents_title_wrap{ display:flex; align-items:center; gap:8px; }

/* タイトル（2行で省略） */
.np-title{
  margin:0;
  font-size:14px; line-height:1.6; color:#333; font-weight:700;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}

/* ふるまい */
.np-card:hover{ border-color:#c6efea; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.np-link:hover .np-title{ text-decoration:underline; }
	
	/* 吹き出しのアニメーション復活 */
  .newpost_fukidashi img { animation: tiltStepAnimation 2s infinite steps(1); width: 100%;}
	
	.stepAnimation{ animation: tiltStepAnimation 2s infinite steps(1); }




  /* ---------- Banner ---------- */
  .baner_wrapper {
    margin: 30px 0;
    display: flex;
	  flex-direction: column;
	  align-items: center;
	  gap: 15px;
  }
  .baner { width: 290px; }
  .baner img { width: 100%; height: 80px; object-fit: contain; }

/* ---------- Shop Ranking---------- */
.shop_ranking_wrapper { background:#fff; padding: 45px 0 50px;}
.shop_ranking_title, .shop_ranking_sub { text-align: center; }
.shop_ranking_title { color:#DB4813; font-size:6rem; line-height:1; display:flex; justify-content:center; }
	
	.shop_ranking_wrapper .Fukidashi img{
		width: 345px;
		height: auto;
	}

/* 横スクロール (そのまま) */
.shop_ranking_contents{
  display:flex;
  overflow-x:auto;
  white-space:nowrap;
  gap:18px;
  margin-top:50px;
  --maxw: 1180px;
  --side: max( (100vw - var(--maxw)) / 2, 16px );
  padding-left: var(--side);
  padding-right: var(--side);
}
	
.shop_ranking_inner{ display:flex; gap:18px; }



/* カード本体 */
.rank_img{
  flex:0 0 auto;
  width:23vw;                /* PC：4枚並び想定のまま */
  max-width:360px;           /* はみ出し防止 */
  min-width:260px;           /* 小さすぎ防止 */
  display:flex;
  flex-direction:column;
  align-items:stretch;
  background:#fff;
  padding:12px;
  scroll-snap-align:start;
}
.rank_img .img-link{
  display:block;
  position:relative;         /* ← バッジ配置の基準 */
  color:inherit;
  text-decoration:none;
}

/* サムネイル領域（角丸 + 比率固定） */
.rank_photo{
	width: 100%;
	height: auto;
	float: none;
  position: relative;
  /*aspect-ratio: 4 / 3;*/
  overflow: hidden;
  border-radius: 16px;
}
.rank_photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;     /* ←はみ出しをカットして全体に収める */
  display: block;
}

/* 左上の順位バッジ（ユーザー準備のPNG） */
.number{
  position: absolute;
  top: -20px;   /* 画像枠の上から10px */
  left: 0;  /* 画像枠の左から10px */
  z-index: 2;
}
	
	.number_kemushi{
		position: absolute;
  top: -15px;   /* 画像枠の上から10px */
  left: 10px;  /* 画像枠の左から10px */
  z-index: 2;
	}
	
.number img{
  width:90px;
  height:auto;
  display:block;
}

/* テキストブロック */
.rank_text_wrap{ margin-top:12px; }

/* カテゴリのピル（taxonomy: main_category） */
.rank_postsub{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}


/* タイトル（2行で省略） */
.rank_text{
  margin-top:8px;
  color:#462408;
}
.rank_text p{
  margin:0;
  font-weight:700;
  line-height:1.6;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
	
	.rank_text_sub{
		margin-top: 15px;
		font-size: 14px;
	}


  /* ---------- Recommend ---------- */
  .shop_recommend_title, .shop_recommend_sub { text-align: center; }
  .shop_recommend_title { color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
	
	.shop_recommend_wrapper{
		padding: 50px 0 0;
	}
	
	.shop_recommend_wrapper .Fukidashi{
		padding: 0 20px;
	}
	
	.shop_recommend_wrapper .Fukidashi img{
		width: 100%;
		height: auto;
	}

  .shop_recommend_contents {
    margin: 50px 0;
    padding: 0 40px;
  }
	
	.shop_recommend_contents .post_text_t p{
		font-weight: bold!important;
	}

  .newpost_shop { width: 100%; float: none;margin-right: 0;margin-bottom: 30px;}
  .post_img_shop { width: 100%; height: 250px; margin-bottom: 10px; }
	.post_img_shop img{
		border-radius: 15px;
	}
  .post_text_t { text-align: left; font-size: 16px; line-height: 20px; color: #462408; font-weight: 700;}
  .post_text   { text-align: left; padding: 5px 0; font-size: 14px; line-height: 20px; color: #462408; }
  .post_sub_shop { margin: 10px 0;}

	/* 画像枠：比率を固定して基準化 */
.post_img_shop{
  position: relative;        /* ← バッジの基準 */
  overflow: visible;
  border-radius: 16px;
  background: #f4f4f4;
}

/* メイン画像をきれいにフィット */
.post_img_shop > img:first-child{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* 左上バッジ（少し角から被せる演出） */
.post_img_shop .post-badge{
  position: absolute;
  top: 12px;
  left: 12px;
  transform: translate(-6px, -6px); /* 角から“ちょい被せ”。不要なら削除 */
  z-index: 5;
  width: clamp(52px, 7vw, 72px);    /* 固定幅にしたい場合は 64px などに */
  height: auto;
  pointer-events: none;             /* クリックを邪魔しない */
}
	
	/* 初期状態：非表示 & 縮小 */
.post_img_shop .post-badge {
  position: absolute;
  top: -8px;
  left: 0;
  width: 74px;
  height: auto;
  opacity: 0;
  transform: scale(0.5);
  transition: opacity 0.6s ease, transform 0.6s ease;
  pointer-events: none;
  z-index: 2;
}

/* 表示状態（クラス追加時） */
.post_img_shop .post-badge.is-inview {
  opacity: 1;
  transform: scale(1);
}
	
/* フェードアウト（自然に消えるだけ） */
.post_img_shop .post-badge.is-out {
  opacity: 0;
  transform: scale(1); /* ← 縮小しない、サイズは維持 */
  transition: opacity 0.8s ease; /* 少し長めで“シュッ” */
}

/* ========== クイック系アニメ ========== */
/* 方向は CSS変数 --dir（1 or -1）で左右／回転方向を切り替えます */

@keyframes badge-sway-quick-kf {
  0%,100% { transform: translateX(0) scale(1); }
  50%     { transform: translateX(calc(var(--dir, 1) * var(--ampX, 14px))) scale(1); }
}
.badge-sway-quick {
  animation-name: badge-sway-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1); /* キビキビ */
}

/* 素早い首振り（回転） */
@keyframes badge-tilt-quick-kf {
  0%,100% { transform: rotate(0deg) scale(1); }
  50%     { transform: rotate(calc(var(--dir, 1) * var(--ampR, 12deg))) scale(1); }
}
.badge-tilt-quick {
  animation-name: badge-tilt-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1);
}

/* 合成（左右揺れ＋首振り）※1つのキーフレームでまとめて transform を管理 */
@keyframes badge-sway-tilt-quick-kf {
  0%,100% { transform: translateX(0) rotate(0deg) scale(1); }
  50%     { transform:
              translateX(calc(var(--dir, 1) * var(--ampX, 12px)))
              rotate(calc(var(--dir, 1) * var(--ampR, 10deg)))
              scale(1);
  }
}
.badge-sway-tilt-quick {
  animation-name: badge-sway-tilt-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1);
}

/* 省エネ設定に配慮 */
@media (prefers-reduced-motion: reduce){
  .badge-sway-quick,.badge-tilt-quick,.badge-sway-tilt-quick{
    animation: none !important;
    transform: none !important;
  }
}

	
  /* ---------- Search Page ---------- */
  .search_wrapper_top {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: 35px 16px 130px;
  background: url("../img/searchBG.png") top center / 100% 98% no-repeat;
}
  .search_inner_top  { padding-bottom: 50px; }

  .search_title, .search_sub { text-align: center; }
  .search_title { padding: 20px 0; color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
  .search_sub   { color: #462408; font-weight: 400; }
	
	.search_title--top{
		margin-bottom: 20px;
	}

  .search_contents_wrap {
    background: #fff;
    border-radius: 30px;
    padding: 10px 20px;
  }
	
	.search_contents_wrap .Fukidashi img{
		width: 100%;
		height: auto;
	}

  .search_txt_m { margin-bottom: 20px; font-size: 2.5rem; color: #462408; font-weight: 400; }
  .search_genre_contents { display: flex; align-items: flex-end; justify-content: space-between; width: 100%; margin-top: 50px; }
  .search_genre_m_a { display: flex; flex-direction: column; align-items: center; justify-content: center; }
  .search_genre_m_a img { margin-bottom: 30px; width: 90%; }

  .search_shop_m { margin: 90px 0; }
  .search_keyword_m { margin-bottom: 20px; }
  .search_keyword_m_contents_wrap { display: inline-block; }
  .search_keyword_m_contents_wrap a { width: 150px; background: #E00E65; color: #fff; }

  .search_area_m { margin: 50px 0 70px; }
	
	.search_genre_icon_wrapper--top{
		gap: 20px;
		justify-content: flex-start;
		padding: 0!important;
	}
	
	.search_genre_icon_wrapper--top .search_genre_title{
		margin: 0;
	}
	
	.search_shopkeyword--top{
		padding: 0;
		margin-bottom: 30px;
	}
	
	.search_flee_wrapper--top{
		padding: 0;
	}
	
	.search_flee_wrapper--top .search-text{
		width: 52vw;
		font-size: 12px!important;
	}

  /* ---------- Movie ---------- */
  .movie_wrapper { margin: 5% 0; }
  .movie_title, .movie_sub { text-align: center; }
  .movie_title { color: #DB4813; font-size: 7rem; line-height: 1; display: flex; justify-content: center; }
  .movie_sub   { color: #9ECF21; text-align: left;}

  .movie_contents { margin-top: 50px; width: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; }
  .video-gallery { width: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; }
  .video-item    { position: relative; width: 70%; padding-bottom: 35%; height: 0; overflow: hidden; border-radius: 25px; }
  .movie_h3      { font-size: 12px; font-weight: 400; color: #9ECF21; text-align: left; width: 70%; margin-bottom: 10px; }
  .video-item iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }

  /* ---------- Instagram ---------- */
  .instagram_wrapper { margin: 40px; }
	
	.instagram_wrapper .Fukidashi img{
		width: 100%;
		height: auto;
	}
	
  .insta_title { color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
  .insta_sub   { color: #9ECF21; }

  .sns_link_wrapper_foot { display: flex; justify-content: center; gap: 30px; margin: 40px 0; }
  .sns_link_down_foot { font-weight: bold; color: #000; padding-top: 10px; }

/* ===== Footer ===== */
.site-footer{
  background:#FBE673; /* スクショの黄色 */
  color:#462408;
}

.footer__wrap{
  width:100%;
  padding:48px 16px 86px;
	margin-bottom: 40px;
}


.footer__inner{
  margin:0 auto;
	display: flex;
	justify-content: space-between;
	flex-direction: column;
}

.footer__head{
  display:flex;
  flex-direction: column;
  margin-bottom:24px;
}

.footer__brand{
  display:flex;
  align-items:flex-start;
	flex-direction: column;
  gap:15px;
}
	
	.footer__links_sk li a{
		font-weight: 700!important;
	}
	
	.footer-sub-stick{
		display: inline-block;
		margin-right: 5px;
		font-weight: 700;
	}
	
	.footer__logo{
		width: 100%;
	}

.footer__logo img{
  width: 100%;
  height:auto;
  display:block;
}

.footer__sns{
  display:flex;
  gap:12px;
}
.footer__sns img{
  width:24px; height:24px; display:block;
}

/* 中段グリッド */
.footer__grid{
  display:flex;
	flex-direction: column;
  margin:16px 0 28px;
	gap: 20px;
}

.footer__heading{
  font-weight:700;
  margin:4px 0 8px;
  letter-spacing:.03em;
	color: #DB4813;
}

.footer__subttl{
  font-size:14px;
	color: #DB4813;
	font-weight: 700;
}

.footer__links{
  display:flex;
	flex-direction: column;
	gap: 20px;
}
.footer__links a{
  color:#DB4813;
  text-decoration:none;
  position:relative;
	font-weight: 700;
	font-size: 14px;
}
	
	.footer__subgroup ul li a{
		font-weight: 400;
	}
	
.footer__links a:hover{ text-decoration:underline; }
	
	.footer__links--li{
		padding-left: 1em;
	}

	
	.footer__right_group{
		display: flex;
		gap: 20px;
		flex-direction: column;
	}
	
	.footer__subgroup--spmenu{
		display: flex;
		flex-direction: row;
		gap: 30px;
	}
	
/* 下段 */
.footer__foot{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-top:16px;
}

.footer__legal{
  display:flex;
  gap:14px;
	column-gap: 50px;
  flex-wrap:wrap;
	text-align: left;
	justify-content: center;
}
.footer__legal a{ color:#462408; text-decoration:none; font-size:16px;  font-weight: 700;}
.footer__legal a:hover{ text-decoration:underline; }

.footer__copy{
  color:#6b4b1f;
  font-size:12px;
  opacity:.85;
	display: flex;
	justify-content: center;
}
	
	.footer--sp__fixed{
		background-color: #AAF3DD;
		position: fixed;
		inset: auto 0 0 0;
		width: 100vw;
		z-index: 8000;
	}
	
	.footer--sp__fixed--flex{
		display: flex;
		align-items: center;
		justify-content: flex-start;
		gap: 15px;
		position: relative;
		padding: 20px 24px;
		font-size: 14px;
	}
	
	.footer--sp__fixed--icon--content{
		display: flex;
		gap: 25px;
		position: absolute;
		bottom: 10px;
		right: 45px;
	}
	
	.footer--sp__fixed--icon a{
		display: flex;
		flex-direction: column;
		align-items: center;
		width: 55px;
		height: 80px;
	}
	
	.footer--sp__fixed--icon a img{
		width: 100%;
		height: auto;
		object-fit: cover;
	}


  /* ---------- Archive / Lists ---------- */
  .archive_post_contents { display: flex; flex-direction: column; justify-content: space-between; box-sizing: border-box; height: 100%; }
	.archive_newpost_contents_wrap{
		display: flex;
		flex-direction: column;
		margin-top: 50px;
		padding: 0 46px;
	}
	
	.archivepost_img_shop{
		height: 104px;
		margin-bottom: 0;
	}
	
	.np-link-archive{
		display: flex;
        align-items: flex-start;
        gap: 10px;
         padding: unset!important;
        text-decoration: none;
		margin-bottom: 30px;
	}
	
	.np-thumb-archive{
		flex: 0 1 auto!important;
        aspect-ratio: auto!important;
        border-radius: 10px;
        overflow: visible!important;
	}
	
	.np-thumb-archive img{
		width: 100%;
        height: auto;
         display: unset!important;
		border-radius: 10px;
	}
	
	.np-card-archive{
		position: relative;
         background: unset!important; 
        border: 1px solid #E8F6F5;
        border-radius:0;
        overflow: hidden;
         margin: unset!important;
         box-shadow: unset!important;
	}
	
	.np-meta-article{
		justify-content: space-between;
		margin: 0 0 10px;
	}
	
	.single-backBtn-an-title{
		margin-bottom: 30px;
		font-size: 28px;
	}
	
	.single-backBtn-an-title a{
		display: inline-block;
		margin-bottom: 20px;
	}

  .wp-pagenavi { display: flex; justify-content: center; margin-top: 100px; }

  .shoplist_contents_wrapper { margin-bottom: 100px; }
	
	.shoplist_contents_wrapper .post-grid{
		grid-template-columns: repeat(2,1fr);
	}

  .alphabet_nation_wrapper {
    width: 100%;
    padding: 40px 25px;
    border: 1px solid #FCBA6E;
    background: #fff;
    border-radius: 20px;
    margin: 20px 0 80px;
  }

  .alphabet_wrapper, .katakana_wrapper { display: flex; flex-wrap: wrap; gap: 4%; row-gap: 50px; justify-content: space-between;}
	.katakana_wrapper{
		margin-top: 50px;
	}
  .alphabet_wrapper a, .katakana_wrapper a { color: #FCBA6E; font-weight: 400; border-bottom: 1px solid #FCBA6E; }
	
	.alphabet_nation_title {
  position: relative;
  font-weight: 700;
  color: #462408;
  text-align: center;
		margin-bottom: 50px;
}
	
	.alphabet_nation_title::after {
  content: "";
  display: block;
  width: 50px;
  height: 5px;
  background-color: #FCBA6E;
  margin: 6px auto 0; /* 上に少し余白を入れて中央寄せ */
  border-radius: 2px;
}
	
	.shoplist_section{
		color: #FCBA6E;
		font-size: 40px;
		font-weight: bold;
	}

  .post-grid  { display: grid; grid-template-columns: repeat(3,1fr); gap: 15px; }
	.rank_text_sub--shoplist{
		margin-top: 5px;
	}
  .post-flex  { display: flex; flex-wrap: wrap; gap: 20px; }
  .post-flex > .newpost_shoplist,
  .post-grid > .newpost_shoplist { flex: 1 1 calc(33.33% - 20px); box-sizing: border-box; }
  .letter-heading { display: block; width: 100%; margin: 40px 0;}
  .newpost_shoplist { /*padding: 10px;*/ text-align: center; }

  .tagpost_wrapper { margin-top: 100px; }
  .tagpost_contents { display: grid; grid-template-columns: repeat(2,1fr); justify-items: center; }
  .tag_newpost_shop { width: 90%; margin: 0 3.5% 5%; }
	
	.archive_contents_wrapper_genre{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		gap: 13px;
	}
	
	.max-width-archive{
		max-width: 1050px;
		margin: 0 auto;
	}
	
	.choice_word{
		display: flex;
		align-items: center;
		gap: 10px;
		font-size: 18px;
	}
	
	.other_genre_wrap{
		background-color: white;
		padding: 16px 10px;
		border-radius: 15px;
		margin-top: 15px;
		margin-bottom: 50px;
	}
	
	.archive-genre-font-size span{
		font-size: 20px!important;
	}
	
	.archive-genre-font-size img{
		width: 45px!important;
		height: 45px;
		margin-right: 30px;
	}
	
	.archive-current-genre{
		/*margin-right: 22px;*/
	}
	
	.archive_contents_wrapper_genre .newpost_shop{
		margin-bottom: 0;
	}
	
	.archive_contents_wrapper_genre .rank_text_sub{
		margin-top: 10px;
	}
	
	.archive-genre-image_other{
		width: 35px!important;
		height: auto;
	}
	
	.post_text_title{
		font-size: 16px;
		font-weight: bold;
		height: 40px;
	}
	
	.page-nav-archive > div > .current{
		background-color: #8FE7CC!important;
	}

  /* ---------- Single Shop / Article ---------- */
  .article_body { background-color: #F4F3EE; padding-top: 63px;}
  /*.article_body p, .article_body h3 { color: #462408; }*/
	
	.post_day{
		display: flex;
		align-items: center;
		gap: 42px;
		margin-bottom: 5px;
	}
	
	.single_main{
		background-color: white;
		border-radius: 50px;
	}
	
	.single_mainTop{
		padding: 10px;
	}
	
	.single-article-shop__body .content{
		width: 100%;
	}
	
	.s_catch{
		max-width: 1000px;
		margin: 0 auto 60px;
	}
	
	.s_catch img{
		width: 100%;
		height: auto;
	}
	
	.forSingle-tag{
		padding: 5px 20px!important;
		font-weight: 700;
		font-size: 14px;
	}
	
	.entry-title{
		padding-bottom: 20px;
		font-size: 24px;
	}
	
	.shop_cta_row{
		display: flex;
		gap: 70px;
	}
	
	/* 画像枠は角丸＋はみ出し隠す（←ここがポイント） */
.s_catch {
  position: relative;
  border-radius: 24px;
  margin: 14px 0 10px;
  width: 100%;
}
.s_catch img { width: 100%; height: auto; display: block;  object-fit: cover;}
	
	.single-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}

.single-article__tag {
  display: inline-block;
  color: #462408;
  background-color: #FFBFD3;
  border-radius: 16px;
  padding: 8px 15px;
  font-size: 14px;
  line-height: 1.4;
  white-space: nowrap;
  text-decoration: none; /* リンク版でも下線を消す */
  transition: opacity 0.3s;
}

.single-article__tag:hover {
  opacity: 0.8;
}


/* エリアバッジの位置（左上） */
.area_pill_wrap {
  position: absolute;
  top: 0;             /* 画像の内側に少し余白 */
  left: 0;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* エリアバッジ本体：左は角丸なし／右だけ“ピル”形状に */
.area_pill {
  position: relative;
  display: inline-block;
  padding: 5px 17px;
  background: #F7CCFF;  /* 薄ピンク */
  color: #3a220d;       /* 濃いブラウン */
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  white-space: nowrap;
  border-radius: 0 0 25px 0; /* 上記12pxはお好みで調整OK */
}

/* 複数ラベル並び時の余白 */
.area_pill + .area_pill { margin-left: 6px; }
	
	.single-backBtn-an-title{
		margin-bottom: 20px;
	}
	
	.single-backBtn-an-title p{
		font-weight: 700;
	}
	
	.single_main_genrepage{
		background-color: unset;
	}
	
	.single_mainTop_genrepage{
		max-width: 1000px;
		padding-top: 0;
	}
	/* ===== SHOP CTA (「このSHOPの詳細を見る」「このSHOPのSNSをみる」) ===== */
	
	.shopbox_first_genrepage{
		display: flex;
		flex-direction: column-reverse;
	}
	
	.shop_article_img1_genrepage{
		width: 100%;
	}

/* ラッパー：必要なら背景色を付ける（任意） */
.shop_cta_area {
  margin: 40px 0 20px;
  background: #7fe0d0;           /* ←スクショのミント系。要らなければ削除OK */
  border-radius: 0 0 32px 32px;   /* 角丸（任意） */
  padding: 10px;
}

/* 行 */
.shop_cta_row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 18px 0;
  border-top: 1px solid rgba(0,0,0,0.08);
	flex-direction: column;
}
.shop_cta_row:first-child { border-top: none; }

/* 左側ラベル */
.shop_cta_label {
  color: #462408;
  font-size: 14px;
  letter-spacing: .05em;
  white-space: nowrap;
	font-weight: 700;
}

/* ===== 1行目：詳細ボタン ===== */
.shop_cta_button {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 12px 18px 12px 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 9999px;          /* ピル型 */
  box-shadow: 0 2px 0 rgba(0,0,0,.06);
  text-decoration: none;
  color: #462408;
  transition: transform .08s ease, box-shadow .08s ease;
}
.shop_cta_button:hover { transform: translateY(-1px); box-shadow: 0 4px 0 rgba(0,0,0,.06); }
.shop_cta_button:active { transform: translateY(0); box-shadow: 0 2px 0 rgba(0,0,0,.06); }

.shop_cta_button_text {
  font-size: 14px;
  line-height: 1;
  font-weight: 600;               /* 日本語側太字イメージ */
}

/* 右端の丸矢印 */
.shop_cta_button_icon {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  font-weight: 700;
  line-height: 1;
  padding-bottom: 1px; /* 矢印の上下バランス微調整 */
}

/* リンクなし時（disabled想定） */
.shop_cta_button.is-disabled {
  cursor: default;
  pointer-events: none;
	padding: 15px 30px;
	background-color: white;
}

/* ===== 2行目：SNSアイコンピル ===== */
.shop_cta_sns .shop_cta_sns_icons {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  padding: 10px 16px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 9999px;
  box-shadow: 0 2px 0 rgba(0,0,0,.06);
}
.shop_cta_sns .sns_icon img {
  width: 28px;
  height: 28px;
  display: block;
  transition: transform .15s ease;
}
.shop_cta_sns .sns_icon:hover img {
  transform: scale(1.06);
}
	
	.article_for_shopinfolink{
		max-width: 100%;
		margin: 0 auto 50px;
		display: flex;
		justify-content: center;
	}
	
	.article_for_shopinfolink a{
		color: white;
		background-color: #462408;
		padding: 20px 60px;
		border-radius: 65px;
	}


  .yw h4 { color: #00C3C5; }
  .day-cat-area { display: flex; gap: 2%; margin-bottom: 20px; border-bottom: none !important; }

  .shoptitle_article { border-bottom: 1px solid #DB4813; }
  .shoptitle_article h3 { color: #462408; }

  .sub_orange {
    color: #DB4813 !important;
    background: #fff;
    border: 1px solid #DB4813;
    border-radius: 10px;
    font-weight: bold;
  }

  .shopbox_first { display: flex; }
  .shop_article_img1  {  margin-right: 3%; }
  .shop_article_text1 {  padding: 20px 0; }
  .shop_article_text1 p { margin-top: 20px; }
	.shopbox_first img{
		width: 100%;
		height: auto;
		display: block;
	}

  .bk h4 { border-bottom: dotted 4px #00C3C5; font-size: 24px; display: inline-block; }

  .shopbox_photogallery { border-top: 2px solid #00C3C5; }
  .photogallery_article { display: grid; grid-template-columns: repeat(4,1fr); justify-items: center; }
  .shop_img_article_5 { width: 90%; height: auto; margin-top: 15px; }
  .shop_img_article_5 img { width: 100%; height: 100%; object-fit: cover; }

  .t_left p { color: #00C3C5; }

  .shopbox_information {
    background: #fff;
    padding: 0 14px;
	  border-radius: 0 30px 30px 30px;
  }
	
	.single__information{
  position: relative;
  background: #fff;
  padding: 15px 50px;
		width: 220px;
		border-top-left-radius: 30px;
		border-top-right-radius: 30px;
		
}
	
	.single__information--h4{
  color: #12B6C8;       /* 見出しもアクセント色に */
  font-weight: 800;
  font-size: 16px;
		padding-bottom: 0!important;
}

  .other_post { width: 100vw; background: #ECF1DD; }
  .other_post_inner { display: flex; flex-direction: column; align-items: center; padding: 40px 0 0; }

  .other_post_inner a {
    font-size: 2rem;
    padding: 20px 40px;
    display: inline-block;
    background: #9FCF24;
    margin-bottom: 50px;
    color: #fff;
  }

  .other_post_link { display: block; width: 15%; padding: 10px 20px; background: #DB4813; text-align: center; border-radius: 20px; }
  .other_post_link a { color: #fff; font-weight: bold; }

  .single_postbox_editied { width: 100vw; background: #ECF1DD; }
  .other { display: flex; justify-content: center; padding: 60px 0 0; }
  .other h4 { padding: 15px 40px; background: #9FCF24; margin-bottom: 60px; }
  .single_readmore_btn p { font-weight: bold; color: #fff; }

  .post_sub_edited { margin-top: 10px; }
  .post_cate_tag { margin-top: 10px; }
  .tag-frame { padding: 5px 10px; border-radius: 20px; color: #462408; font-size: 14px; background-color: #FFBFD3;}

  .post_info_inner strong { color: #DB4813; }

  .shop-info { box-sizing: border-box; }
  .shop-info p { margin: 10px 0; display: flex; align-items: center; }
  .shop-info-label { flex: 0 0 120px; font-weight: bold; margin-right: 20px; text-align: left; }

  .post_sns { margin-top: 20px; }
  .post_sns_icons { display: flex; gap: 20px; }
  .post_sns_icons img { width: 30px; height: 30px; transition: transform .3s; }
  .post_sns_icons img:hover { transform: scale(1.1); }

  .shop_info_readmore { font-size: 85%; }
  .shop_info_readmore a { color: #DB4813; border-bottom: 1px solid #DB4813; font-weight: bold; }

  .post-readmore_box { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-bottom: 40px; }
  .post_img_readmore { height: 50%; }

  /* ---------- Movie / Shorts extra ---------- */
  .video-item-archive { width: 60% !important; }
  .movie_h3_archive { width: 60% !important; margin-bottom: 40px; }
  .choice_word_movie { color: #DB4813 !important; }
  .youtube-short-item { width: 100%; }
  .choice_word_video { color: #DB4813 !important; }

  /* ---------- Misc ---------- */
  /*.max-width { padding: 7vh 9vw; }*/
  .top_info_wrapper { margin-top: 65px; }
  .archivepost_img_article { width: 100%; aspect-ratio: 1/1; height: auto; }
  .postarchive_post_text { padding-top: 0 !important; }
  .archivepost_sub_shop { margin: 5px 0; }
	.shoplist_cate{
		text-align: left;
	}
  .post_readmore { height: 65vh; }

  .tabs { display: flex; justify-content: center; background-color: #F4F3EE; }
  .tab_item { width: calc(100%/2) !important; display: flex !important; justify-content: center; align-items: center; line-height: 40px; }
  .tab_item a { display: block; width: 100%; height: 100%; text-align: center; padding-bottom: 2px; color: #DD4D34; }
  .tab_item a p { display: inline; border-bottom: 1px solid #fff; padding-bottom: 2px; color: #DD4D34; }
  input[name="tab_item"]:checked + .tab_item a p { color: #fff; }
  .eat { border: 3px solid #DD4D34; background: #fff; }

  .genre_icon_txt { display: flex; white-space: nowrap; width: 100%; justify-content: flex-start; gap: 22px;}
  .genre_icon_content { display: flex; align-items: center; gap: 1%; }
  .genre_icon_content a { display: flex; align-items: center; text-decoration: none; color: inherit; }
  .genre_icon_content img { margin-right: 5px; width: 4vw; }
  .genre_icon_content span { color: #462408; white-space: nowrap; font-size: 14px; }

  .shoparticle_area_list { 
	  display: grid; 
	  grid-template-columns: repeat(2,1fr); 
	  justify-items: center; 
	  column-gap: 15px;
	  row-gap: 30px;
	}
	
	.keywordlist_wrapper{
		margin: 70px auto 50px;
	}
	
	.keyword_contents_wrap{
		margin-top: 20px;
		padding: 19px 12px;
		border: solid 1px #FFBFD3;
		border-radius: 30px;
		background-color: white;
	}
	
	
	/*===========================
		エリアから探すページ
	=============================*/
	.taxonomy-area-fv__wrapper{
		margin-top: 60px;
	}
	
	.taxonomy-area-fv__wrapper .choice_word{
		font-size: 16px;
	}
	
	.pan-taxonomy-area{
		margin-bottom: 0;
	}
	
	.pankuzu__bg__wrapper{
		position: relative;
		padding-top: 5px;
	}
	
	.pankuzu__bg--absolute{
		position: absolute;
		inset: 0;
		width: 119vw;
		height: 280px;
		z-index: 0;
		overflow: hidden;
	}
	
	.pankuzu__bg--absolute img{
		width: 100%;
		height: 100%;
		display: block;
		object-fit: cover;
	}
	
	.pankuzu-area{
		position: relative;
		z-index: 1;
		color: white;
	}
	
	.pankuzu-area li a{
		color: white;
	}
	
	.pan-taxonomy-area li:after{
		color: white;
	}
	
	.taxonomy-area__name{
		display: inline-flex;
		flex-direction: column;
		margin-top: 40px;
	}
	
	.area__title{
		font-size: 64px;
		min-height: 1em;
		display: inline-flex;
	}
	
	.taxonomy-area__name span{
		font-size: 20px;
	}
	
	.taxonomy-area__image--box{
		display: flex;
		align-items: center;
		flex-direction: column-reverse;
		margin-top: 20px;
		position: relative;
		gap: 30px;
	}
	
	.taxonomy-area__image img{
		width: 100%;
		height: auto;
		display: block;
	}
	
	.taxonomy-area__image--text{
		line-height: 2;
	}
	
	.area-contents__bg{
		margin-top: 50px;
		background-color: white;
		padding: 50px 0;
	}
	
	.area-contents__title {
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  color: #4B2B14; /* 茶色系。お好みで変更OK */
  position: relative;
  letter-spacing: 0.05em;
  /*text-transform: uppercase;  念のため大文字を保証 */
}

.area-contents__title::after {
  content: "";
  display: block;
  width: 50px;
  height: 10px;
  background-color: #00C3C5;
  margin: 30px auto 50px;
  border-radius: 0;
}
	
	.post_text_title__taxonomy-area{
		display: inline-block;
		height: 50px;
	}
	
	.taxonomy-other-area__wrapper{
		padding: 10px 16px;
	}
	
	.taxonomy-other-area__titlebox{
		display: flex;
		align-items: center;
		gap: 15px;
		font-weight: bold;
		margin-bottom: 20px;
	}
	
	.taxonomy-other-area__content{
		display: flex;
		gap: 10px;
		flex-wrap: wrap;
	}
	
	.taxonomy-other-area__content > div{
		font-size: 12px;
		padding: 8px;
		font-weight: bold;
	}
	
	.taxonomy-other-area__content .search_area_tumon,.taxonomy-other-area__content .search_area_agat{
		width: 130px;
	}
	
	.pageNav--area span.current{
		background:#F3C8FF;
	}
	
	.archive_top_title__search{
		margin: 10px 0 30px;
		background-color: white;
		border-radius: 15px;
	}
	
	.archive_top_title__search .choice_title{
		padding: 10px 15px;
	}
	
	.archive_top_title__search .choice_title h3{
		font-size: 24px;
	}
	
	.archive_contents_wrapper--search{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		column-gap: 15px;
		row-gap: 30px;
	}
	
	.post_day--search{
		margin-bottom: 0;
	}
	
	.pageNav--search{
		margin-top: 50px;
	}
	
	.pageNav--search span.current{
		background: #FBE673;
	}
	
	.serach--down--space{
		margin: 100px auto 50px;
	}
	
	.serach--down--space .search1{
		justify-content: center;
	}
	
	
	/*===========================
		会社概要以下
	=============================*/
	
	/* ===== セクション全体 ===== */
.company-section {
  background: #F4F1EC;          /* 背景色 */
  padding: 26px 0;              /* 上下余白 */
}

/* ラッパー：左見出し + 右カードの2カラム */
.company-wrap {
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  gap: 30px;
  align-items: flex-start;
	flex-direction: column;
  padding: 0 24px;               /* サイド余白 */
}

/* ===== 左見出し ===== */
.company-heading {
  color: #4B2B14;               /* 茶色 */
  letter-spacing: 0.06em;
  font-size: 36px;
  line-height: 1.2;
  position: relative;
  margin: 4px 0 0;
  padding-left: 4px;
}
.company-heading::after {
  content: "";
  display: inline-block;
  width: 28px;                  /* 見本の小さなライン */
  height: 4px;
  background: #00C3C5;          /* 青緑ライン */
  margin-left: 12px;
  vertical-align: middle;
  transform: translateY(-2px);
}

/* ===== 右カード本体 ===== */
.company-card {
  color: #3B2E24;               /* 本文色 */
}

/* ロゴ */
.company-logo {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
	/*transform: translateX(150px);*/
}
.company-logo img {
  display: block;
  max-width: 320px;             /* ロゴ横幅の上限 */
  width: 100%;
  height: auto;
}

/* キャッチコピー */
.company-copy {
  margin-bottom: 18px;
	transform: translateX(13px);
}
.company-copy .catch-ja {
  font-weight: 700;
  color: #4B2B14;
  margin: 0 0 2px;
}
.company-copy .catch-en {
  letter-spacing: 0.06em;
  color: #8C7E71;
  margin: 0;
}

/* 会社情報テーブル（DL） */
.company-table {
  margin: 12px 0 0;
}
.company-table .row {
  display: grid;
  grid-template-columns: 140px 1fr; /* 見出し / 値 */
  gap: 20px;
  padding: 14px 0;
  border-bottom: 1px solid #8FE7CC;
}

	
.company-table dt {
  color: #00C3C5;               /* ラベル色 */
  font-weight: 700;
  white-space: nowrap;
	text-align: right;
	width: 80%;
}
.company-table dd {
  margin: 0;
  line-height: 1.9;
}
	
	.company-wrap__naiyou{
		margin-bottom: 100px;
	}

/* リンク */
.company-table a {
  color: #3B2E24;
  text-decoration: underline;
  text-underline-offset: 2px;
}
	
	/*.company-wrap__naiyou{
		margin-top: 105px;
		margin-bottom: 150px;
	}*/
	
	.naiyou__text{
		font-size: 16px;
	}
	
	
	.terms-page { background:#F4F1EC; padding:48px 0 64px; }
.terms-page__inner { max-width: 980px; margin: 0 auto; /*padding: 0 24px;*/ }


/* ページタイトル */
.terms-page__title {
	color:#4B2B14; 
	font-weight:800; 
	font-size: 30px; 
	margin: 4px 0 28px; 
	position:relative; 
	display: flex;
	flex-direction: column;
	}
.terms-page__title:after {
	content:""; 
	display:inline-block; 
	width:40px; 
	height:4px; 
	background:#00C3C5; 
	vertical-align:middle; 
	transform: translateY(20px); 
	}


/* 本文ラッパ（ここに文章を入れる指定） */
.terms-page__wrapper { /*padding: 28px;*/}


/* 本文体裁 */
.terms-page__wrapper h2 { font-size:18px; margin: 24px 0 8px; color:#4B2B14; padding-top:8px; position:relative; }
.terms-page__wrapper p { line-height:1.9; margin: 0 0 16px; color:#3B2E24;}
.terms-page__wrapper ul, .terms-page__wrapper ol {  margin: 0 0 16px; }
.terms-page__wrapper li { margin: 4px 0; 
	padding-left: 1em;
	text-indent: -1em;
	font-weight: normal;
	}
.terms-page__revised { margin-top: 24px; color:#6b5b4c;}
}



/* ===================================
   共通設定（Tablet: min-width 601px / max-width 1024px）
=================================== */

@media screen and (min-width: 768px) and (max-width: 1024px) {

  .max-width{
		max-width: 1180px;
		margin: 0 auto;
	  padding: 0 16px;
	}
	
	.new-post__sp{
		display: none;
	}
	
	
	.footer--sp,.footer--sp__fixed{
		display: none;
	}
	

  /* ---------- Header ---------- */
  .fv_sp { display: none; }

  .header_wrapper {
    position: fixed;
    width: 100vw;
    background-color: #FBE673;
    z-index: 1000;
  }

  .header_inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
	  max-width: 1180px;
	  margin: 0 auto;
	  padding: 0 15px;
  }

  .logo { padding: 0 30px; }
  .logo img { display: inline-block; width: 20vw; }

  .header_search_wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
	  padding: 5px 0;
	  gap: 32px;
  }

  .header_search {
    display: flex;
    align-items: center;
    border: solid 1px #DB4813;
	  border-radius: 35px;
	  background-color: white;
    padding: 12px 9px;
    gap: 15px;
	  width: 200px;
	  justify-content: center;
  }

  .header_search a,
  .search_shop a,
  .search_keyword a {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 25px;
    font-weight: 400;
	  width: 100%;
	  justify-content: center;
  }
	
	.search_shop a{
		color: #FFA641
	}
	
	.search_keyword a{
		color: #FEA9C3;
	}

  .search_txt { color: #DB4813; }
  .search_icon { 
	  border-right: 1px solid #fff; 
	  padding-top: 10px; 
	}
  .search_icon img { 
	  width: 29px;
	  height: 29px;
	}

  /* ---------- TOP ---------- */
  /*#top { padding-top: 80px !important; }*/
	
	.topMainTitle{
		padding: 0 8%;
	}
	
	.topMainTitle img{
		width: 100%;
		height: auto;
	}

  .top-wrapperNew {
  background-image: url("../img/main-fv-ad.jpg"); /* 画像パス */
  background-size: cover;               /* 縦横比を保って全画面にフィット */
  background-position: center;          /* 中央配置 */
  background-repeat: no-repeat;
  width: 100%;
  height: 86vh;                        /* 画面の高さと同じ */
  display: flex;                        /* 中央寄せ用 */
  justify-content: center;              /* 横方向中央 */
  color: #fff;                          /* テキストを見やすく白に */
  text-align: center;
}
	.topSubTitle{
		margin-top: 70px;
		margin-bottom: 30px;
		color: #FBE673;
		background-color: #DB4813;
		border-radius: 24px;
		display: inline-flex;
		justify-content: center;
		width: 506px;
		padding: 12px 100px;
		font-size: 24px;
		font-weight: bold;
	}
	
	/* ===== 検索フォームエリア ===== */
.topSearch form.hero-search {
  width: min(820px, 92vw);
  height: 56px;
  display: flex;
  align-items: center;
  gap: 12px;

  margin: 70px auto 0; /* 上に余白をあける */
  padding: 0 16px 0 12px;
  border-radius: 9999px;

  /* ガラス風の背景 */
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.35);
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.topSearch form.hero-search:focus-within {
  outline: 2px solid rgba(255,255,255,0.7);
  outline-offset: 2px;
}

/* ===== 虫眼鏡アイコンボタン ===== */
.topSearch .hero-search__icon {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  flex: 0 0 40px;

  border: transparent;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}
.topSearch .hero-search__icon img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

/* ===== 入力フィールド ===== */
.topSearch .hero-search__field {
  flex: 1 1 auto;
  height: 100%;
  border: none;
  background: transparent;
  color: #fff;
  font-size: clamp(14px, 2.3vw, 16px);
  letter-spacing: 0.02em;
}
.topSearch .hero-search__field::placeholder {
  color: rgba(255,255,255,0.85);
}
.topSearch .hero-search__field:focus {
  outline: none;
}
	
	.topPlugin{
		margin-top: 50px;
		padding: 0 8%;
	}
	
	#splw-location-weather-12394.splw-main-wrapper{
		margin-left: 0!important;
	}
	
	.topUnderbar{
		margin-top: -4px;
	}
	
/* ===== キービジュアル ===== */
.kv {
  --kv-max: 1100px;
  position: relative;
  padding: 20px 16px 40px;
  background-color: #F4F3EE;
	margin-top: -10px;
}

.kv__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  align-items: center;
  gap: clamp(24px, 5vw, 64px);
  max-width: var(--kv-max);
  margin: 0 auto;
}

/* 左テキスト */
.kv__eyebrow {
  color: #0abdc6;
  font-size: clamp(12px, 1.8vw, 14px);
  line-height: 1.5;
  margin: 0 0 10px;
}

.kv__headline {
  font-size: 36px;
  line-height: 1.2;
  letter-spacing: .02em;
  margin: 0 0 16px;
}

/* ▼▼ ここから “帯アニメ” 用の修正 ▼▼ */
/* 行ラッパー（帯の器） */
.kv__headline .bgextend{
  display: inline-block;
  margin-bottom: 10px;
  overflow: hidden;
  position: relative;
  opacity: 0;                /* 初期は非表示（IOで is-inview を付与） */
}

/* 文字本体：固定背景は消す／帯より前面に */
.kv__headline .hl{
  background: none;          /* ←固定ピンク背景を無効化 */
  position: relative;
  z-index: 1;
  padding: .05em .25em;
  color: #3a1d00;
  line-height: 1.2;
}

/* 帯は .bgLRextend が付いたときに ::before を伸ばす */
.kv__headline .bgLRextend::before{
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  height: 1.1em;               /* 帯の厚み */
  background-color: #FEA9C3;   /* 帯色 */
  animation: bgLRextendAnime 1s forwards;
}

/* 文字の初期状態と発火 */
.bgappearTrigger{ opacity: 0; }
.bgextend.is-inview{ animation: bgextendAnimeBase 1s forwards; }
.bgappearTrigger.bgappear{ animation: bgextendAnimeSecond 1s .6s forwards; }

/* キーフレーム（必要なら） */
@keyframes bgextendAnimeBase { from{opacity:0;} to{opacity:1;} }
@keyframes bgextendAnimeSecond { from{opacity:0;} to{opacity:1;} }
@keyframes bgLRextendAnime{
  0%   { transform-origin:left;  transform: translateY(-50%) scaleX(0); }
  80%  { transform-origin:left;  transform: translateY(-50%) scaleX(1.05); } /* 少しオーバー */
  100% { transform-origin:left;  transform: translateY(-50%) scaleX(1); }    /* 戻して落ち着く */
}
/* ▲▲ 帯アニメの修正 ここまで ▲▲ */

/* リード（左下に背景画像） */
.kv__lead {
  font-size: clamp(14px, 2vw, 16px);
  line-height: 1.9;
  color: #333;
  margin: 16px 0 0;
  background-image: url("../img/kvBgimage.png");
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: contain;
}

/* 右側のサムネイル画像 */
.kv__right img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 70vh;
  object-fit: contain;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.18));
}

/* グアム地形の固定（右寄せ基準） */
.kvGuam{
  position: absolute;
  left: calc(50% + (var(--kv-max) / 3));
  transform: translateX(-240px);
  top: -190px;
  right: auto;
  z-index: 3;
  pointer-events: none;
}
.kvGuam img{
  width: clamp(245px, 30vw, 500px);
  height: auto;
  display: block;
}


	
  .item-relative {
    position: relative;
    height: 50vh;
    overflow: hidden;
  }
  .item-relative img { width: 100%; height: 100%; object-fit: cover; }

  .plugin_absolute { position: absolute; top: 30%; left: 20%; }

  .top_title_wrapper { display: flex; flex-direction: column; align-items: center; justify-content: space-between; padding-right: 80px; }
  .top_txt   { color: #3AAA8A; font-size: 1.5vw; font-weight: 400; }
  .top_title { color: #DB4814; font-size: 4rem; text-align: center; font-weight: 600; margin: 20px 0; }
  .title_ocean, .title_guamu { font-size: 7rem; line-height: 1; }

  /* ---------- HeaderNav（検索/メニュー中身） ---------- */
  .headerNav_wrapper { height: 100%; }
  .headerNav_inner   { display: flex; justify-content: space-around; height: 100%; padding: 2%; }

  .headerNav_right {
    border-left: 3px solid #DB4813;
    padding-left: 2%;
    margin-bottom: 2%;
    width: 30%;
  }
	
	.headerNav_logo a{
		display: flex;
		justify-content: center;
	}

  .headerNav_logo a img { 
	  width: 200px; 
	  height: auto;
	}
	
	.headerNav_right_lib{
		color: #00C3C5;
	}

  .search_genre_title,
  .search_genre_title {
  width: 175px;
  height: 52px;
  margin: 20px 0;
  font-weight: 400;
  text-align: center;
  line-height: 52px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_genre.png")no-repeat center center;
  background-size: contain; /* 画像を枠内に収める */
  color: white; /* 文字色（必要なら調整） */
}
	
	.search_genre_icon_wrapper{
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 0 10px;
	}
	
	.search_genre_icon_list{
		display: flex;
		gap: 80px;
	}
	
	.search_genre_icon_header a{
		width: 60px;
		height: auto;
	}
	
	.search_genre_top_icon--div{
		display: flex;
		align-items: center;
		white-space: nowrap;
		gap: 10px;
		width: 60px;
		height: auto;
	}
	
	.search_genre_icon_header a img{
		width: 100%;
		height: auto;
		object-fit: cover;
	}

	.search_area_wrapper{
		display: flex;
		gap: 70px;
		margin: 30px 0;
		padding: 0 10px;
	}

  .search_area_title { 
	  width: 175px;
  height: 52px;
  font-weight: 400;
  text-align: center;
  line-height: 52px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_area.png")no-repeat center center;
  background-size: contain; /* 画像を枠内に収める */
  color: white; /* 文字色（必要なら調整） */
	}

  .search_shopkeyword { display: flex; gap: 40px; margin: 30px 0; padding: 0 10px;}

  .search_shop,
  .search_keyword {
    width: 100%;
    background: #fff;
    padding: 10px;
    border-radius: 10px;
  }

  .search_shop    { border: 2px solid #FFA641; }
  .search_keyword { border: 2px solid #FEA9C3; }

  .search_shop img, .search_keyword img { width: 24px; height: 24px; }

  .keyword_readmore a { display: flex; align-items: baseline; justify-content: flex-end; gap: 20px; }
  .shoplist_readmore a { margin-top: 10px; }
  .shoplist_readmore a p { color: #00C3C5; }

  .search_area_content { display: flex; flex-wrap: wrap; gap: 10px; width: 70%; }

  .search_area_tumon, .search_area_agat,
  .search_area_hagania, .search_area_merizo,
  .search_area_tarofofo, .search_area_inalahan {
    background-color: #F3C8FF;
    padding: 15px;
    border-radius: 50px;
    text-align: center;
  }
  .search_area_tumon, .search_area_agat { width: 150px; }
  .search_area_hagania, .search_area_merizo { width: 180px; }
  .search_area_tarofofo { width: 230px; }
  .search_area_inalahan { width: 210px; }

  .search_flee_wrapper { 
	  margin-top: 25px; 
	  display: flex;
	  align-items: center;
	  gap: 35px;
	  padding: 0 10px;
	}
  .search_flee_title   { 
	    width: 200px;
  height: 52px;
  font-weight: 400;
  text-align: center;
  line-height: 52px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_free.png")no-repeat center center;
	  padding: 0 10px;
  background-size: contain; /* 画像を枠内に収める */
	}

  .search1 { display: flex; align-items: center; gap: 10px; }
  .search_flee_icon { background-color: #FBE673; padding: 5px 10px; box-sizing: border-box; border-radius: 10px; width: 70px; display: flex; justify-content: center; }
  .search_image { width: 30px; height: 30px; }
  .search-text { width: 40vw; padding: 5px; border-radius: 13px; border: 2px solid #FBE673; }

  .headerNav_menu { 
	  height: 100%; display: grid;
	  margin-top: 30px;
	}
  .headerNav_menu_list { 
	  max-width: 400px;
	}
	.headerNav_menu_list ul{
		display: flex;
		flex-direction: column;
		align-items: flex-end;
	}
	.sns_link_wrapper{
		max-width: 400px;
		margin: 40px 0;
	}
	.headerNav_left{
		max-width: 868px;
		margin: 0 auto;
	}
	
  .headerNav_menu_list li { list-style: none; margin-bottom: 10px;  text-align: right;}
/* liの枠組み */
.headerNav_menu_list li {
  list-style: none;
  margin-bottom: 20px;

  display: inline-flex;       /* 中身にフィットさせる */
  flex-direction: column;     /* 縦並び */
  align-items: flex-end;      /* 右端を基準に揃える */
  width: max-content;
}

/* 日本語ラベル */
.headerNav_right_lib {
  margin: 0 0 6px 0;
  font-size: 14px;
  line-height: 1;
  color: #00C3C5;
}

/* 英字リンク */
.headerNav_right_link {
  position: relative;
  display: inline-block;
  font-size: 24px;
  line-height: 1.3;
  text-decoration: none; /* デフォルトの下線は消す */
  color: #3a1d00;        /* 好きな文字色に */
  white-space: nowrap;   /* 改行させない */
	padding-right: 0.5em;
	font-weight: 700;
}

/* afterで下線を描画 */
.headerNav_right_link::after {
  content: "";
  position: absolute;
  right: 0;                /* 日本語の右端と揃える */
  bottom: -6px;            /* 文字との距離 */
  width: 100%;             /* 文字幅に合わせたいなら100% */
  height: 2px;
  background-color: #00C3C5;
}


  .sns_link_up { 
	  display: flex; 
	  gap: 20px; 
	  margin-bottom: 30px; 
	  justify-content: flex-end;
	}
	.sns_link_down{
		text-align: right;
	}
  .sns_link_down a, .sns_link_q a { color: #462408; border-bottom: 1px solid #462408; font-weight: normal; }
  .sns_link_down a { font-size: 15px; }
	
	 /* ---------- SLIDE UNDER IMAGE---------- */
	/*.under-slide{
		width: 100vw;
		height: auto;
	}
	
	.under-slide img{
		width: 100%;
		height: auto;
	}*/
	
	.infinity-slide {
  width: 100vw;
  height: 100px;
  overflow: hidden;
  position: relative;
		border-bottom: solid 2px #462408;
}

.infinity-track {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 40px;
  white-space: nowrap;

  animation: infinityScroll 15s linear infinite;
}

.banner {
  font-size: 48px;
  white-space: nowrap;
  padding: 0 40px;
  display: flex;
  align-items: center;
  border-radius: 6px;
  text-decoration: none;
	font-weight: 600!important;
}

/* 無限スクロールのキーフレーム */
@keyframes infinityScroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}




	
	.banner:hover{
		opacity: 0.6;
	}

/* ========== NEW POST / SHOP INFO (CSS, keep .newpost_contents_tag as-is) ========== */
	
	.newpost_wrapper{
		background-color: #F4F3EE;
		margin-top: -10px;
	}

/* ラッパー */
.newpost_inner{
  display: grid;
  grid-template-columns: 30% 1fr;   /* 左固定・右可変 */
  gap: 28px;
  align-items: start;
  margin: 0 auto;
	padding: 80px 16px 0;
}

/* --- 左カラム（吹き出し / 見出し / ボタン） --- */
.newpost-titleWrap{ position: relative; }
.newpost_fukidashi, .Fukidashi{ display: block; margin-bottom: 25px; text-align: center;}

/* 見出し（画像見出しをそのまま使用） */
.newpost_title, .Title{ margin: 0 0 10px; text-align: center; font-size: 36px; font-weight: 400}
.newpost_title img, .Title img{ height: auto; display: block; }
.newpost_title::after,.Title::after {
  content: "";
  display: block;
  width: 46px;
  height: 6px;
  background: #2cd5c4;
  margin: 20px auto 0;   /* ← auto で左右中央寄せ */
}

/* 一覧ボタン（ミントのピル / 左寄せ） */
.newpost_more{ width:auto; margin:15px 0 0; padding:0; background:transparent; text-align:center; border-radius:0; }
.newpost_more a{
  display:inline-block; padding:10px 50px; border-radius:999px;
  background:#2cd5c4; color:#fff; font-weight:700; text-decoration:none;
  box-shadow:0 2px 0 #15b7a8;
}
.newpost_more a:hover{ opacity:.9; }

/* --- 右カラム：横並びカード --- */
.np-card{
  position:relative;
  background:#fff;
  border:1px solid #E8F6F5;          /* 淡いミント枠 */
  border-radius:12px;
  overflow:hidden;
  margin-bottom: 14px;
	box-shadow: 4px 4px 0 #2cd5c4;
}


.np-link{
  display:flex; align-items:center; gap:14px;
  padding:12px; text-decoration:none;
}

/* サムネイル */
.np-thumb{
  flex:0 0 150px;                     /* 画像の横幅 */
  aspect-ratio:16/9;
  border-radius:10px; overflow:hidden;
}
.np-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.np-noimg{
  display:grid; place-items:center; width:100%; height:100%;
  background:#f2f5f5; color:#8aa; font-size:12px;
}

/* テキスト側 */
.np-body{ flex:1 1 auto; min-width:0; }
.np-meta{ display:flex; align-items:center; gap:30px; margin:2px 0 6px; }
.np-date{ font-size:12px; color:#7f8a8a; letter-spacing:.02em; }

/* ※カテゴリ表示は newpost_contents_tag をそのまま利用（ここでは触らない） */
/* もし日付の横に余白が欲しければ、ラッパーだけ軽く整える（見た目は変えない） */
.newpost_contents_title_wrap{ display:flex; align-items:center; gap:8px; }

/* タイトル（2行で省略） */
.np-title{
  margin:0;
  font-size:14px; line-height:1.6; color:#333; font-weight:700;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}

/* ふるまい */
.np-card:hover{ border-color:#c6efea; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.np-link:hover .np-title{ text-decoration:underline; }
	
	/* 吹き出しのアニメーション復活 */
  .newpost_fukidashi img { animation: tiltStepAnimation 2s infinite steps(1); width: 100%;}
	
	.stepAnimation{ animation: tiltStepAnimation 2s infinite steps(1); }




  /* ---------- Banner ---------- */
  .baner_wrapper {
    width: 60%;
    margin: 150px auto 60px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    justify-items: center;
  }
  .baner { width: 290px; }
  .baner img { width: 100%; height: 80px; object-fit: contain; }

/* ---------- Shop Ranking---------- */
.shop_ranking_wrapper { background:#fff; padding: 45px 0 70px;}
.shop_ranking_title, .shop_ranking_sub { text-align: center; }
.shop_ranking_title { color:#DB4813; font-size:6rem; line-height:1; display:flex; justify-content:center; }
	
	.shop_ranking_wrapper .Fukidashi img{
		width: 416px;
		height: auto;
	}

/* 横スクロール (そのまま) */
.shop_ranking_contents{
  display:flex;
  overflow-x:auto;
  white-space:nowrap;
  gap:18px;
  margin-top:50px;
  --maxw: 1180px;
  --side: max( (100vw - var(--maxw)) / 2, 16px );
  padding-left: var(--side);
  padding-right: var(--side);
}
	
.shop_ranking_inner{ display:flex; gap:18px; }



/* カード本体 */
.rank_img{
  flex:0 0 auto;
  width:23vw;                /* PC：4枚並び想定のまま */
  max-width:360px;           /* はみ出し防止 */
  min-width:260px;           /* 小さすぎ防止 */
  display:flex;
  flex-direction:column;
  align-items:stretch;
  background:#fff;
  padding:12px;
  scroll-snap-align:start;
}
.rank_img .img-link{
  display:block;
  position:relative;         /* ← バッジ配置の基準 */
  color:inherit;
  text-decoration:none;
}

/* サムネイル領域（角丸 + 比率固定） */
.rank_photo{
  position: relative;
  /*aspect-ratio: 4 / 3;*/
  overflow: hidden;
  border-radius: 16px;
}
.rank_photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;     /* ←はみ出しをカットして全体に収める */
  display: block;
}

/* 左上の順位バッジ（ユーザー準備のPNG） */
.number{
  position: absolute;
  top: -20px;   /* 画像枠の上から10px */
  left: 0;  /* 画像枠の左から10px */
  z-index: 2;
}
	
	.number_kemushi{
		position: absolute;
  top: -15px;   /* 画像枠の上から10px */
  left: 10px;  /* 画像枠の左から10px */
  z-index: 2;
	}
	
.number img{
  width:90px;
  height:auto;
  display:block;
}

/* テキストブロック */
.rank_text_wrap{ margin-top:12px; }

/* カテゴリのピル（taxonomy: main_category） */
.rank_postsub{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}


/* タイトル（2行で省略） */
.rank_text{
  margin-top:8px;
  color:#462408;
}
.rank_text p{
  margin:0;
  font-weight:700;
  line-height:1.6;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
	
	.rank_text_sub{
		margin-top: 15px;
		font-size: 14px;
	}


  /* ---------- Recommend ---------- */
  .shop_recommend_title, .shop_recommend_sub { text-align: center; }
  .shop_recommend_title { color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
	
	.shop_recommend_wrapper{
		padding: 50px 0 0;
	}

  .shop_recommend_contents {
    margin: 50px 0;
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 20px;
    justify-items: center;
    padding: 0 16px;
  }

  .newpost_shop { width: 100%; }
  .post_img_shop { width: 100%; height: 250px; margin-bottom: 10px; }
	.post_img_shop img{
		border-radius: 15px;
	}
  .post_text_t { text-align: left; font-size: 16px; line-height: 20px; color: #462408; font-weight: 700; height: 40px;}
  .post_text   { text-align: left; padding: 5px 0; font-size: 14px; line-height: 20px; color: #462408; }
  .post_sub_shop { margin-bottom: 14px; }
	.shop_recommend_contents .post_text_t p{
		font-weight: bold!important;
	}

	/* 画像枠：比率を固定して基準化 */
.post_img_shop{
  position: relative;        /* ← バッジの基準 */
  overflow: visible;
  border-radius: 16px;
  background: #f4f4f4;
}

/* メイン画像をきれいにフィット */
.post_img_shop > img:first-child{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* 左上バッジ（少し角から被せる演出） */
.post_img_shop .post-badge{
  position: absolute;
  top: 12px;
  left: 12px;
  transform: translate(-6px, -6px); /* 角から“ちょい被せ”。不要なら削除 */
  z-index: 2;
  width: clamp(52px, 7vw, 72px);    /* 固定幅にしたい場合は 64px などに */
  height: auto;
  pointer-events: none;             /* クリックを邪魔しない */
}
	
	/* 初期状態：非表示 & 縮小 */
.post_img_shop .post-badge {
  position: absolute;
  top: -8px;
  left: 0;
  width: clamp(52px, 7vw, 72px);
  height: auto;
  opacity: 0;
  transform: scale(0.5);
  transition: opacity 0.6s ease, transform 0.6s ease;
  pointer-events: none;
  z-index: 2;
}

/* 表示状態（クラス追加時） */
.post_img_shop .post-badge.is-inview {
  opacity: 1;
  transform: scale(1);
}
	
/* フェードアウト（自然に消えるだけ） */
.post_img_shop .post-badge.is-out {
  opacity: 0;
  transform: scale(1); /* ← 縮小しない、サイズは維持 */
  transition: opacity 0.8s ease; /* 少し長めで“シュッ” */
}

/* ========== クイック系アニメ ========== */
/* 方向は CSS変数 --dir（1 or -1）で左右／回転方向を切り替えます */

@keyframes badge-sway-quick-kf {
  0%,100% { transform: translateX(0) scale(1); }
  50%     { transform: translateX(calc(var(--dir, 1) * var(--ampX, 14px))) scale(1); }
}
.badge-sway-quick {
  animation-name: badge-sway-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1); /* キビキビ */
}

/* 素早い首振り（回転） */
@keyframes badge-tilt-quick-kf {
  0%,100% { transform: rotate(0deg) scale(1); }
  50%     { transform: rotate(calc(var(--dir, 1) * var(--ampR, 12deg))) scale(1); }
}
.badge-tilt-quick {
  animation-name: badge-tilt-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1);
}

/* 合成（左右揺れ＋首振り）※1つのキーフレームでまとめて transform を管理 */
@keyframes badge-sway-tilt-quick-kf {
  0%,100% { transform: translateX(0) rotate(0deg) scale(1); }
  50%     { transform:
              translateX(calc(var(--dir, 1) * var(--ampX, 12px)))
              rotate(calc(var(--dir, 1) * var(--ampR, 10deg)))
              scale(1);
  }
}
.badge-sway-tilt-quick {
  animation-name: badge-sway-tilt-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1);
}

/* 省エネ設定に配慮 */
@media (prefers-reduced-motion: reduce){
  .badge-sway-quick,.badge-tilt-quick,.badge-sway-tilt-quick{
    animation: none !important;
    transform: none !important;
  }
}

	
  /* ---------- Search Page ---------- */
  .search_wrapper_top {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: 80px 16px 240px;
  background: url("../img/searchBG.png") top center / 100% 98% no-repeat;
}
  .search_inner_top  { padding-bottom: 50px; }

  .search_title, .search_sub { text-align: center; }
  .search_title { padding: 20px 0; color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
  .search_sub   { color: #462408; font-weight: 400; }
	
	.search_title--top{
		margin-bottom: 20px;
	}

  .search_contents_wrap {
    background: #fff;
    border: 1px solid #DB4813;
    border-radius: 10px;
    padding: 40px;
  }

  .search_txt_m { margin-bottom: 20px; font-size: 2.5rem; color: #462408; font-weight: 400; }
  .search_genre_contents { display: flex; align-items: flex-end; justify-content: space-between; width: 100%; margin-top: 50px; }
  .search_genre_m_a { display: flex; flex-direction: column; align-items: center; justify-content: center; }
  .search_genre_m_a img { margin-bottom: 30px; width: 90%; }

  .search_shop_m { margin: 90px 0; }
  .search_keyword_m { margin-bottom: 20px; }
  .search_keyword_m_contents_wrap { display: inline-block; }
  .search_keyword_m_contents_wrap a { width: 150px; background: #E00E65; color: #fff; }

  .search_area_m { margin: 50px 0 70px; }
	
	.search_genre_icon_wrapper--top{
		gap: 20px;
		justify-content: flex-start;
	}

  /* ---------- Movie ---------- */
  .movie_wrapper { margin: 5% 0; }
  .movie_title, .movie_sub { text-align: center; }
  .movie_title { color: #DB4813; font-size: 7rem; line-height: 1; display: flex; justify-content: center; }
  .movie_sub   { color: #9ECF21; text-align: left;}

  .movie_contents { margin-top: 50px; width: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; }
  .video-gallery { width: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; }
  .video-item    { position: relative; width: 70%; padding-bottom: 35%; height: 0; overflow: hidden; border-radius: 25px; }
  .movie_h3      { font-size: 12px; font-weight: 400; color: #9ECF21; text-align: left; width: 70%; margin-bottom: 10px; }
  .video-item iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }

  /* ---------- Instagram ---------- */
  .instagram_wrapper { margin: 40px; }
  .insta_title { color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
  .insta_sub   { color: #9ECF21; }

  .sns_link_wrapper_foot { display: flex; justify-content: center; gap: 30px; margin: 40px 0; }
  .sns_link_down_foot { font-weight: bold; color: #000; padding-top: 10px; }

/* ===== Footer ===== */
.site-footer{
  background:#FBE673; /* スクショの黄色 */
  color:#462408;
}

.footer__wrap{
  width:100%;
  padding:48px 16px 28px;
}

.footer__inner{
  margin:0 auto;
	display: flex;
	justify-content: space-between;
}

.footer__head{
  display:flex;
  flex-direction: column;
  margin-bottom:24px;
}

.footer__brand{
  display:flex;
  align-items:flex-start;
	flex-direction: column;
  gap:50px;
}
	
	.footer__links_sk li a{
		font-weight: 700!important;
	}
	
	.footer-sub-stick{
		display: inline-block;
		margin-right: 5px;
		font-weight: 700;
	}

.footer__logo img{
  height:36px; /* ロゴサイズは調整 */
  width:auto;
  display:block;
}

.footer__sns{
  display:flex;
  gap:12px;
}
.footer__sns img{
  width:24px; height:24px; display:block;
}

/* 中段グリッド */
.footer__grid{
  display:flex;
	flex-direction: row;
  margin:16px 0 28px;
	gap: 10px;
}

.footer__heading{
  font-weight:700;
  margin:4px 0 8px;
  letter-spacing:.03em;
	color: #DB4813;
}

.footer__subttl{
  font-size:14px;
  margin:8px 0 6px;
	color: #DB4813;
	font-weight: 700;
}

.footer__links{
  display:flex;
	flex-direction: column;
	gap: 20px;
}
.footer__links a{
  color:#DB4813;
  text-decoration:none;
  position:relative;
	font-weight: 700;
	padding-left: 1em;
	font-size: 14px;
}
	
	.footer__subgroup ul li a{
		font-weight: 400;
	}
	
.footer__links a:hover{ text-decoration:underline; }

	
	.footer__right_group{
		display: flex;
		gap: 15px;
	}
	
/* 下段 */
.footer__foot{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-top:16px;
}

.footer__legal{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
	text-align: left
}
.footer__legal a{ color:#462408; text-decoration:none; font-size:16px;  font-weight: 700;}
.footer__legal a:hover{ text-decoration:underline; }

.footer__copy{
  color:#6b4b1f;
  font-size:12px;
  opacity:.85;
	display: flex;
	justify-content: center;
}


  /* ---------- Archive / Lists ---------- */
  .archive_post_contents { display: flex; flex-direction: column; justify-content: space-between; padding: 10px; box-sizing: border-box; height: 100%; }
	.archive_newpost_contents_wrap{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		grid-row-gap: 30px;
		grid-column-gap: 40px;
		margin-top: 50px;
		padding: 0 16px;
	}
	
	.archivepost_img_shop{
		height: 240px;
	}
	
	.np-link-archive{
		display: flex;
        align-items: flex-start;
        gap: 15px;
         padding: unset!important;
        text-decoration: none;
	}
	
	.np-thumb-archive{
		flex: 0 1 auto!important;
        aspect-ratio: auto!important;
        border-radius: 10px;
        overflow: visible!important;
	}
	
	.np-thumb-archive img{
		width: 180px;
        height: 135px;
         display: unset!important;
		border-radius: 10px;
	}
	
	.np-card-archive{
		position: relative;
         background: unset!important; 
        border: 1px solid #E8F6F5;
        border-radius:0;
        overflow: hidden;
         margin: unset!important;
         box-shadow: unset!important;
	}
	
	.single-backBtn-an-title{
		margin-bottom: 30px;
		font-size: 28px;
	}
	
	.single-backBtn-an-title p{
		font-weight: 700;
	}
	
	.single-backBtn-an-title a{
		display: inline-block;
		margin-bottom: 20px;
	}

  .wp-pagenavi { display: flex; justify-content: center; margin-top: 100px; }

  .shoplist_contents_wrapper { margin-bottom: 100px; }

  .alphabet_nation_wrapper {
    width: 100%;
    padding: 20px 60px;
    border: 1px solid #FCBA6E;
    background: #fff;
    border-radius: 20px;
    margin: 60px 0 80px;
  }

  .alphabet_wrapper, .katakana_wrapper { display: flex; flex-wrap: wrap; gap: 4%; row-gap: 50px; justify-content: center}
	.katakana_wrapper{
		margin-top: 50px;
	}
  .alphabet_wrapper a, .katakana_wrapper a { color: #FCBA6E; font-weight: 400; border-bottom: 1px solid #FCBA6E; }
	
	.alphabet_nation_title {
  position: relative;
  font-weight: 700;
  color: #462408;
  text-align: center;
		margin-bottom: 50px;
}
	
	.alphabet_nation_title::after {
  content: "";
  display: block;
  width: 50px;
  height: 5px;
  background-color: #FCBA6E;
  margin: 6px auto 0; /* 上に少し余白を入れて中央寄せ */
  border-radius: 2px;
}
	
	.shoplist_section{
		color: #FCBA6E;
		font-size: 40px;
		font-weight: bold;
	}

  .post-grid  { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
	.rank_text_sub--shoplist{
		margin-top: 5px;
	}
  .post-flex  { display: flex; flex-wrap: wrap; gap: 20px; }
  .post-flex > .newpost_shoplist,
  .post-grid > .newpost_shoplist { flex: 1 1 calc(33.33% - 20px); box-sizing: border-box; }
  .letter-heading { display: block; width: 100%; margin: 80px 0 40px;}
  .newpost_shoplist { padding: 10px; text-align: center; }

  .tagpost_wrapper { margin-top: 100px; }
  .tagpost_contents { display: grid; grid-template-columns: repeat(3,1fr); justify-items: center; }
  .tag_newpost_shop { width: 90%; margin: 0 3.5% 5%; }
	
	.archive_contents_wrapper_genre{
		display: grid;
		grid-template-columns: repeat(3,1fr);
		gap: 30px;
	}
	
	.max-width-archive{
		max-width: 1050px;
		margin: 0 auto;
	}
	
	.choice_word{
		display: flex;
		align-items: center;
		gap: 10px;
	}
	
	.other_genre_wrap{
		background-color: white;
		padding: 30px 50px;
		border-radius: 15px;
		margin-top: 15px;
		margin-bottom: 50px;
	}
	
	.archive-genre-font-size span{
		font-size: 24px!important;
	}
	
	.archive-genre-font-size img{
		width: 70px;
		height: auto;
		margin-right: 30px;
	}
	
	.archive-current-genre{
		margin-right: 100px;
	}
	
	.archive-genre-image_other{
		width: 35px!important;
		height: auto;
	}
	
	.post_text_title{
		font-size: 16px;
		font-weight: bold;
		height: 40px;
	}
	
	.page-nav-archive > div > .current{
		background-color: #8FE7CC!important;
	}

  /* ---------- Single Shop / Article ---------- */
  .article_body { background-color: #F4F3EE; padding-top: 90px;}
  /*.article_body p, .article_body h3 { color: #462408; }*/
	
	.post_day{
		display: flex;
		align-items: center;
		gap: 42px;
		margin-bottom: 30px;
	}
	
	.single_main{
		background-color: white;
		border-radius: 50px;
	}
	
	.single_mainTop{
		padding: 60px 50px 0;
	}
	
	.s_catch{
		max-width: 1000px;
		margin: 0 auto 60px;
	}
	
	.s_catch img{
		width: 100%;
		height: auto;
		box-shadow: 10px 10px 0 #2cd5c4;
		border-radius: 30px;
	}
	
	.forSingle-tag{
		padding: 10px 30px!important;
		font-weight: 700;
		font-size: 16px;
	}
	
	.entry-title{
		padding-bottom: 20px;
		font-size: 24px;
	}
	
	.shop_cta_row{
		display: flex;
		gap: 70px;
	}
	
	/* 画像枠は角丸＋はみ出し隠す（←ここがポイント） */
.s_catch {
  position: relative;
  border-radius: 24px;
  margin: 14px 0 24px;
  width: 100%;
}
.s_catch img { width: 100%; height: auto; display: block;  object-fit: cover;}
	
	.single-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}

.single-article__tag {
  display: inline-block;
  color: #462408;
  background-color: #FFBFD3;
  border-radius: 16px;
  padding: 8px 15px;
  font-size: 14px;
  line-height: 1.4;
  white-space: nowrap;
  text-decoration: none; /* リンク版でも下線を消す */
  transition: opacity 0.3s;
}

.single-article__tag:hover {
  opacity: 0.8;
}


/* エリアバッジの位置（左上） */
.area_pill_wrap {
  position: absolute;
  top: 0;             /* 画像の内側に少し余白 */
  left: 0;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* エリアバッジ本体：左は角丸なし／右だけ“ピル”形状に */
.area_pill {
  position: relative;
  display: inline-block;
  padding: 15px 25px;
  background: #F7CCFF;  /* 薄ピンク */
  color: #3a220d;       /* 濃いブラウン */
  font-weight: 700;
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
  border-radius: 0 0 25px 0; /* 上記12pxはお好みで調整OK */
}

/* 複数ラベル並び時の余白 */
.area_pill + .area_pill { margin-left: 6px; }
	
	.single-backBtn-an-title{
		margin-bottom: 20px;
	}
	
	.single_main_genrepage{
		background-color: unset;
	}
	
	.single_mainTop_genrepage{
		max-width: 1000px;
		padding-top: 0;
	}
	/* ===== SHOP CTA (「このSHOPの詳細を見る」「このSHOPのSNSをみる」) ===== */
	
	.shopbox_first_genrepage{
		display: flex;
		flex-direction: column-reverse;
	}
	
	.shop_article_img1_genrepage{
		width: 100%;
	}

/* ラッパー：必要なら背景色を付ける（任意） */
.shop_cta_area {
  margin: 40px 0 20px;
  background: #7fe0d0;           /* ←スクショのミント系。要らなければ削除OK */
  border-radius: 0 0 32px 32px;   /* 角丸（任意） */
  padding: 24px 28px 24px 56px;
}

/* 行 */
.shop_cta_row {
  display: flex;
  align-items: center;
  gap: 32px;
  padding: 18px 0;
  border-top: 1px solid rgba(0,0,0,0.08);
}
.shop_cta_row:first-child { border-top: none; }

/* 左側ラベル */
.shop_cta_label {
  flex: 0 0 220px;   /* ラベル幅。スクショっぽく左に固定 */
  color: #462408;
  font-size: 14px;
  letter-spacing: .05em;
  white-space: nowrap;
	font-weight: 700;
}

/* ===== 1行目：詳細ボタン ===== */
.shop_cta_button {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 12px 18px 12px 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 9999px;          /* ピル型 */
  box-shadow: 0 2px 0 rgba(0,0,0,.06);
  text-decoration: none;
  color: #462408;
  transition: transform .08s ease, box-shadow .08s ease;
}
.shop_cta_button:hover { transform: translateY(-1px); box-shadow: 0 4px 0 rgba(0,0,0,.06); }
.shop_cta_button:active { transform: translateY(0); box-shadow: 0 2px 0 rgba(0,0,0,.06); }

.shop_cta_button_text {
  font-size: 14px;
  line-height: 1;
  font-weight: 600;               /* 日本語側太字イメージ */
}

/* 右端の丸矢印 */
.shop_cta_button_icon {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  font-weight: 700;
  line-height: 1;
  padding-bottom: 1px; /* 矢印の上下バランス微調整 */
}

/* リンクなし時（disabled想定） */
.shop_cta_button.is-disabled {
  cursor: default;
  pointer-events: none;
	padding: 15px 30px;
	background-color: white;
}

/* ===== 2行目：SNSアイコンピル ===== */
.shop_cta_sns .shop_cta_sns_icons {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  padding: 10px 16px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 9999px;
  box-shadow: 0 2px 0 rgba(0,0,0,.06);
}
.shop_cta_sns .sns_icon img {
  width: 28px;
  height: 28px;
  display: block;
  transition: transform .15s ease;
}
.shop_cta_sns .sns_icon:hover img {
  transform: scale(1.06);
}
	
	.article_for_shopinfolink{
		max-width: 100%;
		margin: 0 auto 60px;
		display: flex;
		justify-content: center;
	}
	
	.article_for_shopinfolink a{
		color: white;
		background-color: #462408;
		padding: 20px 60px;
		border-radius: 65px;
	}


  .yw h4 { color: #00C3C5; }
  .day-cat-area { display: flex; gap: 2%; margin-bottom: 20px; border-bottom: none !important; }

  .shoptitle_article { border-bottom: 1px solid #DB4813; }
  .shoptitle_article h3 { color: #462408; }

  .sub_orange {
    color: #DB4813 !important;
    background: #fff;
    border: 1px solid #DB4813;
    border-radius: 10px;
    font-weight: bold;
  }

  .shopbox_first { display: flex; }
  .shop_article_img1  {  margin-right: 3%; }
  .shop_article_text1 {  padding: 20px 0; }
  .shop_article_text1 p { margin-top: 20px; }
	.shopbox_first img{
		width: 100%;
		height: auto;
		display: block;
	}

  .bk h4 { border-bottom: dotted 4px #00C3C5; font-size: 24px; display: inline-block;}

  .shopbox_photogallery { border-top: 2px solid #00C3C5; }
  .photogallery_article { display: grid; grid-template-columns: repeat(4,1fr); justify-items: center; }
  .shop_img_article_5 { width: 90%; height: auto; margin-top: 15px; }
  .shop_img_article_5 img { width: 100%; height: 100%; object-fit: cover; }

  .t_left p { color: #00C3C5; }

  .shopbox_information {
    background: #fff;
    padding: 0 30px;
	  border-radius: 0 30px 30px 30px;
  }
	
	.single__information{
  position: relative;
  background: #fff;
  padding: 15px 50px;
		width: 220px;
		border-top-left-radius: 30px;
		border-top-right-radius: 30px;
		
}
	
	.single__information--h4{
  color: #12B6C8;       /* 見出しもアクセント色に */
  font-weight: 800;
  font-size: 16px;
		padding-bottom: 0!important;
}

  .other_post { width: 100vw; background: #ECF1DD; }
  .other_post_inner { display: flex; flex-direction: column; align-items: center; padding: 40px 0 0; }

  .other_post_inner a {
    font-size: 2rem;
    padding: 20px 40px;
    display: inline-block;
    background: #9FCF24;
    margin-bottom: 50px;
    color: #fff;
  }

  .other_post_link { display: block; width: 15%; padding: 10px 20px; background: #DB4813; text-align: center; border-radius: 20px; }
  .other_post_link a { color: #fff; font-weight: bold; }

  .single_postbox_editied { width: 100vw; background: #ECF1DD; }
  .other { display: flex; justify-content: center; padding: 60px 0 0; }
  .other h4 { padding: 15px 40px; background: #9FCF24; margin-bottom: 60px; }
  .single_readmore_btn p { font-weight: bold; color: #fff; }

  .post_sub_edited { margin-top: 10px; }
  .post_cate_tag { margin-top: 10px; }
  .tag-frame { padding: 5px 10px; border-radius: 20px; color: #462408; font-size: 16px; background-color: #FFBFD3;}

  .post_info_inner strong { color: #DB4813; }

  .shop-info { box-sizing: border-box; }
  .shop-info p { margin: 10px 0; display: flex; align-items: center; }
  .shop-info-label { flex: 0 0 120px; font-weight: bold; margin-right: 20px; text-align: left; }

  .post_sns { margin-top: 20px; }
  .post_sns_icons { display: flex; gap: 20px; }
  .post_sns_icons img { width: 30px; height: 30px; transition: transform .3s; }
  .post_sns_icons img:hover { transform: scale(1.1); }

  .shop_info_readmore { font-size: 85%; }
  .shop_info_readmore a { color: #DB4813; border-bottom: 1px solid #DB4813; font-weight: bold; }

  .post-readmore_box { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-bottom: 40px; }
  .post_img_readmore { height: 50%; }

  /* ---------- Movie / Shorts extra ---------- */
  .video-item-archive { width: 60% !important; }
  .movie_h3_archive { width: 60% !important; margin-bottom: 40px; }
  .choice_word_movie { color: #DB4813 !important; }
  .youtube-short-item { width: 100%; }
  .choice_word_video { color: #DB4813 !important; }

  /* ---------- Misc ---------- */
  /*.max-width { padding: 7vh 9vw; }*/
  .top_info_wrapper { margin-top: 100px; }
  .archivepost_img_article { width: 100%; aspect-ratio: 1/1; height: auto; }
  .postarchive_post_text { padding-top: 0 !important; }
  .archivepost_sub_shop { margin: 10px 0; }
	.shoplist_cate{
		text-align: left;
	}
  .post_readmore { height: 65vh; }

  .tabs { display: flex; justify-content: center; background-color: #F4F3EE; }
  .tab_item { width: calc(100%/2) !important; display: flex !important; justify-content: center; align-items: center; line-height: 40px; }
  .tab_item a { display: block; width: 100%; height: 100%; text-align: center; padding-bottom: 2px; color: #DD4D34; }
  .tab_item a p { display: inline; border-bottom: 1px solid #fff; padding-bottom: 2px; color: #DD4D34; }
  input[name="tab_item"]:checked + .tab_item a p { color: #fff; }
  .eat { border: 3px solid #DD4D34; background: #fff; }

  .genre_icon_txt { display: flex; white-space: nowrap; width: 100%; justify-content: flex-start; gap: 30px;}
  .genre_icon_content { display: flex; align-items: center; gap: 1%; }
  .genre_icon_content a { display: flex; align-items: center; text-decoration: none; color: inherit; }
  .genre_icon_content img { margin-right: 5px; width: 4vw; }
  .genre_icon_content span { color: #462408; white-space: nowrap; font-size: 1.5rem; }

  .shoparticle_area_list { display: grid; grid-template-columns: repeat(3,1fr); justify-items: center; }
	
	.keywordlist_wrapper{
		margin: 110px auto 150px;
	}
	
	.keyword_contents_wrap{
		margin-top: 30px;
		padding: 30px 40px;
		border: solid 1px #FFBFD3;
		border-radius: 30px;
		background-color: white;
	}
	
	
	/*===========================
		エリアから探すページ
	=============================*/
	.taxonomy-area-fv__wrapper{
		margin-top: 80px;
	}
	
	.pankuzu__bg__wrapper{
		position: relative;
		padding-top: 20px;
	}
	
	.pankuzu__bg--absolute{
		position: absolute;
		inset: 0;
		width: 100vw;
		height: 280px;
		z-index: 0;
	}
	
	.pankuzu__bg--absolute img{
		width: 100%;
		height: 100%;
		display: block;
	}
	
	.pankuzu-area{
		position: relative;
		z-index: 1;
		color: white;
	}
	
	.pankuzu-area li a{
		color: white;
	}
	
	.pan-taxonomy-area li:after{
		color: white;
	}
	
	.taxonomy-area__name{
		display: inline-flex;
		flex-direction: column;
		margin-top: 60px;
	}
	
	.area__title{
		font-size: 64px;
		min-height: 1em;
		display: inline-flex;
	}
	
	.taxonomy-area__name span{
		font-size: 20px;
	}
	
	.taxonomy-area__image--box{
		display: flex;
		align-items: center;
		margin-top: 30px;
		position: relative;
	}
	
	.taxonomy-area__image img{
		width: 100%;
		height: auto;
		display: block;
	}
	
	.taxonomy-area__image--text{
		line-height: 2;
	}
	
	.area-contents__bg{
		margin-top: 50px;
		background-color: white;
		padding: 50px 0;
	}
	
	.area-contents__title {
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  color: #4B2B14; /* 茶色系。お好みで変更OK */
  position: relative;
  letter-spacing: 0.05em;
  /*text-transform: uppercase;  念のため大文字を保証 */
}

.area-contents__title::after {
  content: "";
  display: block;
  width: 50px;
  height: 10px;
  background-color: #00C3C5;
  margin: 30px auto 50px;
  border-radius: 0;
}
	
	.post_text_title__taxonomy-area{
		display: inline-block;
		height: 50px;
	}
	
	.taxonomy-other-area__wrapper{
		padding: 10px 16px;
	}
	
	.taxonomy-other-area__titlebox{
		display: flex;
		align-items: center;
		gap: 15px;
		font-weight: bold;
		margin-bottom: 20px;
	}
	
	.taxonomy-other-area__content{
		display: flex;
		gap: 10px;
		flex-wrap: wrap;
	}
	
	.taxonomy-other-area__content > div{
		font-size: 12px;
		padding: 8px;
		
	}
	
	.pageNav--area span.current{
		background:#F3C8FF;
	}
	
	.archive_top_title__search{
		margin: 50px 0;
		background-color: white;
		border-radius: 15px;
	}
	
	.archive_top_title__search .choice_title{
		padding: 20px 50px;
	}
	
	.archive_top_title__search .choice_title h3{
		font-size: 30px;
	}
	
	.archive_contents_wrapper--search{
		display: grid;
		grid-template-columns: repeat(3,1fr);
		column-gap: 50px;
		row-gap: 20px;
	}
	
	.post_day--search{
		margin-bottom: 0;
	}
	
	.pageNav--search{
		margin-top: 50px;
	}
	
	.pageNav--search span.current{
		background: #FBE673;
	}
	
	.serach--down--space{
		margin: 50px auto 100px;
	}
	
	.serach--down--space .search1{
		justify-content: center;
	}
	
	
	/*===========================
		会社概要以下
	=============================*/
	
	/* ===== セクション全体 ===== */
.company-section {
  background: #F4F1EC;          /* 背景色 */
  padding: 48px 0;              /* 上下余白 */
}

/* ラッパー：左見出し + 右カードの2カラム */
.company-wrap {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 180px 1fr; /* 左見出し / 右カード */
  gap: 50px;
  align-items: start;
  padding: 0 24px;               /* サイド余白 */
}

/* ===== 左見出し ===== */
.company-heading {
  color: #4B2B14;               /* 茶色 */
  font-weight: 800;
  letter-spacing: 0.06em;
  font-size: 22px;
  line-height: 1.2;
  position: relative;
  margin: 4px 0 0;
  padding-left: 4px;
}
.company-heading::after {
  content: "";
  display: inline-block;
  width: 28px;                  /* 見本の小さなライン */
  height: 4px;
  background: #00C3C5;          /* 青緑ライン */
  margin-left: 12px;
  vertical-align: middle;
  transform: translateY(-2px);
}

/* ===== 右カード本体 ===== */
.company-card {
  color: #3B2E24;               /* 本文色 */
}

/* ロゴ */
.company-logo {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
	transform: translateX(150px);
}
.company-logo img {
  display: block;
  max-width: 320px;             /* ロゴ横幅の上限 */
  width: 100%;
  height: auto;
}

/* キャッチコピー */
.company-copy {
  margin-bottom: 18px;
	transform: translateX(150px);
}
.company-copy .catch-ja {
  font-weight: 700;
  color: #4B2B14;
  margin: 0 0 2px;
}
.company-copy .catch-en {
  letter-spacing: 0.06em;
  color: #8C7E71;
  margin: 0;
}

/* 会社情報テーブル（DL） */
.company-table {
  margin: 12px 0 0;
}
.company-table .row {
  display: grid;
  grid-template-columns: 140px 1fr; /* 見出し / 値 */
  gap: 90px;
  padding: 14px 0;
  border-bottom: 1px solid #8FE7CC;
}

	
.company-table dt {
  color: #00C3C5;               /* ラベル色 */
  font-weight: 700;
  white-space: nowrap;
	text-align: right;
}
.company-table dd {
  margin: 0;
  line-height: 1.9;
}

/* リンク */
.company-table a {
  color: #3B2E24;
  text-decoration: underline;
  text-underline-offset: 2px;
}
	
	/*.company-wrap__naiyou{
		margin-top: 105px;
		margin-bottom: 150px;
	}*/
	
	.naiyou__text{
		font-size: 18px;
		font-weight: bold;
	}
	
	
	.terms-page { background:#F4F1EC; padding:48px 0 64px; }
.terms-page__inner { max-width: 980px; margin: 0 auto; padding: 0 24px; }


/* ページタイトル */
.terms-page__title {
	color:#4B2B14; 
	font-weight:800; 
	font-size: 30px; 
	margin: 4px 0 28px; 
	position:relative; 
	display: flex;
	flex-direction: column;
	}
.terms-page__title:after {
	content:""; 
	display:inline-block; 
	width:40px; 
	height:4px; 
	background:#00C3C5; 
	vertical-align:middle; 
	transform: translateY(20px); 
	}


/* 本文ラッパ（ここに文章を入れる指定） */
.terms-page__wrapper { padding: 28px;}


/* 本文体裁 */
.terms-page__wrapper h2 { font-size:18px; margin: 24px 0 8px; color:#4B2B14; padding-top:8px; position:relative; }
.terms-page__wrapper p { line-height:1.9; margin: 0 0 16px; color:#3B2E24;}
.terms-page__wrapper ul, .terms-page__wrapper ol {  margin: 0 0 16px; }
.terms-page__wrapper li { margin: 4px 0; 
	padding-left: 1em;
	text-indent: -1em;
	font-weight: normal;
	}
.terms-page__revised { margin-top: 24px; color:#6b5b4c;}
}



/* ===================================
   共通設定（PC: min-width 1025px）
=================================== */

@media screen and (min-width: 1025px) {
	.max-width{
		max-width: 1180px;
		margin: 0 auto;
	}
	
	.new-post__sp{
		display: none;
	}
	
	.footer--sp,.footer--sp__fixed{
		display: none;
	}
	
	

  /* ---------- Header ---------- */
  .fv_sp { display: none; }

  .header_wrapper {
    position: fixed;
    width: 100vw;
    background-color: #FBE673;
    z-index: 1000;
  }

  .header_inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
	  max-width: 1180px;
	  margin: 0 auto;
  }

  .logo { padding: 0 30px; }
  .logo img { display: inline-block; width: 9vw; }

  .header_search_wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
	  padding: 5px 0;
	  gap: 32px;
  }

  .header_search {
    display: flex;
    align-items: center;
    border: solid 1px #DB4813;
	  border-radius: 35px;
	  background-color: white;
    padding: 12px 9px;
    gap: 15px;
	  width: 200px;
	  justify-content: center;
  }

  .header_search a,
  .search_shop a,
  .search_keyword a {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 25px;
    font-weight: 400;
	  width: 100%;
	  justify-content: center;
  }
	
	.search_shop a{
		color: #FFA641
	}
	
	.search_keyword a{
		color: #FEA9C3;
	}

  .search_txt { color: #DB4813; }
  .search_icon { 
	  border-right: 1px solid #fff; 
	  padding-top: 10px; 
	}
  .search_icon img { 
	  width: 29px;
	  height: 29px;
	}

  /* ---------- TOP ---------- */
  #top { padding-top: 80px !important; }

  .top-wrapperNew {
  background-image: url("../img/main-fv-ad.jpg");
  background-size: cover;               /* 縦横比を保って全画面にフィット */
  background-position: center;          /* 中央配置 */
  background-repeat: no-repeat;
  width: 100%;
  height: 87vh;                        /* 画面の高さと同じ */
  display: flex;                        /* 中央寄せ用 */
  justify-content: center;              /* 横方向中央 */
  color: #fff;                          /* テキストを見やすく白に */
  text-align: center;
}
	.topSubTitle{
		margin-top: 70px;
		margin-bottom: 30px;
		color: #FBE673;
		background-color: #DB4813;
		border-radius: 24px;
		display: inline-flex;
		justify-content: center;
		width: 506px;
		padding: 12px 100px;
		font-size: 24px;
		font-weight: bold;
	}
	
	/* ===== 検索フォームエリア ===== */
.topSearch form.hero-search {
  width: min(820px, 92vw);
  height: 56px;
  display: flex;
  align-items: center;
  gap: 12px;

  margin: 30px auto 0; /* 上に余白をあける */
  padding: 0 16px 0 12px;
  border-radius: 9999px;

  /* ガラス風の背景 */
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.35);
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.topSearch form.hero-search:focus-within {
  outline: 2px solid rgba(255,255,255,0.7);
  outline-offset: 2px;
}

/* ===== 虫眼鏡アイコンボタン ===== */
.topSearch .hero-search__icon {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  flex: 0 0 40px;

  border: transparent;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}
.topSearch .hero-search__icon img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

/* ===== 入力フィールド ===== */
.topSearch .hero-search__field {
  flex: 1 1 auto;
  height: 100%;
  border: none;
  background: transparent;
  color: #fff;
  font-size: clamp(14px, 2.3vw, 16px);
  letter-spacing: 0.02em;
}
.topSearch .hero-search__field::placeholder {
  color: rgba(255,255,255,0.85);
}
.topSearch .hero-search__field:focus {
  outline: none;
}
	
	.topPlugin{
		margin-top: 50px;
	}
	
	/*#splw-location-weather-12394.splw-main-wrapper{
		margin-left: 0!important;
	}*/
	
	.topUnderbar{
		margin-top: -4px;
	}
	
/* ===== キービジュアル ===== */
.kv {
  --kv-max: 1100px;
  position: relative;
  padding: 20px 16px 40px;
  background-color: #F4F3EE;
	margin-top: -10px;
}

.kv__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  align-items: center;
  gap: clamp(24px, 5vw, 64px);
  max-width: var(--kv-max);
  margin: 0 auto;
}

/* 左テキスト */
.kv__eyebrow {
  color: #0abdc6;
  font-size: clamp(12px, 1.8vw, 14px);
  line-height: 1.5;
  margin: 0 0 10px;
}

.kv__headline {
  font-size: 48px;
  line-height: 1.2;
  letter-spacing: .02em;
  margin: 0 0 16px;
}

/* ▼▼ ここから “帯アニメ” 用の修正 ▼▼ */
/* 行ラッパー（帯の器） */
.kv__headline .bgextend{
  display: inline-block;
  margin-bottom: 10px;
  overflow: hidden;
  position: relative;
  opacity: 0;                /* 初期は非表示（IOで is-inview を付与） */
}

/* 文字本体：固定背景は消す／帯より前面に */
.kv__headline .hl{
  background: none;          /* ←固定ピンク背景を無効化 */
  position: relative;
  z-index: 1;
  padding: .05em .25em;
  color: #3a1d00;
  line-height: 1.2;
}

/* 帯は .bgLRextend が付いたときに ::before を伸ばす */
.kv__headline .bgLRextend::before{
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  height: 1.1em;               /* 帯の厚み */
  background-color: #FEA9C3;   /* 帯色 */
  animation: bgLRextendAnime 1s forwards;
}

/* 文字の初期状態と発火 */
.bgappearTrigger{ opacity: 0; }
.bgextend.is-inview{ animation: bgextendAnimeBase 1s forwards; }
.bgappearTrigger.bgappear{ animation: bgextendAnimeSecond 1s .6s forwards; }

/* キーフレーム（必要なら） */
@keyframes bgextendAnimeBase { from{opacity:0;} to{opacity:1;} }
@keyframes bgextendAnimeSecond { from{opacity:0;} to{opacity:1;} }
@keyframes bgLRextendAnime{
  0%   { transform-origin:left;  transform: translateY(-50%) scaleX(0); }
  80%  { transform-origin:left;  transform: translateY(-50%) scaleX(1.05); } /* 少しオーバー */
  100% { transform-origin:left;  transform: translateY(-50%) scaleX(1); }    /* 戻して落ち着く */
}
/* ▲▲ 帯アニメの修正 ここまで ▲▲ */

/* リード（左下に背景画像） */
.kv__lead {
  font-size: clamp(14px, 2vw, 16px);
  line-height: 1.9;
  color: #333;
  margin: 16px 0 0;
  background-image: url("../img/kvBgimage.png");
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: contain;
}

/* 右側のサムネイル画像 */
.kv__right img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 70vh;
  object-fit: contain;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.18));
}

/* グアム地形の固定（右寄せ基準） */
.kvGuam{
  position: absolute;
  left: calc(50% + (var(--kv-max) / 3));
  transform: translateX(-240px);
  top: -200px;
  right: auto;
  z-index: 3;
  pointer-events: none;
}
.kvGuam img{
  width: clamp(300px, 36vw, 560px);
  height: auto;
  display: block;
}


	
  .item-relative {
    position: relative;
    height: 50vh;
    overflow: hidden;
  }
  .item-relative img { width: 100%; height: 100%; object-fit: cover; }

  .plugin_absolute { position: absolute; top: 30%; left: 20%; }

  .top_title_wrapper { display: flex; flex-direction: column; align-items: center; justify-content: space-between; padding-right: 80px; }
  .top_txt   { color: #3AAA8A; font-size: 1.5vw; font-weight: 400; }
  .top_title { color: #DB4814; font-size: 4rem; text-align: center; font-weight: 600; margin: 20px 0; }
  .title_ocean, .title_guamu { font-size: 7rem; line-height: 1; }

  /* ---------- HeaderNav（検索/メニュー中身） ---------- */
  .headerNav_wrapper { height: 100%; }
  .headerNav_inner   { display: flex; justify-content: space-around; height: 100%; padding: 2%; }

  .headerNav_right {
    border-left: 3px solid #DB4813;
    padding-left: 2%;
    margin-bottom: 2%;
    width: 30%;
  }
	
	.headerNav_logo a{
		display: flex;
		justify-content: center;
	}

  .headerNav_logo a img { 
	  width: 316px; 
	  height: auto;
	}
	
	.headerNav_right_lib{
		color: #00C3C5;
	}

  .search_genre_title,
  .search_genre_title {
  width: 175px;
  height: 52px;
  margin: 20px 0;
  font-weight: 400;
  text-align: center;
  line-height: 52px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_genre.png")no-repeat center center;
  background-size: contain; /* 画像を枠内に収める */
  color: white; /* 文字色（必要なら調整） */
}
	
	.search_genre_icon_wrapper{
		display: flex;
		align-items: center;
		gap: 70px;
	}
	
	.search_genre_icon_list{
		display: flex;
		gap: 80px;
		/*width: 100%;*/
	}
	
	.search_genre_icon_header a{
		/*display: flex;
		align-items: center;
		gap: 10px;*/
	}
	
	.search_genre_top_icon--div{
		width: 80px;
		height: 90px;
		display: flex;
		white-space: nowrap;
		align-items: center;
		gap: 10px;
	}
	
	.search_genre_top_icon--div img{
		width: 100%;
		height: auto;
		object-fit: cover;
	}

	.search_area_wrapper{
		display: flex;
		gap: 70px;
		margin: 70px 0;
	}

  .search_area_title { 
	  width: 175px;
  height: 52px;
  font-weight: 400;
  text-align: center;
  line-height: 52px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_area.png")no-repeat center center;
  background-size: contain; /* 画像を枠内に収める */
  color: white; /* 文字色（必要なら調整） */
	}

  .search_shopkeyword { display: flex; gap: 40px; margin: 50px 0; }

  .search_shop,
  .search_keyword {
    width: 240px;
    background: #fff;
    padding: 10px;
    border-radius: 10px;
  }

  .search_shop    { border: 2px solid #FFA641; }
  .search_keyword { border: 2px solid #FEA9C3; }

  .search_shop img, .search_keyword img { width: 24px; height: 24px; }

  .keyword_readmore a { display: flex; align-items: baseline; justify-content: flex-end; gap: 20px; }
  .shoplist_readmore a { margin-top: 10px; }
  .shoplist_readmore a p { color: #00C3C5; }

  .search_area_content { display: flex; flex-wrap: wrap; gap: 10px; width: 70%; }

  .search_area_tumon, .search_area_agat,
  .search_area_hagania, .search_area_merizo,
  .search_area_tarofofo, .search_area_inalahan {
    background-color: #F3C8FF;
    padding: 10px;
    border-radius: 50px;
    text-align: center;
  }
  .search_area_tumon, .search_area_agat { width: 150px; }
  .search_area_hagania, .search_area_merizo { width: 180px; }
  .search_area_tarofofo { width: 230px; }
  .search_area_inalahan { width: 210px; }

  .search_flee_wrapper { 
	  margin-top: 25px; 
	  display: flex;
	  align-items: center;
	  gap: 35px;
	}
  .search_flee_title   { 
	    width: 200px;
  height: 52px;
  font-weight: 400;
  text-align: center;
  line-height: 52px; /* 文字を縦方向中央に */
  background:url("../img/icon/hukidashi_free.png")no-repeat center center;
	  padding: 0 10px;
  background-size: contain; /* 画像を枠内に収める */
	}

  .search1 { display: flex; align-items: center; gap: 10px; }
  .search_flee_icon { background-color: #FBE673; padding: 5px 10px; box-sizing: border-box; border-radius: 10px; width: 70px; display: flex; justify-content: center; }
  .search_image { width: 30px; height: 30px; }
  .search-text { width: 30vw; padding: 5px; border-radius: 13px; border: 2px solid #FBE673; }

  .headerNav_menu { 
	  height: 100%; display: grid;
	  margin-top: 30px;
	}
  .headerNav_menu_list { 
	  margin: 40px 0; 
	  max-width: 400px;
	}
	.headerNav_menu_list ul{
		display: flex;
		flex-direction: column;
		align-items: flex-end;
	}
	.sns_link_wrapper{
		max-width: 400px;
		margin: 40px 0;
	}
	.headerNav_left{
		max-width: 868px;
		margin: 0 auto;
	}
	
  .headerNav_menu_list li { list-style: none; margin-bottom: 10px;  text-align: right;}
/* liの枠組み */
.headerNav_menu_list li {
  list-style: none;
  margin-bottom: 20px;

  display: inline-flex;       /* 中身にフィットさせる */
  flex-direction: column;     /* 縦並び */
  align-items: flex-end;      /* 右端を基準に揃える */
  width: max-content;
}

/* 日本語ラベル */
.headerNav_right_lib {
  margin: 0 0 6px 0;
  font-size: 14px;
  line-height: 1;
  color: #00C3C5;
}

/* 英字リンク */
.headerNav_right_link {
  position: relative;
  display: inline-block;
  font-size: 24px;
  line-height: 1.3;
  text-decoration: none; /* デフォルトの下線は消す */
  color: #3a1d00;        /* 好きな文字色に */
  white-space: nowrap;   /* 改行させない */
	padding-right: 0.5em;
	font-weight: 700;
}

/* afterで下線を描画 */
.headerNav_right_link::after {
  content: "";
  position: absolute;
  right: 0;                /* 日本語の右端と揃える */
  bottom: -6px;            /* 文字との距離 */
  width: 100%;             /* 文字幅に合わせたいなら100% */
  height: 2px;
  background-color: #00C3C5;
}


  .sns_link_up { 
	  display: flex; 
	  gap: 20px; 
	  margin-bottom: 30px; 
	  justify-content: flex-end;
	}
	.sns_link_down{
		text-align: right;
	}
  .sns_link_down a, .sns_link_q a { color: #462408; border-bottom: 1px solid #462408; font-weight: normal; }
  .sns_link_down a { font-size: 15px; }
	
	 /* ---------- SLIDE UNDER IMAGE---------- */
	/*.under-slide{
		width: 100vw;
		height: auto;
	}*/
	
	.infinity-slide {
  width: 100vw;
  height: 100px;
  overflow: hidden;
  position: relative;
		border-bottom: solid 2px #462408;
}

.infinity-track {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 40px;
  white-space: nowrap;

  animation: infinityScroll var(--scroll-speed, 40s) linear infinite;
}

.banner {
  font-size: 40px;
  font-weight: 600 !important;
  white-space: nowrap;
  /*padding: 0 40px;*/
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  border-radius: 6px;
	padding-bottom: 5px;

  color: #462408; /* 通常時の文字色（お好みで） */

  /* ★ ホバー用にあらかじめ線を用意（色だけ透明にしておく） */
  border-bottom: 1px solid transparent;

  /* ★ 色と線の色をなめらかに変える */
  transition: color 0.3s ease, border-bottom-color 0.3s ease;
}

/* ホバー時のアニメーション先の状態 */
.banner:hover {
  color: #FBE673;
  border-bottom: solid 2px #FBE673;
}

/* 無限スクロールのキーフレーム */
@keyframes infinityScroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-1 * var(--scroll-distance)));
  }
}

	
	.under-slide img{
		width: 100%;
		height: auto;
	}

/* ========== NEW POST / SHOP INFO (CSS, keep .newpost_contents_tag as-is) ========== */
	
	.newpost_wrapper{
		background-color: #F4F3EE;
		margin-top: -10px;
	}

/* ラッパー */
.newpost_inner{
  display: grid;
  grid-template-columns: 30% 1fr;   /* 左固定・右可変 */
  gap: 28px;
  align-items: start;
  margin: 0 auto;
	padding-top: 80px;
}

/* --- 左カラム（吹き出し / 見出し / ボタン） --- */
.newpost-titleWrap{ position: relative; }
.newpost_fukidashi, .Fukidashi{ display: block; margin-bottom: 25px; text-align: center;}

/* 見出し（画像見出しをそのまま使用） */
.newpost_title, .Title{ margin: 0 0 10px; text-align: center; font-size: 48px; font-weight: 400}
.newpost_title img, .Title img{ height: auto; display: block; }
.newpost_title::after,.Title::after {
  content: "";
  display: block;
  width: 46px;
  height: 6px;
  background: #2cd5c4;
  margin: 20px auto 0;   /* ← auto で左右中央寄せ */
}

/* 一覧ボタン（ミントのピル / 左寄せ） */
.newpost_more{ width:auto; margin:15px 0 0; padding:0; background:transparent; text-align:center; border-radius:0; }
.newpost_more a{
  display:inline-block; padding:10px 50px; border-radius:999px;
  background:#2cd5c4; color:#fff; font-weight:700; text-decoration:none;
  box-shadow:0 2px 0 #15b7a8;
}
.newpost_more a:hover{ opacity:.9; }

/* --- 右カラム：横並びカード --- */
.np-card{
  position:relative;
  background:#fff;
  border:1px solid #E8F6F5;          /* 淡いミント枠 */
  border-radius:12px;
  overflow:hidden;
  margin:14px 0;
	box-shadow: 4px 4px 0 #2cd5c4;
}


.np-link{
  display:flex; align-items:center; gap:14px;
  padding:12px; text-decoration:none;
}

/* サムネイル */
.np-thumb{
  flex:0 0 150px;                     /* 画像の横幅 */
  aspect-ratio:16/9;
  border-radius:10px; overflow:hidden;
}
.np-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.np-noimg{
  display:grid; place-items:center; width:100%; height:100%;
  background:#f2f5f5; color:#8aa; font-size:12px;
}

/* テキスト側 */
.np-body{ flex:1 1 auto; min-width:0; }
.np-meta{ display:flex; align-items:center; gap:30px; margin:2px 0 6px; }
.np-date{ font-size:12px; color:#7f8a8a; letter-spacing:.02em; }

/* ※カテゴリ表示は newpost_contents_tag をそのまま利用（ここでは触らない） */
/* もし日付の横に余白が欲しければ、ラッパーだけ軽く整える（見た目は変えない） */
.newpost_contents_title_wrap{ display:flex; align-items:center; gap:8px; }

/* タイトル（2行で省略） */
.np-title{
  margin:0;
  font-size:16px; line-height:1.6; color:#333; font-weight:700;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}

/* ふるまい */
.np-card:hover{ border-color:#c6efea; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.np-link:hover .np-title{ text-decoration:underline; }
	
	/* 吹き出しのアニメーション復活 */
  .newpost_fukidashi img { animation: tiltStepAnimation 2s infinite steps(1); width: 100%; height: auto; object-fit: cover;}
	
	.stepAnimation{ animation: tiltStepAnimation 2s infinite steps(1); }




  /* ---------- Banner ---------- */
  .baner_wrapper {
    width: 60%;
    margin: 150px auto 60px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    justify-items: center;
  }
  .baner { width: 290px; }
  .baner img { width: 100%; height: 80px; object-fit: contain; }

/* ---------- Shop Ranking---------- */
.shop_ranking_wrapper { background:#fff; padding: 45px 0 70px;}
.shop_ranking_title, .shop_ranking_sub { text-align: center; }
.shop_ranking_title { color:#DB4813; font-size:6rem; line-height:1; display:flex; justify-content:center; }

/* 横スクロール (そのまま) */
.shop_ranking_contents{
  display:flex;
  overflow-x:auto;
  white-space:nowrap;
  gap:18px;
  margin-top:50px;
  --maxw: 1180px;
  --side: max( (100vw - var(--maxw)) / 2, 16px );
  padding-left: var(--side);
  padding-right: var(--side);
}
	
.shop_ranking_inner{ display:flex; gap:18px; }

	.shop_ranking_wrapper .Fukidashi img{
		width: 292px;
		height: auto;
	}

/* カード本体 */
.rank_img{
  flex:0 0 auto;
  width:23vw;                /* PC：4枚並び想定のまま */
  max-width:360px;           /* はみ出し防止 */
  min-width:260px;           /* 小さすぎ防止 */
  display:flex;
  flex-direction:column;
  align-items:stretch;
  background:#fff;
  padding:12px;
  scroll-snap-align:start;
}
.rank_img .img-link{
  display:block;
  position:relative;         /* ← バッジ配置の基準 */
  color:inherit;
  text-decoration:none;
}

/* サムネイル領域（角丸 + 比率固定） */
.rank_photo{
  position: relative;
  aspect-ratio: 4 / 3;   /* ←これで比率固定 */
  overflow: hidden;
  border-radius: 16px;
}
.rank_photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;     /* ←はみ出しをカットして全体に収める */
  display: block;
}

/* 左上の順位バッジ（ユーザー準備のPNG） */
.number{
  position: absolute;
  top: -20px;   /* 画像枠の上から10px */
  left: 0;  /* 画像枠の左から10px */
  z-index: 2;
}
	
	.number_kemushi{
		position: absolute;
  top: -15px;   /* 画像枠の上から10px */
  left: 10px;  /* 画像枠の左から10px */
  z-index: 2;
	}
	
.number img{
  width:90px;
  height:auto;
  display:block;
}

/* テキストブロック */
.rank_text_wrap{ margin-top:12px; }

/* カテゴリのピル（taxonomy: main_category） */
.rank_postsub{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}


/* タイトル（2行で省略） */
.rank_text{
  margin-top:8px;
  color:#462408;
}
.rank_text p{
  margin:0;
  font-weight:700;
  line-height:1.6;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
	
	.rank_text_sub{
		margin-top: 15px;
		font-size: 14px;
	}


  /* ---------- Recommend ---------- */
  .shop_recommend_title, .shop_recommend_sub { text-align: center; }
  .shop_recommend_title { color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
	
	.shop_recommend_wrapper{
		padding: 50px 0 100px;
	}

  .shop_recommend_contents {
    margin-top: 50px;
    display: grid;
    grid-template-columns: repeat(3,1fr);
    row-gap: 70px;
	  column-gap: 50px;
    justify-items: center;
    padding: 0 8%;
  }

  .newpost_shop { width: 100%; }
  .post_img_shop { width: 100%; height: 250px; margin-bottom: 10px; }
	.post_img_shop img{
		border-radius: 15px;
	}
	.shop_recommend_contents .post_text_t p{
		font-weight: bold!important;
	}
  .post_text_t { text-align: left; font-size: 18px; line-height: 20px; color: #462408; margin-bottom: 16px; font-weight: 700;}
  .post_text   { text-align: left; padding: 5px 0; font-size: 16px; line-height: 20px; color: #462408; }
  .post_sub_shop { margin-bottom: 14px; }

	/* 画像枠：比率を固定して基準化 */
.post_img_shop{
  position: relative;        /* ← バッジの基準 */
  overflow: visible;
  border-radius: 16px;
  background: #f4f4f4;
}

/* メイン画像をきれいにフィット */
.post_img_shop > img:first-child{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* 左上バッジ（少し角から被せる演出） */
.post_img_shop .post-badge{
  position: absolute;
  top: 12px;
  left: 12px;
  transform: translate(-6px, -6px); /* 角から“ちょい被せ”。不要なら削除 */
  z-index: 2;
  width: clamp(52px, 7vw, 72px);    /* 固定幅にしたい場合は 64px などに */
  height: auto;
  pointer-events: none;             /* クリックを邪魔しない */
}
	
	/* 初期状態：非表示 & 縮小 */
.post_img_shop .post-badge {
  position: absolute;
  top: -8px;
  left: 0;
  width: clamp(52px, 7vw, 72px);
  height: auto;
  opacity: 0;
  transform: scale(0.5);
  transition: opacity 0.6s ease, transform 0.6s ease;
  pointer-events: none;
  z-index: 2;
}

/* 表示状態（クラス追加時） */
.post_img_shop .post-badge.is-inview {
  opacity: 1;
  transform: scale(1);
}
	
/* フェードアウト（自然に消えるだけ） */
.post_img_shop .post-badge.is-out {
  opacity: 0;
  transform: scale(1); /* ← 縮小しない、サイズは維持 */
  transition: opacity 0.8s ease; /* 少し長めで“シュッ” */
}

/* ========== クイック系アニメ ========== */
/* 方向は CSS変数 --dir（1 or -1）で左右／回転方向を切り替えます */

@keyframes badge-sway-quick-kf {
  0%,100% { transform: translateX(0) scale(1); }
  50%     { transform: translateX(calc(var(--dir, 1) * var(--ampX, 14px))) scale(1); }
}
.badge-sway-quick {
  animation-name: badge-sway-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1); /* キビキビ */
}

/* 素早い首振り（回転） */
@keyframes badge-tilt-quick-kf {
  0%,100% { transform: rotate(0deg) scale(1); }
  50%     { transform: rotate(calc(var(--dir, 1) * var(--ampR, 12deg))) scale(1); }
}
.badge-tilt-quick {
  animation-name: badge-tilt-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1);
}

/* 合成（左右揺れ＋首振り）※1つのキーフレームでまとめて transform を管理 */
@keyframes badge-sway-tilt-quick-kf {
  0%,100% { transform: translateX(0) rotate(0deg) scale(1); }
  50%     { transform:
              translateX(calc(var(--dir, 1) * var(--ampX, 12px)))
              rotate(calc(var(--dir, 1) * var(--ampR, 10deg)))
              scale(1);
  }
}
.badge-sway-tilt-quick {
  animation-name: badge-sway-tilt-quick-kf;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.25,.6,.2,1);
}

/* 省エネ設定に配慮 */
@media (prefers-reduced-motion: reduce){
  .badge-sway-quick,.badge-tilt-quick,.badge-sway-tilt-quick{
    animation: none !important;
    transform: none !important;
  }
}

	
  /* ---------- Search Page ---------- */
  .search_wrapper_top {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: 80px 0 240px;
  background: url("../img/searchBG.png")bottom center / 105% auto no-repeat;
}
  .search_inner_top  { padding-bottom: 50px; }

  .search_title, .search_sub { text-align: center; }
  .search_title { padding: 20px 0; color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
  .search_sub   { color: #462408; font-weight: 400; }

  .search_contents_wrap {
    background: #fff;
    border: 1px solid #DB4813;
    border-radius: 10px;
    padding: 50px;
  }

  .search_txt_m { margin-bottom: 20px; font-size: 2.5rem; color: #462408; font-weight: 400; }
  .search_genre_contents { display: flex; align-items: flex-end; justify-content: space-between; width: 100%; margin-top: 50px; }
  .search_genre_m_a { display: flex; flex-direction: column; align-items: center; justify-content: center; }
  .search_genre_m_a img { margin-bottom: 30px; width: 90%; }

  .search_shop_m { margin: 90px 0; }
  .search_keyword_m { margin-bottom: 20px; }
  .search_keyword_m_contents_wrap { display: inline-block; }
  .search_keyword_m_contents_wrap a { width: 150px; background: #E00E65; color: #fff; }

  .search_area_m { margin: 50px 0; }

  /* ---------- Movie ---------- */
  .movie_wrapper { margin: 5% 0; }
  .movie_title, .movie_sub { text-align: center; }
  .movie_title { color: #DB4813; font-size: 7rem; line-height: 1; display: flex; justify-content: center; }
  .movie_sub   { color: #9ECF21; text-align: left;}

  .movie_contents { margin-top: 50px; width: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; }
  .video-gallery { width: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; }
  .video-item    { position: relative; width: 70%; padding-bottom: 35%; height: 0; overflow: hidden; border-radius: 25px; }
  .movie_h3      { font-size: 12px; font-weight: 400; color: #9ECF21; text-align: left; width: 70%; margin-bottom: 10px; }
  .video-item iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }

  /* ---------- Instagram ---------- */
  .instagram_wrapper { margin: 40px; }
  .insta_title { color: #DB4813; font-size: 6rem; line-height: 1; display: flex; justify-content: center; }
  .insta_sub   { color: #9ECF21; }

  .sns_link_wrapper_foot { display: flex; justify-content: center; gap: 30px; margin: 40px 0; }
  .sns_link_down_foot { font-weight: bold; color: #000; padding-top: 10px; }

/* ===== Footer ===== */
.site-footer{
  background:#FBE673; /* スクショの黄色 */
  color:#462408;
}

.footer__wrap{
  width:100%;
  padding:48px 0 28px;
}

.footer__inner{
  margin:0 auto;
	display: flex;
	justify-content: space-between;
	padding-top: 50px;
}

.footer__head{
  display:flex;
  flex-direction: column;
  margin-bottom:24px;
}

.footer__brand{
  display:flex;
  align-items:flex-start;
	flex-direction: column;
  gap:50px;
}
	
	.footer__links_sk li a{
		font-weight: 700!important;
	}
	
	.footer-sub-stick{
		display: inline-block;
		margin-right: 5px;
		font-weight: 700;
	}

.footer__logo img{
  height:36px; /* ロゴサイズは調整 */
  width:auto;
  display:block;
}

.footer__sns{
  display:flex;
  gap:12px;
}
.footer__sns img{
  width:24px; height:24px; display:block;
}

/* 中段グリッド */
.footer__grid{
  display:flex;
	flex-direction: row;
  gap:28px 60px;
  margin:16px 0 28px;
}

.footer__heading{
  font-weight:700;
  margin:4px 0 8px;
  letter-spacing:.03em;
	color: #DB4813;
}

.footer__subttl{
  font-size:16px;
  margin:8px 0 6px;
	color: #DB4813;
	font-weight: 700;
}

.footer__links{
  display:flex;
	flex-direction: column;
	gap: 20px;
}
.footer__links a{
  color:#DB4813;
  text-decoration:none;
  position:relative;
	font-weight: 700;
	padding-left: 1em;
}
	
	.footer__subgroup ul li a{
		font-weight: 400;
	}
	
.footer__links a:hover{ text-decoration:underline; }

	
	.footer__right_group{
		display: flex;
		gap: 30px;
	}
	
/* 下段 */
.footer__foot{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-top:16px;
}

.footer__legal{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
	text-align: left
}
.footer__legal a{ color:#462408; text-decoration:none; font-size:16px;  font-weight: 700;}
.footer__legal a:hover{ text-decoration:underline; }

.footer__copy{
  color:#6b4b1f;
  font-size:12px;
  opacity:.85;
	display: flex;
	justify-content: center;
}


  /* ---------- Archive / Lists ---------- */
  .archive_post_contents { display: flex; flex-direction: column; justify-content: space-between; padding: 10px; box-sizing: border-box; height: 100%; }
	.archive_newpost_contents_wrap{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		grid-row-gap: 50px;
		grid-column-gap: 40px;
		margin-top: 50px;
	}
	
	.np-link-archive{
		display: flex;
        align-items: flex-start;
        gap: 15px;
         padding: unset!important;
        text-decoration: none;
	}
	
	.np-thumb-archive{
		flex: 0 1 auto!important;
        aspect-ratio: auto!important;
        border-radius: 10px;
        overflow: visible!important;
	}
	
	.np-thumb-archive img{
		width: 180px;
        height: 135px;
         display: unset!important;
		border-radius: 10px;
	}
	
	.np-card-archive{
		position: relative;
         background: unset!important; 
        border: 1px solid #E8F6F5;
        border-radius:0;
        overflow: hidden;
         margin: unset!important;
         box-shadow: unset!important;
	}
	
	.single-backBtn-an-title{
		margin-bottom: 30px;
		font-size: 28px;
	}
	
	.single-backBtn-an-title a{
		display: inline-block;
		margin-bottom: 20px;
	}

  .wp-pagenavi { display: flex; justify-content: center; margin-top: 100px; }

  .shoplist_contents_wrapper { margin-bottom: 100px; }

  .alphabet_nation_wrapper {
    width: 100%;
    padding: 20px 60px;
    border: 1px solid #FCBA6E;
    background: #fff;
    border-radius: 20px;
    margin: 60px 0 80px;
  }

  .alphabet_wrapper, .katakana_wrapper { display: flex; flex-wrap: wrap; gap: 4%; row-gap: 50px; justify-content: center}
	.katakana_wrapper{
		margin-top: 50px;
	}
  .alphabet_wrapper a, .katakana_wrapper a { color: #FCBA6E; font-weight: 400; border-bottom: 1px solid #FCBA6E; }
	
	.alphabet_nation_title {
  position: relative;
  font-weight: 700;
  color: #462408;
  text-align: center;
		margin-bottom: 50px;
}
	
	.alphabet_nation_title::after {
  content: "";
  display: block;
  width: 50px;
  height: 5px;
  background-color: #FCBA6E;
  margin: 6px auto 0; /* 上に少し余白を入れて中央寄せ */
  border-radius: 2px;
}
	
	.shoplist_section{
		color: #FCBA6E;
		font-size: 82px;
		font-weight: bold;
	}

  .post-grid  { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
  .post-flex  { display: flex; flex-wrap: wrap; gap: 20px; }
  .post-flex > .newpost_shoplist,
  .post-grid > .newpost_shoplist { flex: 1 1 calc(33.33% - 20px); box-sizing: border-box; }
  .letter-heading { display: block; width: 100%; margin: 80px 0; 40px}
  .newpost_shoplist { padding: 10px; text-align: center; }

  .tagpost_wrapper { margin-top: 100px; }
  .tagpost_contents { display: grid; grid-template-columns: repeat(4,1fr); justify-items: center; }
  .tag_newpost_shop { width: 90%; margin: 0 3.5% 5%; }
	
	.archive_contents_wrapper_genre{
		display: grid;
		grid-template-columns: repeat(3,1fr);
		row-gap: 50px;
		column-gap: 60px;
	}
	
	.max-width-archive{
		max-width: 1050px;
		margin: 0 auto;
	}
	
	.choice_word{
		display: flex;
		align-items: center;
		gap: 10px;
	}
	
	.other_genre_wrap{
		background-color: white;
		padding: 30px 50px;
		border-radius: 15px;
		margin-top: 15px;
		margin-bottom: 50px;
	}
	
	.archive-genre-font-size span{
		font-size: 38px!important;
	}
	
	.archive-genre-font-size img{
		width: 70px;
		height: auto;
		margin-right: 30px;
	}
	
	.archive-current-genre{
		margin-right: 100px;
	}
	
	.archive-genre-image_other{
		width: 35px!important;
		height: auto;
	}
	
	.post_text_title{
		font-size: 18px;
		font-weight: bold;
	}
	
	.page-nav-archive > div > .current{
		background-color: #8FE7CC!important;
	}

  /* ---------- Single Shop / Article ---------- */
  .article_body { background-color: #F4F3EE; }
  /*.article_body p, .article_body h3 { color: #462408; }*/
	
	.post_day{
		display: flex;
		align-items: center;
		gap: 42px;
		margin-bottom: 30px;
	}
	
	.single_main{
		background-color: white;
		border-radius: 50px;
	}
	
	.single_mainTop{
		padding: 60px 50px 0;
	}
	
	.s_catch{
		max-width: 1000px;
		margin: 0 auto 60px;
	}
	
	.s_catch img{
		width: 100%;
		height: auto;
		box-shadow: 10px 10px 0 #2cd5c4;
		border-radius: 30px;
	}
	
	.forSingle-tag{
		padding: 10px 30px!important;
		font-weight: 700;
		font-size: 16px;
	}
	
	.entry-title{
		padding-bottom: 20px;
	}
	
	.shop_cta_row{
		display: flex;
		gap: 70px;
	}
	
	/* 画像枠は角丸＋はみ出し隠す（←ここがポイント） */
.s_catch {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  margin: 14px 0 24px;
  width: 100%;
	height: 600px;
}
.s_catch img { width: 100%; height: auto; display: block;  object-fit: cover;}
	
	.single-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}

.single-article__tag {
  display: inline-block;
  color: #462408;
  background-color: #FFBFD3;
  border-radius: 16px;
  padding: 8px 15px;
  font-size: 14px;
  line-height: 1.4;
  white-space: nowrap;
  text-decoration: none; /* リンク版でも下線を消す */
  transition: opacity 0.3s;
}

.single-article__tag:hover {
  opacity: 0.8;
}


/* エリアバッジの位置（左上） */
.area_pill_wrap {
  position: absolute;
  top: -5px;             /* 画像の内側に少し余白 */
  left: -5px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* エリアバッジ本体：左は角丸なし／右だけ“ピル”形状に */
.area_pill {
  position: relative;
  display: inline-block;
  padding: 15px 25px;
  background: #F7CCFF;  /* 薄ピンク */
  color: #3a220d;       /* 濃いブラウン */
  font-weight: 700;
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
  border-radius: 0 0 25px 0; /* 上記12pxはお好みで調整OK */
}

/* 複数ラベル並び時の余白 */
.area_pill + .area_pill { margin-left: 6px; }
	
	.single-backBtn-an-title{
		margin-bottom: 0;
		margin-bottom: 20px;
	}
	
	.single-backBtn-an-title p{
		font-weight: 700;
	}
	
	.single_main_genrepage{
		background-color: unset;
	}
	
	.single_mainTop_genrepage{
		max-width: 1000px;
		padding-top: 0;
	}
	/* ===== SHOP CTA (「このSHOPの詳細を見る」「このSHOPのSNSをみる」) ===== */
	
	.shopbox_first_genrepage{
		display: flex;
		flex-direction: column-reverse;
	}
	
	.shop_article_img1_genrepage{
		width: 100%;
	}

/* ラッパー：必要なら背景色を付ける（任意） */
.shop_cta_area {
  margin: 40px 0 10px;
  background: #7fe0d0;           /* ←スクショのミント系。要らなければ削除OK */
  border-radius: 0 0 32px 32px;   /* 角丸（任意） */
  padding: 24px 28px 24px 56px;
}

/* 行 */
.shop_cta_row {
  display: flex;
  align-items: center;
  gap: 32px;
  padding: 18px 0;
  border-top: 1px solid rgba(0,0,0,0.08);
}
.shop_cta_row:first-child { border-top: none; }

/* 左側ラベル */
.shop_cta_label {
  flex: 0 0 220px;   /* ラベル幅。スクショっぽく左に固定 */
  color: #462408;
  font-size: 14px;
  letter-spacing: .05em;
  white-space: nowrap;
	font-weight: 700;
}

/* ===== 1行目：詳細ボタン ===== */
.shop_cta_button {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 12px 18px 12px 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 9999px;          /* ピル型 */
  box-shadow: 0 2px 0 rgba(0,0,0,.06);
  text-decoration: none;
  color: #462408;
  transition: transform .08s ease, box-shadow .08s ease;
}
.shop_cta_button:hover { transform: translateY(-1px); box-shadow: 0 4px 0 rgba(0,0,0,.06); }
.shop_cta_button:active { transform: translateY(0); box-shadow: 0 2px 0 rgba(0,0,0,.06); }

.shop_cta_button_text {
  font-size: 16px;
  line-height: 1;
  font-weight: 600;               /* 日本語側太字イメージ */
}

/* 右端の丸矢印 */
.shop_cta_button_icon {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  font-weight: 700;
  line-height: 1;
  padding-bottom: 1px; /* 矢印の上下バランス微調整 */
}

/* リンクなし時（disabled想定） */
.shop_cta_button.is-disabled {
  cursor: default;
  pointer-events: none;
	padding: 20px 40px;
	background-color: white;
}

/* ===== 2行目：SNSアイコンピル ===== */
.shop_cta_sns .shop_cta_sns_icons {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  padding: 10px 16px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 9999px;
  box-shadow: 0 2px 0 rgba(0,0,0,.06);
}
.shop_cta_sns .sns_icon img {
  width: 28px;
  height: 28px;
  display: block;
  transition: transform .15s ease;
}
.shop_cta_sns .sns_icon:hover img {
  transform: scale(1.06);
}
	
	.article_for_shopinfolink{
		max-width: 100%;
		margin: 0 auto 100px;
		display: flex;
		justify-content: center;
	}
	
	.article_for_shopinfolink a{
		color: white;
		background-color: #462408;
		padding: 20px 60px;
		border-radius: 65px;
	}


  .yw h4 { color: #00C3C5; }
  .day-cat-area { display: flex; gap: 2%; margin-bottom: 20px; border-bottom: none !important; }

  .shoptitle_article { border-bottom: 1px solid #DB4813; }
  .shoptitle_article h3 { color: #462408; }

  .sub_orange {
    color: #DB4813 !important;
    background: #fff;
    border: 1px solid #DB4813;
    border-radius: 10px;
    font-weight: bold;
  }

  .shopbox_first { display: flex; }
  .shop_article_img1  { width: 100%; margin-right: 3%; }
	.shop_article_img1 img{
		width: 100%;
		height: auto;
	}
  .shop_article_text1 { width: 100%; padding: 20px 0; }
  .shop_article_text1 p { margin-top: 20px; }

  .bk h4 { border-bottom: dotted 4px #00C3C5; font-size: 24px; display: inline-block;}

  .shopbox_photogallery { border-top: 2px solid #00C3C5; }
  .photogallery_article { display: grid; grid-template-columns: repeat(4,1fr); justify-items: center; }
  .shop_img_article_5 { width: 90%; height: auto; margin-top: 15px; }
  .shop_img_article_5 img { width: 100%; height: 100%; object-fit: cover; }
	
	.single__information{
  position: relative;
  background: #fff;
  padding: 15px 50px;
		width: 220px;
		border-top-left-radius: 30px;
		border-top-right-radius: 30px;
		
}
	
	.single__information--h4{
  color: #12B6C8;       /* 見出しもアクセント色に */
  font-weight: 800;
  font-size: 16px;
		padding-bottom: 0!important;
}

  .t_left p { color: #00C3C5; }

  .shopbox_information {
    margin: 0 0 80px;
    background: #fff;
    padding: 0 30px;
	  border-radius: 0 30px 30px 30px;
  }

  .other_post { width: 100vw; background: #ECF1DD; }
  .other_post_inner { display: flex; flex-direction: column; align-items: center; padding: 40px 0 0; }

  .other_post_inner a {
    font-size: 2rem;
    padding: 20px 40px;
    display: inline-block;
    background: #9FCF24;
    margin-bottom: 50px;
    color: #fff;
  }

  .other_post_link { display: block; width: 15%; padding: 10px 20px; background: #DB4813; text-align: center; border-radius: 20px; }
  .other_post_link a { color: #fff; font-weight: bold; }

  .single_postbox_editied { width: 100vw; background: #ECF1DD; }
  .other { display: flex; justify-content: center; padding: 60px 0 0; }
  .other h4 { padding: 15px 40px; background: #9FCF24; margin-bottom: 60px; }
  .single_readmore_btn p { font-weight: bold; color: #fff; }

  .post_sub_edited { margin-top: 10px; }
  .post_cate_tag { margin-top: 10px; }
  .tag-frame { padding: 5px 10px; border-radius: 20px; color: #462408; font-size: 16px; background-color: #FFBFD3;}

  .post_info_inner strong { color: #DB4813; }

  .shop-info { box-sizing: border-box; }
  .shop-info p { margin: 10px 0; display: flex; align-items: center; }
  .shop-info-label { flex: 0 0 120px; font-weight: bold; margin-right: 20px; text-align: left; }

  .post_sns { margin-top: 20px; }
  .post_sns_icons { display: flex; gap: 20px; }
  .post_sns_icons img { width: 30px; height: 30px; transition: transform .3s; }
  .post_sns_icons img:hover { transform: scale(1.1); }

  .shop_info_readmore { font-size: 85%; }
  .shop_info_readmore a { color: #DB4813; border-bottom: 1px solid #DB4813; font-weight: bold; }

  .post-readmore_box { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-bottom: 40px; }
  .post_img_readmore { height: 50%; }

  /* ---------- Movie / Shorts extra ---------- */
  .video-item-archive { width: 60% !important; }
  .movie_h3_archive { width: 60% !important; margin-bottom: 40px; }
  .choice_word_movie { color: #DB4813 !important; }
  .youtube-short-item { width: 100%; }
  .choice_word_video { color: #DB4813 !important; }

  /* ---------- Misc ---------- */
  /*.max-width { padding: 7vh 9vw; }*/
  .top_info_wrapper { margin-top: 100px; }
  .archivepost_img_article { width: 100%; aspect-ratio: 1/1; height: auto; }
  .postarchive_post_text { padding-top: 0 !important; }
  .archivepost_sub_shop { margin: 10px 0; }
	.shoplist_cate{
		text-align: left;
	}
  .post_readmore { height: 65vh; }

  .tabs { display: flex; justify-content: center; background-color: #F4F3EE; }
  .tab_item { width: calc(100%/2) !important; display: flex !important; justify-content: center; align-items: center; line-height: 40px; }
  .tab_item a { display: block; width: 100%; height: 100%; text-align: center; padding-bottom: 2px; color: #DD4D34; }
  .tab_item a p { display: inline; border-bottom: 1px solid #fff; padding-bottom: 2px; color: #DD4D34; }
  input[name="tab_item"]:checked + .tab_item a p { color: #fff; }
  .eat { border: 3px solid #DD4D34; background: #fff; }

  .genre_icon_txt { display: flex; white-space: nowrap; width: 100%; justify-content: flex-start; gap: 30px;}
  .genre_icon_content { display: flex; align-items: center; gap: 1%; }
  .genre_icon_content a { display: flex; align-items: center; text-decoration: none; color: inherit; }
  .genre_icon_content img { margin-right: 5px; width: 4vw; }
  .genre_icon_content span { color: #462408; white-space: nowrap; font-size: 1.5rem; }

  .shoparticle_area_list { display: grid; grid-template-columns: repeat(3,1fr); justify-items: center; }
	
	.keywordlist_wrapper{
		margin: 110px auto 150px;
	}
	
	.keyword_contents_wrap{
		margin-top: 30px;
		padding: 30px 40px;
		border: solid 1px #FFBFD3;
		border-radius: 30px;
		background-color: white;
	}
	
	
	/*===========================
		エリアから探すページ
	=============================*/
	.taxonomy-area-fv__wrapper{
		margin-top: 80px;
	}
	
	.pankuzu__bg__wrapper{
		position: relative;
		padding-top: 20px;
	}
	
	.pankuzu__bg--absolute{
		position: absolute;
		inset: 0;
		width: 100vw;
		height: 350px;
		z-index: 0;
	}
	
	.pankuzu__bg--absolute img{
		width: 100%;
		height: 100%;
		display: block;
	}
	
	.pankuzu-area{
		position: relative;
		z-index: 1;
		color: white;
	}
	
	.pankuzu-area li a{
		color: white;
	}
	
	.pan-taxonomy-area li:after{
		color: white;
	}
	
	.taxonomy-area__name{
		display: inline-flex;
		flex-direction: column;
		margin-top: 60px;
	}
	
	.area__title{
		font-size: 98px;
		min-height: 1em;
		display: inline-flex;
	}
	
	.taxonomy-area__name span{
		font-size: 20px;
	}
	
	.taxonomy-area__image--box{
		display: flex;
		align-items: center;
		margin-top: -80px;
		position: relative;
	}
	
	.taxonomy-area__image--text{
		line-height: 2;
	}
	
	.area-contents__bg{
		margin-top: 50px;
		background-color: white;
		padding: 50px 0;
	}
	
	.area-contents__title {
  text-align: center;
  font-size: 48px;
  font-weight: 700;
  color: #4B2B14; /* 茶色系。お好みで変更OK */
  position: relative;
  letter-spacing: 0.05em;
  /*text-transform: uppercase;  念のため大文字を保証 */
}

.area-contents__title::after {
  content: "";
  display: block;
  width: 50px;
  height: 10px;
  background-color: #00C3C5;
  margin: 30px auto 50px;
  border-radius: 0;
}
	
	.post_text_title__taxonomy-area{
		display: inline-block;
		height: 50px;
	}
	
	.taxonomy-other-area__wrapper{
		padding: 50px 100px;
	}
	
	.taxonomy-other-area__titlebox{
		display: flex;
		align-items: center;
		gap: 15px;
		font-weight: bold;
		margin-bottom: 20px;
	}
	
	.taxonomy-other-area__content{
		display: flex;
		gap: 10px;
	}
	
	.pageNav--area span.current{
		background:#F3C8FF;
	}
	
	.archive_top_title__search{
		margin: 50px 0;
		background-color: white;
		border-radius: 15px;
	}
	
	.archive_top_title__search .choice_title{
		padding: 45px 50px;
	}
	
	.archive_top_title__search .choice_title h3{
		font-size: 48px;
	}
	
	.archive_contents_wrapper--search{
		display: grid;
		grid-template-columns: repeat(3,1fr);
		column-gap: 50px;
		row-gap: 20px;
	}
	
	.post_day--search{
		margin-bottom: 0;
	}
	
	.pageNav--search{
		margin-top: 50px;
	}
	
	.pageNav--search span.current{
		background: #FBE673;
	}
	
	.serach--down--space{
		margin: 50px auto 100px;
	}
	
	.serach--down--space .search1{
		justify-content: center;
	}
	
	
	/*===========================
		会社概要以下
	=============================*/
	
	/* ===== セクション全体 ===== */
.company-section {
  background: #F4F1EC;          /* 背景色 */
  padding: 48px 0;              /* 上下余白 */
}

/* ラッパー：左見出し + 右カードの2カラム */
.company-wrap {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 180px 1fr; /* 左見出し / 右カード */
  gap: 50px;
  align-items: start;
  padding: 0 24px;               /* サイド余白 */
}

/* ===== 左見出し ===== */
.company-heading {
  color: #4B2B14;               /* 茶色 */
  font-weight: 800;
  letter-spacing: 0.06em;
  font-size: 22px;
  line-height: 1.2;
  position: relative;
  margin: 4px 0 0;
  padding-left: 4px;
}
.company-heading::after {
  content: "";
  display: inline-block;
  width: 28px;                  /* 見本の小さなライン */
  height: 4px;
  background: #00C3C5;          /* 青緑ライン */
  margin-left: 12px;
  vertical-align: middle;
  transform: translateY(-2px);
}

/* ===== 右カード本体 ===== */
.company-card {
  color: #3B2E24;               /* 本文色 */
}

/* ロゴ */
.company-logo {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
	transform: translateX(150px);
}
.company-logo img {
  display: block;
  max-width: 320px;             /* ロゴ横幅の上限 */
  width: 100%;
  height: auto;
}

/* キャッチコピー */
.company-copy {
  margin-bottom: 18px;
	transform: translateX(150px);
}
.company-copy .catch-ja {
  font-weight: 700;
  color: #4B2B14;
  margin: 0 0 2px;
}
.company-copy .catch-en {
  letter-spacing: 0.06em;
  color: #8C7E71;
  margin: 0;
}

/* 会社情報テーブル（DL） */
.company-table {
  margin: 12px 0 0;
}
.company-table .row {
  display: grid;
  grid-template-columns: 140px 1fr; /* 見出し / 値 */
  gap: 90px;
  padding: 14px 0;
  border-bottom: 1px solid #8FE7CC;
}

	
.company-table dt {
  color: #00C3C5;               /* ラベル色 */
  font-weight: 700;
  white-space: nowrap;
	text-align: right;
}
.company-table dd {
  margin: 0;
  line-height: 1.9;
}

/* リンク */
.company-table a {
  color: #3B2E24;
  text-decoration: underline;
  text-underline-offset: 2px;
}
	
	.company-wrap__naiyou{
		margin-top: 105px;
		margin-bottom: 150px;
	}
	
	.naiyou__text{
		font-size: 18px;
		font-weight: bold;
	}
	
	
	.terms-page { background:#F4F1EC; padding:48px 0 64px; }
.terms-page__inner { max-width: 980px; margin: 0 auto; padding: 0 24px; }


/* ページタイトル */
.terms-page__title {
	color:#4B2B14; 
	font-weight:800; 
	font-size: 30px; 
	margin: 4px 0 28px; 
	position:relative; 
	display: flex;
	flex-direction: column;
	}
.terms-page__title:after {
	content:""; 
	display:inline-block; 
	width:40px; 
	height:4px; 
	background:#00C3C5; 
	vertical-align:middle; 
	transform: translateY(20px); 
	}


/* 本文ラッパ（ここに文章を入れる指定） */
.terms-page__wrapper { padding: 28px;}


/* 本文体裁 */
.terms-page__wrapper h2 { font-size:18px; margin: 24px 0 8px; color:#4B2B14; padding-top:8px; position:relative; }
.terms-page__wrapper p { line-height:1.9; margin: 0 0 16px; color:#3B2E24;}
.terms-page__wrapper ul, .terms-page__wrapper ol {  margin: 0 0 16px; }
.terms-page__wrapper li { margin: 4px 0; 
	padding-left: 1em;
	text-indent: -1em;
	font-weight: normal;
	}
.terms-page__revised { margin-top: 24px; color:#6b5b4c;}

	
}

@media screen and (min-width:768px) and (max-width:1000px){
	.footer__inner{
		display: flex;
		flex-direction: column;
		padding: 10px;
	}
	
	.np-link-archive{
		flex-direction: column;
	}
	
	.np-thumb-archive img{
		width: 100%;
		height: 250px;
		display: block;
	}
	}