/*---------------------
|- all
---------------------*/
body {
	font-family: "Noto Sans JP", sans-serif;
}
a {
	color: #000;
	text-decoration: none;
}
img {
	width: 100%;
	height: 100%;
	display: block;
}
.disPc {
	display: block;
}
.disSp {
	display: none;
}
@media (hover: hover){
	.cs-link {
		display: block;
		transition: all .2s ease;
	}
	.cs-link:hover {
		opacity: .7;
	}
}
@media screen and (max-width: 768px){
	.disPc {
		display: none;
	}
	.disSp {
		display: block;
	}
}
/*---------------------
|- header
---------------------*/
.header {
	position: sticky;
	top: 0;
	background: #EBEBE4;
	z-index: 50;
}
.header-top {
	background: #FFC300;
}
.header-top__txt {
	width: 77%;
	min-height: 50px;
	margin: 0 auto;
	display: flex;
	align-items: center;
}
.header-top__txt a {
	font-size: var(--fs16);
	font-weight: 600;
	letter-spacing: .06rem;
}
.header-btm {
	width: 78%;
	min-height: 90px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.lang {
	display: flex;
	gap: 0 20px;
}
.lang__item {
	list-style: none;
}
.lang__item.jp {
	position: relative;
}
.lang__item.jp::before {
	content: '';
	position: absolute;
	top: 6px;
	right: -11px;
	width: 1px;
	height: 18px;
	background: #000;
}
.lang__item a {
	font-size: var(--fs18);
	font-weight: 300;
	transition: all .2s ease;
}
@media (hover: hover){
	.header-top__txt a:hover,
	.lang__item a:hover {
		text-decoration: underline;
	}
}
@media screen and (max-width: 1116px){
	.header-top__txt a {
		font-size: var(--fs14);
	}
	.lang__item a {
		font-size: var(--fs15);
	}
}
@media screen and (max-width: 768px){
	.header-top {
		padding: 0 10px;
	}
	.header-top__txt {
		width: 100%;
		min-height: 40px;
		justify-content: center;
	}
	.header-top__txt a {
		font-size: var(--fs12);
		letter-spacing: -.01rem;
	}
	.header-btm {
		width: 90%;
		max-height: 65px;
		min-height: auto;
	}
	.logo {
		width: 55%;
		max-width: 235px;
	}
	.lang {
		gap: 0 11px;
	}
	.lang__item.jp::before {
		top: 8px;
		right: -6px;
		width: 1px;
		height: 12px;
		background: #000;
	}
	.lang__item a {
		font-size: var(--fs13);
	}
}
@media screen and (max-width: 381px){
	.header-top__txt a {
		font-size: var(--fs11);
	}
}
/*---------------------
|- main
---------------------*/
.main {
	background: #EBEBE4;
}
/*---------------------
|- mail-magazine
---------------------*/
.mail-magazine {
	padding: 120px 0;
}
.mail-magazine__txt {
	padding: 0 10px;
	margin-bottom: 60px;
	font-size: var(--fs24);
	text-align: center;
	line-height: 2;
}
.mail-magazine__btn {
	width: 605px;
	margin: 0 auto;
}
.en .mail-magazine__btn {
	width: 920px;
}
.mail-magazine__btn a {
	position: relative;
	width: 100%;
	padding: 12px 0 15px;
	color: #fff;
	font-size: var(--fs30);
	font-weight: 500;
	text-align: center;
	background: #002823;
	border-radius: 5px;
	display: block;
}
.mail-magazine__btn a::before {
	content: '';
	position: absolute;
	top: 50%;
	right: 8%;
	transform: translateY(-50%);
	width: 26px;
    height: 19px;
    background: url(/assets/img/btn_arrow_white.svg) no-repeat;
    background-size: 100%;
    transition: .3s;
}
@media (hover: hover){
	.mail-magazine__btn a {
		transition: .3s;
	}
	.mail-magazine__btn a:hover {
		opacity: .8;
	}
	.mail-magazine__btn a:hover::before {
		right: 7%;
	}
}
@media screen and (max-width: 1116px){
	.en .mail-magazine__btn {
		width: 650px;
	}
	.en .mail-magazine__btn a {
		font-size: var(--fs24);
	}
	.en .mail-magazine__btn a::before {
		right: 3%;
	}
	@media (hover: hover){
		.en .mail-magazine__btn a:hover::before {
			right: 2%;
		}
	}
}
@media screen and (max-width: 768px){
	.mail-magazine {
		padding: 65px 0 60px;
	}
	.mail-magazine__txt,
	.en .mail-magazine__btn a {
		margin-bottom: 30px;
		font-size: var(--fs16);
	}
	.mail-magazine__btn, .en .mail-magazine__btn {
		width: 80%;
		max-width: 310px;
	}
	.mail-magazine__btn a {
		padding: 15px 0 19px 0;
		font-size: var(--fs17);
		border-radius: 3px;
	}
	.mail-magazine__btn a {
		padding: 17px 0 18px 0;
	}
	.mail-magazine__btn a::before {
		width: 13px;
		height: 10px;
	}
	.en .mail-magazine__btn a::before {
		right: 8%;
	}
}
@media screen and (max-width: 330px){
	.mail-magazine__txt {
		font-size: var(--fs15);
	}
	.mail-magazine__btn a {
		font-size: var(--fs16);
	}
	.mail-magazine__btn a::before {
		right: 10px;
	}
}
/*---------------------
|- footer
---------------------*/
.footer {
	background: #a9aeb1;
}
.footer-inner {
	max-width: 1600px;
	margin: 0 auto;
	padding: 52px 76px;
	gap: 0 20px;
}
.footer-link {
	margin-bottom: 30px;
	display: flex;
	flex-direction: column;
	gap: 5px 0;
}
.footer-link__item {
	list-style: none;
}
.footer-link__item a {
	color: #fff;
	font-size: var(--fs14);
	display: inline-block;
}
.footer-btm {
	display: flex;
	justify-content: space-between;
	align-items: end;
}
.copyright {
	color: #fff;
	font-size: var(--fs11);
}
.footer-logo img {
	width: 92px;
}
.btn-pagetop {
    position: fixed;
    right: 25px;
    bottom: 50px;
    width: 50px;
	height: 50px;
	background: rgb(0,0,0,.3);
	border-radius: 50px;
    cursor: pointer;
	z-index: 20;
}
.btn-pagetop img {
	width: 35px;
	margin: 0 auto;
}
@media screen and (max-width: 768px){
	.footer-inner {
		padding: 40px 20px 20px;
	}
	.btn-pagetop {
		right: 20px;
		bottom: 20px;
	}
	.btn-pagetop img {
		width: 30px;
	}
}
/*---------------------
|- font
---------------------*/
:root {
	--fs10: .625rem;
	--fs11: .687rem;
	--fs12: .75rem;
	--fs13: .812rem;
	--fs14: .875rem;
	--fs15: .937rem;
	--fs16: 1rem;
	--fs17: 1.06rem;
	--fs18: 1.12rem;
	--fs19: 1.18rem;
	--fs20: 1.25rem;
	--fs21: 1.31rem;
	--fs22: 1.37rem;
	--fs23: 1.43rem;
	--fs24: 1.5rem;
	--fs25: 1.56rem;
	--fs26: 1.62rem;
	--fs27: 1.68rem;
	--fs28: 1.75rem;
	--fs29: 1.81rem;
	--fs30: 1.87rem;
	--fs36: 2.25rem;
	--fs38: 2.375rem;
}