@charset "utf-8";
/* CSS Document */

*{
	margin: 0;
	padding: 0;
    word-break: break-all;
}

html { 
	overflow-y: scroll;
	overflow-x: hidden;
	font-size: 62.5%;
	-webkit-text-size-adjust: 100%;
}


body {
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 500;
	font-style: normal;
	font-size: 1.35rem;/*16*/
	/*-webkit-text-size-adjust: none;*/
	line-height: 1.5;
	color: #000000;
	overflow: hidden;
}

html.is-open {
	overflow: hidden;
}

.noto-sans-jp-400 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.noto-sans-jp-500 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.noto-sans-jp-700 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.audiowide-regular {
  font-family: "Audiowide", sans-serif;
  font-weight: 400;
  font-style: normal;
}

img {
	max-width: 100%;
	height: auto;
	border: 0;
	vertical-align: top;
	vertical-align: bottom;
}
a {
	/*overflow: hidden;*/
	outline: none;
	color: #000000;
	text-decoration:none;
}
.pc_hide {
}

.sp_hide {
	display: none !important;
}

a {
	opacity: 1;/*-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;*/
}

/* iOSでのデフォルトスタイルをリセット */
input[type="submit"], input[type="button"] {
	border-radius: 0;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
	appearance: button;
	border: none;
	box-sizing: border-box;
	cursor: pointer;
}

select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    outline: none;
    background: transparent;
}


select::-ms-expand {
    display: none;
}

h1,h2,h3,h4{
	font-weight: 500;
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

#all_wrap,
#contents{
	overflow: hidden;
}

ol, ul {
    list-style: none;
	box-sizing: border-box;
}

/*===================================
	仕様
=====================================*/

.down-to-top02 {
	opacity: 0;
	transform: translateY(100px);
	transition: all 1s;
}

.down-to-top02.scrollin {
	opacity: 1;
	transform: translateY(0);
}

.fadeUpTrigger{
	opacity: 0;
}


.fadeUp{
animation-name:fadeUpAnime;
animation-duration:1.0s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(75px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}

/*===================================
	#header_wrap
=====================================*/

#header_wrap{
	width: 100%;
	height: 65px;
	background: rgba(255,255,255,0.85);
	display: flex;
	justify-content: flex-end;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
}

#header_wrap h1{
	width: 58.4722%;/*421*/
	position: absolute;
	top: 50%;
	left: 2.3611%;/*17*/
	transform: translateY(-50%);
}

#header_wrap h1 img{
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: calc(130px * 0.82 / 2 );
	object-fit: contain;
}

#header_wrap .head_contact{
	width: 18.0555%;/*130*/
	height: 100%;
}

#header_wrap .head_contact a{
	display: flex;
	justify-content: center;
	align-items: flex-end;
	width: 100%;
	height: 100%;
	background: url("images/common/mail_ico.webp")no-repeat #e81c24 center top 15px;
	background-size: 28px auto;
	font-size: 1.0rem;
	line-height: 1;
	letter-spacing: 0.1em;
	color: #fff;
	padding-bottom: 9px;
	box-sizing: border-box;
}

.gtranslate_wrapper{
	width: 18.0555%;/*130*/
	margin-top: 9px;
	position: absolute;
	right: 18.75%;/*135*/
}

.gt_float_switcher .gt-selected .gt-current-lang span.gt-lang-code{
	display: none;
}


.gt_float_switcher .gt_options a{
	font-size: 0;
}

.gt_float_switcher .gt-selected .gt-current-lang span.gt_float_switcher-arrow{
	width: 8px !important;
	height: 12px !important;
	position: absolute;
	top: 17px;
	right: 5px;
	z-index: 1;
}

.gt_options.gt-open{
	max-width: 100% !important;
}



/*===================================
	#footer_wrap
=====================================*/

#footer_wrap{
	padding: 21px 0 35px;
	background: #edf2f4;
}

#footer_wrap .foot_logo{
	display: flex;
	justify-content: center;
	width: 73.1944%;/*527*/
	margin: 0 auto;
}

#footer_wrap .foot_logo img{
	width: 100%;
	height: auto;
}

#footer_wrap p.copy_txt{
	padding-top: 38px;
	font-size: 1.0rem;
	line-height: 1;
	color: #000;
	text-align: center;
}

/*===================================
	#footer_wrap
=====================================*/

.totop{
	display: none;
	width: 3.45rem;
	position: fixed;
	bottom: 19px;
	right: 3px;
	z-index: 100;
}

.totop img{
	width: 100%;
	height: auto;
}