@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700;900&display=swap&subset=japanese');


/* CSS Document */

/*商品*/
 .is-tour {
	padding:10px;
}

.is-tour li {
	background-color:#fff;"
}
.ui-static-grid-lg-space-article-card {
        margin-top:20px;
    }

.card__imgTag {
          padding: 2px 8px;
          font-size: 12px;
          font-weight: bold;
          color: #fff;
          background-color: #697180;
        position: absolute;
          top: 0;
          right: 0;
          }

       &:empty {
            display: none;
}

 
 .ui-static-product-card[data-product-card-type=secondary] .ui-static-product-card-departure-arival-info {
        padding:0 14px;
	 width:51%;
    }

.product__list--point {
	background-color:#e90000;
	text-align:center;
	color:#fff;
	padding:3px;
	font-weight:bold;
	margin:10px 0 !important;
}

 .card__price--compact {
        display: block;
        font-size: 20px;
        color: #e90000;;
        font-weight: bold;
        word-break: auto-phrase;
      }

.card__calender,
      .product__list--notes {
        font-size: 12px;
        color: #697180;
      }


.ui-static-grid-item {
   height:100%;
	display:flex;
}

.ui-static-product-card .ui-static-product-card-inner {
    height:initial;
}


  .ui-static-product-card[data-product-card-type=secondary] .ui-static-product-card-label {
	  text-align:center;
}

.card__imgTag {
	display:none;
}

.ui-static-image-container img {
  height:initial;
	
}

.ui-static-product-card[data-product-card-type=secondary] .ui-static-product-card-label {
	position:static;
padding: 5px 8px;
	width: 100%;
    display: block;
    box-sizing: border-box; 
    }

section.tour-section .ui-static-product-card .ui-static-product-card-title {
    font-weight: 500;
    margin: 0;
    letter-spacing: 0;
    line-height: 1.2;
    font-size: 20px!important;
    margin-top: 4px;
}


/* ==========================================================================
   SP版
   ========================================================================== */
.ui-static-section-wrapper {
    padding-top: 0 ;
    padding-bottom: 60px ;
}


/* ナビゲーション設定 */
html {
  scroll-behavior: auto;
  scroll-padding-top: 20px;
}

/****セクション間隔****/
.ui-static-container-space-m {
  margin-top: 20px; 
  margin-bottom: 20px; 
}

/****MV****/

.ui-static-main-visual-bg-big {
    background-image: url("../img/main_sp.jpg");
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    height: auto !important;
    min-height: 0 !important;
    display: flex;
    justify-content: center;
    align-items: center;
	aspect-ratio: 3 / 2;
	max-width: 100% !important;
    box-sizing: border-box !important;
	margin-bottom: 0 !important;
}

.ui-static-main-visual {
    position: relative;
    text-align: center;
    width: 100%;
	max-width: 100% !important;
    overflow: hidden;
}


.ui-static-main-visual-no-image {
    background: transparent;
}


/**** SP用ナビゲーション配置（3個+2個の2段構成・位置揃え・全下線仕様） ****/

/* ナビ全体の背景と上下の余白 */
.ui-static-navigation {
  background-color: #e72121;
  padding: 12px 0;
  text-align: center;
}

/* 親要素（ul）：上段の軸と下段の軸を固定して並べる設定 */
.ui-static-navigation-ul {
  list-style: none !important;
  margin: 0 auto !important;
  padding: 0 10px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  flex-direction: row !important;
  justify-content: flex-start !important; 
  row-gap: 11px !important;
  column-gap: 0 !important;
}

/* 子要素（li）：幅の固定、区切り線の配置 */
.ui-static-navigation-ul li.ui-static-navigation-item {
  width: 32% !important; 
  max-width: 32% !important;
  min-width: 32% !important;
  
  display: flex !important;
  flex-direction: row !important;
  justify-content: center !important;
  align-items: center !important;
  
  margin: 0 0.66% !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  position: relative !important;
}

.ui-static-navigation-ul li.ui-static-navigation-item::after,
.ui-static-navigation-variant-primary .ui-static-navigation-item:not(:last-of-type):after {
  background-color: transparent !important;
  display: none !important;
  content: none !important;
}

.ui-static-navigation-ul li.ui-static-navigation-item:nth-child(1),
.ui-static-navigation-ul li.ui-static-navigation-item:nth-child(2),
.ui-static-navigation-ul li.ui-static-navigation-item:nth-child(3),
.ui-static-navigation-ul li.ui-static-navigation-item:nth-child(4),
.ui-static-navigation-ul li.ui-static-navigation-item:nth-child(5) {
  border-bottom: 1px solid rgba(255, 255, 255, 0.5) !important;
}

.ui-static-navigation-ul li.ui-static-navigation-item:nth-child(4) {
  margin-left: 17.16% !important; 
}

.ui-static-link-black {
  color: #ffffff !important;
  text-decoration: none;
  font-weight: normal;
  font-size: 13px !important;
  display: inline-block !important;
  width: 85% !important;
  text-align: center !important;
  white-space: nowrap !important;
  position: relative;
  padding-bottom: 11px !important; 
}


/* --- 上段：番組詳細エリア --- */
.tv-contents-wrapper {
  /* 【修正】横並び（flex）を解除し、上から順に縦並びにする設定 */
  display: block !important;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto 0px !important; 
  padding: 0 10px; /* スマホ画面の左右に適切な余白を確保 */
  box-sizing: border-box;
}

/* 【修正】横幅の制限（50%ずつなど）を解除し、100%広げて縦に積む */
.tv-left-block, .tv-right-block {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  flex: none !important;
}

/* 【修正】右ブロック（動画エリア）が下に来るよう、隙間をマージンで調整 */
.tv-right-block {
  margin-top: 30px; /* 左テキストと右画像の間の適切な隙間 */
}

/* タイトル画像・見出し・説明文 */
.tv-left-block .ui-static-container div, .ui-static-container h1, .ui-static-container h2, .ui-static-container h3, .ui-static-container h4, .ui-static-container h5, .ui-static-container h6, .ui-static-container p {
    margin-bottom: 10px;
}

/* 【修正】スマホの画面幅に合わせて、大きすぎる見出しサイズを調整 */
.tv-left-block .ui-static-container div, .ui-static-container h2 {
    margin-bottom: 15px;
	font-size: 23px !important; /* スマホで見やすい見出しサイズに縮小 */
    font-weight: bold;
    text-align: center; /* 中央寄せにしてバランスを整える */
}

.tv-img-container,
.img-container {
  padding: 0 !important; /* 周りの余白をゼロに */
  width: 100%;
}

/* タイトル画像調整 */
.tv-left-block .tv-img-container {
  width: 100% !important; /* 【修正】スマホ画面に合わせて画像を横幅いっぱいに拡大 */
  padding: 0 !important;
  margin: 0 auto 20px auto !important; /* 画像の下にテキストとの隙間を確保 */
}

.tv-left-block .tv-img-container img {
  width: 100%;
  height: auto !important;
  display: block;
  margin-top: 10px;
}

.ui-static-heading {
  font-size: 23px !important;
  margin: 15px 0;
  line-height: 1.4;
}

.ui-static-text {
  font-size: 14px;
  line-height: 1.6;
  color: #333;
}

/* 放送内容 画像エリア（旧動画エリア） */
.movie {
  width: 100%;
}

.movie img {
  display: block;
  width: 100%;
  height: auto;
  box-sizing: border-box;
}

/* --- 下段：放送予定エリア（薄青背景） --- */

.content-container {
  background-color: #dff1f4; /* 薄青の背景色 */
  /* 水色の背景高さを1.5倍に（上下paddingを45pxに） */
  padding: 30px 0;
  margin-top: 35px;
  
  /* 親の幅を無視して画面の左右いっぱいに広げる設定 */
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.tv-program {
  background: #ffffff; /* 白い看板部分 */
  
  /* === 【ここを調整！】幅の設定を修正 === */
  width: calc(100vw - 40px); /* 画面幅いっぱいにしつつ、スマホ等での左右の最小余白を20pxずつ確保 */
  max-width: 1020px;          /* コンテンツラッパーの幅（上限）にカチッと合わせる */
  margin: 0 auto;
  
  /* 【修正】上から下へ「テキスト→画像」と正しく流すため、縦並びのFlexに指定 */
  padding: 40px 5px 25px 5px; 
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  position: relative;
  
  /* 内側の白い背景を角丸にする */
  border-radius: 12px; 
  box-sizing: border-box;
}

/* 不要になった最下部の点線を完全に消去 */
.tv-program::after {
  display: none !important;
  content: none !important;
}

/* 【修正】テキスト群：最上部に配置し、このエリアの【一番下】に点線を引きます */
.tv-program-col-center {
  order: 1 !important; /* 1番上に配置 */
  width: 100% !important;
  flex: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  
  /* テキストのすぐ下に点線を敷きます（これで画像2枚の上に点線が配置されます） */
  border-bottom: 4px dotted #e72121 !important; 
  padding-bottom: 15px !important; /* テキストから点線までの隙間 */
  margin-bottom: 0px !important;  /* 点線から下の画像2枚までの隙間 */
}

/* 【修正】画像2枚を包むための横並び用コンテナを制御 */
/* ※HTML構造で並列になっている画像2枚を、点線の下で綺麗に「横並び」に直します */
.tv-program {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
}

.left-img-box {
  order: 2 !important; /* 点線の下（左側）に配置 */
  display: inline-block !important;
  margin: 0 10px !important; 
}

.right-img-box {
  order: 3 !important; /* 点線の下（右側）に配置 */
  display: inline-block !important;
  margin: 0 10px !important; 
}

/* 各ロゴのサイズ調整（スマホ画面に収まるようmax-heightを調整） */
.left-img-box img { 
  max-height: 55px !important; 
  display: block !important;
  margin: 0 !important;
}

.right-img-box img {
	max-height: 65px !important;
	display: block !important;
	margin: 0 !important;
}

/* 赤い四角（バッジ）を白い枠線（上辺）の真ん中が通る位置に調整 */
.red-badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%); /* バッジのちょうど中心が白枠の上辺に重なる */
  display: inline-block;
  background-color: #e50012;
  color: #ffffff;
  font-size: 15px;
  font-weight: bold;
  padding: 3px 15px;
  margin-bottom: 0; /* 位置固定のため不要なマージンをリセット */
  white-space: nowrap;
  z-index: 10;
}

/* テキストグループ（6/9〜アベレンまで） */
.text-group {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 3px;
  font-size: 20px;
  font-weight: bold;
}

.text-red {
	color: #e50012;
	font-size: 14px;
}
.text-black {
	color: #000000;
	font-size: 12px;
	margin-top: 10px
}

.tv-program .ui-static-text-note {
	font-size: 10px;
	font-weight: normal;
}

/* ==========================================================================
   アベレンのツアー紹介（SP用・縦積みレイアウト完全版）
   ※元のカラー・あしらい・枠線デザインをすべて100%維持しています
   ========================================================================== */

section.highlights-section .ui-static-container.ui-static-container-space-m {
	row-gap: 0px;
}

/* --- アベレンのツアー紹介 --- */
.highlights-section .ui-static-heading {
  display: flex !important;
  flex-direction: column-reverse !important; /* サブタイトルを上、メインを下にする */
  align-items: center !important;
  text-align: center !important;
  margin-bottom: 30px !important; /* スマホ向けに余白を少し調整 */
}

/* サブタイトル */
section.highlights-section .ui-static-heading-subtitle {
  font-size: 14px !important;
  font-weight: 900 !important;
  color: #e72121 !important;
  margin-bottom: 10px !important;
　white-space: nowrap !important;
  word-break: keep-all !important;
  display: inline-block !important;}

/* メインタイトル */
.highlights-section .ui-static-heading-size-huge {
  font-size: 23px !important; /* スマホ画面幅に合わせて僅かに縮小、はみ出し防止 */
  font-weight: bold !important;
  color: #222222 !important;
  line-height: 1.3 !important;
}

/* 注意書き */
section.highlights-section .ui-static-text-note {
  font-size: 10px !important;
  color: #666 !important;
}

/* --- カードリスト共通設定 --- */
.card-list {
  max-width: 1000px !important;
  margin: 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 35px !important;       /* スマホ用のカード同士の縦の隙間 */
  padding: 0px !important; /* 画面端にベタ塗り影がくっつくのを防ぐ左右余白 */
  box-sizing: border-box !important;
  width: 100% !important;
}

/* カード1行のレイアウト（SP用：強制的に上から下への縦積みに変更） */
.card-item,
.card-item.is-reverse {
  display: flex !important;
  flex-direction: column !important; /* PC版の row / row-reverse を完全に上書きして縦積みに */
  align-items: stretch !important;    /* 横幅いっぱいに広げる */
  gap: 0px !important;               /* 写真とテキスト枠の間の隙間 */
  width: 100% !important;
}

/* 写真を約80%のサイズに縮小するための比率調整 (SP版は100%幅にリセット) */
.card-media-container,
.card-content-container {
  flex: none !important;
  width: 100% !important;
}

/* 画像自体の設定 */
.card-image-container img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
}

/* --- テキストを囲む枠（位置調整・背景色、およびベタ塗り影を追加） --- */
.card-text-inner-container {
  position: relative !important; /* バッジを絶対配置（左上重ね）にするための基準点 */
  background-color: #ffffff !important; /* 影の上に重なるため、背景を白に固定 */
  border-width: 3px !important;
  border-style: solid !important;
  border-radius: 12px !important;
  padding: 45px 20px 20px 20px !important;
  min-height: auto !important;
  box-sizing: border-box !important;
  display: block !important; 
  margin: 20px 5px 5px 0 !important; 
  width: auto !important;
}

.border-blue { 
  border-color: #395db5 !important; 
  box-shadow: 5px 5px 0 0 #395db5 !important; 
}
.border-red  { 
  border-color: #e72121 !important; 
  box-shadow: 5px 5px 0 0 #e72121 !important; 
}

/* --- バッジのデザイン） --- */
.card-text-inner-container .badge {
  position: absolute !important;
  top: -3px !important;
  left: -3px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #ffffff !important;
  font-weight: bold !important;
  font-size: 15px !important;
  height: 38px !important;
  padding: 0 45px 0 35px !important;
  margin-bottom: 0 !important;
  border-top-left-radius: 9px !important;
  border-bottom-right-radius: 12px !important;
  clip-path: polygon(0 0, 100% 0, calc(100% - 15px) 100%, 0 100%) !important;
}

/* バッジの背景色 */
.bg-blue { background-color: #395db5 !important; }
.bg-red  { background-color: #e72121 !important; }

/* --- カードの見出し・文字・隙間調整 --- */
.card-text-inner-container h3 {
  font-size: 18px !important;
  font-weight: bold !important;
  line-height: 1.4 !important;
  display: block !important;
  text-align: left !important;
  justify-content: flex-start !important;
  align-items: flex-start !important;
  margin-top: 0 !important;
  margin-bottom: 10px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.card-text-inner-container p {
  font-size: 13px !important;
  line-height: 1.6 !important;
  color: #444444 !important;
  text-align: left !important;
  margin: 0 !important; 
  padding: 0 !important;
}

/* --- セクション中央揃え --- */
.highlights-section {
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 25px !important;
}

.highlights-section .ui-static-container {
  width: 100% !important;
  max-width: 1000px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
/* --- ステッカーエリア --- */
.sticker {
  width: 100% !important;
  max-width: 1000px; 
  margin: 20px auto 0 !important;
  margin-bottom: 40px;
  padding: 0 !important;
  box-sizing: border-box !important;
}

.sticker__inner {
  width: 100% !important;
  padding: 0 !important;
}

.sticker__inner img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
  margin: 0 auto !important;
}

/* PC用・SP用画像の切り替え */
.sticker .pc-only { display: none !important; }
.sticker .sp-only { display: block !important; }


/* --- ツアーポイント1 --- */

.point-section {
  margin-top: 50px;
}

.point-section .ui-static-heading {
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  text-align: center;
  margin-bottom: 30px;
}



/* サブタイトル（tour point 1） */
section.point-section .ui-static-heading-subtitle {
  font-size: 16px;
  font-weight: 900;
  color: #2b62c1; /* 特徴的な青色 */
  margin-bottom: 10px;
}

/* メインタイトル（最旬のスポット巡り！） */
section.point-section .ui-static-heading-size-huge {
  font-size: 32px;
  font-weight: bold;
  color: #000000;
}

/* --- コンテナと背景色（薄青） --- */
.point-section .ui-static-container {
  background-color: #e6f2f5;
  box-sizing: border-box;
  width: 100vw !important;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  padding: 40px 0; 
}

/* --- 縦積み --- */
.point-card-grid-container {
  max-width: 1000px;
  margin: 0 auto !important; 
  display: grid;
  grid-template-columns: 1fr;
  gap: 25px;
  width: 100%;
  padding: 0 20px;
  box-sizing: border-box;
}

/* --- カード --- */
.point-card-item {
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  padding: 15px;
  box-sizing: border-box;
}

/* 画像コンテナ */
.point-image-container {
  width: 100%;
  margin: 0 auto 15px auto; 
}

.point-image-container img {
  width: 100%;
  height: auto !important;
  display: block;
}

/* テキストコンテナ */
.point-text-container {
  width: 100%;
  display: block !important;
}

/* --- カード内の見出し・本文調整 --- */
.point-text-container h3 {
  font-size: 18px;
  font-weight: bold;
  color: #2b62c1;
  line-height: 1.4;
  display: block !important;
  text-align: left !important;
  justify-content: flex-start !important;
  margin: 10px 0 8px 0 !important;
  padding: 0 !important;
}

.point-section .point-text-container h3 {
  font-size: 16px !important;
}

.point-text-container p {
  font-size: 13px;
  line-height: 1.6;
  color: #333333;
  
  /* 本文の左寄せとマージン排除 */
  text-align: left !important;
  margin: 0 !important;
  padding: 0 !important;
}


/* --- 特典 --- */

/* 【修正】セクションの上に70pxの余白を追加 */
.special-section {
  margin-top: 50px;
}

.special-section .ui-static-heading {
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  text-align: center;
  margin-bottom: 35px;
}

/* サブタイトル（tour point 2） */
section.special-section .ui-static-heading-subtitle {
  font-size: 16px;
  font-weight: 900;
  color: #e50012; /* 特徴的な赤色 */
  margin-bottom: 10px;
}

/* メインタイトル */
.special-section .ui-static-heading-size-huge {
  font-size: 32px;
  font-weight: bold;
  color: #222222;
}

/* --- コンテナと背景色（薄いオレンジ） --- */
.special-section .ui-static-container {
  background-color: #ffe6d5; /* 薄いオレンジの背景色 */
  box-sizing: border-box;
  
  /* 【修正】オレンジの背景をセクションラッパーの幅を超えて画面の左右限界まで広げる */
  width: 100vw !important;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  
  /* 左右のpaddingは内側のカードコンテナに任せるため、上下のみ40pxを設定 */
  padding: 40px 0;
}

/* --- カードリストの囲み（中央寄せ） --- */
.special-card-list-container {
  max-width: 1000px;
  margin: 0 auto !important;
  display: flex;
  flex-direction: column;
  gap: 25px; /* カード同士の縦の隙間 */
  width: 100%;
  
  /* 【修正】画面が狭いとき（スマホ等）にカードが画面端に張り付かないよう左右余白をここで確保 */
  padding: 0 20px;
  box-sizing: border-box;
}

/* --- 特典カード1枚ずつのスタイル --- */
.special-card-item {
  background-color: #ffffff;
  border: 2px solid #e50012; /* 外枠の赤い線 */
  display: flex;
  flex-direction: column; /* 横並びから、下へ流れる「縦積み」に変更 */
  
  /* 【修正】リボンの長さ(60px) ＋ 空けたい隙間(20px) ＝ 上の内余白(padding-top)を80pxに設定 */
  padding: 80px 20px 25px 20px; 
  
  position: relative; /* リボンの絶対配置の基準にする */
  box-sizing: border-box;
  min-height: 140px; /* カードの最小高さを確保 */
}

/* --- 特典リボンバッジ（中央上配置に修正） --- */
.special-ribbon {
  background-color: #e50012;
  color: #ffffff;
  width: 60px;          /* ほんの少しスリムに */
  
  /* 【修正】リボンの長さを75pxから60pxに縮小 */
  height: 70px;         
  
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  
  /* カードの「中央上」にぴったり配置する設定 */
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%); /* 完全に真ん中に重ねるトリップ */
  z-index: 2;
}

/* リボンの下部をV字にくり抜く設定（リボン幅に合わせて調整） */
.special-ribbon::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  border-left: 30px solid transparent;
  border-right: 30px solid transparent;
  border-bottom: 12px solid #ffffff; /* 親要素の白背景と同じ色で切り抜く */
}

.special-ribbon-text {
  font-size: 12px;
  font-weight: bold;
  margin-top: -8px; /* 位置の微調整 */
}

.special-ribbon-num {
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
}

/* --- テキストエリア（縦積み・中央揃えへの修正） --- */
.special-text-container {
  flex: 1;
  display: block !important;
  padding-left: 0; /* 左横並び用の余白をリセット */
  box-sizing: border-box;
}

/* 特典名見出し (T-moneyカード等) */
.special-text-container h3.text-red {
  font-size: 22px;
  font-weight: bold;
  color: #e50012 !important;
  display: block !important;
  text-align: center !important; /* 見出しを「中央揃え」に変更 */
  margin: 0 0 5px 0 !important;
  padding: 0 !important;
}

.special-section h3.ui-static-heading.ui-static-heading-size-small.ui-static-heading-left.ui-static-heading-bold.text-red {
	font-size: 19px !important;
}

/* キャッチコピー (観光の移動で使える！等) */
.special-text-container .text-sub-title {
  font-size: 16px;
  font-weight: bold;
  color: #222222 !important;
  text-align: center !important; /* 小見出し（キャッチコピー）を「中央揃え」に変更 */
  margin: 0 0 12px 0 !important;
}

/* 説明文本文 */
.special-text-container p:not(.text-sub-title) {
  font-size: 13px;
  line-height: 1.6;
  color: #444444 !important;
  text-align: left !important; /* 本文テキストは「左寄せ」を維持 */
  margin: 0 !important;
  padding: 0 !important;
}


.tour-section .ui-static-container.ui-static-container-space-m {
	background-color: #dff1f4;
}


/* --- ツアーセクション全体設定 --- */
.tour-section {
  /* 【要件】セクションの一番上に70pxのマージントップ */
  margin-top: 70px; 
}

.tour-section .ui-static-heading {
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  text-align: center;
  margin-bottom: 35px;
}

/* サブタイトル */
section.tour-section .ui-static-heading-subtitle {
  font-size: 14px;
  font-weight: 900;
  color: #2b62c1; /* 特徴的な青色 */
  margin-bottom: 10px;
  white-space: nowrap !important;
}

/* メインタイトル */
.tour-section .ui-static-heading-size-huge {
  font-size: 21px !important;
  font-weight: bold !important;
  color: #222222;
}

/* --- 【要件】コンテナと水色背景（画面幅いっぱいに広げる） --- */
.tour-section .ui-static-container.ui-static-container-space-m {
  background-color: #dff1f4; /* 水色の背景色 */
  box-sizing: border-box;
  width: 100vw !important;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  padding: 20px 0 50px 0; 
}

/* --- 内側コンテンツの幅制限（商品枠を崩さないためのガード） --- */
.tour-section .product-list-wrapper {
  max-width: 1000px; /* 特典やカードリストの最大幅（1000px）と同期 */
  margin: 0 auto !important;
  width: 100%;
  
  /* 画面が狭いとき（スマホ等）にカードが画面端に張り付かないよう左右余白をここで確保 */
  padding: 0 20px;
  box-sizing: border-box;
}

/* 商品カード下のボタン用ラッパー制限（幅の広がり防止） */
.tour-section .ui-static-button.tour {
  max-width: 1000px;
  margin-top: 40px !important; /* 商品カードとの間に程よい隙間を確保 */
  margin-left: auto !important;
  margin-right: auto !important;
}




/****コタキナバル説明（縦並び・1カラム構成）

.description-kotaki .ui-static-item-card-horizontal-reverse {
    display: flex !important;
    /* rowからcolumnに変更して縦並び化
    flex-direction: column !important; 
    align-items: flex-start !important;
    gap: 24px !important;
    background-color: transparent !important;
    border: none !important;
    width: 100% !important;
}****/

/* テキストエリア
.description-kotaki .ui-static-item-card-details {
    display: flex !important;
    flex-direction: column !important;
    /* 幅を100%に変更
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    grid-template-columns: none !important;
}

/* 地図エリア
.description-kotaki .ui-static-image-container {
    /* 幅を100%に変更
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    display: block !important;
}

/* 地図画像
.description-kotaki .ui-static-image {
    width: 100% !important;
    height: auto !important;
    display: block !important;
}

.description-kotaki .ui-static-image img {
    width: 100% !important;
    height: auto !important;
    position: static !important;
    aspect-ratio: auto !important;
    object-fit: contain !important;
}

/* 見出し・サブタイトル（ここから下の装飾設定は維持）
.description-kotaki h2.font-normal {
    font-weight: bold !important;
    text-align: center !important;
    padding-top: 30px !important;
    margin-bottom: 20px !important;
    position: relative !important;
    display: block !important;
}

.description-kotaki .ui-static-heading-subtitle {
    position: absolute !important;
    top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 100% !important;
    text-align: center !important;
    font-weight: bold !important;
	margin-top: 0 !important;
    margin-bottom: 0 !important;
}

/* 魅力マップ
.description-kotaki .ui-static-content-image {
    width: 100% !important;
    max-width: 100% !important;
    margin-top: 24px !important;
    display: block !important;
}

.description-kotaki .ui-static-content-image img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
}

/* 説明文テキスト
h2.ui-static-heading.ui-static-heading-size-huge.ui-static-heading-left.ui-static-heading-with-subtitle-top {
    font-weight: bold;
    margin-top: 10px;
    margin-bottom: 20px;
}

.description-kotaki .ui-static-text-black {
    text-align: left !important;
    line-height: 1.8 !important;
    margin-bottom: 0 !important;
}


/****スケジュール表（SP用：往路・復路を縦積み）

.flight-schedule {
	background-color: #f2f2f2;
	padding: 20px 0;
}

section.flight-schedule .layout-d {
    padding: 0 20px;
    box-sizing: border-box;
}

.flight-schedule .ui-static-table-table {
    background-color: #ffffff;
}

.ui-static-table-table thead th {
    background-color: #2e7d32 !important;
    color: #ffffff !important;
}

.ui-static-table-table-wrapper {
    display: flex;
    flex-direction: column; /* 横並びから縦並びに変更
    gap: 24px;
    text-align: center;
}

 .flight-schedule .ui-static-table.ui-static-table-variant-basic .ui-static-table-table-wrapper .ui-static-table-table th, .ui-static-table.ui-static-table-variant-basic .ui-static-table-table-wrapper .ui-static-table-table td {
	flex: 1;
  　text-align: center;
}


.ui-static-text.ui-static-text-small {
    color: #000000;
}

.flight-schedule h2.ui-static-heading.ui-static-heading-size-huge.font-normal {
    font-weight: bold !important;
}

.flight-schedule .ui-static-heading-subtitle {
	white-space: nowrap !important;
}

/* 早割
.flight-image-container .u-sp-only {
	text-align: center !important;
    width: 100%;
}

.flight-image-container  .u-sp-only　img {
    max-width: 100% !important;
    height: auto !important;
    display: inline-block;
}

.flight-image-container .u-pc-only { display: none; }

/**** コタキナバルの楽しみ方
h2.ui-static-heading.ui-static-heading-size-enormous.ui-static-heading-center.color-green {
    margin-top: 20px ;
	margin-bottom: 10px ; 
    padding-top: 0 ;
	color: #2e7d32 ;
	font-size: 28px;
	font-weight:bold;
}

.ui-static-heading.ui-static-heading-size-medium.color-green.ui-static-heading-left.ui-static-heading-light-lg.ui-static-heading-bold.enjoy-kotaki {
	font-size: 20px;
	font-weight: bold;
	}

.layout-c {
    margin-top: 10px;
    margin-bottom: 80px;
}

.ui-static-item-card-details .ui-static-heading.ui-static-heading-size-medium.color-green {
    font-size: 32px;
	color: #2e7d32 !important;
    line-height: 1.2;
    margin-top: 0;
    margin-bottom: 4px;
    padding-top: 0;
    padding-bottom: 0;
}

.ui-static-item-card-details .ui-static-item-card-description .font-normal {
    font-size: 14px;
	font-weight: normal;
    line-height: 1.5;
    color: #333333;
    margin-top: 0;
    padding-top: 0;
}

.ui-static-item-card-details.ui-static-container-space-xs {
    padding-top: 12px;
    padding-bottom: 8px;
}

.ui-static-grid-list {
    margin-top: 20;
}


/**** タブ（SP横並び・正方形・三角形復活版）

.ui-static-tab-container {
    width: 100%;
    margin-top: 40px !important; 
    margin-bottom: 40px !important; 
}

/* ボタンリストを横並び（Flex）に変更
.ui-static-tab-button-list {
    display: flex !important; 
    flex-direction: row !important;
    justify-content: center !important;
    gap: 10px !important; /* ボタン間の隙間 */
    padding-bottom: 15px !important; /* 三角形が表示されるスペースを確保
    border-bottom: none !important;
}

.ui-static-tab-button {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    flex: 1 !important; /* 幅を均等に
    aspect-ratio: 1 / 1 !important;
    max-width: 160px !important;
    padding: 8px 2px !important;
    text-align: center;
    background-color: #ffffff;
    color: #2e7d32;
    border: 1px solid #2e7d32;
    border-radius: 4px;
    position: relative; /* 三角形配置用
    box-sizing: border-box !important;
    text-decoration: none !important;
}

/* アクティブ時の色
.ui-static-tab-button.is-active {
    background-color: #2e7d32 !important;
    color: #ffffff !important;
}

/* 三角形（吹き出し）の復活
.ui-static-tab-button.is-active::after {
    display: block !important;
    content: "" !important;
    position: absolute;
    bottom: -20px; /* ボタンの下に配置
    left: 50%;
    transform: translateX(-50%);
    width: 0 !important;
    height: 0 !important;
    border-style: solid !important;
    border-width: 14px 11px 0 11px !important; /* 三角形のサイズ
    border-color: #2e7d32 transparent transparent transparent !important;
}

/* サブタイトル：サイズ調整
.ui-static-tab-button .sub {
    display: block;
    font-size: 12px !important; /* 横並び用に少し小さく
    margin-bottom: 4px;
    font-weight: 700 !important;
    line-height: 1.2;
}

/* メインタイトル：サイズ調整
.ui-static-tab-button .main {
    display: block;
    font-size: 21px !important; /* 25pxだと正方形からはみ出すため調整
    font-weight: 700;
    line-height: 1.2;
    word-break: break-all; /* 改行を許容
}

.ui-static-tab-content-item.is-active {
    display: block !important;
    margin-top: 10px; /* 三角形との距離 */
}

/* タブボタン内の不要なbefore/afterを完全にリセット
.ui-static-tab-button::before {
    display: none !important;
    content: none !important;
}


/****タブ内コンテンツ****/

/****タブ１見出し
h2.ui-static-heading.ui-static-heading-size-huge.font-normal.tab-1-heading {
    font-weight: bold !important;
    font-size: 28px !important;
    color: #2e7d32 !important;
    margin-top: 40px !important;
    margin-bottom: 0px !important;
    padding-top: 0 !important;
    text-align: center;
    align-items: center;
    position: static !important; 
    display: flex !important;
    flex-direction: column-reverse !important;
}

/* サブタイトル
section.tab-1 span.ui-static-heading-subtitle {
    display: block !important;
    position: static !important;
    transform: none !important;
    margin-bottom: 10px !important;
    font-size: 16px !important;
    font-weight: bold;
}

/* 人気No.1を強調
section.tab-1 .highlight-text {
	font-weight: bold;
	font-size: 13px;
	color: #342715;
	background: linear-gradient(transparent 55%, #fcdf52 55%);
	padding: 0px 0px 0px 2px;
}

/****リスト全体
.ui-static-grid-list.ui-static-grid-col-1.ui-static-grid-space-01 {
	margin-top:40px
}

/* --- カードの囲い（デザイン・色は維持）
.layout-e .ui-static-item-card {
    display: block !important;
    border: 1px solid #2e7d32; 
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 24px; 
    background-color: #ffffff;
    min-height: 0 !important;
}

/* --- 上側：画像エリア
.layout-e .ui-static-image {
    display: block !important;
    width: 100% !important;
    flex: none !important;
    padding: 8px;
    margin-bottom: 0 !important;
}

.layout-e .ui-static-image-container {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    border-radius: 2px;
    overflow: hidden;
}

.layout-e .ui-static-image-container img {
    width: 100%;
    height: 100%;
    object-fit: cover; 
}

/* --- 下側：テキスト詳細エリア
.layout-e .ui-static-item-card-details {
    display: block !important;
    width: 100% !important;
    padding: 15px 20px 20px 20px !important;
    text-align: left;
}

/* --- カード内見出し（色・フォント設定を維持）
.layout-e .ui-static-item-card-details h3.ui-static-heading {
    display: flex !important;
    align-items: baseline;
    gap: 8px;
    margin-top: 0 !important;
    margin-bottom: 8px !important;
    color: #2e7d32;
    font-size: 20px !important;
    font-weight: 600 !important;
}

/* 世界遺産アイコン
.world_heritage-icon {
    width: auto;
    height: 20px;
    flex-shrink: 0;
    position: relative;
    top: 2px;
}


/* --- カード内説明文（フォント設定を維持）
.layout-e .ui-static-item-card-description {
    margin: 0;
    font-size: 15px !important;
    font-weight: 400 !important;
    line-height: 1.6;
    color: #333333;
    text-align: left;
    display: block;
}


/* 食事エリア

.meal-banner-container {
  margin-top: 0px;
  padding: 0px;
  width: 100%;
}

.meal-banner-bar {
  background-color: #ff264f;
  color: #ffffff;
  text-align: center;
  padding: 12px 20px;
  border-radius: 0px;
  font-weight: bold;
  font-size: 16px;
  line-height: 1.4;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.meal-banner-subtext {
  margin-top: 10px;
  text-align: center;
  font-size: 13px;
  color: #333333;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.5;
}


/* --- 2つ目のタブ専用のデザイン指定

/* タブ2の大見出し
.tab-2-heading {
    color: #cf3700 !important;
    margin-top: 0 !important;
    margin-bottom: 30px !important;
    padding-top: 0 !important;
    text-align: center;
	font-size: 28px;
	font-weight:bold;
}

/* キナバル公園とポーリン温泉(オレンジ枠）
.enjoy-kotakinabalu .ui-static-item-card-full-width {
    border-color: #cf3700 !important;
}

/* グリッド親要素
.tab-item-style-02 .ui-static-grid-list {
    display: block !important;
}

.tab-item-style-02 .ui-static-image-badge {
	background-color: #cf3700 !important;
}	

/* カード本体
.tab-item-style-02 .ui-static-item-card:nth-child(n+2) {
    width: 100% !important; 
    flex: none !important;
    border: 1px solid #cf3700 !important;
    background-color: #ffffff;
    border-radius: 4px;
    overflow: hidden;
    display: block !important;
    margin-bottom: 24px !important;
}

/* 画像エリア
.tab-item-style-02 .ui-static-item-card:nth-child(n+2) .ui-static-image {
    width: 100% !important;
    max-width: 100% !important;
    padding: 15px 15px 0 15px !important;
    margin-bottom: 0 !important;
    aspect-ratio: auto !important; 
    height: auto !important;
    min-height: 0 !important;
    
    display: block !important;
    background: transparent !important;
}

/* テキストエリア
.tab-item-style-02 .ui-static-item-card:nth-child(n+2) .ui-static-item-card-details {
    width: 100% !important;
    padding: 10px 15px 20px 15px !important; /* 下側のパディングを調整 
    display: block !important;
}

/* 文字色・サイズ（変更なし）
.layout-e.tab-item-style-02 .ui-static-item-card-details h3.ui-static-heading {
    color: #cf3700 !important;
    font-size: 20px !important;
    margin-bottom: 8px !important;
    line-height: 1.4 !important;
    text-align: left !important;
}

.tab-item-style-02 .ui-static-item-card-description {
    color: #333333 !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
    margin: 0 !important;
    text-align: left !important;
}

.tab-item-style-02 .ui-static-image-container {
    width: 100% !important;
    height: auto !important;
    position: static !important;
}

/* 画像自体のフィット設定 
.tab-item-style-02 .ui-static-image-container img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
}

/* --- ２つから選べるオプショナルツアー

/* 見出し（ブルー）
.tab-2-heading.color-blue {
    color: #2176ba !important;
    margin: 40px 0 30px !important;
    text-align: center;
	font-size: 28px;
	font-weight:bold;
}

/* 1. グリッド親要素
.tab-item-style-03 .ui-static-grid-list {
    display: block !important;
    width: 100% !important;
}

/* 2. カード本体
.layout-e.tab-item-style-03 .ui-static-item-card.ui-static-item-card-half-width {
    width: 100% !important;
    flex: none !important;
    display: block !important; /* flex-direction: row を解除
    border: 1px solid #2176ba !important;
    background-color: #ffffff;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 24px !important;
}

/* 3. 上側：画像エリア（バッジと画像を含むエリア）
.tab-item-style-03 .ui-static-item-card.ui-static-item-card-half-width .ui-static-image {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 15px 15px 0 15px !important;
    height: auto !important;
    background: none !important;
}

/* バッジ（プランA/B） 
.ui-static-image-badge {
    display: block !important;
    width: 100% !important;
    background-color: #2176ba !important;
    color: #ffffff !important;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    padding: 6px 0;
    margin-bottom: 12px !important;
    border-radius: 50px;
}

/* 4. 画像コンテナ（バッジの下に配置）
.tab-item-style-03 .ui-static-image-container {
    width: 100% !important;
    position: relative !important;
    height: 0 !important;
    padding-top: 60% !important;
    overflow: hidden !important;
    border-radius: 2px;
    margin-bottom: 0 !important;
}

.tab-item-style-03 .ui-static-image-container img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* 5. 下側：テキスト詳細エリア 
.tab-item-style-03 .ui-static-item-card.ui-static-item-card-half-width .ui-static-item-card-details {
    display: block !important;
    width: 100% !important;
    padding: 15px 20px 20px 20px !important; 
}

/* テキストスタイル（色・サイズ維持）
.layout-e.tab-item-style-03 .ui-static-item-card-details h3.ui-static-heading {
    color: #2176ba !important;
    font-size: 20px !important;
    margin-bottom: 8px !important;
    line-height: 1.4 !important;
    text-align: left !important;
    display: block !important;
}

.tab-item-style-03 .ui-static-item-card-description {
    color: #333333 !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
    text-align: left !important;
    margin: 0 !important;
}

/****おすすめホテル****/

/* セクション背景 
.hotel-section {
    background-color: #fffdf2 !important;
	padding: 20px 10px;
}

/* 見出し 
.hotel-section h2.ui-static-heading.ui-static-heading-size-enormous.ui-static-heading-center.ui-static-heading-with-icon.heading-hotel {
    margin-top: 20px;
    margin-bottom: 10px;
    color: #f39800 !important;
    font-weight: bold !important;
}

.hotel-grid {
    display: block !important;
    padding: 10px;
}

/* カード本体（オレンジ枠）
.hotel-card {
    width: 100% !important;
    flex: none !important;
    background-color: #ffffff;
    border: 2px solid #f39800 !important;
    border-radius: 4px;
    margin-bottom: 20px !important;
    display: block !important;
}

.hotel-content {
    padding: 20px !important; /* SP用に余白を少し調整 */
    display: block !important;
}

/* タグ（丸枠見出し）
.tag {
    display: inline-block;
    border: 1px solid #f39800;
    color: #f39800;
    font-size: 11px; /* 少し縮小
    font-weight: bold;
    padding: 2px 10px;
    border-radius: 50px;
    margin-bottom: 4px;
}

/* ホテル名とアイコンのコンテナ（SP用調整）
.hotel-header-container {
    display: flex;
    align-items: center; 
    gap: 10px;
    margin: 15px 0 !important;
    width: 100%;
}

.hotel-header-container .hotel-name {
    margin: 0 !important;
    font-size: 19px !important;
    flex: 0 1 auto;
}

.hotel-section h3.hotel-name {
	font-weight: bold !important;
	color: #f39800 !important;
}
	
	
/* ★ゴルフアイコンを枠内に収める修正★ 
.icon-box {
    position: relative;
    flex: 0 0 100px;
	min-width: 50px;
    height: 60px;
    display: flex;
    align-items: center;
}

.golf-icon {
    position: static !important;
    transform: none !important;
    width: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    height: auto !important;
}

/* キャッチコピー・説明文
.hotel-catch {
    font-weight: bold !important;
    color: #333333;
    font-size: 15px !important;
    margin-bottom: 10px !important;
}

.hotel-description {
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: #333333;
    margin-bottom: 20px !important;
}


.hotel-images {
    display: flex !important;
    gap: 10px;
    margin-top: 15px;
}

.hotel-images .img-box {
    width: 50% !important;
	flex: 1;
    aspect-ratio: 4 / 3;
    margin-bottom: 0px;
    background-color: #dfedff;
    overflow: hidden;
    border-radius: 2px;
}

.hotel-images .img-box:last-child {
    margin-bottom: 0;
}

.hotel-images img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/****おすすめツアー



section.tour h2.ui-static-heading.ui-static-heading-size-enormous.ui-static-heading-center.ui-static-heading-with-icon.heading-tour {
	color:#333333;
	font-weight:bold !important;
	margin-top: 0px;
	margin-bottom: 10px;
}

.heading-tour-title{
	font-weight:bold;
}

.tour-section .ui-static-heading-subtitle {
	white-space: nowrap;
}	

.tour-section02 .ui-static-heading-subtitle {
	white-space: nowrap;
}	

.color-green {
	color:#2e7d32;
}

.ui-static-heading.ui-static-heading-size-enormous.ui-static-heading-center.heading-tour-title.color-green {
 font-size: 20px;
	}

/* --- セクション全体 ---
.tour-section {
    background-color: #f5f4fd;
    padding: 40px 10px 40px 10px;
}

/****ツアー見出し部分
.point-heading-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-top: 0;
    margin-bottom: 10px;
}

/****タグ

.tour-tag.size-small.color-purple {
	display: inline-block;
	border: 1px solid #6f23f2;
	color:#6f23f2;
	background-color:#FFFFFF;
	font-size: 16px;
    font-weight: bold;
    padding: 2px 12px;
    border-radius: 50px;
}

/****ツアー名見出し

.tour span.ui-static-heading-subtitle {
	margin-bottom: 20px;
}

h4.ui-static-heading.ui-static-heading-size-huge.ui-static-heading-left.ui-static-heading-with-subtitle-top {
	font-weight:bold;
	margin-top: 10px;
	margin-bottom: 0px;
	}

.tour .ui-static-container h4 p {
	margin-top: 20px;
	}

.tour span.ui-static-heading-subtitle {
	margin-bottom: 20px;
}

/****ツアーポイントリスト

/* 外側の枠
.point-list-wrapper {
  margin: 0 auto !important;
  width: 90%;
  padding: 0px 20px;
  background-color: #ffffff;
}

/* リスト全体
.point-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.point-item {
  display: flex;
  align-items: center;
  padding: 5px 5px 5px 5px;
  margin: 20px 5px 30px 5px;
  border-bottom: 2px dashed #d63384;
  border-bottom-weight:bold;
}

/* 画像コンテナ
.point-icon {
  width: 35px;
  height: 35px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
　margin-right: 10px;
}

/* 画像 
.point-icon img {
  width: 100%;
  height: auto;
  display: block;
}

/* テキスト
.point-text {
  margin-botton: 0px;
  font-size: 16px;
  font-weight: bold;
  color: #333333;
  line-height: 1.5;
}

/* 商品カード下のボタン

.ui-static-button.ui-static-button-secondary.ui-static-button-large.tour {
 margin: 0 auto;
 display: flex;
 justify-content: center;	
}

/* ２つめのツアー

.tour-section02 {
    background-color: #f4ffef;
    padding: 40px 10px 40px 10px;
}

.point-item.color-green {
  display: flex;
  align-items: center;
  padding: 5px 5px 5px 5px;
  margin: 20px 5px 30px 5px;
  border-bottom: 2px dashed #50d528;
  border-bottom-weight:bold;
}

/* 画像コンテナ
.point-icon.color-green {
  width: 35px;
  height: 35px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
　margin-right: 10px;
}

/* 画像
.point-icon.color-green img {
  width: 100%;
  height: auto;
  display: block;
}

.tour-tag.size-small.color-green {
	display: inline-block;
	border: 1px solid #2e7d32;
	color:#2e7d32;
	background-color:#FFFFFF;
	font-size: 16px;
    font-weight: bold;
    padding: 2px 12px;
    border-radius: 50px;
}

/****おすすめ特集****/
.tokusyuWrap {
 margin-top:80px;
}

.tokusyuWrap .title-section-category {
 text-align:center;
 font-size:28px;
 font-weight: bold;
}

.tokusyu, .reco-banner__list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 15px;
  padding: 15px;
  box-sizing: border-box;
}

.reco-banner__item {
  width: calc(50% - 10px); 
  box-sizing: border-box;
}

.tokusyu li a, .reco-banner__link {
  display: block;
  box-shadow: 0px 0px 0px 1px #000;
  transition: opacity .4s;
}
.tokusyu li a:hover, .reco-banner__link:hover {
  box-shadow: 0px 0px 0px 2px #000;
  opacity: 0.6;
}
.tokusyu li img, .reco-banner__image {
  width: 100%;
}