/*========================================================================
//
// common
//
//========================================================================*/
/********* SP - iPhone 6 or higher (screen width up to 761px) ************/
@media (max-width:761px) {
	html, body {
		height: 100%;
		font-size: calc(100vw / 37.5);
	}
	article {
		overflow: hidden;
	}
	.wrapper {
		padding: 0 6%;
		position: relative;
	}
	.pc_contents {
		display: none;
	}
}
/*========================================================================
//
// header
//
//========================================================================*/
/********* SP - iPhone 6 or higher (screen width up to 761px) ************/
@media (max-width: 761px) {
	#ghead {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		z-index: 900;
	}
	.ci_wrap {
		width: 100%;
		margin: 0;
	}
	#ci {
		width: 17%;
		margin: 9px 0 0 14px;
		filter: brightness(0) invert(1);
	}

	
	/* head_navi start ------------------ */
	#head_navi {
		display: none;
	}
	/* head_navi end ------------------ */
	
}
/*========================================================================
//
// Page Top
//
//========================================================================*/
/********* SP - iPhone 6 or higher (screen width up to 761px) ************/
@media (max-width: 761px) {
	.pagetop{
		position: fixed;
		right: 20px;
		bottom: -60px;
		z-index:9000;
		transition: all 0.8s cubic-bezier(0.03, 0.36, 0.18, 1) 0s;
	}
	
	.pagetop_act{
	bottom: 0;
	}

	.pagetop li a:before {
        content: "";
        display: block;
        width: 10px;
        height: 10px;
        border-right: solid 2px #fff;
        border-bottom: solid 2px #fff;
        position: absolute;
        top: 55%;
        left: 50%;
        transform: translate(-50%, -50%) rotate(-135deg);
    }
    

	.pagetop li a{
		display:block;
		background: #000;
		width: 56px;
		height: 56px;
		transition: all 0.4s cubic-bezier(0.03, 0.36, 0.18, 1) 0s;
	}

}
/*========================================================================
//
// Hamburger menu
//
//========================================================================*/
/********* SP - iPhone 6 or higher (screen width up to 761px) ************/
@media (max-width:761px) {
	/* Menu ----------------------------- */
	/* Menu ----------------------------- */
	#drawer-icon {
		position: fixed;
		cursor: pointer;
		display: inline-block;
		height: 56px;
		width: 56px;
		top: 18px;
		right: 18px;
		z-index: 9990;
		background: #cc2328;
		transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
	}

	#drawer-icon span {
		background: #fff;
		border-radius: 4px;
		display: block;
		height: 2px;
		position: absolute;
		top: 41%;
		left: 50%;
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
		transition: all 0.3s ease-in-out;
		width: 22px;
	}
	#drawer-icon span::before, #drawer-icon span::after {
		background: #fff;
		border-radius: 2px;
		content: "";
		display: block;
		height: 100%;
		position: absolute;
		top: 50%;
		left: 0;
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
		transform: rotate(0);
		transition: all 0.3s ease-in-out;
		width: 22px;
	}
	#drawer-icon span::before {
		margin-top: -30%;
	}
	#drawer-icon span::after {
		margin-top: 24%;
	}
	#drawer-icon.fix {}
	#drawer-icon:after {
		content: "Menu";
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 1.0rem;
		letter-spacing: 1px;
		line-height: 100%;
		color: #fff;
		margin: 36px 0 0 0;
		text-align: center;
		display: block;
	}
	/* CLOSE ----------------------------- */
	#drawer-close-icon {
		position: absolute;
		cursor: pointer;
		display: inline-block;
		width: 60px;
		top: 12px;
		right: 6px;
		z-index: 9999;
		box-sizing: border-box;
		height: 62px;
	}
	#drawer-close-icon:after {
		content: "CLOSE";
		font-family: 'Barlow', sans-serif;
		font-weight: 500;
		font-size: 1.2rem;
		letter-spacing: 0.1rem;
		line-height: 100%;
		color: #fff;
		margin: 37px 0 0 0;
		text-align: center;
		display: block;
	}
	#drawer-close-icon span {
		display: block;
		height: 100%;
		position: absolute;
		top: 34%;
		left: 51%;
		transform: translate(-50%, -50%);
		width: 100%;
	}
	#drawer-close-icon span::before, #drawer-close-icon span::after {
		content: "";
		background: #fff;
		display: block;
		height: 2px;
		width: 20px;
		position: absolute;
		top: 50%;
		left: 32%;
		transform: translate(-50%, -50%);
	}
	#drawer-close-icon span::before {
		transform: rotate(-45deg);
	}
	#drawer-close-icon span::after {
		transform: rotate(45deg);
	}
	/* menu area ----------------------------- */
	#drawer-content {
		position: fixed;
		top: 0;
		right: 0;
		z-index: 10001;
		width: 100vw;
		height: 100%;
		-webkit-backdrop-filter: blur(10px);
		backdrop-filter: blur(10px);
		background: rgb(0 0 0/ 80%);
		transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
		transform: translateX(100%);
	}
	#drawer-content.act {
		overflow-y: auto;
		overflow-x: hidden;
		transform: translateX(0);
		box-shadow: 6px 0 25px rgba(0, 0, 0, 0.16);
	}
	#drawer-content-inner {
		width: 100%;
		height: 100%;
		box-sizing: border-box;
		padding: 14px;
		overflow-y: auto;
		overflow-x: hidden;
	}
	#drawer-close {
		display: none;
		cursor: pointer;
		position: fixed;
		z-index: 10000;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		transition: all 0.3s ease-in-out 0s;
	}
	#drawer-close.act {
		display: block;
	}
	#drawer-content .h_nav {
		display: flex;
		gap:0 10px;
	}

	#drawer-content .h_nav a {
		display: block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 1.4rem;
		color: #fff;
		letter-spacing: 0.1rem;
		line-height: 1;
		padding: 20px 14px;
		border: 1px solid #ffffff36;
		position: relative;
	}

	#drawer-content .h_nav a span{
		display:inline-block;
		font-size: 1.2rem;
		padding: 0 0 0 6px;
		margin: 0 -8px 0 0;
	}

	#drawer-content .nav_flex{
		/* display: flex; */
		/* gap: 0 20px; */
		margin: 40px 0 30px;
	}

	#drawer-content .nav_flex a{
		display: block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 1.5rem;
		color: #fff;
		letter-spacing: 0.2rem;
		line-height: 1;
		padding: 0 20px 40px;
	}

	#drawer-content .nav_flex p{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		font-size: 1.5rem;
		color: #909090;
		letter-spacing: 0.2rem;
		padding: 0 0 10px 19px;
	}

	#drawer-content .nav_flex ul.reason_list{
		border-left:2px solid #646464;
		margin: 0 0 0 40px;
	}

	#drawer-content .nav_flex ul.reason_list a{
		font-size: 1.4rem;
		padding: 16px 30px 16px;
	}

	#drawer-content .nav_flex a span{
		display:inline-block;
		font-size: 1.2rem;
		padding: 0 0 0 6px;
		margin: 0 -8px 0 0;
	}

	#drawer-content .nav_flex_f{
		/* display: flex; */
		padding: 30px 0 40px;
	}

	#drawer-content .nav_flex_f p{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		font-size: 1.3rem;
		color: #909090;
		letter-spacing: 0.2rem;
		padding: 0 0 10px 20px;
	}

	#drawer-content .nav_flex_f p span{
		display:inline-block;
		width:18px;
		margin:0 10px 0 0;
		opacity:0.5;
	}

	#drawer-content .nav_flex_f .lang_list{
		display:flex;
		padding:0 0 0 20px;
	}

	#drawer-content .nav_flex_f .lang_list a{
		display: block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 1.3rem;
		color: #fff;
		letter-spacing: 0.2rem;
		line-height: 1;
		padding: 0 20px 4px;
	}

	#drawer-content .nav_flex_f .lang_list li{
		border-right:1px solid #616161;
	}

	#drawer-content .nav_flex_f .lang_list li:first-child{
		border-left:1px solid #616161;
	}

	#drawer-content .nav_flex_f .sns_wrap{
		padding: 30px 0 0;
	}

	#drawer-content .nav_flex_f .sns_list{
		display:flex;
		gap:0 10px;
		padding: 0 0 0 20px;
	}

	#drawer-content .nav_flex_f .sns_list a{
		display:block;
		line-height:0;
		width: 32px;
	}

	
	
	.scroll-prevent {
	  /*動き固定*/
	  position: fixed;
	  /*奥行きを管理*/
	  z-index: -1;
	  /*下2つで背景を元のサイズのまま表示することができる*/
	  width: 100%;
	  height: 100%;
		top: 0;
  		right: 0;
	}
}

/*========================================================================
//
// footer
//
//========================================================================*/
/********* SP - iPhone 6 or higher (screen width up to 761px) ************/
@media (max-width:761px) {
	footer {
		background: #262626;
		position: relative;
	}
	
	#f_info_wrap{
		background:#f0f0f0;
		padding: 80px 0 60px;
	}

	#f_info_wrap .bg_eng_txt{
		font-family: 'Noto Serif JP', serif;
		font-weight: 300;
		font-size: 5.6rem;
		letter-spacing: 0.5rem;
		font-feature-settings: 'palt';
		color: #ffffff;
		line-height: 1;
		position:absolute;
		left: 50%;
		top: -30px;
		opacity: 0.7;
		transform:translate(-50%,0);
	}
	
	#f_info_wrap h2{
		font-family: 'Noto Serif JP', serif;
		font-weight: 500;
		font-size: 2.4rem;
		letter-spacing: 0.6rem;
		font-feature-settings: 'palt';
		color:#000;
		line-height:1.4;
		text-align:center;
		padding: 0 0 26px;
		position: relative;
	}
	
	#f_info_wrap .info_btn_wrap{
		background: #fff;
		border-radius: 8px;
		position: relative;
		margin: 0 auto 23px;
		padding: 30px 36px 30px;
		box-sizing: border-box;
	}
	
	#f_info_wrap .info_btn_wrap .txt_list{
		/* display: flex; */
		/* flex-wrap: wrap; */
		/* gap: 4px 0; */
	}
	
	#f_info_wrap .info_btn_wrap .txt_list li{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size:1.5rem;
		letter-spacing: 0.2rem;
		font-feature-settings: 'palt';
		color:#000;
		line-height: 1.4;
		padding: 0 0 10px;
	}
	
	#f_info_wrap .info_btn_wrap .note_txt{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:300;
		font-size:1.3rem;
		letter-spacing: 0.2rem;
		font-feature-settings: 'palt';
		color:#000;
		line-height: 1.4;
		padding: 0 0 30px;
	}

	#f_info_wrap .btn_contact{
	}
	
	#f_info_wrap .btn_contact a{
		display:block;
		width: 100%;
		margin: 0 auto;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:400;
		font-size:1.6rem;
		letter-spacing:0.2rem;
		font-feature-settings: 'palt';
		text-align:center;
		color:#fff;
		line-height:1;
		padding: 12px 0 13px;
		border-radius:30px;
		background: linear-gradient( to right,  #db8500 0%,#ff9b00 50%, #ffbc54 100% );
		position:relative;
	}

	#f_info_wrap .btn_contact a span.tt{
		
	}

	#f_info_wrap .btn_contact a span.ty{
		line-height: 0;
		display:block;
		width:6px;
		position:absolute;
		right: 19px;
		top:50%;
		transform:translate(0,-50%);
	}


	#f_info_wrap .info_sub_wrap{
	width: 90%;
	margin: 0 auto;
	}


	#f_info_wrap .btn_sns a{
		display:block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:400;
		font-size:1.6rem;
		letter-spacing:0.2rem;
		font-feature-settings: 'palt';
		line-height: 1.4;
		padding: 0 24px 20px 50px;
		margin: 0 0 19px;
		position: relative;
		border-bottom: 1px solid #ccc;
	}

	#f_info_wrap .btn_sns a span.sns{
		display: block;
		position: absolute;
		width: 40px;
		top: 5px;
		left: 0;
	}

	#f_info_wrap .btn_sns a span.ty{
		line-height: 0;
		display:block;
		width: 10px;
		position:absolute;
		right: 0;
		top:50%;
		transform:translate(0,-50%);
		filter: brightness(0.5);
	}


	#f_info_wrap .tel_info{
		position: relative;
	}

	#f_info_wrap .tel_info p{
		display:block;
		font-family: 'Noto Serif JP', serif;
		font-weight:600;
		font-size:2.6rem;
		letter-spacing:0.2rem;
		font-feature-settings: 'palt';
		line-height: 1.2;
		padding: 0 0 0 36px;
	}

	#f_info_wrap .tel_info p.note_txt{
		display:block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:400;
		font-size:1.3rem;
		letter-spacing:0.1rem;
		font-feature-settings: 'palt';
		line-height: 1.4;
		padding: 0 0 0 38px;
	}

	#f_info_wrap .tel_info .img_icon{
		width: 27px;
		position:absolute;
		left:0;
		top: 7px;
	}

	#f_group_wrap{
		background:#3d3d3d;
		padding: 46px 0;
	}

	#f_group_wrap .wrapper{
	}

	#f_group_wrap .bg_eng_txt{
		font-family: 'Noto Serif JP', serif;
		font-weight: 300;
		font-size: 3.8rem;
		letter-spacing: 0.5rem;
		font-feature-settings: 'palt';
		color: #ffffff;
		line-height: 1;
		text-align: right;
		position:absolute;
		right: 25px;
		top: -30px;
		opacity: 0.05;
	}
	
	#f_group_wrap h2{
		font-family: 'Noto Serif JP', serif;
		font-weight: 500;
		font-size:2.4rem;
		letter-spacing: 0.6rem;
		font-feature-settings: 'palt';
		color:#fff;
		line-height:1.4;
		padding: 0 0 25px;
	}

	#f_group_wrap ul{
		display:flex;
		justify-content:space-between;
		gap: 0 10px;
	}

	#f_group_wrap ul a{
		display:block;
		line-height:0;
		overflow:hidden;
		border-radius:4px;
	}


	#f_sitemap_wrap{
		padding: 46px 0;
	}

	#f_sitemap_wrap .wrapper{
	padding: 0 9%;
	}

	#f_sitemap_wrap .company_info_wrap{
	padding: 0 0 28px;
	}

	#f_sitemap_wrap .company_info_wrap .ci_foot{
		width: 70px;
		opacity: 0.5;
		margin: 0 0 16px;
	}

	#f_sitemap_wrap .company_info_wrap h2{
		display:block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:600;
		font-size: 1.8rem;
		letter-spacing: 0.1rem;
		font-feature-settings: 'palt';
		line-height: 1.4;
		padding: 0 0 10px;
		color: #858585;
	}

	#f_sitemap_wrap .company_info_wrap p{
		display:block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		font-size: 1.3rem;
		letter-spacing: 0.1rem;
		font-feature-settings: 'palt';
		line-height: 1.4;
		padding: 0 0 6px;
		color: #858585;
	}

	#f_sitemap_wrap .company_info_wrap .tel_info li{
		display:block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:500;
		font-size: 1.5rem;
		letter-spacing:0.2rem;
		font-feature-settings: 'palt';
		line-height: 1.2;
		padding: 0 0 2px;
		color: #858585;
	}

	#f_sitemap_wrap .f_sitemap{
		display: none;
	}

	#f_sitemap_wrap .f_sitemap a{
		display: block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 1.4rem;
		color: #bababa;
		letter-spacing: 0.1rem;
		line-height: 1;
		padding: 0 10px 17px 0;
	}

	#f_sitemap_wrap .f_sitemap p{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		font-size: 1.5rem;
		color: #858585;
		letter-spacing: 0.2rem;
		padding: 0 0 10px;
		margin: -5px 0 0;
	}

	#f_sitemap_wrap .f_sitemap ul.reason_list{
		border-left:2px solid #646464;
	}

	#f_sitemap_wrap .f_sitemap ul.reason_list a{
		font-size: 1.3rem;
		padding: 6px 0 6px 14px;
	}

	#f_sitemap_wrap .f_sitemap a span{
		display:inline-block;
		font-size: 1.2rem;
		padding: 0 0 0 7px;
	}

	#f_sitemap_wrap .f_other p{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		font-size: 1.3rem;
		color: #858585;
		letter-spacing: 0.1rem;
		padding: 0 0 10px;
	}

	#f_sitemap_wrap .f_other p span{
		display:inline-block;
		width:18px;
		margin:0 10px 0 0;
		opacity:0.5;
	}

	#f_sitemap_wrap .f_other .lang_list{
		display:flex;
	}

	#f_sitemap_wrap .f_other .lang_list a{
		display: block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 1.3rem;
		color: #bababa;
		letter-spacing: 0.1rem;
		line-height: 1;
		padding: 0 9px 4px;
	}

	#f_sitemap_wrap .f_other .lang_list li{
		border-right:1px solid #616161;
	}

	#f_sitemap_wrap .f_other .lang_list li:first-child{
		border-left:1px solid #616161;
	}

	#f_sitemap_wrap .f_other .sns_wrap{
		padding: 20px 0 0;
	}

	#f_sitemap_wrap .f_other .sns_list{
		display:flex;
		gap:0 10px;
	}

	#f_sitemap_wrap .f_other .sns_list a{
		display:block;
		line-height:0;
		width: 32px;
	}

}
/*========================================================================
//
// GDPR Cookie
//
//========================================================================*/
/********* SP - iPhone 6 or higher (screen width up to 761px) ************/
@media (max-width:761px) {
	.g-gdpr {
		width: 80%;
		padding: 30px 10%;
		justify-content: center;
		align-items: center;
		background: rgba(0, 0, 0, .75);
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 10000;
		-webkit-backdrop-filter: blur(15px);
		backdrop-filter: blur(15px);
		transition: 1s;
		transform: translateY(100%);
		animation: anime-gdpr 1s both 1s;
	}
	.is-gdpr_off .g-gdpr {
		animation: anime-gdpr_off 1s both;
	}
	.g-gdpr__text {
		display: block;
		color: #cacaca;
		text-shadow: 0 0 3px #000;
		padding: 0 0 20px;
		font-size: 1.4rem;
	}
	.g-gdpr__text a {
		color: #85b9d0;
		text-decoration: underline !important;
		padding: 0 .15em;
		display: inline-block;
	}
	a.g-gdpr__button {
		color: #fff;
		font-size: 1.6rem;
		font-weight: 700;
		line-height: 1;
		text-align: center;
		white-space: nowrap;
		vertical-align: middle;
		padding: 1em 2em 1em 2em;
		display: block;
		background: #0096df;
		border: 1px solid #fff;
		transition: .2s;
		cursor: pointer;
	}
}