@charset "UTF-8";
html,body{
	padding:0;
	margin:0;
	/*font-family: "Sawarabi Mincho", "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "游明朝", YuMincho, serif;*/
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
	font-weight: 400;
	/*background: #fff;*/
	background: rgb(255,255,255);
	line-height: 1.8em;
	color: #212121;
	position: relative;
}

body {
   text-size-adjust: 100%;
   -webkit-text-size-adjust: 100%;
}
body.home {
	font-family: "Sawarabi Mincho", "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "游明朝", YuMincho, serif;
}

@media print {
    body {
        zoom: 0.68;
        -webkit-print-color-adjust: exact;
    }
}

html, body { height: 100%;}
 
body > footer#footer {
  position: sticky;
  top: 100vh;
}

h1, h2, h3, h4 {
	font-family: "Sawarabi Mincho", "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "游明朝", YuMincho, serif;
}
h2.h2-page-title {
	position: relative;
	border-bottom: 5px solid #dee2e6;
	/*padding: 4px 4px;*/
	padding-bottom: .5rem;
	margin: 50px 0;
}
/*h2.h2-page-title::after {
  content:'';
  position: absolute;
  background: url("../images/h2wave.svg");
  display: block;
  width: 100%;
  height: 16px;
  background-repeat: repeat-x;
  background-size: contain;
}*/

h3.headlineH3 span {
    background: #fff;
	display: inline-block;
	padding-right: .5rem;
}
h3.headlineH3 {
    padding: 0.8rem 0 0;
    margin-bottom: 0.2rem;
	position: relative;
	overflow:hidden;
}
h3.headlineH3:after {
    content: '';
	position: absolute;
	top: calc(50% + .4rem);
	display: inline-block;
	width: 100%;
	height: 1px;
	background-color: #ccc;
}
h4.headlineH4 {
  position: relative;
  display: inline-block;
  z-index: 1;
  overflow: hidden;
}

/* マーカーの擬似要素 */
h4.headlineH4::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0.1em;
  width: 100%;
  height: 40%;
  background: rgba(222, 226, 230, 0.5);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.8s ease-out;
  z-index: -1;
}

/* アニメーション開始用のクラス */
h4.headlineH4.marker-animate::before {
  transform: scaleX(1);
}


a {
	color: #715746;
}
a:hover {
	color: #033480;
	text-decoration: underline;
}
a.arrow-right:after {
	content: '';
	display: inline-block;
	margin-left: .5rem;
	height: 24px;
	width: 24px;
	background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21.5 12H0.5' stroke='black' stroke-width='1.5' stroke-miterlimit='10'/%3E%3Cpath d='M13.86 4.35999L21.5 12L13.86 19.64' stroke='black' stroke-width='1.5' stroke-miterlimit='10'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	
}

@media (min-width: 751px) {
	a[href*="tel:"] {
	pointer-events: none;
	cursor: default;
	text-decoration: none;
	}
}

.pcnone {display: block!important;}
.spnone {display: none!important;}

@media print, screen and (min-width: 769px) {
	.pcnone {display: none!important;}
	.spnone {display: block!important;}
}

.position-relative {
	position: relative;
}

strong { font-weight: 700; }

hr.wp-block-separator {
	height: 0;
	margin: 30px 0;
	padding: 0;
	border: 0;
	color: transparent;
	border-top: 3px solid #C3CCD5;
}


.inner {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
}

.flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.san-serif {
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}
.serif {
	font-family: "Sawarabi Mincho", "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "游明朝", YuMincho, serif;
}


/* body
--------------------------------*/


/* --------------------------------
	Header (Navigation)
-------------------------------- */
/*============
@keyframes
=============*/
@keyframes equalizer01 {
  0% {
    width: 70%;
  }
  10% {
    width: 50%;
  }
  20% {
    width: 100%;
  }
  30% {
    width: 10%;
  }
  40% {
    width: 50%;
  }
  50% {
    width: 70%;
  }
  60% {
    width: 50%;
  }
  70% {
    width: 10%;
  }
  80% {
    width: 100%;
  }
  90% {
    width: 10%;
  }
  100% {
    width: 70%;
  }
}
@keyframes equalizer02 {
  0% {
    width: 30%;
  }
  10% {
    width: 20%;
  }
  20% {
    width: 40%;
  }
  30% {
    width: 10%;
  }
  40% {
    width: 20%;
  }
  50% {
    width: 30%;
  }
  60% {
    width: 20%;
  }
  70% {
    width: 10%;
  }
  80% {
    width: 40%;
  }
  90% {
    width: 10%;
  }
  100% {
    width: 30%;
  }
}

/* ハンバーガーメニュー*/
.nav-ham {
  display: none;
  position: absolute;
  top: 10px;
  right: 10px;
  width: 60px;
  height: 50px;
  transform: translate(0, 0);
  transition: all .5s;
  cursor: pointer;
  z-index: 10000;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2240%22%20height%3D%2240%22%20viewBox%3D%220%200%2040%2040%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Ccircle%20cx%3D%2220%22%20cy%3D%2220%22%20r%3D%2220%22%20fill%3D%22%23F3EBDC%22%2F%3E%3C%2Fsvg%3E');
  background-size: cover;
  background-repeat: no-repeat;
}

.nav-ham span {
  display: block;
  position: absolute;
  left: 10px;
  width: 30px;
  height: 2px;
  background-color: #666;
  transition: all .5s;
}
.nav-ham span:nth-child(1) {
  top: 15px;
  width: 60px;
  animation: equalizer01 7000ms infinite;
}
.nav-ham span:nth-child(2) {
  top: 25px;
  width: 30px;
  animation: equalizer02 5000ms infinite;
  animation-delay: 0.33s;
}
.nav-ham span:nth-child(3) {
  top: 35px;
  width: 20px;
  animation: equalizer02 5000ms infinite;
}


.header-sec {
    height: 55px;
    padding: 0 20px;
  }
.header-ul {
    display: none;
  }
  /*sp nav*/
.nav-ham {
    display: block;
    position: absolute;
  top: 10px;
  right: 10px;
  width: 50px;
  height: 50px;
  transform: translate(0, 0);
  transition: all .5s;
  cursor: pointer;
    z-index: 10000;
  }
  .open .nav-ham {
    position: fixed;
  }
.open .nav-ham span {
  background-color: #715746;
  width: 30px;
}
.open .nav-ham span:nth-child(1) {
  transform: translate(0, 10px) rotate(-45deg);
  animation: unset;
}
.open .nav-ham span:nth-child(2) {
  opacity: 0;
  animation: unset;
}
.open .nav-ham span:nth-child(3) {
  transform: translate(0, -10px) rotate(45deg);
  animation: unset;
}
  .open .nav-layout {
    visibility: visible;
    opacity: 1;
    transform: translateX(0);
  }
  
  .open .nav-layout nav ul.h-nav {
	background: #fff;
	width: 80%;
	margin: 60px auto 30px;
	border-radius: 30px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	
  }
  .open .nav-layout nav ul.h-nav li {
  width: 90%;
  } 
 .open .nav-layout nav ul.h-nav li:after {
	content: '';
	display: block;
  }
   .open .nav-layout nav ul.h-nav li:last-child {
  border-bottom: none;
  }
  .open .nav-layout ul li {
    transform: translateX(0);
  }
  .overlay {
    content: "";
    display: block;
    width: 0;
    height: 0;
    background-color: rgba(0, 0, 0, 0.5);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    opacity: 0;
    transition: opacity 0.5s;
  }
.nav-layout {
  position: fixed;
  background: rgba(243, 235, 220, 1);
  top: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  color: #715746;
  display: flex;
  justify-content: center;
  visibility: hidden;
  opacity: 0;
  transform: translateX(100%);
  transition: 0.5s ease-in-out;
  z-index: 5000;
}
.nav-layout nav {
  display: flex;
  flex-wrap: wrap;
}
.nav-layout a {
	text-decoration: none;
}
.nav-layout .h-lang {
  order: 2;
  width: 100%;
  margin-top: 0;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}
.nav-layout ul {
  text-align: center;
  padding-left: 0;
}

.nav-layout .h-nav {
  order: 1;
  width: 100%;
  /*margin-top: 46%;*/
  margin-top: 16%;
  font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}

.nav-layout ul.h-lang {
  text-align: center;
}
.nav-layout ul li {
  position: relative;

  transform: translateX(-200px);
  transition: transform 1.3s ease;
}

.nav-layout ul li:nth-child(2) {
  transition-delay: 0.15s;
}

.nav-layout ul li:nth-child(3) {
  transition-delay: 0.3s;
}

.nav-layout ul li:nth-child(4) {
  transition-delay: 0.45s;
}
.nav-layout ul li:nth-child(5) {
  transition-delay: 0.6s;
}
.nav-layout ul li:nth-child(6) {
  transition-delay: 0.75s;
}
.nav-layout ul li a {
  font-size: 1.2rem;
  color: #715746;
}
.nav-layout  ul.h-lang {
	display: flex;
	justify-content: center;
}
.nav-layout  ul.h-lang li {
  border-bottom: none;
}

.nav-layout  ul.h-lang li a {
  font-size: .8rem;
}

.nav-layout  ul.h-lang li a:before {
  content: '|';
  padding: 0 .5rem;
  color: #715746;
}
.nav-layout  ul.h-lang li:first-child a:before {
  content: '';
  padding-right: 0;
}


/* スマホ用の子メニューを非表示 */
.nav-layout ul.h-nav ul {
  display: none;
}
.nav-layout ul.h-nav li.open > ul {
  display: block;
}
.nav-layout nav ul.h-nav li ul li {
	margin:0 auto;
	padding: 5px 0;
	text-align: center;
}
.nav-layout nav ul.h-nav li ul li a {
	
	font-size: 1rem;
}


/* 矢印アイコンのスタイル */
.icon-chevron {
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-left: 10px;
  transition: transform 0.3s ease;
  fill: none;
  stroke: #715746;
  stroke-width: 2;
  vertical-align: middle;
}

/* 矢印の回転アニメーション */
.rotated {
  transform: rotate(180deg);
}



@media only screen and (min-width: 768px) {
	.nav-ham {
		display: none;
	}
	.nav-layout {
		justify-content: end;
	}
	.nav-layout,.open .nav-layout {
		position: relative;
		background: transparent;
		top: 0;
		right: 0;
		width: 100%;
		height: auto;
		/*color: #715746;*/
		color: #333;
		visibility: visible;
		opacity: 2;
		transform: none;
		transition: 0;
	}
	
	
	.nav-layout .h-lang {
		order: 1;
		width: 100%;
		margin-top: 0;
	}
	.nav-layout ul {
		text-align: center;
	}
	
	.nav-layout .h-nav {
		order: 1;
		width: 100%;
		margin-top: 0;
	}
	
	.nav-layout ul.h-lang {
		text-align: center;
		justify-content: end;
		margin: 0;
	}

	.nav-layout ul {
		list-style: none;
		position: relative;
		text-align: center;
		margin-top: 0;
		display: flex;
		width: 100%;
		justify-content: space-between;
		align-items: center;
		background: transparent;
	}
	.nav-layout ul li {
		font-size: 1rem;
		margin: 0 5px;
		position: relative;
		margin-bottom: 0;
		transform: none;
		transition: inherit;
	}
	.nav-layout ul li a {
		display: block;
		color: #333;
		font-weight: 400;
		padding-bottom: 3px;
		font-size: 1rem;
	}
	.nav-layout ul li a:hover {
		color: #999;
		transition: 0s;
	}
	.nav-layout ul li:nth-child(2),.nav-layout ul li:nth-child(3),.nav-layout ul li:nth-child(4),.nav-layout ul li:nth-child(5),.nav-layout ul li:nth-child(6){
		transition-delay: inherit;
	}
	.nav-layout  ul.h-lang li a:before {
		padding: 0 .5rem 0 0;
}


	.nav-layout nav ul.h-nav ul {
		transform: scaleY(0);/*デフォルトでは非表示の状態にしておく*/
		transform-origin: center top;/*変形を適応する基準をtopとする*/
		transition: all .3s;/*表示の変化を0.3秒に指定*/
		position: absolute;
		top: 30px;
		/*left: 0;*/
		left: -50px;
		background: #fff;
		box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
		/*border: 1px solid #715746;*/
		border: 1px solid #ccc;
	}
	
	.nav-layout nav ul.h-nav ul:after {
		bottom: 100%;
		/*left: 20px;*/
		left: 70px;
		border: solid transparent;
		content: "";
		height: 0;
		width: 0;
		position: absolute;
		pointer-events: none;
		border-color: rgba(113, 87, 70, 0);
		/*border-bottom-color: #715746;*/
		border-bottom-color: #ccc;
		border-width: 10px;
		margin-left: -10px;
	}
	
	
	.nav-layout nav ul.h-nav li.open ul {
		transform: scaleY(1);/*Gナビメニューにホバーしたら表示*/
		display:flex;
		flex-wrap: wrap;
		/*width: 18.5rem;*/
		width: 15rem;
		margin:0;
	}
	
	.nav-layout nav ul.h-nav li ul li {
		margin:0;
		padding: 10px;
	}
	.nav-layout nav ul.h-nav li.open ul li {
		transition: all .3s;
		position: relative;
		width: 100%;
	}
	.nav-layout nav ul.h-nav li.open ul li:not(:first-child)::before{
		content: "";
		width: 100%;
		height: 1px;
		/*background-color: #715746;*/
		background-color: #ccc;
		position: absolute;
		top: 0;
		left: 0;
	}
	.nav-layout nav ul.h-nav li.open ul li:hover {
		/*background-color: #715746;*/
		background-color: #ccc;
	}
	.nav-layout nav ul.h-nav li.open ul li:hover a {
		/*color: #fff;*/
		color: #333;
	}
	.nav-layout nav ul.h-nav li.open ul li a {
		display: flex;
		flex-wrap: wrap;
		/*justify-content: center;*/
		justify-content: start;
		align-items: center;
		/*color: #715746;*/
		color: #666;
		text-decoration: none;
		position: relative;
		width: 100%;
	}
	.nav-layout nav ul.h-nav li.open ul li a::before {
		content: '';
		display: block;
		width: 6px;
		height: 6px;
		/*border-top: 2px solid #715746;
		border-left: 2px solid #715746;*/
		border-top: 2px solid #ccc;
		border-left: 2px solid #ccc;
		transform: rotate(135deg);
		position: absolute;
		right: 15px;
		top: calc(50% - 5px);
	}
	.nav-layout nav ul.h-nav li.open ul li:hover a::before {
		border-top: 2px solid #fff;
		border-left: 2px solid #fff;
	
	}
	
	/* 矢印アイコンのスタイル */
	.icon-chevron {
		margin-left: 3px;
	}
}

/* --------------------------------
	Footer (Navigation)
-------------------------------- */
footer {
	background: #EEEEEF;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
	font-size: .85rem;
}

footer a {
	color: #184265;
	text-decoration: none;
}
footer .container .row div {
	display: flex;
}
footer ul {
	padding-left: 0;
}
footer ul ul {
	margin-left: 0;
	padding-left: 0;
}
footer ul ul li {
	position: relative;
	padding-left: .6rem;
	margin-left: .5rem;
}
footer ul ul li:before {
	position: absolute;
	content: '';
	background: #184265;
	height: .6rem;
	width: .3rem;
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	left: 0;
	top: .5rem;
}

footer .f-links {
	display: flex;
	flex-wrap: wrap;
	flex-flow: column;
	justify-content:flex-end;
}

/* contact
--------------------------------*/
a.f-contact{
	display: block;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	text-align: center;
	background: #B00015;
	color: #fff;
	padding: .5rem 2rem;
	font-size: .85rem;
	transition: .5s;
	z-index: 997;
	text-decoration: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}


a.f-contact:hover{
	text-decoration: none;
	background: #184265;
	transition: .5s;
}

@media print, screen and (min-width:768px) {
	a.f-contact{
		position: sticky;
		bottom: 50px;
		margin-bottom: -50px;
		left: auto;
		margin-left: auto;
		margin-right: 20px;
		height: 100px;
		width: 100px;
		border-radius: 50%;
		padding: .5rem 0;
		font-size: .85rem;
	box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.35);
		
	}
	a.f-contact span {
		display:inline;
		width: auto;
		line-height: 1rem;
		height: auto;
		margin:0 auto;
	}
	a.f-contact span {
		display:block;
		width: 100%;
		line-height: 1rem;
		height: 1rem;
		margin:1rem auto 0;
	}
}


/* Cookie consent
--------------------------------*/
.cky-consent-container,
.cky-modal,
.cky-consent-container,
.cky-btn-revisit-wrapper {
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}
.cky-notice-btn-wrapper button {
	font-weight: 400;
}
@media print, screen and (min-width:768px) {
	.cky-notice-btn-wrapper {
		min-width: 400px!important;
	}
}

/* Index
--------------------------------*/

#main-img {
	height: 500px;
}
.hero {
	margin-top: 30px;
	width: 100%;
/*	background: linear-gradient(to right, #ffffff 0%, #ffffff calc(50% + 125px), #F3EBDC calc(50% + 125px), #F3EBDC 100%);*/
	height: 250px;
}

.hero-image .clip-path {
	background: #F3EBDC;
	clip-path: inset(0 0 0 0 round 250px 0 0 0);
	height: 250px;
	width: 100%;
	overflow：hidden;
	margin-bottom: 30px;
}
.hero01-02 {

}
@media only screen and (min-width: 992px) {
	.hero {
		position: relative;
		height: 500px;
		background: linear-gradient(to right, #ffffff 0%, #ffffff calc(50% + 350px), #F3EBDC calc(50% + 350px), #F3EBDC 100%);
	}
	.hero-image .clip-path {
		clip-path: inset(0 0 0 0 round 500px 0 0 0);
		height: 500px;
		margin-bottom: 0;
	}
	.hero01-02 {
		
	}

}
.index-cTitle {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	padding: 2rem 0;
}
.index-cTitle h2 {
	margin-bottom: 0;
	font-size: 1.7rem;
}
.index-cTitle-list {
	margin-left: 2rem;
}
.index-cTitle-list a {
	text-decoration: none;
	color: #000;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	
}


/* Company */
#company-info {
	background: url('../images/bg-index01.jpg') center center no-repeat;
	background-size: cover;
}
.btn-company {
	display:block;
	background: #fff;
	padding: 30px 0px 30px 10px;
	border-radius: 20px;
	margin: 10px 0px;
	color: #000;
	text-decoration: none;
	font-size: .9rem;
	box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.35);
}
.btn-company:hover {
	text-decoration: none;
    background: #184265;
	transition: .5s;
	color: #fff;
}
@media only screen and (min-width: 992px) {
	#company-info {
		margin-top: 60px;
	}
	.btn-company {
		display:block;
		background: #fff;
		padding: 30px 0px 30px 25px;
		border-radius: 20px;
		margin: 10px 20px;
		color: #000;
		text-decoration: none;
		font-size: 1.1rem;
		box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.35);
	}
}

/* Business */
#IndexBusiness {
	background: #F1F8FF;
	padding-bottom: 50px;
}
@media only screen and (min-width: 768px) {
	#IndexBusiness {
		padding-bottom: 0;
	}
}
.tab_set {
    display: flex;
    flex-wrap: wrap;
    margin-top: 20px;
	justify-content: end;
	margin-top: -80px;
}

.tab_label {
    color: #fff;
    background: #8396A5;
    padding: 20px 30px;
    margin-left: 10px;
    order: -1;
    position: relative;
    line-height: 1.5;
    cursor: pointer;
	border-radius: 30px 30px 0 0;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
	text-align: center;
}
.tab_label:hover {
    background: #184265;
	transition: all .5s;
}

.tab_content {
    display: none;
    padding: 30px;
	background: #fff;
	border-radius: 30px 0 30px 30px;
}

.tab_switch:checked+.tab_label {
    background: #fff;
	color: #000;
}

.tab_switch:checked+.tab_label+.tab_content {
    display: block;
}

.tab_switch {
    display: none;
}
@media print,screen and (max-width:920px) {
    .tab_set {
		margin-top: 0;
    }
}
@media print,screen and (max-width:767px) {
    .tab_set {
        display: block;
		margin-top: 0;
    }
    .tab_label {
        display: block;
		border-radius: 30px;
		margin-left: 0px;
		margin-top: 20px;
    }
	.tab_switch:checked+.tab_label {
		border-radius: 30px 30px 0 0;
	}
    .travelclinic .tab_label.last {
        border-bottom: none;
    }

    .travelclinic .tab_switch:checked+.tab_label {
        border-bottom: 1px solid #59A8B7;
    }
	.tab_content {
		border-radius: 0 0 30px 30px;
	}
}

.index-slider {
	margin: 50px 0 0;
}
/* 各スライドのサイズ指定 */
.index-slider .slide {
  width: 25%;
  padding: 0;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .index-slider .slide {
    width: 50%;
  }
}

/* 正方形レイアウト */
.image-container {
  position: relative;
  width: 100%;
  padding-top: 100%; /* 正方形 */
  overflow: hidden;
  background: #f0f0f0;
}

.image-container img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* 横長画像 → 高さ100%で中央配置 */
.image-container.landscape img {
  height: 100%;
  width: auto;
}

/* 縦長画像 → 幅100%で中央配置 */
.image-container.portrait img {
  width: 100%;
  height: auto;
}

/* キャプション */
.image-container .caption {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 10rem;
  background: rgba(255, 255, 255, .8);
  color: #000;
  padding: 7px 10px;
  font-size: 14px;
  box-sizing: border-box;
  text-align: center;
}

.slick-dots {
	bottom: -50px;
}

.slick-dots li button:before { 
	font-size: 12px;
	color: #D9D9D9;
	opacity: 1;
}
.slick-dots li.slick-active button:before {
    color: #B00015;
}

/* FAQ */
#indexFaq {
	background: url('../images/bg-index03.png') center center no-repeat;
	background-size: cover;
	padding: 30px;
	margin: 0;
}
#indexFaq .container a {
	display: block;
	border: 5px solid #CCC0B8;
	background: #fff;
	margin: 50px auto;
	width: 80%;
	text-decoration: none;
	padding: 30px 50px;
}
#indexFaq .container a dl {
	margin:0;
	padding: 0;
	font-weight: 400;
}
#indexFaq .container a dl dt {
	font-size: 2rem;
	margin:0;
	padding: 0 0 1rem;
}
#indexFaq .container a dl dd {
	font-size: 1rem;
	margin:0;
	padding: 0;
}
@media (min-width: 768px) {
	#indexFaq .container a {
		width: 70%;
	}
	#indexFaq .container a dl {
		display:flex;
		align-items: center;
		justify-content: space-between;
	}
	#indexFaq .container a dl dt {
		width: 6rem;
		margin:0;
		padding: 0;
	}
	#indexFaq .container a dl dd {
		width: calc(100% - 8rem);
		margin:0;
		padding: 0;
	}
}

/* Recruitment */
#indexRecruit {
	background: #F3F3F3;
}
#indexRecruit .card {
	border: none;
	border-radius: 0;
	box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.35);
	max-width: 300px;
	margin: 0 auto;
	font-size: .85rem;
}
#indexRecruit .card-image {
	display:flex;
	align-items:center;
}

#indexRecruit .card-image img {
	display: block;
	object-fit: cover;
	height: 120px;
	width: 100%;
}
#indexRecruit .card-body a {
	position: relative;
	display:block;
	width: 100%;
	text-decoration: none;
	color: #000;
	padding: 5px 10px;
}
#indexRecruit .card-body a:hover {
	color: #033480;
	transition: all .5s;
}

#indexRecruit .card-body a:after {
	content: '';
	display: block;
	position: absolute;
	right: 0;
	top:.5rem;
	height: 20px;
	width: 20px;
	background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21.5 12H0.5' stroke='black' stroke-width='1.5' stroke-miterlimit='10'/%3E%3Cpath d='M13.86 4.35999L21.5 12L13.86 19.64' stroke='black' stroke-width='1.5' stroke-miterlimit='10'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	
}
#indexRecruit .card-body a:hover:after {
	background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21.5 12H0.5' stroke='rgb(24 61 101)' stroke-width='1.5' stroke-miterlimit='10'/%3E%3Cpath d='M13.86 4.35999L21.5 12L13.86 19.64' stroke='rgb(24 61 101)' stroke-width='1.5' stroke-miterlimit='10'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	
}
@media (min-width: 768px) {
	#indexRecruit .card {
		font-size: 1rem;
	}
	#indexRecruit .card-image img {
		height: 200px;
	}
	#indexRecruit .card-body a {
		padding: 10px 10px;
	}
	#indexRecruit .card-body a:after {
		top:.9rem;
		
	}
}

a.btn-entry {
position: relative;
	padding: 20px 50px;
	background: #B00015;
	color: #fff;
	text-decoration: none;
	border-radius: 40px;
	padding-right: 60px;
}
a.btn-entry:hover {
	background: #184265;
	transition: all .5s;
}
a.btn-entry:after {
	content: '';
	display: block;
	position: absolute;
	right: 20px;
	top:20px;
	height: 20px;
	width: 20px;
	background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21.5 12H0.5' stroke='white' stroke-width='1.5' stroke-miterlimit='10'/%3E%3Cpath d='M13.86 4.35999L21.5 12L13.86 19.64' stroke='white' stroke-width='1.5' stroke-miterlimit='10'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
}

a.btn-link {
position: relative;
	padding: 7px 30px;
	background: #B00015;
	color: #fff;
	text-decoration: none;
	border-radius: 30px;
	padding-right: 60px;
}
a.btn-link:hover {
	background: #184265;
	transition: all .5s;
	color: #fff;
}
a.btn-link:after {
	content: '';
	display: block;
	position: absolute;
	right: 10px;
	top:13px;
	height: 13px;
	width: 13px;
	background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21.5 12H0.5' stroke='white' stroke-width='1.5' stroke-miterlimit='10'/%3E%3Cpath d='M13.86 4.35999L21.5 12L13.86 19.64' stroke='white' stroke-width='1.5' stroke-miterlimit='10'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
}


/* Topics */
#topics {
}
#topics .col-6 {
	padding: 0 20px;
}
#topics .card {
	border: none;
	border-radius: 0;
	box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.35);
	margin: 0 auto 30px;
	font-size: .9rem;
}
#topics .card a {
	text-decoration: none;
	color: #000;
}
#topics .card a:hover {
	color: #184265;
}
#topics .card .topics-cat {
	display: inline-block;
	font-size: .75rem;
	line-height: .75rem;
	padding: 5px 15px;
	margin-right: 2px;
	margin-bottom: 1rem;
	background: #715746;
	color: #fff;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}
#topics .card .card-date {
	font-size: .85rem;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
	text-align: right;
}

@media (min-width: 768px) {
	.topics-items:after {
		content: "";
		display: block;
		width: 25%;
		height: 0;
	}
}

/* --------------------------------
	2ND Page Common
-------------------------------- */
.breadcrumb-item+.breadcrumb-item {
    font-size: .85rem;
}
breadcrumb-item+.breadcrumb-item::before {
    content: '';
}
.breadcrumb {
	margin:0;
}
.breadcrumb ul {
	display: flex;
	flex-wrap: wrap;
    font-size: .85rem;
	padding-left: 0;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
	color: #666;
}

.breadcrumb ul li a {
	padding-right: .5rem;
	color: #666;
}
.breadcrumb ul li:after {
	content: '>';
	padding: 0 .5rem;
}
.breadcrumb ul li:last-child:after {
	content: '';
}
/*@media (min-width: 768px) {
	.breadcrumb ul {
		padding-left: 20px;
	}
}*/


.h-catTitle {
  position: relative;
  height: 130px;
  display: flex;
  flex-wrap: wrap;
  align-items: start;
  justify-content: center;
  background: url('../images/bg-h-chattitle.png') center center;
  background-size: cover;
  overflow: hidden;
  margin-top: 50px;
}

.h-catTitle::before {
  content: '';
  position: absolute;
  top: -120%; /* 楕円の位置調整 */
  left: 50%;
  transform: translateX(-50%);
  width: 120%;
  height: 200%;
  background: white;
  border-radius: 50%;
  z-index: 1;
}

.h-catTitle .container {
  position: relative;
  z-index: 2;
  text-align: center;
}

.nav-links {
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	margin: 60px 0;
}
.nav-previous, .nav-next {
	max-width: 48%;
}
.nav-previous a, .nav-next a {
	color: #666;
	text-decoration: none;
	font-size: .9rem;
}

/* --------------------------------
	TOPICS
-------------------------------- */
.topics-list {
	width: 100%;
	border-bottom: dotted 1px #d1d1d1;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}
.topics-list .topics-date,
.important-notice .topics-date {
	width: 6rem;
	font-size: .85rem;
	line-height: 1.35rem;
	margin: .25rem 0;
}

.important-notice .topics-date {
	width: 6rem;
}
.topics-list .topics-cat {
	margin-bottom: .5rem;
}
.topics-list .topics-cat span,
.important-notice span  {
	font-size: .75rem;
	line-height: .75rem;
	padding: .2rem 15px;
	background: #715746;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
	color: #fff;
}
.topics-list .topics-text {
	width: 100%;
}
.topics-list .topics-text a,
.important-notice .topics-text a {
	color: #000;
	text-decoration: none;
}
.topics-list .topics-text a:hover,
.important-notice .topics-text a:hover {
	color: #715746;
	text-decoration: underline;
}
.important-notice {
	border: 1px solid #d1d1d1;
	border-left: 10px solid #B00015;
	border-radius: 10px;
	padding: 20px 20px 0px;
	margin: 30px 0;
	display: flex;
	flex-wrap: wrap;
}
.important-notice .cat-important {
	width: 8rem;
}
.important-notice span {
	font-size: .75rem;
	line-height: .75rem;
	padding: .2rem 15px;
	background: #B00015;
	color: #fff;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}


#topics .card .topics-cat.cat-corporate-news, .topics-list .topics-cat.cat-corporate-news span { background: #184265; }
#topics .card .topics-cat.cat-important-news, .topics-list .topics-cat.cat-important-news span { background: #B00015; }

.important-notice .topics-text {
		width: 100%;
}

@media screen and (min-width: 768px), print {
    .topics-list {

    }
	.topics-list .topics-date {
		font-size: .85rem;
		line-height: 1.35rem;
		margin-bottom: .5rem;
	}
	.topics-list .topics-cat {
		width: 8rem;
		margin-bottom: .5rem;
	}
	.topics-list .topics-text,
	.important-notice .topics-text {
		width: calc(100% - 14rem);
	}
}

/* --------------------------------
	Privacy Policy
-------------------------------- */
ol.list-privacy {
	padding: 1rem 0;
	list-style: decimal;
}
ol.list-privacy li {
	padding-bottom: 1rem;
}
/* --------------------------------
	table responsive
-------------------------------- */
table.table.table-rpsv {
	border: 1px solid #ccc;
	border-bottom: none;
}
table.table.table-rpsv th {
	background: rgba(0,0,0,0.05);
	border-bottom: 1px solid #ccc;
}
table.table.table-rpsv td {
	background: rgba(255,255,255,1);
	border-bottom: 1px solid #ccc;
}
table.table.table-rpsv th,
table.table.table-rpsv td {
	padding: 20px;
}

@media screen and (max-width: 640px) {
  table.table.table-rpsv {
    width: 100%!important;
  }
	table.table.table-rpsv th,
	table.table.table-rpsv td {
		display: block!important;
		width: 100%!important;
	}
}
/* --------------------------------
	Company info
-------------------------------- */
.btn-company02 a {
	position: relative;
	box-sizing: border-box;
	display:block;
	width: 100%;
	background: #fff;
	padding: 30px 0px 30px 45px;
	border-radius: 20px;
	margin: 10px 0px;
	color: #000;
	text-decoration: none;
	font-size: .9rem;
	box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.35);
	
}
.btn-company02 a:hover {
	text-decoration: none;
    background: #184265;
	transition: .5s;
	color: #fff;
	cursor: pointer;
}
.btn-company02 a:before {
	display:block;
	position: absolute;
	width: 20px;
	height: 20px;
	content: '';
	top: calc(50% - 11px);
	left: 1rem;
	background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22Layer_1%22%20data-name%3D%22Layer%201%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%221.5%22%20width%3D%2224%22%20height%3D%2224%22%20color%3D%22%23000000%22%3E%3Cdefs%3E%3Cstyle%3E.cls-63ce7424ea57ea6c8380058e-1%7Bfill%3Anone%3Bstroke%3AcurrentColor%3Bstroke-miterlimit%3A10%3B%7D%3C%2Fstyle%3E%3C%2Fdefs%3E%3Cline%20class%3D%22cls-63ce7424ea57ea6c8380058e-1%22%20x1%3D%2221.5%22%20y1%3D%2212%22%20x2%3D%220.5%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cpolyline%20class%3D%22cls-63ce7424ea57ea6c8380058e-1%22%20points%3D%2213.86%204.36%2021.5%2012%2013.86%2019.64%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E');
	background-size: contain;
}
.btn-company02 a:hover:before {
	background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22Layer_1%22%20data-name%3D%22Layer%201%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%221.5%22%20width%3D%2224%22%20height%3D%2224%22%20color%3D%22%23ffffff%22%3E%3Cdefs%3E%3Cstyle%3E.cls-63ce7424ea57ea6c8380058e-1%7Bfill%3Anone%3Bstroke%3AcurrentColor%3Bstroke-miterlimit%3A10%3B%7D%3C%2Fstyle%3E%3C%2Fdefs%3E%3Cline%20class%3D%22cls-63ce7424ea57ea6c8380058e-1%22%20x1%3D%2221.5%22%20y1%3D%2212%22%20x2%3D%220.5%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cpolyline%20class%3D%22cls-63ce7424ea57ea6c8380058e-1%22%20points%3D%2213.86%204.36%2021.5%2012%2013.86%2019.64%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E');
	transition: .5s;
	background-size: contain;
}
@media only screen and (min-width: 992px) {
	.btn-company02 a {
		padding: 30px 0px 30px 45px;
		font-size: 1.1rem;
	}
}

/* --------------------------------
	History
-------------------------------- */
.timeline {
  position: relative;
  margin: 80px auto 3rem auto;
  padding-bottom: 1px;
}
.timeline:before {
  position: absolute;
  top: 0px;
  top: -30px;
  left: 45px;
  width: 3px;
  height: 100%;
  content: '';
  background: #b00015;
}
.timeline .timeline_item {
  margin: 40px 0px 0px 80px;
  padding-bottom: 20px;
}
.timeline_item {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.timeline_item.visible {
  opacity: 1;
  transform: translateY(0);
}

.timeline .timeline_item .time_date .time {
  font-family: serif;
  font-size: 6em;
  font-weight: bold;
  position: relative;
  margin: 0;
  letter-spacing: 3px;
  color: rgba(176,0,21,0.1);
}
.timeline .timeline_item .time_date .time:before {
  position: absolute;
  top: 50%;
  left: -42px;
  width: 15px;
  height: 15px;
  content: '';
  /*transform: rotate(45deg);*/
  border-radius: 50%;
  border: 3px solid #b00015;
  background: #fff;
}
.timeline .timeline_item .time_date .flag {
  font-size: 1.3rem;
  font-weight: bold;
  margin: -60px 0 0 0;
  color: #000;
}
.timeline .timeline_item .desc {
  line-height: 1.8rem;
  margin-top: 10px;
  padding-left: 20px;
  border-left: 1px solid #b00015;
  /*margin-bottom: 60px;*/
  margin-bottom: 20px;
}
@media only screen and (max-width: 767px) {
  .timeline:before {
    left: 15px;
  }
  .timeline .timeline_item .time_date .time:before {
    left: -32px;
  }
  .timeline .timeline_item {
    margin: 0px 0px 0px 40px;
  }
  .timeline .timeline_item .desc {
    padding-left: 0px;
    border-top: 1px solid #b00015;
    border-left: none;
  }
}

/* --------------------------------
	About us
-------------------------------- */
.title-aboutus {
	position: relative;
	width: 100%;
	height: 300px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	text-align: center;
	overflow: hidden; /* 擬似要素のはみ出し防止 */
	margin-bottom: 60px;
	animation: fade-in 3s;
	animation-fill-mode: forwards;
}
@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.title-aboutus::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/bg-aboutus.webp) no-repeat bottom center;
	background-size: cover;
	opacity: 0;
	animation: fadein-bg 3s ease-in-out forwards;
	z-index: 0;
}

@keyframes fadein-bg {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

/* 中のテキストや要素を前面に出すため */
.title-aboutus > * {
	position: relative;
	z-index: 1;
}

.title-aboutus h2 {
text-shadow: 2px 2px 10px rgba(255,255,255,1),
			-2px 2px 10px rgba(255,255,255,1),
			2px -2px 10px rgba(255,255,255,1),
			-2px -2px 10px rgba(255,255,255,1);
	letter-spacing: .15rem;
	line-height: 3rem;
}
.title-aboutus h2 strong {
	color: #B00015;
	font-size: 2.4rem;
}
@media screen and (min-width: 768px), print {
	.title-aboutus {
		height: 500px;
	}
	.title-aboutus h2 {
	text-shadow: 3px 3px 3px rgba(255, 255, 255, 1),
				-3px -3px 3px rgba(255, 255, 255, 1), 
				3px -3px 2px rgba(255, 255, 255, 1), 
				-3px 3px 2px rgba(255, 255, 255, 1);
		letter-spacing: .15rem;
		line-height: 4rem;
	}
}
.column-aboutus {
	background: url(../images/company/bg-aboutus-column.svg) no-repeat top right;
	background-size: contain;
	opacity: 0;
	animation: fadein-bg 5s ease-in-out forwards;
	z-index: 0;
}

.item-aboutus{
	display: flex;
	flex-wrap: wrap;
	margin: 0 auto 50px;
	width: 100%;
}
.item-aboutus .item-aboutus-inner{
	width: 100%;
	text-align: center;
}
.item-aboutus-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	aspect-ratio: 16 / 9;
	padding: 20px;
	border-radius: 20px;
	overflow:hidden;
}

.item-aboutus {
  opacity: 0;
  transform: translateY(200px);
  transition: opacity 2s ease, transform 1s ease;
}

.item-aboutus.visible {
  opacity: 1;
  transform: translateY(0);
}


.item-aboutus.item-aboutus01 .item-aboutus-inner {
	background: url(../images/company/aboutus01.webp) no-repeat top center;
	background-size: cover;
}
.item-aboutus.item-aboutus02 .item-aboutus-inner {
	background: url(../images/company/aboutus02.webp) no-repeat center center;
	background-size: cover;
}
.item-aboutus.item-aboutus03 .item-aboutus-inner {
	background: url(../images/company/aboutus03.webp) no-repeat center center;
	background-size: cover;
}
.item-aboutus.item-aboutus04 .item-aboutus-inner {
	background: url(../images/company/aboutus04.webp) no-repeat center center;
	background-size: cover;
}

.item-aboutus-inner h2 {
text-shadow: 2px 2px 10px rgba(255,255,255,1),
			-2px 2px 10px rgba(255,255,255,1),
			2px -2px 10px rgba(255,255,255,1),
			-2px -2px 10px rgba(255,255,255,1);
	/*line-height: 2.3rem;*/
	line-height: 1.7rem;
	font-size: 1.2rem;
}

.item-aboutus-inner h2 span {
	color: #B00015;
	font-size: 1.5rem;
}
@media screen and (min-width: 768px), print {
	.item-aboutus-inner h2 {
		line-height: 4rem;
		font-size: 2rem;
	}
	.item-aboutus-inner h2 span {
		font-size: 2.5rem;
	}
	.item-aboutus.item-aboutus01{
		justify-content: start;
	}
	.item-aboutus.item-aboutus02{
		justify-content: end;
	}
	.item-aboutus.item-aboutus01 .item-aboutus-inner,
	.item-aboutus.item-aboutus02 .item-aboutus-inner{
		width: 70%;
		}
}


button.nav-link {
    color: #fff;
    background: #8396A5;
    padding: 20px 30px;
    margin-right: 5px;
    order: -1;
    position: relative;
    line-height: 1.5;
    cursor: pointer;
	border-radius: 30px 30px 0 0;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
	text-align: center;
}

button.nav-link:hover {
    background: #184265;
	color: #fff;
	transition: all .5s;
}

button.nav-link.active {
    background: #fff;
	color: #000;
}
.casestudy-card:hover {
	cursor: pointer;
}
.casestudy-card img {
	opacity:1;
	transition: all .5s;
}
.casestudy-card:hover img {
	cursor: pointer;
	opacity:0.8;
	transition: all .5s;
}

.accordion-header button.accordion-button {
    background: #fff;
	color: #000;
	font-family: "Zen Kaku Gothic New", "メイリオ", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}
.accordion-header button.accordion-button:hover {
    background: #fff;
	color: #000;
	transition: all .5s;
}
.accordion-header button.accordion-button.collapsed {
    color: #fff;
    background: #8396A5;
}
.accordion-header button.accordion-collapse.collapsed.show {
    background: #fff;
	color: #000;
}
/* モーダル全体（背景） */
#imageModal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 10001;
  justify-content: center;
  align-items: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}

/* 表示状態 */
#imageModal.show {
  display: flex;
  opacity: 1;
}
.modal-content {
	position: relative;
  max-width: 90%;
}

/* 中の画像部分だけズーム */
.modal-img {
  max-width: 100%;
  max-height: 90%;
  transition: transform 0.4s ease;
  transform: scale(0.9);
  opacity: 0;
  margin: auto;
}

/* 表示時に画像ズーム＆フェード */
#imageModal.show .modal-img {
  transform: scale(1);
  opacity: 1;
}

.close-btn {
	position: absolute;
	top: -40px; right: 0px;
	font-size: 2rem;
	color: #fff;
	background: none;
	border: none;
	cursor: pointer;
	transition: transform 0.4s ease;
}

@media screen and (min-width: 768px), print {
	.modal-content {
		max-width: 700px;
		max-height: 90%;
	}
}
.link-faq-list li a {
	text-decoration: none;
	color: #000;
}
.link-faq-list li:before {
	content: '';
    display: inline-block;
	width: 1rem;
    height: 1rem;
	background-image: url("data:image/svg+xml,	%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-caret-down-fill' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: bottom center;
}
dl.faq {
	margin: 30px 0;
}

dl.faq dt {
    margin-bottom: 1em;
    color: #333333;
	font-size: 1.1rem;
}

dl.faq dt::before,
dl.faq dd::before {
    margin-right: .4em;
    font-weight: 700;
}

dl.faq dt::before {
    content: "Q.";
	color: #184265;
}

dl.faq dd {
    margin: 0 0 2.5em;
    padding: 1em 1.5em;
    background-color: #f2f2f2;
    color: #333333;
	border-radius: 10px;
}

dl.faq dd::before {
    content: "A.";
	color: #B00015;
}

ul.list-jirei {
	margin: 20px 0 30px;
}
ul.list-jirei li strong {
	display: block;
	width: 100%;
}
ul.list-jirei li {
	padding-bottom: 1rem;
}
@media screen and (min-width: 768px), print {
	ul.list-jirei li strong {
		display: inline-block;
		width: 9rem;
	}
	ul.list-jirei li {
		padding-bottom: .5rem;
	}
}

