@charset "UTF-8";
/*--------------------------------
	　サイト共通設定
--------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
}
html {
	font-size: 62.5%;
}
body, table, input, textarea, select, option {
	font-family: 'Zen Kaku Gothic New', sans-serif;
}
input,button,textarea,select {
	margin: 0;padding: 0;border: none;border-radius: 0;background: none;outline: none;-webkit-appearance: none;-moz-appearance: none;appearance: none;
	font-family: 'Zen Kaku Gothic New', 'Noto Sans JP', "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Arial, Verdana, sans-serif;
	color: #000000;
}
.poppins {
	font-family: 'Poppins', sans-serif;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
	display: block;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
:focus {
	outline: 0;
}
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
}
a, a:link {
	text-decoration: none;
}
textarea {resize: vertical;}
select::-ms-expand {display: none;}
::placeholder {
	color: #C7C7C7;
}
/*.ie11対策*/
input:-ms-input-placeholder {
	color: #C7C7C7;
}
select:invalid {
	color: #C7C7C7;
}
/*.ie11対策*/
[type="checkbox"],
[type="radio"] {
	visibility: hidden;
	width:1px;
	position: absolute;
}
input,
select {
	-webkit-appearance: none;
}
/*--------------------------------
	　全体レイアウト
--------------------------------*/
body {
	position: relative;
	color: #000000;
	font-size: 1.6rem;
	line-height: 1.56;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #FFF;
}
@media all and (max-width: 1024px) {
	body {
		min-width: inherit;
		font-size: 1.2rem;
	}
}
.content {
	width: 109.5rem;
	margin: 0 auto;
	box-sizing: border-box;
}
@media all and (max-width: 1239px) { /* 1095px + 133px + α  */
	.content {
		width: calc( 100% - 4rem );
		margin: 0 auto;
	}
}
/*--------------------------------
	　ヘッダー
--------------------------------*/
header {
	position: fixed;
	z-index: 3;
	top: 0;
	left: 0;
	width: 13rem;
	height: 100%;
	background: #FFF;
	transition: .5s;
}
header.open {
	width: 53rem;
	border-radius: 0 0 16rem 0;
	background: #EDA00C;
}
header .header-item {
	position: relative;
	height: 100%;
	border-right: 2px solid #FFD481;
	transition: .5s;
	cursor: pointer;
}
header.open .header-item {
	border-right: unset;
	overflow-y: auto;
	overflow-x: hidden;
}
header .header-item .site-logo {
	position: absolute;
	top: 5rem;
	left: 3.5rem;
}
header .header-item .site-logo img {
	transition: .1s;
}
header.open .header-item .site-logo img {
	filter: brightness(0) invert(1);
}
header .header-item nav {
	position: absolute;
	top: 0;
	left: 13rem;
	width: 40rem;
/*	padding: 6.2rem 0 0 20rem;*/
	padding: 0 0 2rem 0;
	opacity: 0;
	visibility: hidden;
}
header.open .header-item nav {
	opacity: 1;
	visibility: visible;
}
header .header-item nav ul.gnav {
	margin: 0 0 0;
}
header .header-item nav ul.gnav li a {
	display: block;
	box-sizing: border-box;
	padding: 1.75rem 0 1.75rem 7rem;
	color: #FFF;
	line-height: 1.4;
}
header .header-item nav ul.gnav li:first-child a {
	padding: 6.2rem 0 1.75rem 7rem;
}
header .header-item nav ul.gnav li:last-child a {
	padding: 1.75rem 0 8.75rem 7rem;
}
header .header-item nav ul.gnav li a span {
	display: block;
}
header .header-item nav ul.gnav li a span.en {
	font-family: 'Poppins', sans-serif;
	font-weight: 600;
	font-size: 2.4rem;
}
header .header-item nav ul.gnav li a span.jp {
	font-size: 1.3rem;
	letter-spacing: 0.05em;
}
header .header-item nav ul.social {
	display: flex;
	padding: 0 0 0 0;
}
header .header-item nav ul.social li a {
	display: flex;
	align-items: center;
}
header .header-item nav ul.social li:first-child a {
	padding: 1.7rem 2rem 1.7rem 7rem;
}
header .header-item nav ul.social li:nth-of-type(2) a {
	padding: 2rem 10rem 2.1rem 2rem;
}
header .header-item .menu {
	position: absolute;
	bottom: 4.5rem;
	left: 5rem;
	width: 2.6rem;
	height: 2.6rem;
	cursor: pointer;
	z-index: 2;
	transition: opacity .25s ease;
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
}
header .header-item .menu span {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 2px;
	background: #EDA00C;
	border: none;
	border-radius: 10rem;
	-webkit-transition: all .35s ease;
	transition: all .35s ease;
	cursor: pointer;
}
header .header-item .menu span:nth-of-type(2) {
	top: 0.7rem;
}
header .header-item .menu span:nth-of-type(3) {
	top: 1.4rem;
}
header .header-item .menu.open .top {
	-webkit-transform: translateY(0.7rem) translateX(0) rotate(-45deg);
	-ms-transform: translateY(0.7rem) translateX(0) rotate(-45deg);
	transform: translateY(0.7rem) translateX(0) rotate(-45deg);
	background: #FFF;
}
header .header-item .menu.open .middle {
	opacity: 0;
	background: #FFF;
}
header .header-item .menu.open .bottom {
	-webkit-transform: translateY(-0.7rem) translateX(0) rotate(45deg);
	-ms-transform: translateY(-0.7rem) translateX(0) rotate(45deg);
	transform: translateY(-0.7rem) translateX(0) rotate(45deg);
	background: #FFF;
}
header .header-item .menu-txt {
	position: absolute;
	left: 4rem;
	top: calc( 50% - 2rem);
	width: 5rem;
	rotate: 90deg;
	text-align: center;
}
header .header-item .menu-txt p {
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 1.4rem;
	color: #EDA00C;
	letter-spacing: 0.05em;
}
header.open .header-item .menu-txt p {
	color: #FFF;
}
body.fixed {
	position: relative;
	overflow: hidden;
}
@media all and (min-width: 1025px) {
	body.fixed .cover {
		position: fixed;
		top: 0;
		width: 100%;
		height: 100%;
		z-index: 2;
		background: rgba( 255, 255, 255 , 0.8);
	}
	header .header-item:hover {
		background: #EDA00C;
	}
	header.open .header-item:hover {
		background: unset;
	}
	header .header-item:hover .site-logo img {
		filter: brightness(0) invert(1);
	}
	header .header-item:hover .menu span {
		background: #FFF;
	}
	header .header-item:hover .menu-txt p {
		color: #FFF;
	}
}
@media all and (max-width: 1024px) {
	body.fixed {
		position: relative;
		overflow: hidden;
	}
	body.fixed::before {
		content: "";
		position: fixed;
		width: 100%;
		height: 100%;
		z-index: 2;
		background: rgba( 255, 255, 255 , 0.8);
	}
	header {
		position: static;
		width: 100%;
		height: 7rem;
	}
	header.open {
		width: unset;
		background: unset;
	}
	header .header-item {
		height: unset;
		background: unset;
		border-right: unset;
	}
	header .header-item .site-logo {
		position: static;
		padding: 1.5rem 0 0 1.5rem;
	}
	header.open .header-item .header-item-gnav {
		position: fixed;
		z-index: 2;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		aspect-ratio: 1 / 2;
		box-sizing: border-box;
		overflow-y: scroll;
	}
	header .header-item .header-item-gnav .header-item-gnav-in {
		position: absolute;
		left: 100%;
		top: 0;
		width: 100%;
		background: #EDA00C;
		border-radius: 0 0 0 12rem;
		transition: .5s;
	}
	header.open .header-item .header-item-gnav .header-item-gnav-in {
		left: 0;
	}
	header .header-item nav {
		display: none;
		position: static;
		padding: 0 0 6.5rem 0;
		transition: .5s;
		opacity: 0;
	}
	header.open .header-item nav {
		display: block;
		width: 100%;
		transition-property: display opacity;
		transition-behavior: allow-discrete;
		transition-duration: .3s;
		opacity: 1;
		@starting-style {
			height: 0px;
			opacity: 0;
		}
	}
	header .header-item nav ul.gnav li a {
		padding: 1.75rem 0 1.75rem 9rem;
	}
	header .header-item nav ul.gnav li:first-child a {
		padding: 4.25rem 0 1.75rem 9rem;
	}
	header .header-item nav ul.gnav li:last-child a {
		padding: 1.75rem 0 8.75rem 9rem;
	}
	header .header-item nav ul.gnav li a span.en {
		font-size: 2.5rem;
	}
	header .header-item .menu {
		position: fixed;
		left: unset;
		bottom: unset;
		right: 1rem;
		top: 1rem;
		width: 4.8rem;
		height: 4.8rem;
		display: flex;
		align-items: center;
		justify-content: center;
		background: #EDA00C;
		border-radius: 100%;
	}
	header .header-item nav ul.social {
		padding: 0 0 0 0;
	}
	header .header-item nav ul.social li:first-child a {
		padding: 1.7rem 2rem 1.7rem 9rem;
	}
	header .header-item .menu span {
		left: 1.3rem;
		top: 1.6rem;
		width: 2rem;
		background: #FFF;
	}
	header .header-item .menu span:nth-of-type(2) {
		top: 2.3rem;
	}
	header .header-item .menu span:nth-of-type(3) {
		top: 3rem;
	}
	header .header-item .menu-txt {
		display: none;
	}
	header:has(+ main.under) {
		height: unset;
	}
	header:has(+ main.under) .site-logo {
		display: none;
	}
}
@media all and (min-width: 1025px) {
	footer {
		padding: 4rem 0 6rem 13rem;
	}
}
footer {
	background: #FFFAE5;
}
footer .f-logo {
	display: flex;
	justify-content: center;
	margin: 0 0 7rem;
}
footer nav {
	margin: 0 0 7rem;
}
footer nav ul.f-nav {
	display: flex;
	justify-content: center;
	gap: 0 5rem;
	margin: 0 0 5rem;
}
footer nav ul.f-nav li {}
footer nav ul.f-nav li a {
	font-size: 1.4rem;
	font-weight: 500;
	color: #5D5D5D;
	letter-spacing: 0.05em;
	transition: .3s;
}
footer nav ul.f-nav li a:hover {
	color: #AAAAAA;
}
footer nav ul.social {
	display: flex;
	justify-content: center;
	gap: 0 4rem;
}
footer nav ul.social li {}
footer nav ul.social li a {
	display: flex;
	align-items: center;
	transition: .3s;
}
footer nav ul.social li a:hover {
	filter: invert(50%);
}
footer nav ul.social li:nth-of-type(2) {
	padding: 0.4rem 0 0.3rem 0;
}
footer address {
	font-style: normal;
	font-weight: 400;
	font-size: 1.1rem;
	color: #777777;
	text-align: center;
}
@media all and (max-width: 1120px) and (min-width: 1025px) {
	footer nav ul.f-nav {
		gap: 0 3.5rem;
	}
}
@media all and (max-width: 1024px) {
	footer {
		padding: 10rem 0 5rem 0;
	}
	footer .f-logo {
		max-width: 25rem;
		margin: 0 auto 4rem;
	}
	footer nav {
		margin: 0 0 5rem;
	}
	footer nav ul.f-nav {
		display: block;
	}
	footer nav ul.f-nav li {
		margin: 0 auto 3rem;
		text-align: center;
	}
}
@media all and (min-width: 1025px) {
	main {
		padding: 0 0 0 13rem;
	}
}