@charset "utf-8";
@import url("reset.css");

:root {
	--BaseColor:#595757;
	--DarkGray:#898989;
	--LightGray:#AAA;
}

.sp {
	display: block;
}

.pc {
	display: none;
}

p.no_data {
	text-align: center;
	color:#888;
}

#wrapper {
	width:100vw;
	overflow: hidden;
	opacity: 1;
}

.container {
	width:90%;
	margin:0 auto;
}

.container > p.no_data {
	padding:5em 0;
}

.overlay {
	display: none;
	width:100vw;
	height:100vh;
	position: fixed;
	top:0;
	left:0;
	z-index: 98;
	background: rgba(0,0,0,0.7);
}

header img {
	width:100%;
	height:auto;
}

header .logo_area_sp {
	width:100%;
}

header .logo_area_sp a {
	display: block;
	width:180px;
	padding:8px;
}

header .logo_area_sp > p {
	background:#F5F5F5;
	color:var(--BaseColor);
	font-size:2.9vw;
	font-weight: 300;
	line-height:1.0;
	padding:0.3em 0.3em;
	text-align: center;
	display: block;
}

header #nav_trigger {
	width:57px;
	height:52px;
	position: absolute;
	top:20px;
	right:0;
	z-index: 9;
}

header #nav_trigger.fixed {
	position: fixed;
	top:0;
}

header #nav_trigger span {
	width:30px;
	height:0;
	border-top:solid 1px var(--BaseColor);
	position: absolute;
	right:13px;
}

header #nav_trigger span:nth-of-type(1) {
	top:16px;
}

header #nav_trigger span:nth-of-type(2) {
	top:26px;
}

header #nav_trigger span:nth-of-type(3) {
	top:36px;
}

header #nav_contents {
	background:#FFF;
	position: fixed;
	width:340px;
	top:0;
	right:-350px;
	box-sizing: border-box;
	transition-duration: .3s;
	z-index: 99;
}

header #nav_trigger.active + #nav_contents {
	top:0;
	right:0;
}

header #nav_contents nav {
	height:calc(100vh - 120px);
	overflow-y: scroll;
	padding:0;
	padding:60px 40px;
	position: relative;
}

header #nav_contents nav .menu_close {
	position: absolute;
	top:0;
	right:0;
	width:57px;
	height:52px;
}

header #nav_contents nav .menu_close span {
	width:0;
	height:36px;
	border-left:solid 1px var(--BaseColor);
	position: absolute;
	top:12px;
	right:28px;
}

header #nav_contents nav .menu_close span:nth-of-type(1){
	transform:rotate(45deg);
} 

header #nav_contents nav .menu_close span:nth-of-type(2){
	transform:rotate(-45deg);
}

header #nav_contents nav ul {
	width:100%;
	padding-bottom:60px;
}

header #nav_contents nav ul li a {
	font-family: "Noto Sans", sans-serif;
	font-weight:600;
	font-size:1.2em;
	letter-spacing: 0.1em;
	text-decoration: none;
	display: block;
	padding:0.7em 0;
	color:var(--DarkGray);
	transition-duration: .3s;
}

header #nav_contents nav ul li a span {
	display: block;
	font-family: "Noto Sans JP", sans-serif;
	font-size:0.7em;
	font-weight:400;
	letter-spacing:0.08em;
	color:var(--BaseColor);
}

header #nav_contents nav ul li.nav_contact {
	margin-top:40px;
}

header #nav_contents nav ul li.nav_contact a {
	border-top:solid 1px var(--BaseColor);
}
/*
header #nav_contents nav ul li.nav_contact p {
	font-size:0.9em;
	padding-top:0.7em;
}
*/
main img {
	max-width: 100%;
}

.breadcrumb {
	padding:11px 13px;
	font-size:11px;
	line-height: 1.8;
	background: #F5F5F5;
}

.breadcrumb li {
	display: inline;
	vertical-align: top;
	color:var(--DarkGray);
}

.breadcrumb li a {
	color:var(--DarkGray);
}

.breadcrumb li + li {
	margin-left:0.5em;
	padding-left:1.3em;
	position: relative;
}

.breadcrumb li + li:before {
	content:"";
	position: absolute;
	top:0.7em;
	left:0;
	width:5px;
	height:5px;
	border-right:solid 1px var(--DarkGray);
	border-top:solid 1px var(--DarkGray);
	transform: rotate(45deg);
	margin-top:-2px;
}


footer {
	text-align:center;
}

footer nav ul {
	border-top:solid 1px #DDD;
	margin:0 0 1.5em;
}

footer nav ul li {
	text-align: left;
}

footer nav ul li a {
	display: block;
	padding:1em 1.6em;
	font-family: "Noto Sans", sans-serif;
	font-size:0.9em;
	letter-spacing: 0.08em;
	text-decoration: none;
	color:#000;
	background: #F5F5F5;
	border-bottom:solid 1px #DDD;
	position: relative;
}

footer nav ul li a span {
	display: inline-block;
	margin-right:1.5em;
	font-weight:300;
	font-size: 1.3em;
	letter-spacing: 0.2em;
	color:var(--DarkGray);
	width: 8.5em;
}

footer nav ul li a:after {
	content:"";
	position: absolute;
	top:50%;
	right:1.5em;
	width:8px;
	height:8px;
	margin-top:-5px;
	border-right:solid 1px var(--LightGray);
	border-top:solid 1px var(--LightGray);
	transform: rotate(45deg);
}

footer ul.footer_subnavi {
	display: inline-flex;
	gap:2em;
}

footer ul.footer_subnavi li {
	font-size:0.9em;
}

footer ul.footer_subnavi li a {
	color:var(--DarkGray);
	text-decoration: underline;
}

footer p.copyright {
	text-align: center;
	font-family: "Noto Sans", sans-serif;
	color: var(--LightGray);
	font-size:0.8em;
	letter-spacing: 0.1em;
	padding:4em 0 10em;
}

.cta_fixed {
	position: fixed;
	bottom:0;
	left:0;
	width:100%;
	z-index: 97;
	box-shadow: 0 -5px 5px -5px rgba(0,0,0,0.2);
	background: #FFF;
	padding:0.6em;
	box-sizing: border-box;
	text-align: center;
}

.cta_fixed p {
	font-size:0.85em;
	color:var(--DarkGray);
	letter-spacing: 0.1em;
}

.cta_fixed a {
	display: flex;
	background: #FFF;
	color:var(--BaseColor);
	border:solid 1px var(--BaseColor);
	margin:0.3em auto 0;
	padding:0.7em 1em;
	box-sizing: border-box;
	width:90%;
	max-width: 400px;
	text-decoration: none;
	align-items: center;
	justify-content: center;
	gap:10px;
}

.cta_fixed a i {
	width: 24px;
}

.cta_fixed a i img {
	width: 100%;
	height:auto;
}


@media print, screen and (min-width: 440px) {

header .logo_area_sp > p {
	font-size:12px;
	line-height: 12px;
	padding:4px 11px 5px;
}

header #nav_trigger {
	top:21px;
}



}

@media print, screen and (min-width: 640px) {


}

@media print, screen and (min-width: 768px) {
/*
header #nav_contents nav ul li.nav_contact a {
	color:var(--BaseColor);
}

header #nav_contents nav ul li.nav_contact p {
	font-size:11px;
	color: var(--DarkGray);
	letter-spacing: 0.08em;
}
*/
footer nav ul {
	display: flex;
	flex-wrap: wrap;
}

footer nav ul li {
	width:50%;
}

footer nav ul li:nth-of-type(odd) a {
	border-right: solid 1px #DDD;
}

}


@media print, screen and (min-width: 960px) {

}


@media print, screen and (min-width: 1200px) {

.sp {
	display: none;
}

.pc {
	display: block;
}

header .logo_area_pc {
	width:100%;
	padding:40px 20px 20px;
	box-sizing: border-box;
	text-align: center;
	transition-duration: .3s;
}

header .logo_area_pc a {
	width:200px;
	padding:0;
	margin-bottom:30px;
	display: inline-block;
}

header .logo_area_pc > p {
	font-size:12px;
	box-sizing: border-box;
	text-align: center;
	background: none;
	color:var(--BaseColor);
	line-height:1.7;
	letter-spacing: 0.1em;
	transition-duration: .3s;
}

header .logo_area_pc > p span {
	display:inline-block;
	font-weight:600;
}

header .logo_area_pc > img {
	display: none;
	width:230px;
	margin:10px auto 0;
}

header #nav_trigger {
	display: none;
}

header #nav_contents {
	right:auto;
	left:0;
	width:300px;
}

header #nav_contents nav {
	height:100vh;
	padding:0 0 30px;
}

header #nav_contents nav .menu_close {
	display: none;
}

header #nav_contents nav ul {
	padding-bottom:0;
}

header #nav_contents nav ul li a {
	font-size:14px;
	padding:0.6em 0;
	margin:0 48px 0 32px;
}

header #nav_contents nav ul li a:hover {
	opacity: 0.5;
}

header #nav_contents nav ul li a span {
	display: none;
}

header #nav_contents nav ul li.nav_contact {
	margin-top:20px;
}

header #nav_contents nav ul li.nav_contact a {
	margin:0 48px 0 30px;
	padding:1.5em 0;
}

.breadcrumb {
	padding:24px 0 12px;
	font-size: 12px;
	background: none;
}

main {
	min-height: 800px;
}

main,
footer {
	margin-left:300px;
}

footer {
	padding-top:2em;
}

footer nav {
	display: none;
}

footer p.copyright {
	padding:2em 0;
	font-weight:300;
}

.cta_fixed {
	display: none;
}

main .container {
	width:calc((100vw - 300px) * 21 / 23);
}


}


@media print, screen and (min-width: 1400px) {

header #nav_contents {
	transition-duration: .3s;
}

}


@media print, screen and (min-width: 1200px) and (min-height: 900px) {

header .logo_area_pc a {
	width:200px;
	margin-bottom:50px;
}

header .logo_area_pc {
	padding:40px 20px 40px;
}

header #nav_contents nav ul li a {
	font-size:1em;
}

header #nav_contents nav ul li a span {
	display: block;
	font-size:11px;
}

header #nav_contents nav ul li.nav_contact {
	margin-top:30px;
}

}

@media print, screen and (min-width: 1200px) and (min-height: 960px) {

header .logo_area_pc > p {
	line-height:1.9;
}

header .logo_area_pc > img {
	display: block;
}



}