@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Inter:wght@400;700&family=M+PLUS+Rounded+1c:wght@900&display=swap');
html,body{
  font-family: "Inter", "Noto Sans JP", "Hiragino Sans" , "ヒラギノ角ゴ ProN", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, "游ゴシック Medium", YuGothic, YuGothicM, sans-serif;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	color: #2E3A3C;
	line-height: 1.5;
  letter-spacing: 0.02em;
}
header,footer,div,section,article,nav,a,p,span,ul,ol,li,dl,dt,dd,h1,h2,h3,h4,h5,h6,img,dl,dt,dd,form,input,textarea{ box-sizing: border-box; }
::selection { background: #ddd; }
::-moz-selection { background: #ddd; }
a,a img{
  color: #2E3A3C;
  transition: opacity 0.3s;
  text-decoration: none;
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* Internet Explorer */
  -khtml-user-select: none; /* KHTML browsers (e.g. Konqueror) */
  -webkit-user-select: none; /* Chrome, Safari, and Opera */
  -webkit-touch-callout: none; /* Disable Android and iOS callouts*/
}
a:hover,a:hover img{ opacity: 0.7;cursor: pointer; }
img,picture{
	max-width: 100%;
	display: block;
}
.clear{ clear: both; }
.overflow{ overflow: hidden; }




body{ padding-top: 7.8rem; }
body.login{ padding-top: 0; }


nav{
  width: 100%;
  height: 7.8rem;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;

  display: flex;
  justify-content: flex-start;
  align-items: center;
  background-color: #fff;
}
nav a.logo{
  display: block;
  margin-left: 2rem;
}
nav a.logo img{
  height: 6rem;
}
nav .user{
  margin: 0 2rem 0 auto;
}


.user{
  display: flex;
  align-items: center;
}
.user img.ico{
  width: 4.2rem;
  height: 4.2rem;
  border-radius: 50%;
  object-fit: cover;
  margin-right: 1.2rem;
}
.user .user-name{
  font-size: 1.6rem;
  font-weight: 700;
}
.user .user-id,
.user .logout{
  display: inline-block;
  font-size: 1.5rem;
  line-height: 1.2;
}
.user .user-id{
  opacity: 0.5;
  margin-right: 0.5em;
  padding-top: 0.5rem;
}
.user .logout{
  font-weight: 700;
  border: none;
  vertical-align: top;
  background-color: rgb(63 131 248);
  color: rgb(255 255 255);
  border-radius: 0.25rem;
  padding: 0.5rem 0.75rem;
}


.language{
  font-size: 1.4rem;
  font-weight: 700;
  position: relative;
}
.language .valid{
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 4.2rem;
  border-radius: 2.1rem;
  padding: 0 1.2rem;
  background-color: #F5F5F5;
  cursor: pointer;
}
.language img.ico{
  width: 3rem;
  margin-right: 0.6rem;
}
.language ul.select{
  display: none;
  width: 16rem;
  background: #fff;
  box-shadow: 0 0 0.6rem rgba(0,0,0,0.07);
  border-radius: 1.2rem;
  padding: 1.2rem 1rem;
  position: absolute;
  right: 0;
  bottom: 5.2rem;
}
.language ul.select li{
  display: block;
}
.language ul.select li a{
  display: flex;
  align-items: center;
  line-height: 4.2rem;
  border-radius: 2.1rem;
  padding: 0 1.2rem;
  transition: background 0.3s;
}
.language ul.select li a:hover{
  background-color: #F5F5F5;
  opacity: 1;
}
.language ul.select li a:hover img{
  opacity: 1;
}


h1.headline{
  font-size: 2.1rem;
  text-align: center;
  background: radial-gradient(#F8F8F8,#E9EBEA);
  padding: 2.3rem 0;
}
h1.headline .txt{
  font-family: "Inter", 'Noto Sans JP', "Hiragino Sans", "ヒラギノ角ゴ ProN", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, "游ゴシック Medium", YuGothic, YuGothicM, sans-serif;
  padding-left: 3rem;
}
h1.headline img{
  width: auto;
  height: 7.4rem;
  margin: 0 auto;
}


h1.h1-1{
  font-size: 2.4rem;
  text-align: center;
  margin: 3rem 0;
}


.contact-box{
  background: #F5F5F5;
  border-radius: 1.2rem;
  padding: 3rem;
  margin-top: 4rem;
}

p.contact{
  font-size: 1.5rem;
  line-height: 1.6;
}
p.contact a{
  font-weight: 700;
}
p.contact a.mailto{
  text-decoration: underline;
}


.next-btn{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 5.6rem;
  border-radius: 0.6rem;
  background: #2E3A3C;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 700;
  margin-top: 4rem;
  position: relative;
  transition: opacity 0.3s;
}
.next-btn.gr{
  background: #3D886B;
  border: none;
}
.next-btn.bk::before{
  content: "";
  display: block;
  width: 0.6rem;
  height: 100%;
  background: url(../images/arrow-right_w.svg) center center no-repeat;
  background-size: contain;
  position: absolute;
  top: 0;
  right: 1.1rem;
}
.next-btn:hover{
  opacity: 0.7;
}


.back-btn{
  display: flex;
  justify-content: center;
  margin-top: 3rem;
}
.back-btn a{
  display: flex;
  align-items: center;
}
.back-btn a::before{
  content: "";
  display: block;
  width: 0.6rem;
  height: 100%;
  background: url(../images/arrow-left.svg) center center no-repeat;
  background-size: contain;
  margin-right: 1rem;
}


form input[type=text],
form input[type=password],
.select-wrap select{
  display: block;
  width: 100%;
  border-radius: 0.6rem;
  padding: 1em;
  background: #EFEFEF;
  border: none;
  font-size: 1.5rem;
  color: #2E3A3C;
  letter-spacing: 0.02em;
}
form input[type=submit]:hover{
  opacity: 0.7;
}


footer{
  padding: 2rem 0;
}
footer .content{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
footer .copy{
  font-size: 1.2rem;
  opacity: 0.5;
}




/*　PC
------------------------------------------------------------------------------------------------*/
@media (min-width: 769px){
.sp{ display: none !important; }

html{ font-size: 10px; }
body{ font-size: 1.6rem; }

.content{
  width: 100%;
	max-width: 85rem;
	margin: 0 auto;
}




/*　タブレット
------------------------------------------------------------------------------------------------*/
@media (max-width: 1100px){

html{ font-size: 0.9vw; }




}/*　タブレットここまで */
}/*　PCここまで */




/*　スマホ
------------------------------------------------------------------------------------------------*/
@media (max-width: 768px){
.pc{ display: none !important; }

html{ font-size: 2.5vw; }
body{ font-size: 1.5rem; line-height: 1.6; }

.content{
	width: 100%;
	padding: 0 1.8rem;
}


body{ padding-top: 8rem; }


nav{
  height: 8rem;
}
nav a.logo{
  margin-left: 1.8rem;
}
nav a.logo img{
  height: 60px;
}


#nav-drawer {
  position: relative;
  margin-left: auto;
}
.nav-unshown { display:none !important; }
#nav-open {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4.8rem;
  height: 4.8rem;
  border-radius: 50%;
  background: #303C3E;
  cursor: pointer;
  position: fixed;
  top: 1.2rem;
  right: 1.2rem;
  z-index: 999;
}
#nav-open span,#nav-open span:before,#nav-open span:after {
  content: "";
  display: block;
  background: #fff;
  width: 2.1rem;
  height: 3px;
  border-radius: 1.5px;
  position: absolute;
  margin-top: -1.2rem;
  transition: .3s ease-in-out;
}
#nav-open .txt{
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 0.8rem;
  font-size: 900;
  color: #fff;
  margin-top: 1.8rem;
}
#nav-open .txt:before{
  content: "MENU";
}
#nav-open span{
  background: transparent;
}
#nav-open span:before {
  bottom: 0.4rem;
  transform: rotate(0);
  transition: bottom .15s .15s, transform .15s;
}
#nav-open span:after {
  bottom: -0.4rem;
  transform: rotate(0);
  transition: bottom .15s .15s, transform .15s;
}
#nav-close {
  display: block;
  position: fixed;
  z-index: 99;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  transition: .3s ease-in-out;

  overflow-y: scroll;
  overscroll-behavior: contain;
  -ms-overflow-style: none; /* バー非表示 IE・Edge用 */
  scrollbar-width: none; /* バー非表示 Firefox用 */
  touch-action: none;
}
/*閉じる用の薄黒カバー*/
#nav-close::before{
  content: "";
  display: block;
  width: 100%;
  height: calc(100% + 1px);
  background: #2E3A3C;
  opacity: 0;
  transition: .3s ease-in-out;
}
/*中身*/
#nav-content {
  overflow: auto;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 998;
  width: 80%;
  height: calc(100% + 1px);
  background: #fff;
  padding: 10rem 2.4rem 6rem;
  transition: .3s ease-in-out;
  -webkit-transform: translateX(105%);
  transform: translateX(105%);

  overflow-y: scroll;
  overscroll-behavior: contain;
  -ms-overflow-style: none; /* バー非表示 IE・Edge用 */
  scrollbar-width: none; /* バー非表示 Firefox用 */
}
#nav-content::before{
  content: "";
  display: block;
  width: 1px;
  height: calc(100% + 1px);
  position: absolute;
  left: 0;
  top: 0;
}
/* バー非表示 Chrome・Safari用 */
#nav-close::-webkit-scrollbar,
#nav-content::-webkit-scrollbar{
  display:none;
}
/*チェックが入ったらもろもろ表示*/
#nav-input:checked ~ #nav-open .txt:before{
  content: "CLOSE";
}
#nav-input:checked ~ #nav-close {
  pointer-events: inherit;
}
#nav-input:checked ~ #nav-close::before{
  opacity: 0.3;
}
#nav-input:checked ~ #nav-close #nav-content {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);
}
#nav-input:checked ~ #nav-open span {
  background: transparent;
}
#nav-input:checked ~ #nav-open span:before {
  bottom: 0;
  transform: rotate(-30deg);
  transition: bottom .15s, transform .15s .15s;
}
#nav-input:checked ~ #nav-open span:after {
  bottom: 0;
  transform: rotate(30deg);
  transition: bottom .15s, transform .15s .15s;
}


#nav-content .user{
  margin: 0 0 3.7rem;
}
#nav-content .language{
  margin-top: 3rem;
}
#nav-content img.nav-logo{
  width: 12rem;
  margin: 4rem auto 0;
}
#nav-content .txt{
  font-family: "Inter", 'Noto Sans JP', "Hiragino Sans", "ヒラギノ角ゴ ProN", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, "游ゴシック Medium", YuGothic, YuGothicM, sans-serif;
  text-align: center;
}


.user img.ico{
  width: 6rem;
  height: 6rem;
}
.user .user-name{
  margin-bottom: 0.3em;
}
.user .user-id{
  display: block;
  margin-right: 0;
}


.language ul.select{
  width: 100%;
  background-color: #F5F5F5;
  box-shadow: none;
  position: unset;
  margin-top: 1rem;
}
.language ul.select li a:hover{
  background-color: #e5e5e5;
}
.language ul.select li a{
  justify-content: center;
}


h1.headline{
  font-size: 2.1rem;
  padding: 3rem 0;
}
h1.headline img{
  height: 60px;
}


h1.h1-1{
  font-size: 1.8rem;
  margin: 1.5rem 0 3rem;
}


.contact-box{
  padding: 1.5rem;
}


.next-btn{
  font-size: 1.5rem;
}


footer{
  text-align: center;
}
footer .content{
  display: block;
}




}/*　スマホここまで */



