@charset "utf-8";

:root{
	--main-color: #F39801;
	--pale-color: #F8F7F1;
	--orange: #F08035;
	--green: #99BB17;
	--blue: #1193E5;
}

body{ min-width: 1200px; margin: 0 auto; font-family: 'Noto-Sans-JP-Regular'; }
a:hover{ opacity: 0.6; }
#wrapper{ padding: 104px 0 0; }
.sp{ display: none; }

.btn__link{ display: flex; align-items: center; gap: 19px; }
.btn__arrow{ display: flex; align-items: center; justify-content: center; width: 68px; height: 68px; border-radius: 100px; background: var(--main-color); border: 1px solid var(--main-color); }
.btn-linktxt{ font-size: 18px; }

.top_btn{ }
.top_btn a{ display: flex; align-items: center; justify-content: center; margin: 0 auto; width: 370px; height: 65px; font-size: 20px; color: #fff !important; background: var(--main-color) }

.title{ text-align: center; background: url(../images/index/logo_bg_01.svg) no-repeat center center; background-size: 611px; color: #fff; padding: 19px 0 67px; }
.title__en{ font-size: 56px; font-family: "memimas-pro", sans-serif; font-weight: 900; font-style: normal; letter-spacing: 0.01em; color: #fff; line-height: 80%;}
.title__ja{ font-size: 18px; font-family: 'Noto-Sans-JP-Bold'; }
.desc{ line-height: 2; }

.iframe-wrapper { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }
.iframe-wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }


/* ------------------------------------------------------------ header */
header { transition: all 0.6s; z-index: 150; position: fixed; left: 0; right: 0; top: 0; display: flex; justify-content: space-between; align-items: center; min-width: 1200px; background: #fff; }
header.is-scroll{ background: #fff; }
header h1{ position: relative; z-index: 150; width: 250px; margin-left: 26px; }
header h1 img{ width: 100%; height: auto; }

.nav { display: flex; align-items: center; justify-content: flex-end; gap: 30px; }
.nav .nav_box_sp{display: flex; align-items: center; justify-content: flex-end; gap: 30px; }
.gnav { }
.gnav__link { padding: 20px 22px; font-size: 19px; }

.nav-contact { width: 174px; background: var(--main-color); color: #fff; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 11px; padding: 25px 22px; }
.nav-contact__icon { width: 29px; height: auto; display: block; }
.nav-contact__txt { font-size: 14px; color: #fff; }

.sp-header{ display: none; }


/* ------------------------------------------------------------ cta */
.cta { background: var(--pale-color); padding: 40px 0 53px; font-family: 'Noto-Sans-JP-Bold'; text-align: center; }
.cta__box { background: #fff; border-radius: 19px; padding: 40px 40px 57px; }
.cta__title { margin: 0 0 31px; font-size: 29px; line-height: 1.5; }
.cta-flex { display: flex; justify-content: center; align-items: center; gap: 84px; margin: 0 0 47px; }

.cta-btn { position: relative; display: flex; align-items: center; justify-content: center; width: 324px; height: 65px; border-radius: 100px; background: var(--main-color); box-shadow: 0 5px 0 #D88700; }
.cta-btn__txt { padding-left: 30px; color: #fff; font-size: 19px; }
.cta-btn__icon { position: absolute; left: 26px; top: 50%; transform: translate(0,-50%); width: 29px; height: auto; }

.cta-tel__num { margin: 0 0 5px; display: flex; align-items: center; gap: 5px; font-weight: 900; letter-spacing: .02em; }
.cta-tel__num a { font-size: 46px; font-family: 'din1451alt'; }
.cta-tel__icon { width: 23px; height: auto; }
.cta-tel__time { margin: 0px 0px 0 30px; font-size: 12px; font-family: 'Noto-Sans-JP-Regular'; text-align: center;}

.cta-note { text-align: center; font-size: 16px; line-height: 1.5; }


/* ------------------------------------------------------------ footer */
footer{ padding: 50px 3% 0; border-top: 1px solid #DEDEDE; background: #707070;color: #fff; }
.footer_flex{display: flex; justify-content: space-between; padding:0 0 25px;}
.footer__inner{ margin: 0 auto; max-width: 1428px; }
.footer__catch { margin-bottom: 8px; font-size: 19px; font-family: 'Noto-Sans-JP-Bold'; line-height: 185%;}
.footer__title { font-size: 56px; line-height: 145%; font-family: 'Noto-Sans-JP-Bold'; }
footer .link_box{width: 538px; height: auto;}
footer .link_box .footer__nav .footer-nav-list{display: flex; justify-content: flex-end}
footer .link_box .footer__nav .footer-nav-list .footer__nav-item:not(:last-child){margin-right: 48px;}
footer .link_box .logo_btn{display: block; width: 377px; margin: 0 0 0 auto;}
footer .link_box .logo_btn img{display: block; width: 100%; height: auto;}
.footer__nav-item a { display: block; line-height: 180%; font-size: 15px; color: #fff;}

.footer__bottom{ display: flex; justify-content: space-between; align-items: center; padding: 35px 0; border-bottom: 1px solid #DEDEDE; border-top: 1px solid #DEDEDE; }
.footer__bottom .cta-flex{ gap: 20px; margin: 0; width: 52%; max-width: 606px;}
.footer__bottom .cta-tel{ min-width: 290px; }
.footer__bottom .cta-tel__num a { font-size: 43px; color: #fff; }
.footer__bottom .cta-btn { width: calc(100% - 300px); max-width: 294px; height: 56px; box-shadow: 0 3px 0 #D88700; }
.footer__bottom .cta-btn__txt { font-size: 16px; }
.footer__bottom .cta-btn__icon{ width: 23px; }
.footer__logo{ width: 19%; }
.footer__address{ font-size: 14px; line-height: 1.5; min-width: 350px;margin: 0 10px; }
footer .cta-tel__time { margin-left: 58px; text-align: left;}
.copy{ padding: 30px 0 60px; font-size: 15px; text-align: right; }


/* ------------------------------------------------------------ mobile ------------------------------------------------------------ */
@media only screen and (max-width:  768px) {

	body{ min-width: 100%; }
	#wrapper{ padding: 80px 0 0; }
	.pc{ display: none; }
	.sp{ display: block; }

	.btn__link { gap: 15px; justify-content: flex-end; }
	.btn__arrow { width: 40px; height: 40px; }
	.btn-linktxt { font-size: 16px; }
	
	.top_btn a{ width: 100%; }

	.title__en { font-size: 32px; }
	.title__ja { font-size: 13px; }
	
	.title { background: url(../images/index/logo_bg_01.svg) no-repeat center top; background-size: 339px; padding: 9px 0 35px; }
/* ------------------------------------------------------------ header */
	header{ padding: 3%; min-width: 100%; }
	header h1{ width: 140px; margin-left: 0; }
	
	.nav{ overflow-y: scroll; display: none; z-index: 100;position: absolute; top: 0; left: 0; right: 0; width: 100%; height: 100vh; align-items: flex-start; justify-content: flex-start; flex-direction: column; padding: 100px 20px 0; background: #fff; }
	.nav .nav_box_sp{height: 100vh; display: block;}
	nav{ width: 100%; padding: 0 0 50px;}
	.gnav__link { padding: 15px; display: block; border-bottom: 1px solid var(--main-color); }
	.nav-contact { display: none; }
	
	.sp-header{ display: flex; flex-direction: column; gap: 10px; align-items: center; width: 100%; }
	.sp-header .cta-flex{ margin: 20px 0 0; }
	
	.burger{ position: relative; z-index: 150; cursor: pointer; position: relative; width: 30px; height: 20px; }
	.burger span{ transition: all .3s ease; position: absolute; width: 100%; height: 1px; background: var(--main-color); }
	.burger span:first-of-type{ top: 5px; }
	.burger span:last-of-type{ top: 15px; }
	
	.nav.is-active{ transition: all .3s ease; opacity: 1; visibility: visible; }
	.burger.is-active span{ transition: all .3s ease; }
	.burger.is-active span:first-of-type{ transform: rotate(25deg); top: 10px; }
	.burger.is-active span:last-of-type{ transform: rotate(-25deg); top: 10px; }


/* ------------------------------------------------------------ cta */
	.cta{ padding: 30px 0; }
	.cta__box { padding: 25px 5% 43px; }
	.cta__title { margin: 0 0 17px; font-size: 21px; line-height: 143%;}
	.cta-flex { gap: 15px; margin: 0 0 20px; flex-direction: column; width: 100%; }
	.cta-btn { width: 100%; height: 59px; }
	.cta-btn__icon { width: 24px; }
	.cta-btn__txt { padding-left: 21px; font-size: 19px; }
	
	.cta-tel { min-width: 100%;padding: 20px 0 0px; }
	.cta-tel__num { margin: 0 0 5px;justify-content: center; }
	.cta-tel__icon { width: 23px; }
	.cta-tel__num a { font-size: 46px; }
	.cta-tel__time { margin: 0 0px 0 30px; font-size: 12px; text-align: center; }
	.cta-note { font-size: 15px; line-height: 154%;}


/* ------------------------------------------------------------ footer */
	footer { padding: 40px 5% 0; }
	.footer_flex{display: block; padding: 0;}
	footer .link_box { width: 100%;}
	footer .link_box .footer__nav .footer-nav-list {display: block;}
	.footer__catch { font-size: 16px; }
	.footer__title { font-size: 33px; }
	.footer__head { margin-bottom: 10px; }
	.footer__nav { padding: 0; margin: 0; }
	footer .link_box .footer__nav .footer-nav-list .footer__nav-item:not(:last-child) { margin-right: 0;}
	.footer__nav-item a { padding: 16px 0; font-size: 16px; line-height: 160%;}
	.footer__nav-item:not(:last-child) a{border-bottom: 1px solid #fff;}
	
	footer .link_box .logo_btn{width: 80%; margin: 0 auto ;}
	
	.footer__bottom { padding: 30px 0; flex-direction: column; }
	.footer__address { width: 100%; font-size: 13px; text-align: center; padding: 12px 0 0; }
	.footer__bottom .cta-flex { margin: 20px auto 0;width: 100%; max-width: 100%; }
	.footer__bottom .cta-btn {width: 100%; max-width: 294px; height: 56px;}
	.footer__logo { width: 57%; }

	.copy{ padding: 20px 0 50px; font-size: 12px; }



}
