@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Delius&family=Noto+Sans+JP&family=Playwrite+AU+TAS&family=Zen+Maru+Gothic:wght@400;500;700&display=swap');

*, :after, :before {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html{
	overflow: auto;
}

html,body{
    width: 100%;
}

body {
  color : #21110D;
	font-family: 'Noto Sans JP','Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, 'メイリオ', Osaka, 'MS PGothic', arial, helvetica;
	font-weight: 400;
	-webkit-text-size-adjust: 100%;
	position: relative;
}

@media screen and (min-width: 1601px) {
	body{
		background-size: 100%;
	}
}

@media screen and (min-width: 769px) {
	body{
		min-width: 1200px;
		overflow: hidden;
	}
}

.ipad{
	min-width: 1200px;
}

a,
a img{
	text-decoration: none;
	transition: 0.3s ease-out;
}

.clearfix:after {
  content:" ";
  display:block;
  clear:both;
}

/*header
--------------------------------------------------*/
.header{
	position: relative;
}

.floating__nav{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 300;
	min-width: 1200px;
}

.header__logo{
	position: absolute;
	top: 33px;
	left: 35px;
	z-index: 310;
}

.header__logo a{
	display: block;
	width: 257px;
	height: 86px;
	background: url(../img/logo_pc.svg) no-repeat 0 0/100%;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
}

.header__nav{
	position: absolute;
	top: 29px;
	right: 56px;
}

.nav__index{
	position: absolute;
	top: 0;
	right: 0;
	width: fit-content;
	display: flex;
	flex-direction: row;
}

.nav__item{
	margin-left: 30px;
	white-space: nowrap;
	position: relative;
}

.nav__item:first-child{
	margin-left: 0;
}

.nav__item a{
	width: 100%;
	height: 50px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	font-size: 16px;
	letter-spacing: 0.06em;
	color: #21110d;
}

.ipad .nav__item a{
	font-size: 13px;
}

@media screen and (max-width: 1300px) {
	.header__nav{
		right: 20px;
	}

	.nav__item{
		margin-left: 20px;
	}
}

@media screen and (min-width: 769px) {
	/*hover*/
	.nav__item a:hover,
	.header__logo a:hover{
		opacity: .6;
	}
	
	/*fixed*/
	.is-fixed{
		position: fixed;
		z-index: 500;
		background: #fff;
		box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
		height: 106px;
	}

	.is-fixed .header__logo{
		top: 10px;
	}
}

@media screen and (max-width: 768px) {
	.floating__nav{
		min-width: auto;
	}

	.header__logo{
		top: 12px;
		left: 20px;
	}

	.header__logo a{
		width: 134px;
		height: 47px;
		background-image: url(../img/logo_sp.svg);
	}

	.header__nav,
	.nav__btn{
		display: none;
	}
}

/*mainvisual
--------------------------------------------------*/
.mainvisual{
	width: 100%;
	height: 0;
	overflow: hidden;
	padding-top: 62.5%;
	position: relative;
	background: url(../img/mv_pc.webp) no-repeat 0 0/100%;

}

.mv__txt{
	background: url(../img/mv_txt_pc.svg) no-repeat 0 0/100%;
	width: 35.8125%;
	height: 14.6%;
	position: absolute;
	top: 38.6%;
	left: 6.1875%;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	z-index: 150;
}
@media screen and (max-width: 768px) {
	.mainvisual{
		padding-top: 168%;
		background-image: url(../img/mv_sp.webp);
	}

	.mv__txt{
		background-image: url(../img/mv_txt_sp.svg);
		width: 72.53%;
		height: 10.95%;
		top: 45.55%;
		left: 12.26%;
	}
}

/*SP navi
--------------------------------------------------*/
/*hamburger SP*/
@media screen and (max-width: 768px) {
	.hamburger{
		position: fixed;
    top: 14px;
		right: 13px;
    width: 45px;
    height: 45px;
		z-index: 700;
		background: #F39800;
		border-radius: 45px;
	}
	
	.hamburger__inner{
		position: absolute;
		top: 19px;
		left: 14px;
		width: 16px;
		height: 8px;
		cursor: pointer;
	}

	.hamburger__line{
		background: #fff;
		display: block;
		height: 1px;
		position: absolute;
		transition: 0.3s ease-out;
		width: 100%;
	}

	.hamburger__line--c{
		background: transparent;
	}

	.hamburger__line--b{
		bottom: 0px;
		}

	.hamburger__line--t.nav--active{
		transform: rotate(45deg);
		top: 3px;
	}

	.hamburger__line--c.nav--active{
		transform:scaleX(0);
	}

	.hamburger__line--b.nav--active{
		top: 3px;
		transform: rotate(135deg);
	}
}

/*navi*/
.sp-nav{
	background: rgba(0,0,0,0.8);
	display: none;
	height: 100%;
	width: 100%;
	position: fixed;
	z-index: 600;
	top: 0;
	left: 0;
}

.sp-nav__container{
	align-items:center;
	display: flex;
	height: 100%;
	justify-content: center;
	position: absolute;
	width: 100%;
}

.sp-nav__index {
	width: 230px;
	margin: 0 auto;
}

.sp-nav__item{
	margin-bottom: 15px;
	padding-bottom: 15px;
	text-align: center;
}

.sp-nav__item:last-child{
	border: none;
}

.sp-nav__item a{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-weight: 500;
	font-size: 16px;
	letter-spacing: 0.1em;
	line-height: 1.5;
	color: #fff;
}

.sp-nav__btn{
	width: 140px;
	margin: 0 auto;
}

.sp-nav__btn img{
	width: 100%;
}

.sp-nav__btn__item{
	margin-bottom: 20px;
	height: 50px;
}

.sp-nav__btn__item a{
	display: flex;
	align-items: center;
	height: 100%;
	background: #222524 url(../img/floating_btn_arrow.svg) no-repeat top 50% right 15px;
	padding-left: 15px;
	font-size: 16px;
	line-height: 1;
	color: #fff;
}

.sp-nav__btn__item:nth-child(2) a{
	background-color: #707070;
}

/*break
--------------------------------------------------*/
.pc--hidden{
	display: none;
}

.sp--hidden{
	display: block;
}

@media screen and (max-width: 768px) {
	.pc--hidden{
		display: block;
	}
	
	.sp--hidden{
		display: none;
	}
}

/*heading
--------------------------------------------------*/
.content__heading{
	line-height: 1;
	display: flex;
	flex-direction: column;
}

.content__heading--en{
	font-family: "Playwrite AU TAS";
	font-size: 64px;
	color: #f39800;
	margin-bottom: 22px;
	padding-left: 2px;
}

.content__heading--ja{
	font-weight: 700;
	font-size: 22px;
	letter-spacing: 0.12em;
	color: #302d2c;
	padding-left: 27px;
	background: url(../img/heading_circle.svg) no-repeat 0 50%;
}

@media screen and (max-width: 768px) {
	.content__heading--en{
		font-size: 34px;
		margin-bottom: 10px;
	}

	.content__heading--ja{
		font-size: 16px;
		padding-left: 15px;
		background-size: 10px;
		background-position-y: 6px;
	}
}

/*about us
--------------------------------------------------*/
.aboutus{
	padding: 127px 0 21px 0;
	background: #FEEACA;
}

.aboutus__container{
	width: 980px;
	margin: 0 auto;
	position: relative;
}

.aboutus__heading{
	margin-bottom: 55px;
}

.aboutus__txt__area{
	width: 452px;
}

.aboutus__txt{
	font-weight: 500;
	font-size: 20px;
	letter-spacing: 0.06em;
	line-height: 2em;
	margin-bottom: 2em;
}

.aboutus__map{
	width: 662px;
	position: absolute;
	top: -19px;
	right: -178px;
}

.aboutus__map img{
	width: 100%;
}

@media screen and (max-width: 768px) {
	.aboutus{
		padding: 50px 0 10px 0;
	}

	.aboutus__container{
		width: auto;
		padding: 0 20px;
	}

	.aboutus__heading{
		margin-bottom: 30px;
	}

	.aboutus__txt__area{
		width: 100%;
	}

	.aboutus__txt{
		font-size: 16px;
		letter-spacing: 0.06em;
		line-height: 1.8;
		margin-bottom: 1.8em;
	}

	.aboutus__map{
		width: 100%;
		position: relative;
		top: auto;
		right: auto;
	}
}

/*data
--------------------------------------------------*/
.data{
	background: #FEEACA url(../img/data_bg.webp) no-repeat bottom 0 left 0/100%;
	padding: 100px 0 248px 0;
}

.data__container{
	width: 980px;
	margin: 0 auto;
}

.data__heading{
	margin-bottom: 60px;
}

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

.data__item{
	width: 310px;
	height: 521px;
	padding: 43px 24px 0 38px;
	box-sizing: border-box;
	border-radius: 20px;
	background: #fff url(../img/data_img_01.webp) no-repeat top 141px left 53%/232px;
}

.data__item:nth-child(2){
	background: #fff url(../img/data_img_02.webp) no-repeat top 100px left 59%/244px;
}

.data__item:nth-child(3){
	background: #fff url(../img/data_img_03.webp) no-repeat top 106px left 71%/244px;
}

.data__ttl{
	font-weight: 700;
	font-size: 22px;
	line-height: 1;
	letter-spacing: 0.12em;
	color: #302d2c;
	padding-bottom: 10px;
	background: url(../img/data_dotline.svg) repeat-x bottom 0 left 0;
	width: fit-content;
	margin: 0 auto 296px auto;
}

.data__txt{
	font-size: 16px;
	letter-spacing: 0.06em;
	line-height: 1.875;
}

@media screen and (max-width: 768px) {
	.data{
		background: #FEEACA url(../img/data_bg.webp) no-repeat bottom 0 left 0/100%;
		padding: 20px 0 50px 0;
	}

	.data__container{
		width: auto;
		padding: 0 20px;
	}

	.data__heading{
		margin-bottom: 30px;
	}

	.data__list{
		flex-wrap: wrap;
		width: 280px;
		margin: 0 auto;
	}

	.data__item{
		width: 280px;
		height: auto;
		padding: 20px;
		border-radius: 10px;
		background-size: 186px;
		background-position-y: 70px;
		margin-bottom: 30px;
	}

	.data__item:nth-child(2){
		background-size: 195px;
		background-position-y: 80px;
	}

	.data__item:nth-child(3){
		background-size: 195px;
		background-position-y: 80px;
	}

	.data__ttl{
		font-size: 18px;
		padding-bottom: 10px;
		margin: 0 auto 220px auto;
	}
}

/*support and stepup
--------------------------------------------------*/
.support{
	padding: 97px 0 109px 0;
	background: #fff;
}

.support__container{
	width: 980px;
	margin: 0 auto;
}

.support__heading{
	margin-bottom: 49px;
}

.support__heading .content__heading--en{
	margin-bottom: 38px;
}

.support__read{
	font-weight: 500;
	font-size: 20px;
	letter-spacing: 0.06em;
	line-height: 2;
	margin-bottom: 66px;
}

.support__block-1{
	display: flex;
	justify-content: space-between;
	margin-bottom: 87px;
}

.support__ph__area{
	width: 444px;
	line-height: 0;
}

.support__ph img{
	width: 100%;
}

.support__txt__area{
	width: 490px;
	padding-top: 74px;
}

.suppoert__ttl{
	line-height: 0;
	margin-bottom: 32px;
	padding-left: 2px;
}

.support__txt{
	font-size: 16px;
	letter-spacing: 0.06em;
	line-height: 1.875;
	margin-bottom: 5px;
}

.support__block-2{
	margin-bottom: 109px;
}

.support__block-2 .support__txt{
	width: 490px;
}

.support__graph{
	line-height: 0;
	position: relative;
}

.support__graph::after{
	content: '';
	display: block;
	background: url(../img/support_02_img.svg) no-repeat 0 0/100%;
	width: 147px;
	height: 192px;
	position: absolute;
	bottom: -82px;
	right: -54px;
}

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

.support__block-3 .support__txt__area{
	padding-top: 103px;
}

@media screen and (max-width: 768px) {
	.support{
		padding: 50px 0;
	}

	.support__container{
		width: auto;
		padding: 0 20px;
	}

	.support__heading{
		margin-bottom: 30px;
	}

	.support__heading .content__heading--en{
		margin-bottom: 25px;
	}

	.support__read{
		font-size: 18px;
		line-height: 1.8;
		margin-bottom: 30px;
	}

	.support__block-1{
		display: block;
		margin-bottom: 20px;
	}

	.support__ph__area{
		width: 100%;
		margin-bottom: 20px;
	}

	.support__txt__area{
		width: 100%;
		padding-top: 0;
	}

	.suppoert__ttl{
		margin-bottom: 20px;
		padding-left: 0;
	}

	.suppoert__ttl img{
		height: 75px;
	}

	.support__txt{
		font-size: 16px;
		letter-spacing: 0.06em;
		line-height: 1.875;
		margin-bottom: 0;
	}

	.support__block-2{
		margin-bottom: 50px;
		position: relative;
	}

	.support__block-2 .support__txt{
		width: 100%;
		margin-bottom: 20px;
	}

	.support__graph{
		line-height: 0;
		position: relative;
		overflow-x: scroll;
		/* scrollbar-width: none; */
		cursor: grab;
	}

	.support__graph img{
		height: 360px;
	}

	.support__graph::after{
		display: none;
	}
	.support__block-2::after{
		content: '';
		display: block;
			background: url(../img/support_02_img.svg) no-repeat 0 0 / 100%;
			width: 77px;
			height: 102px;
			position: absolute;
			bottom: -70px;
			right: 0;
	}

	.support__block-3{
		display: block;
	}

	.support__block-3 .support__txt__area{
		padding-top: 0;
	}
}

/*Staff’s Voice
--------------------------------------------------*/
.voice{
	padding: 134px 0 142px 0;
	background:
	 url(../img/voice_bg_top.webp) no-repeat top 0 left 0/100%,
	 url(../img/voice_bg_btm.webp) no-repeat bottom 0 left 0/100%,
	 #FDF5E6;
}

.voice__container{
	width: 980px;
	margin: 0 auto;
}

.voice__heading{
	margin-bottom: 169px;
	align-items: center;
}

.voice__heading .content__heading--en{
	margin-bottom: 38px;
}

.voice__heading .content__heading--ja{
	background: none;
	padding: 0 0 0 3px;
}

.voice__list{
	display: flex;
	flex-wrap: wrap;
}

.voice__item{
	width: 442px;
	margin-right: 96px;
	margin-bottom: 22px;
	background:url(../img/voice_ph_01.webp) no-repeat 0 0/100%;
	padding-top: 337px;
	position: relative;
	transition: 0.3s ease-out;
	cursor: pointer;
}

.voice__item:nth-child(2n){
	margin-right: 0;
}

.voice__item:nth-child(odd){
	margin-top: -69px;
}

.voice__item:nth-child(2){
	background-image: url(../img/voice_ph_02.webp);
}

.voice__item:nth-child(3){
	background-image: url(../img/voice_ph_03.webp);
}

.voice__item:nth-child(4){
	background-image: url(../img/voice_ph_04.webp);
	margin-top: 33px;
}

.voice__mhd{
	font-weight: 600;
	font-size: 22px;
	letter-spacing: 0.12em;
	line-height: 1.545;
	color: #000;
	margin-bottom: 28px;
}

.voice__name__area{
	display: flex;
	margin-bottom: 8px;
}

.voice__name{
	font-family: "Playwrite AU TAS";
	font-size: 50px;
	line-height: 1;
	color: #f39800;
	padding-left: 3px;
	margin-right: 12px;
}

.voice__name span{
	font-weight: 500;
	font-size: 18px;
	letter-spacing: 0.12em;
	line-height: 1;
	color: #000;
}

.voice__position{
	position: relative;
	display: flex;
	flex-direction: column;
	margin-top: -8px;
}

.voice__pos{
	width: fit-content;
	height: 27px;
	border-radius: 15px;
	background: #d2e6f1;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 15px;
	letter-spacing: 0.06em;
	line-height: 1;
	padding: 0 15px;
	margin-bottom: 4px;
}

.voice__place{
	font-weight: 500;
	font-size: 16px;
	letter-spacing: 0.12em;
	line-height: 1;
	color: #000;
	padding-left: 3px;
}

.voice__no{
	font-family: 'Delius';
	font-size: 27px;
	line-height: 1;
	color: #f39800;
	padding-bottom: 40px;
	background: url(../img/voice_arrow.svg) no-repeat bottom 0 left 5px;
	position: absolute;
	right: 23px;
	top: 232px;
}

@media screen and (min-width: 769px) {
	.voice__item:hover{
		opacity: 0.6;
	}
}

@media screen and (max-width: 768px) {
	.voice{
		padding: 50px 0;
		background:
		url(../img/voice_bg_top.webp) no-repeat top 0 left 50%/800px,
		url(../img/voice_bg_btm.webp) no-repeat bottom 0 left 0/100%,
		#FDF5E6;
	}

	.voice__container{
		width: auto;
		padding: 0 20px;
	}

	.voice__heading{
		margin-bottom: 30px;
	}

	.voice__heading .content__heading--en{
		margin-bottom: 20px;
	}

	.voice__heading .content__heading--ja{
		background: none;
		padding: 0 0 0 3px;
	}

	.voice__list{
		display: block;
		width: 280px;
		margin: 0 auto;
	}

	.voice__item{
		width: 100%;
		margin-right: 0;
		margin-bottom: 40px;
		padding-top: 210px;
	}


	.voice__item:nth-child(odd){
		margin-top: 0;
	}

	.voice__item:nth-child(4){
		margin-top: 0;
	}

	.voice__mhd{
		font-size: 16px;
		margin-bottom: 15px;
	}

	.voice__name__area{
		margin-bottom: 5px;
		display: block;
	}

	.voice__name{
		font-size: 30px;
		padding-left: 0;
		margin: 0 0 10px 0;
	}

	.voice__name span{
		font-size: 12px;
		margin-left: 5px;
	}

	.voice__position{
		position: relative;
		display: flex;
		flex-direction: column;
		margin-top: 0;
	}

	.voice__pos{
		height: 22px;
		font-size: 12px;
		padding: 0 10px;
		margin-bottom: 4px;
	}

	.voice__place{
		font-size: 14px;
		padding-left: 0;
	}

	.voice__no{
		right: 15px;
		top: 125px;
	}
}

/*modal
--------------------------------------------------*/
.modal{
	margin: 50px auto;
	width: 980px;
	background: #FDF5E6 url(../img/modal_bg.webp) no-repeat top 0 left 50%/100%;
	padding: 97px 58px 70px 58px;
	box-sizing: border-box;
	position: relative;
	border-radius: 10px;
}

.modal__close__top{
	position: absolute;
	width: 44px;
	top: 13px;
	right: 15px;
	transition: 0.3s ease-out;
	cursor: pointer;
	z-index: 300;
	line-height: 0;
}

.modal__close__btm{
	width: 220px;
	margin: 0 auto;
	transition: 0.3s ease-out;
	cursor: pointer;
	line-height: 0;
}

.modal__entry__btn{
	width: 220px;
	margin: 0 auto 18px auto;
}

.modal__entry__btn a{
	display: block;
}

.modal__close__top img,
.modal__close__btm img,
.modal__entry__btn img{
	width: 100%;
}

.modal__header{
	margin-bottom: 45px;
	display: flex;
	justify-content: space-between;
}

.modal__header__ph{
	width: 442px;
}

.modal__ph{
	line-height: 0;
}

.modal__ph img{
	width: 100%;
}

.modal__header__txt{
	width: 410px;
}

.modal__mhd{
	font-weight: 600;
	font-size: 22px;
	letter-spacing: 0.12em;
	line-height: 1.545;
	color: #000;
	margin-bottom: 28px;
}

.modal__name__area{
	display: flex;
	margin-bottom: 10px;
}

.modal__name{
	font-family: "Playwrite AU TAS";
	font-size: 50px;
	line-height: 1;
	color: #f39800;
	padding-left: 1px;
	margin-right: 12px;
}

#modal-4 .modal__name{
	margin-right: 0;
}

.modal__name span{
	font-weight: 500;
	font-size: 18px;
	letter-spacing: 0.12em;
	line-height: 1;
	color: #000;
}

.modal__position{
	position: relative;
	display: flex;
	flex-direction: column;
	margin-top: -8px;
}

.modal__pos{
	width: fit-content;
	height: 27px;
	border-radius: 15px;
	background: #d2e6f1;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 15px;
	letter-spacing: 0.06em;
	line-height: 1;
	padding: 0 15px;
	margin-bottom: 4px;
}

.modal__place{
	font-weight: 500;
	font-size: 16px;
	letter-spacing: 0.12em;
	line-height: 1;
	color: #000;
}

.modal__no{
	font-family: 'Delius';
	font-size: 27px;
	line-height: 1;
	color: #f39800;
	margin-bottom: 39px;
	padding-top: 4px;
}

.modal__qa{
	margin-bottom: 72px;
}

.modal__q{
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: 'Zen Maru Gothic';
	font-weight: 500;
	font-size: 18px;
	line-height: 1.45;
	letter-spacing: 0.06em;
	margin-bottom: 12px;
}

.modal__q span{
	display: block;
	width: 798px;
	padding-top: 1px;
}

.modal__q::before{
	display: block;
	content: '';
	background: url(../img/modal_icon_q.svg) no-repeat 0 0/100%;
	width: 53px;
	height: 45px;
}

.modal__a{
	border-radius: 10px;
	background: #fff;
	padding: 20px 22px 18px 22px;
	font-family: 'Zen Maru Gothic';
	font-weight: normal;
	font-size: 16px;
	letter-spacing: 0.06em;
	line-height: 1.875;
	margin-bottom: 38px;
}

.schedule{
	width: 660px;
	border-radius: 10px;
	background: #fff;
	border: 2px solid #f39800;
	margin: 0 auto 38px auto;
	padding: 39px 0 11px 0;
	position: relative;
}

.schedule__ttl{
	position: absolute;
	top: 43px;
	left: 42px;
	line-height: 1;
}

.schedule__ttl--en{
	font-family: "Playwrite AU TAS";
	font-size: 30px;
	color: #f39800;
	margin-bottom: 15px;
	display: flex;
	flex-direction: column;
}

.schedule__ttl--ja{
	font-weight: 700;
	font-size: 16px;
	letter-spacing: 0.12em;
	color: #302d2c;
	padding-left: 2px;
}

.schedule__note {
	display: block;
	font-weight: 700;
	font-size: 16px;
	letter-spacing: 0.12em;
	color: #302d2c;
	padding-left: 2px;
	padding-top: 8px;
}

.schedule__tbl{
	margin-left: 259px;
}

.schedule__tbl th{
	font-family: 'Delius';
	font-size: 18px;
	line-height: 1;
	letter-spacing: 0.02em;
	text-align: right;
	color: #2587bc;
	width: 50px;
}

.schedule__tbl td{
	width: max-content;
	font-family: 'Zen Maru Gothic';
	font-weight: 500;
	font-size: 15px;
	line-height: 1;
	letter-spacing: 0.06em;
	padding-left: 27px;
	padding-bottom: 30px;
	position: relative;
}

.schedule__tbl td::after{
	content: '';
	display: block;
	width: 1px;
	height: 100%;
	background: #707070;
	position: absolute;
	top: 0;
	left: 13px;
	z-index: 50;
}

.schedule__tbl tr:last-child td::after{
	display: none;
}

.schedule__tbl td::before{
	content: '';
	display: block;
	background: url(../img/modal_schedule_circle.webp) no-repeat 0 0/100%;
	width: 16px;
	height: 21px;
	position: absolute;
	top: -1px;
	left: 5px;
	z-index: 100;
}

@media screen and (min-width: 769px) {
	.modal__entry__btn a:hover,
	.modal__close:hover{
		opacity: 0.6;
	}
}

@media screen and (max-width: 768px) {
	.modal{
		margin: 30px auto 60px auto;
		width: 90%;
		padding: 20px 20px 40px 20px;
	}

	.modal__close__top{
		width: 35px;
		top: 10px;
		right: 10px;
	}

	.modal__close__btm{
		width: 180px;
	}

	.modal__entry__btn{
		width: 180px;
		margin-bottom: 10px;
	}

	.modal__header{
		margin-bottom: 30px;
		display: block;
	}

	.modal__header__ph{
		width: 100%;
	}

	.modal__header__txt{
		width: 100%;
	}

	.modal__mhd{
		font-size: 18px;
		margin-bottom: 20px;
	}

	.modal__name__area{
		display: block;
		margin-bottom: 5px;
	}

	.modal__name{
		font-size: 30px;
		padding-left: 0;
		margin: 0 0 12px 0;
	}

	.modal__name span{
		font-size: 16px;
		margin-left: 5px;
	}

	.modal__position{
		margin-top: 0;
	}

	.modal__pos{
		height: 25px;
		font-size: 14px;
		padding: 0 10px;
	}

	.modal__place{
		margin-bottom: 15px;
	}

	.modal__no{
		font-size: 24px;
		margin-bottom: 10px;
		padding-top: 0;
	}

	.modal__qa{
		margin-bottom: 30px;
	}

	.modal__q{
		display: block;
		font-size: 16px;
		margin-bottom: 10px;
	}

	.modal__q span{
		width: 100%;
		padding-top: 0;
		padding: 0 0 0 40px;
		background: url(../img/modal_icon_q.svg) no-repeat top 50% left 0/30px;
	}

	.modal__q::before{
		display: none;
	}

	.modal__a{
		padding:15px;
		font-size: 14px;
		margin-bottom: 30px;
	}

	.schedule{
		width: 100%;
		margin: 0 auto 30px auto;
		padding: 20px 20px 10px 20px;
	}

	.schedule__ttl{
		position: relative;
		top: auto;
		left: auto;
		margin-bottom: 30px;
	}

	.schedule__tbl{
		margin-left: 0;
	}

	.schedule__tbl td{
		line-height: 1.5;
		padding-bottom: 20px;
		width:auto;
	}
}

/*Environment
--------------------------------------------------*/
.environment{
	padding: 80px 0 17px 0;
	background: #FEEACA;
}

.environment__container{
	width: 980px;
	margin: 0 auto;
	position: relative;
}

.environment__heading{
	margin-bottom: 104px;
}

.environment__list{
	display: flex;
	flex-wrap: wrap;
}

.environment__item{
	width: 275px;
	margin-bottom: 72px;
	margin-right: 77px;
}

.environment__item:nth-child(3){
	margin-right: 0;
}

.environment__item:nth-child(4){
	margin-left: 177px;
}

.environment__item:nth-child(n+4){
	margin-bottom: 0;
}

.environment__img{
	line-height: 0;
	margin-bottom: 28px;
}

.environment__img img{
	width: 100%;
}

.environment__txt{
	font-size: 16px;
	letter-spacing: 0.06em;
	line-height: 1.875;
	color: #21110d;
}

@media screen and (max-width: 768px) {
	.environment{
		padding: 30px 0 5px 0;
	}

	.environment__container{
		width: auto;
		padding: 0 20px;
	}

	.environment__heading{
		margin-bottom: 30px;
	}

	.environment__list{
		display: block;
		width: 280px;
		margin: 0 auto;
	}

	.environment__item{
		width: 100%;
		margin-bottom: 30px;
		margin-right: 0;
	}
	.environment__item:nth-child(4){
		margin-left: 0;
	}

	.environment__img{
		line-height: 0;
		margin-bottom: 15px;
		text-align: center;
	}

	.environment__img img{
		width: 180px;
	}

	.environment__txt{
		font-size: 14px;
	}
}

/*side botton ・ sp entry button
--------------------------------------------------*/
/*side btn*/
.side__nav__btn{
	width: 175px;
	position: absolute;
	top: 676px;
	right: 57px;
	z-index: 500;
	line-height: 0;
}

.side__nav__btn a{
	display: block;
}

.side-fixed{
	position: fixed;
	top: 130px;
}

/*sp entry button*/
.floating__btm__btn{
	display: none;
}

@media screen and (min-width: 769px) {
	.side__nav__btn a:hover{
		opacity: .7;
	}
}

@media screen and (max-width: 768px) {
	.side__nav__btn{
		display: none;
	}

	.floating__btm__btn{
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 40px;
		z-index: 300;
		display: flex;
	}

	.floating__btm__btn a{
		display: block;
		width: 100%;
		font-weight: 600;
		font-size: 18px;
		line-height: 40px;
		letter-spacing: 0.12em;
		text-align: center;
		color: #fff;
		background: #2587BC;
	}
}

/*フッター上
--------------------------------------------------*/
.foot__entry{
	position: relative;
}

.pg__top{
	position: absolute;
	right: 22px;
	bottom: -90px;
}

.foot__entry__container{
	width: 980px;
	margin: 0 auto 134px auto;
	padding-top: 407px;
	position: relative;
}

.foot__entry__balloon{
	position: absolute;
	right: 66px;
	top: 92px;
	line-height: 0;
}

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

.foot__entry__btn__item{
	width: 468px;
	line-height: 0;
}

.foot__entry__btn__item img{
	width: 100%;
}

@media screen and (min-width: 769px) {
	.foot__entry__btn a:hover,
	.pg__top a:hover{
		opacity: .7;
	}
}

@media screen and (max-width: 768px) {
	.pg__top{
		right: 10px;
		bottom: -50px;
	}

	.pg__top img{
		width: 50px;
	}

	.foot__entry__container{
		width: auto;
		padding: 130px 20px 0 20px;
		margin-bottom: 30px;
	}

	.foot__entry__balloon{
		right: 20px;
		top: 0;
	}

	.foot__entry__balloon img{
		width: 180px;
	}

	.foot__entry__btn{
		display: block;
		width: 240px;
		margin: 0 auto;
	}

	.foot__entry__btn__item{
		width: 100%;
		margin-bottom: 20px;
	}
}

/*フッター
--------------------------------------------------*/
.footer{
	background: #FEEACA url(../img/footer_bg.webp) no-repeat top 0 left 50%;
}

.footer p,
.footer a{
	color: #000;
}

.footer__container{
	margin: 0 50px;
	padding: 0 0 26px 0;
	display: flex;
	justify-content: space-between;
}

.footerLink__list{
	display: flex;
}

.footerLink__item{
	font-size: 14px;
	letter-spacing: 0.05em;
	line-height: 1;
}

.footerLink__item::before{
	content: ' 　｜ 　';
	font-size: 14px;
	letter-spacing: 0.05em;
	line-height: 1;
	color: #000;
}

.footerLink__item:first-child::before{
	display: none;
}

.copyright{
	font-size: 14px;
	letter-spacing: 0.05em;
	line-height: 1;
}

.footerLink__item a:hover{
	text-decoration: underline;
}

@media screen and (min-width: 1601px) {
	.footer{
		background-size: 100%;
	}
}

@media screen and (max-width: 768px) {
	.footer{
		background: #FEEACA url(../img/footer_bg.webp) no-repeat top 0 right 0/auto 100%;
		padding-bottom: 40px;
	}

	.footer__container{
		margin: 0;
		padding: 20px 0;
		flex-direction: column;
		align-items: center;
	}

	.footerLink__list{
		flex-wrap: wrap;
		justify-content: center;
		margin: 0 0 20px 0;
	}

	.footerLink__item{
		font-size: 12px;
		line-height: 2;
		letter-spacing: 0;
		white-space: nowrap;
	}

	.footerLink__item::before{
		content: '｜';
		font-size: 12px;
	}

	.copyright{
		font-size: 10px;
	}
}