/*layout*/
@charset "utf-8";
.contents-width-l { width: 90%; max-width: 1200px;  margin: 0 auto; }
.contents-width { width: 90%; max-width: 1000px;  margin: 0 auto; }
.contents-width-s { width: 90%; max-width: 770px;  margin: 0 auto; }

.conts-section { padding: 100px 0; }
.conts-section-t { padding-top: 100px; }

.conts-section-s { padding: 50px 0; }
.conts-section-s-t { padding-top: 50px; }

@media screen and (max-width: 900px) {
	.conts-section { padding: 50px 0; }
	.conts-section-t { padding-top: 50px; }
	.conts-section-s { padding: 30px 0; }
	.conts-section-s-t { padding-top: 30px; }
}

.header { display: flex; justify-content: space-between; align-items: center; position: sticky; width: 100%; left: 0; top: 0; margin: auto; background: rgba(255,255,255,.8); z-index: 99;}
.head-menu { display: flex; font-size: .875rem; white-space: nowrap;}
.head-menu  > li { position: relative;}
.head-menu  > li > a { display: flex; height: 80px; padding: 0 1.5em; align-items: center; }
.head-menu .submenu { position: absolute; top: 100%; left: 50%; margin: -1px auto auto; background: rgba(255, 255, 255, .9); color: #787878; text-align: center; opacity: 0; pointer-events: none; transition: transform .3s, opacity .3s; transform: translate(-50%,-5px); }
.head-menu .submenu::before { content: ''; width: calc(100% - 1em); height: 3px; background: #555555; position: absolute; top: -2px; left: 0; right: 0; margin: auto; }
.head-menu .submenu > li + li { border-top: 1px solid #DDDDDD; }
.head-menu .submenu > li > a { display: block; padding: .5em;}

.head-menu .lang { display: flex; align-items: center; }
.head-menu .lang select { display: block; border-color: #CCC;padding: .3em;  }

@media (hover:hover) {
	.head-menu > li:hover .submenu { opacity: 1; transform: translate(-50%,0); pointer-events: auto; }
}

.btn-hamburger { display: none; }

@media screen and (max-width: 900px) {
	.head-menu { transform: translateX(100%); transition: transform .3s; position: fixed; top: 0; right: 0; margin: auto; background: #FFF; width: 60%; padding: 5rem 5%; height: 100%; flex-direction: column; }
	.head-menu  > li:not(:last-child) { margin-right: 0; margin-bottom: 2em; }
	.head-menu > li > a { padding: 0; height: auto; }

	.open .head-menu { transform: translateX(0); box-shadow: 0 0 20px rgba(0,0,0,.1); }

	.header-logo { width: 100px;margin: 0; }

	.btn-hamburger { display: block; position: absolute; right: 10px; height: 10px; z-index: 99; width: 40px; height: 40px; margin: auto; background: none; border: none; white-space: nowrap; text-indent: 200%; overflow: hidden; }
	.btn-hamburger::before,
	.btn-hamburger::after { content: ''; width: 20px; height: 2px; display: block; border-radius: 2em; background: #000850; position: absolute; inset: 0; margin: auto; transition: transform .3s; }
	.btn-hamburger::before { transform: translateY(-6px); box-shadow: 0 6px 0  #000850; }
	.btn-hamburger::after { transform: translateY(6px); }

	.open .btn-hamburger::before { transform: rotate(-45deg); box-shadow: none; }
	.open .btn-hamburger::after { transform: rotate(45deg); }

	.head-menu .submenu { opacity: 1; transform: none; position: relative; padding-left: 2em; text-align: left; top: auto; left: auto; right: auto; margin: auto; pointer-events: auto; width: 100%; }
	.head-menu .submenu::before { display: none; }
	.head-menu .submenu > li + li { border: none; }
}

.fixed-navi { position: fixed; right: 20px; bottom: 20px; margin: auto; display: block; z-index: 98; }
.fixed-navi .button a { font-size: 0.875rem;}
.button a { display: inline-block; width: 100%; max-width: 420px; white-space: nowrap; padding: 1em 3em; border: 1px solid #B19F6F; border-radius: 7px; letter-spacing: .1em; background: url(../img/common/arrow.svg) right 20px center no-repeat, linear-gradient(0deg,rgba(248, 247, 244, 1) 1%, rgba(255, 255, 255, 1) 100%); font-size: clamp(1rem,1.125vw,1.125rem);}

.footer { background: #B19F6F; color: #FFF; padding: 100px 0; }
.footer .inner { width: 1100px; margin: 0 auto; max-width: 90%; }
.footer-cv { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 40px; }
.footer-cv a { display: flex; justify-content: center; align-items: center; text-align: center; gap: 10px; font-size: 1.2rem; padding: .7em; background: url(../img/common/arrow_w.svg) right 20px center no-repeat; border: 1px solid; border-radius: 10px; }
.footer-cv a::before { content: ''; display: block; width: 27px; height: 24px; background: url(../img/common/mail.svg) center no-repeat;}
.footer-cv a.tel::before { width: 18px; height: 24px; background: url(../img/common/tel.svg);}

.footer-sns { margin: 40px 0; display: flex; justify-content: center; }
.footer-sns > li + li { margin-left: 15px;}
.footer-sns svg { fill: #B19F6F;}

.footer-menu { display: flex; align-items: center; justify-content: center; font-size: .875rem; }
.footer-menu > li + li { margin-left: 2em; }

.footer-logo { width: 40%; max-width: 233px; margin: 50px auto 0; display: block; }

.copyright{ text-align: center; background: #9B8A5E; color: #FFF; font-size: .8rem; padding: .5em; display: block; }

@media screen and (max-width: 900px) {
	.footer { padding: 70px 0; }
	.footer-cv { grid-template-columns: 1fr; gap: 15px;  }
	.footer-menu { flex-direction: column; }
	.footer-menu > li + li { margin-left: 0; margin-top: 1em; }
	.footer-logo{ width: 200px; }
	.copyright{ font-size: .7rem; }
}
@media screen and (max-width: 768px) {
	.copyright { padding-bottom: 6rem; }
}