@charset "UTF-8";
/* =========================================================
	共通
========================================================= */
img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
  line-height: 0;
}
li {
  list-style: none;
}
/*a {
  text-decoration: none;
}*/
a:hover {
  opacity: .7;
  transition: .2s;
}
strong {
  font-weight: bold;
}
.sp {
  display: none;
}
@media only screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
}
.wp_in {
  width: 100%;
  max-width: 1070px;
  margin: 0 auto;
}

.wp_in.add-flow {
	padding:0 10px;
  width: 100%;
  max-width: 1220px;
  margin: 0 auto;
}

@media only screen and (max-width: 1200px) {
	.wp_in {
		width: 90%;
	}
}
@media only screen and (max-width: 768px) {
	.wp_in {
		width: 100%;
	}
}

.mb0 {
	margin-bottom: 0 !important;
}

.pdb0 {
	padding-bottom: 0 !important;
}

/* =========================================================
	header
========================================================= */
header {
	background-color: #fff;
}
.hd {
	border-bottom: 5px solid #E60000;
}
.hd_in {
	max-width: 1200px;
	display: flex;
	align-items: center;
	align-content: center;
	justify-content: space-between;
	width: auto;
	padding: 30px 20px 25px;
	box-sizing: content-box;
	margin: 0 auto;
}
.hd_logo {
	width: 153px;
	height: 37px;
	text-indent: -9999px;
	white-space: normal;
	overflow: hidden;
	background-image: url("../imgs/logo_mufg.svg");
	background-repeat: no-repeat;
	background-position: top left;
	background-size: 153px auto;
}
.hd_in a {
	display: block;
}
.hd_ufj {
	width: 133px;
	height: 20px;
	text-indent: -9999px;
	white-space: normal;
	overflow: hidden;
	background-image: url("../imgs/logo_bank.svg");
	background-repeat: no-repeat;
	background-position: top left;
	background-size: 133px auto;
}
.hd_in.biz {
	padding-top: 13px;
	padding-bottom: 15px;
}
.hd_biz {
	width: 110px;
	height: 22px;
	text-indent: -9999px;
	white-space: normal;
	overflow: hidden;
	background-image: url("../imgs/logo_biz.svg");
	background-repeat: no-repeat;
	background-position: top left;
	background-size: 110px auto;
}
@media only screen and (max-width: 768px) {
	.hd {
		border-bottom: 4px solid #E60000;
	}
	.hd_in {
		padding: 20px 15px;
	}
	.hd_logo {
		max-width: 95px;
		width: 47.02%;
		height: 25px;
		background-size: 94px auto;
	}
	.hd_ufj {
		width: 85px;
		height: 15px;
		background-size: 100% auto;
	}
	.hd_in.biz {
		padding: 20px 15px;
	}
	.hd_biz {
		width: 66px;
		height: 13px;
		background-size: 100% auto;
	}
}

/* =========================================================
	■kv-sec
========================================================= */
.main-wrap {
	margin: 0 auto 0;
	max-width: 1920px;
}

/* =========================================================
	kv_area
========================================================= */
.kv-area {
  min-height: 670px;
  max-height: 670px;
  height: 100%;
  overflow: hidden;
  background-size: cover;
  background-position: center;
}

.kv-area {
  background-image: url("../imgs/kv_bg.png");
}

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

.kv-area .kv img {
	max-width: 1130px;
}

/* ▼ 1130px 以下では高さをリキッドに変える */
@media screen and (max-width: 1130px) {
  .kv-area {
    height: auto;      /* 固定を解除 */
    min-height: 0;     /* 必要なら削除 */
    max-height: none;  /* 670px の上限を外す */
  }

  .kv-area h1 img {
    width: 100%;
    height: auto;      /* 画像も自然に縮む */
    object-fit: contain; /* cover のままでも可 */
  }
}

/* =========================================================
	キャンペーン
========================================================= */

/* ▼ PC 基本（背景画像あり） */
.campaign-area {
  position: relative;
  margin: 0 auto 80px;
  width: 100%;
  max-width: 1920px;

  /* 下地色（1070px以下で画像なしにする際も使う） */
  background-color: #f8dede;

  background-image: url("../imgs/campaign_bg.png");
  background-repeat: repeat-y;
  background-position: top center;
  background-size: 1920px auto;

  overflow: hidden;
}

@media (max-width: 1070px) {
  .campaign-area {
    background-image: none !important;
    background-color: #f8dede;
  }
}

@media (max-width: 767px) {
  .campaign-area {
    margin-bottom: 40px;
    background-image: url("../imgs/campaign_bg_sp.png") !important;
    background-repeat: repeat-y;
    background-position: top center;
    background-size: 100% auto;
  }
}



/* =========================================================
	contents-area
========================================================= */
.contents-area {
	margin: 0 auto 0;
	padding: 50px 20px 70px;
	max-width: 1240px;
}

.contents-area.bottom {
	padding: 0px 20px 60px;
}

@media only screen and (max-width: 768px) {
.contents-area {
	padding: 25px 10px 0px;
}
	
.contents-area.bottom {
	padding: 0px 20px 60px;
}
}

.info-area {
	margin: 0 auto 0;
	padding: 15px 40px;
	max-width: 1070px;
	background: #fff;
}

.info-list {
	font-size: 1.6rem;
}

.info-list > li {
	margin-top: 20px;
}

.info-list > li:first-child {
	margin-top: 0;
}

.info-list a {
	color: #003399;
	text-underline-offset: 2px;
}

@media only screen and (max-width: 768px) {
.info-area {
	margin: 0 10px;
	padding: 4vw 4vw;
}

.info-list {
	font-size: 4.3vw;
}	
}


/*アイコン（別ウインドウ）*/
.add-window {
  position: relative;
  padding-right: 24px; /* アイコンの余白（調整可） */
}

.add-window-w {
  position: relative;
  padding-right: 24px; /* アイコンの余白（調整可） */
}


.add-window::after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 13px;
  background: url("../imgs/icon_window.svg") no-repeat center / contain;
  margin-left: 10px; /* テキストとの隙間 */
}

.add-window-w::after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 13px;
  background: url("../imgs/icon_window_w.svg") no-repeat center / contain;
  margin-left: 10px; /* テキストとの隙間 */
}

/*アイコン（注意）*/
.add-caution {
  position: relative;
  padding-left: 38px; /* アイコン分の余白（調整可） */
}

.add-caution::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.1em; /* テキストと高さを揃えるため 少し下げる */
  width: 31px;
  height: 28px;
  background: url("../imgs/icon_caution.svg") no-repeat center / contain;
	vertical-align: middle;
}


/*概要
=============================*/
.overview {
	margin: 50px auto 0;
	max-width: 1070px;
}

@media only screen and (max-width: 768px) {
.overview {
	margin: 5.5vw auto 0;
}	
}

/*対象商品
=============================*/
.area-frame {
	margin: 80px auto 0;
	/*padding: 10px;*/
	max-width: 1044px;
	background: #faf4da;
	border: solid 4px #d80c18;
	border-radius: 20px;
}

.area-frame.product {
	padding: 40px 40px 55px;
}

/**/
.elig-ttl-area {
	padding: 10px 20px 0;
	background: url("../imgs/elig_ttl_bg.svg") no-repeat top right;
}

@media only screen and (max-width: 1000px) {
.elig-ttl-area {
	padding: 10px 20px 0;
	background: url("../imgs/elig_ttl_bg.svg") no-repeat top right;
	background-size:12%;
}
}

.elig-ttl {
	margin: 0 auto 0;
	max-width: 540px;
}

.elig-intro {
	margin-top: 22px;
	font-size: 1.8rem;
}

@media only screen and (max-width: 768px) {
.area-frame {
	margin: 30px auto 0;
	border-radius: 30px;
}
.area-frame.product {
	margin:8vw 10px 0;
	padding: 5px 5px 30px;
}
	
.elig-ttl-area {
	padding: 0;
	background: none;
}
	
.elig-ttl {
	max-width: none;
}
	
.elig-intro {
	margin-top: 0;
	padding: 3vw 2vw 0;
	display: block;
	font-size: 5vw;
}
}

/*株式リスト
-----------------*/
.stock-cate-list {
	margin: 30px auto 0;
}

.stock-cate-list > li {
	margin-top: 30px;
}

.stock-cate-list > li:first-child {
	margin-top: 0;
}


@media only screen and (max-width: 768px) {
.stock-cate-list {
	margin: 4vw 2vw 0;
}
	
.stock-cate-list > li {
	margin-top: 4.5vw;
}

}

/* ▼ 外枠と角丸はここで統一管理 */
.stock-cate-box {
  overflow: hidden;
}

/* ▼ タイトルバー（角丸は付けない！） */
.stock-cate-ttl {
  height: 80px;
  font-size: 30px;
  font-weight: bold;
  color: #fff;
	border-radius: 10px;
  background: #ea8f41;
  display: flex;
  align-items: center;
  justify-content: center;
  
  position: relative;
  cursor: pointer;
}

@media only screen and (max-width: 768px) {
.stock-cate-ttl {
  height: 15.5vw;
  font-size: 6.5vw;
	border-radius: 8px;
}	
}

/* ▼ 矢印回転 */
.stock-cate-ttl::after {
  content: "";
  position: absolute;
  right: 24px;
  top: 50%;
  width: 18px;
  height: 18px;
  transform: translateY(-50%) rotate(0deg);
  transform-origin: 50% 50%;
  background: url("../imgs/arrows_d.svg") no-repeat center / contain;
  transition: transform 0.25s ease;
}

.stock-cate-ttl.is-open::after {
  transform: translateY(-50%) rotate(180deg);
}

.stock-cate-ttl.is-open {
	border-radius: 10px 10px 0 0;
}

/* ▼ アコーディオンエリア（角丸なし） */
.stock-cate-area {
  display: none;
  background: #fff;
  padding: 24px 40px 40px;
	border: solid 4px #ea8f41;
	border-top: none;
	border-radius: 0 0 10px 10px;
}

.stock-intro {
	font-size: 2.0rem;
}

@media only screen and (max-width: 768px) {
.stock-cate-area {
  display: none;
  padding: 15px;
	border: solid 3px #ea8f41;
	border-top: none;
	border-radius: 0 0 8px 8px;
}
	
.stock-intro {
	font-size: 4vw;
}	
}

/*ファンド種類テーブル
=============================*/
/**/
.stock-cate-box {
	margin-top: 20px;
}

.stock-type-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: auto;
}

@media only screen and (max-width: 768px) {
.stock-cate-box {
	overflow-x: scroll;
}
	
.stock-type-table {
	white-space: nowrap;
	}
}

/* th（上部赤エリア） */
.stock-type-table th {
  background-color: #d80c18;
  color: #fff;
	line-height: 1.4;
  padding: 8px;
  border: 1px solid #000;
	border-bottom: none;
  text-align: center;
	white-space: nowrap;
}

/* td 共通 */
.stock-type-table td {
	line-height: 1.4;
  padding: 8px;
  border: 1px solid #000;
  text-align: center;
}

@media only screen and (max-width: 768px) {
.stock-type-table th,.stock-type-table td {
	font-size:3.8vw;
	}
}

/* 1列目の td を左寄せ＆幅100% */
.stock-type-table td:first-child {
  text-align: left;
  width: 100%;
}

/* 行ごとの背景色（白／ピンク） */
.stock-type-table tbody tr:nth-child(odd) td {
  background-color: #ffffff;
  color: #000;
}
.stock-type-table tbody tr:nth-child(even) td {
  background-color: #fbefef; /* ご指定のピンク */
}

/* バッジ風ボタン */
.stock-type-table__badge {
	margin-left:15px;
  display: flex;
	align-items:center;
  padding: 0 12px;
	height:26px;
  border-radius: 100px;
  background-color: #2f74b5;
  color: #fff;
  font-size: 0.9em;
  white-space: nowrap;
}

/**/
.stock-type-table__fundset {
	display: flex;
	align-items: center;
}
/*通し番号*/
.stock-type-table__number {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 28px;
  height: 28px;
  background-color: #d80c18; /* 赤丸 */
  color: #fff;               /* 白文字 */
  font-size: 1.6rem;
  border-radius: 50%; /* 丸くする */
  margin-right: 6px; /* 文字との余白 */
  flex-shrink: 0;    /* 数字が潰れないように */
  line-height: 1;    /* 高さ調整（中央寄せ補助） */
}

@media only screen and (max-width: 768px) {
.stock-type-table__number {
  width: 6vw;
  height: 6vw;
  font-size: 3.6vw;
}	
}

/**/
.stock-type-table__fund a {
	color:#003399;
	text-underline-offset: 2px;
}

.stock-type-table__fund a:hover {
	color: #E60000;
}

/* 1行目の <th> */
.stock-type-table thead tr:first-child th:nth-child(1) {
  border-right-color: #fff; /* ファンド名称 右線 白 */
}

.stock-type-table thead tr:first-child th:nth-child(2) {
  border-left-color: #fff;  /* （※）ネット専用 左線 白 */
  border-right-color: #fff; /* （※）ネット専用 右線 白 */
}

.stock-type-table thead tr:first-child th:nth-child(3) {
  border-bottom-color: #fff; /* NISA 下線 白 */
}

/* 2行目の「つみたて投資枠」 */
.stock-type-table thead tr:nth-child(2) th:nth-child(1) {
  border-right-color: #fff; /* つみたて投資枠 右線 白 */
}

/* NISA（1行目 3番目の th）下線を白で表示 */
.stock-type-table thead tr:first-child th:nth-child(3) {
  border-bottom: 1px solid #fff; /* ← color だけでなく style も指定 */
}

.stock-notes {
	margin-top: 20px;
	font-size: 1.4rem;
}

.stock-notes > li {
	text-indent: -1em;
	padding-left: 1em;
}

@media (max-width:768px) {
.stock-notes {
	margin-top: 5vw;
	font-size: 3.2vw;
}
}

/*追従エリア
=============================*/
.follow-area {
	padding: 0 20px;
	/*height: 250px;*/
	height: 210px;
  background: rgba(255, 255, 255, 0.8);
	display: flex;
	align-items: center;
	justify-content: center;
}

.order-btn-list {
	width: 1010px;
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap:0 56px;
}

.order-btn-list .txt {
	margin: 0 auto 20px;
	max-width: 410px;
}

.order-btn-list .btn img {
  filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.3));
}


@media only screen and (max-width: 768px) {
.follow-area {
	padding: 0 10px;
	/*height: 250px;*/
	height: 210px;
}

.order-btn-list {
	width: 1010px;
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap:0 15px;
}

.order-btn-list .txt {
	margin: 0 auto 2vw;
	max-width: 40vw;
}
	
.order-btn-list .txt.ty2 {
	max-width: 45vw;
}
}

@media only screen and (max-width: 690px) {
.follow-area {
	padding: 0 10px;
	height: 140px;
}	
}

/*キャンペーン詳細
=============================*/
.area-frame.detail {
	margin: 10px auto 0;
	padding: 20px 35px 50px;
}

@media only screen and (max-width: 768px) {
.area-frame.detail {
	margin: 50px auto 0;
	padding: 5px 5px 10px;
}	
}

.detail-ttl {
	margin: 0 auto;
	max-width: 824px;
}

/*詳細テーブル*/
.campaign-detail-table {
	margin: 20px auto 0;
  width: 100%;
  border-collapse: collapse;
  font-size: 1.6rem;
}

.campaign-detail-table th,
.campaign-detail-table td {
  border: 1px solid #000;
  vertical-align: middle;
  color: #000;
}

@media only screen and (max-width: 768px) {
.campaign-detail-table {
	margin: 20px 10px 0;
  width: inherit;
  font-size: 4.5vw;
	line-height: 1.5;
}
	
.campaign-detail-table th,
.campaign-detail-table td {
  border: none;
  display: block;
}
	
}

.campaign-detail-table th {
	padding: 10px;
  background: #dfca8b;
	font-weight: normal;
	white-space: nowrap;
}

.campaign-detail-table td {
	padding: 10px 20px;
	width: 100%;
  background: #fff;
}

.campaign-detail-table td ul > li {
	text-indent: -1em;
	padding-left: 1em;
}

.campaign-detail-table td ul > li .circle {
	color: #dfca8b;
}

@media only screen and (max-width: 768px) {
.campaign-detail-table td {
	padding: 10px 0px 20px;
	width: 100%;
  background: inherit;
}	
}

/*NISA
=============================*/
.nisa-frame {
	margin: 80px auto 0;
	max-width: 1044px;
}

.nisa-inframe {
	padding: 50px 40px;
	text-align: center;
	background: #fff;
	border: solid 4px #ea8f41;
	border-radius: 0 0 20px 20px;
}

.nisa-intro {
	font-size: 22px;
	font-weight: bold;
	line-height: 1.5;
}

@media only screen and (max-width: 768px) {
.nisa-frame {
	margin: 30px auto 0;
}
	
.nisa-inframe {
	padding: 0px 0px 40px;
	border: solid 4px #ea8f41;
	border-radius: 0 0 30px 30px;
}

.nisa-intro {
	padding: 15px 20px;
	font-size: 5vw;
	line-height: 1.5;
	text-align: left;
}	
}

/**/


/* ▼ PC：リキッド比率配置（590 : 45 : 325） */
.nisa-present {
  margin-top: 35px;
  max-width: 960px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  gap: 0;
}

/* 左：590px → 61.458% */
.nisa-present > .plan {
  flex: 0 0 61.458%;
}

/* 中：45px → 4.687% */
.nisa-present > .nisa-plan-arrows {
  flex: 0 0 4.687%;
  display: flex;
  align-items: center;
  justify-content: center;
	padding: 0 10px;
}

/* 右：325px → 33.854% */
.nisa-present > .present {
  flex: 0 0 33.854%;
}

/* ▼ SP：3要素すべて縦1列 */
@media (max-width: 768px) {
  .nisa-present {
    flex-direction: column;
    align-items: center; /* 横幅を中央寄せする場合 */
  }

  .nisa-present > li {
    width: 100%;
    flex: none;
    max-width: 100%;
  }

  .nisa-plan-arrows {
    margin: 10px 0; /* 任意で調整可 */
  }
  .nisa-plan-arrows img {
		width: 11vw;
	}
	
}


/**/
.nisa-plan-set {
	padding: 12px;
	background: #ea8f41;
	border-radius: 20px;
}

.nisa-plan-ttl {
	margin: 0 auto;
	max-width: 466px;
}

.nisa-plan-list {
	margin-top: 7px;
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap:0 10px;
}

@media only screen and (max-width: 768px) {
.nisa-plan-set {
	padding: 18px 25px;
	border-radius: 0px;
}

.nisa-plan-ttl {
	margin: 0 auto;
}

.nisa-plan-list {
	margin-top: 13px;
	display: grid;
	grid-template-columns: repeat(1,1fr);
	gap:15px 0px;
}
}

@media only screen and (max-width: 690px) {
.nisa-plan-ttl {
	margin: 0 auto;
	padding:0 8vw;
}	
}

.nisa-present .present {
	text-align:left;
}

.nisa-present .present-notes {
	margin-top: 10px;
	font-size: 1.45rem;
	line-height: 1.6;
}

.nisa-notes {
	margin-top: 25px;
	font-size: 20px;
	line-height: 1.6;
}

@media only screen and (max-width: 768px) {
.nisa-present .present {
	margin-left: 0px;
	padding: 0px 16px 0;
}

.nisa-present .present-notes {
	margin-top: 10px;
	font-size: 3.8vw;
	line-height: 1.5;
}

.nisa-notes {
	margin-top: 20px;
	font-size: 5vw;
	line-height: 1.6;
}	
}

.nisa-btn {
	margin: 20px auto 0;
	max-width: 804px;
}

.nisa-btn img {
	filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.3));
}

@media only screen and (max-width: 768px) {
.nisa-btn {
	margin: 20px 16px 0;
}	
}

.support-plan-btn {
	margin: 20px auto 0;
	max-width: 804px;
}

.support-plan-btn a {
	display: block;
	color: #fff;
	text-decoration: none;
}

.support-plan-btn p {
	height: 100px;
	font-size: 2.6rem;
	font-weight: bold;
	color: #fff;
	line-height: 1.4;
	background: #eb4275 url("../imgs/arrows_r_w.svg") no-repeat right 54px center;
	background-size: 14px;
	border: solid 2px #fff;
	border-radius: 100px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	filter: drop-shadow(2px 4px 8px rgba(0, 0, 0, 0.4));
}

.support-plan-btn .add-window-w {
	padding-left:60px;
}

.support-plan-btn .add-window-w::after {
	margin-left: 20px;
}

@media only screen and (max-width: 768px) {
.support-plan-btn {
	margin: 20px 17px 0;
}
.support-plan-btn p {
	height: 26vw;
	font-size: 5.2vw;
	line-height: 1.3;
	background: #eb4275 url("../imgs/arrows_r_w.svg") no-repeat right 3.5vw center;
	background-size: 2.7vw;
	border: solid 3px #fff;
	filter: drop-shadow(2px 4px 8px rgba(0, 0, 0, 0.4));
}

.support-plan-btn .add-window-w {
	padding-left:40px;
}

.support-plan-btn .add-window-w::after {
	margin-left: 10px;
}	
}

/*申し込み方法
=============================*/
.howto-frame {
	margin: 80px auto 0;
	max-width: 1044px;
	padding: 50px 20px;
	text-align: center;
	background: #faf4da;
	border: solid 4px #d80c18;
	border-radius: 20px;
}

@media only screen and (max-width: 768px) {
.howto-frame {
	margin: 50px auto 0;
	padding: 24px 5px;
	border: solid 4px #d80c18;
	border-radius: 30px;
}	
}

.howto-ttl {
	margin: 0 auto 0;
	max-width: 546px;
}

.howto-intro {
	margin-top: 23px;
	font-size: 1.8rem;
	line-height: 1.7;
}

.howto-intro span {
	font-size: 2.2rem;
	font-weight: bold;
	color: #d80c18;
}

@media only screen and (max-width: 768px) {
.howto-intro {
	margin-top: 5.2vw;
	font-size: 4.8vw;
}

.howto-intro span {
	margin-top:1vw;
	font-size: 6vw;
	line-height:1.3;
	display:inline-block;
}	
}

.howto-guide-btn {
	margin: 10px auto 0;
	max-width: 800px;
}

.howto-guide-btn img {
	filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.3));
}

@media only screen and (max-width: 768px) {
.howto-guide-btn {
	margin: 0px 10px 0;
}
}

.invest-btn {
	margin: 40px auto 0;
	max-width: 800px;
}

.invest-btn p {
	height: 84px;
	font-size: 2.2rem;
	font-weight: bold;
	color: #d80c18;
	border: solid 2px #d80c18;
	border-radius: 100px;
	background: #fff url("../imgs/arrows_red.svg") no-repeat right 54px center;
	background-size: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.invest-btn a {
	display: block;
	text-decoration: none;
}

@media only screen and (max-width: 768px) {
.invest-btn {
	margin: 25px 15px 0;
}

.invest-btn p {
	height: 22vw;
	font-size: 5.7vw;
	line-height:1.3;
	border: solid 3px #d80c18;
	border-radius: 100px;
	background: #fff url("../imgs/arrows_red.svg") no-repeat right 4vw center;
	background-size: 2.7vw;
}
}

/* =========================================================
	ヘッジ
========================================================= */
/* ヘッジ */
.nisa2025_hedge {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 15px;
}
.caution_financial_products {
    background-color: #F2F2F2;
    padding: 30px;
}
.caution__ttl {
    position: relative;
    padding-left: 34px;
    font-weight: 700;
    margin-bottom: 10px;
}
.caution__ttl::before {
    position: absolute;
    content: "";
    background-image: url("../imgs/icon_caution.svg");
    background-size: contain;
    width: 24px;
    height: 21px;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
.caution__list_01 {
    margin-bottom: 20px;
}
.caution__list_01 li {
    padding-left: 18px;
    position: relative;
    margin-top: 5px;
}
.caution__list_01 li::before {
    content: '';
    position: absolute;
    display: block;
    width: 8px;
    height: 8px;
    background-color: #999;
    border-radius: 50%;
    top: .5em;
    left: 1px;
}
.caution__list_02 li {
    padding-left: 13px;
    position: relative;
    margin-top: 5px;
    font-size: 14px;
}
.caution__list_02 li::before {
    content: '';
    position: absolute;
    display: block;
    width: 5px;
    height: 5px;
    background-color: #333;
    border-radius: 50%;
    top: .55em;
    left: 1px;
}
.a-heading5 {
    font-size: 16px;
}
.m-collist-notes {
    font-size: 14px;
}
.nisa2025 p.a-fz-xs {
    font-size: 12px;
}
/* お問い合わせ */
.a-ico_arw-r {
    font-size: 14px;
}
.a-fz-l {
    font-size: 18px;
    font-weight: 700;
}
.a-fz-xl {
    font-size: 20px;
}
.m-linktel {
    font-size: 36px;
}
.o-section-s {
    margin-top: 0!important;
}
@media (max-width:768px) {
        .m-linktel {
        font-size: 29px;
    }
}
/* =========================================================
	footer
========================================================= */
.t-footer_bottom-popup .t-footer_copyright {
  font-size: 1.9rem;
}

.t-footer {
	/*padding-bottom: 250px;*/
	padding-bottom: 210px;
	}

.t-pagetop {
	z-index: 60 ;
	}

@media (max-width:768px) {
.t-pagetop {
  /*bottom: 150px;*/
	bottom: 220px;
}
	
.t-footer {
	/*padding-bottom: 140px;*/
	padding-bottom: 210px;
	}
	
.t-footer_bottom-popup .t-footer_copyright {
  font-size: 1.6rem;
}	
}

@media (max-width:490px) {
.t-pagetop {
  bottom: 150px;
}
	
.t-footer {
	padding-bottom: 140px;
	}	
}

/* =========================================================
	追従ボタン
========================================================= */
/* ▼ PC：.follow-area はスクロールで上部固定（is-fixed が付いたときだけ） */
@media screen and (min-width: 768px) {
  .follow-area {
    position: static;
    z-index: 20;
  }

  .follow-area.is-fixed {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
    /* 必要なら背景色 */
  }

}

@media screen and (min-width: 768px) {
  /* follow-area が固定になっている間だけ、下のエリアを押し下げる */
  .contents-area.bottom.is-follow-offset {
    margin-top: 340px; /* PC の .follow-area の高さに合わせる */
  }
}

/* =========================================================
   follow-area 共通（土台）
========================================================= */
.follow-area {
  padding: 0 20px;
  background: rgba(255, 255, 255, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 20;
}

@media screen and (max-width: 768px) {
.follow-area {
	margin-top: 30px;
}	
}

.order-btn-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* PC：follow-area が画面下で固定される */
.follow-area.is-fixed-bottom {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 50;
    margin: 0; /* 念のため */
  }

