@charset "UTF-8";


/*========================================

  Elements

========================================*/


body {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	position: relative;
	min-width: 1200px;
	margin: 0;
	padding: 0;
	color: #333;
	background: #ece9e2;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
}


html,
body {
	height: 100%;
}

body.overflowhidden {
	overflow: hidden;
	height: 100%;
}

@media screen and (max-width: 767px) {
	body {
		width: 100vw;
		min-width: auto;
	}
}

p,
h1,
h2,
h3,
h4,
h5,
dt,
dd,
th,
td,
ul,
li,
strong {
	margin: 0;
	padding: 0;
	font-weight: 400;
}

p {
	line-height: 1.7em;
}

/* Link ---------------*/
a {
	overflow: hidden;
	text-decoration: none;
	color: #222;
}

a:visited {
	text-decoration: none;
	color: #222;
}

a:hover {
	text-decoration: none;
	color: #808080;
}

a:focus,
textarea:focus,
input:focus {
	border: none;
	outline: none;
}

a:active {
	border: none;
	outline: none;
}

/*========================================

  main

========================================*/

main {
	text-align: center;
	padding-top: 0 !important;
}

main .innr {
	padding: 500px 0;
}

.ancher {
	display: block;
}

@media screen and (max-width: 767px) {
	.main_innr {
		width: 90%;
	}

	.ancher {
		display: inline;
	}
}


.anckerlink {
	position: relative;
	z-index: -1;
	display: block;
	margin-top: -70px;
	padding-top: 70px;
}

@media screen and (max-width: 767px) {
	.anckerlink {
		display: block;
		margin-top: -14vw;
		padding-top: 14vw;
	}
}

img {
	max-width: 100%;
	height: auto;
	transition: .3s;
	vertical-align: bottom;
}

a:hover img {
	opacity: .7;
	filter: alpha(opacity=70);
	-moz-opacity: .7;
}

.spblock {
	display: none;
}

.spinline {
	display: none;
}

.pcinline {
	display: inline;
}

@media screen and (max-width: 767px) {
	.spblock {
		display: block;
	}

	.spinline {
		display: inline;
	}

	.pcinline {
		display: none;
	}
}



.blocklink {
	cursor: pointer;
	transition: .3s;
}

.blocklink:hover {
	opacity: .7;
	filter: alpha(opacity=70);
	-moz-opacity: .7;
}

.nolink,
.nolinkpc {
	cursor: default;
}

.nolink:hover,
.nolinkpc:hover {
	opacity: 1;
	filter: alpha(opacity=100);
	-moz-opacity: 1;
}

.nolink:hover img,
.nolinkpc:hover img {
	opacity: 1;
	filter: alpha(opacity=100);
	-moz-opacity: 1;
}



/*========================================

  header

========================================*/
header {
	margin-top: 20px;
	padding: 0 50px;
	width: 100%;
	box-sizing: border-box;
}

header .innr {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

header .innr .sp_btn {
	display: none;
}

header .innr .links nav {
	display: flex;
	align-items: center;
}

header .innr .links nav .page {
	display: flex;

}

header .innr .links nav .page li {
	list-style: none;
	font-family: 'Lato', sans-serif;
	font-weight: 700;
	font-style: italic;
	font-size: 24px;
	letter-spacing: 2px;
	margin: 0 12px;
}

header .innr .links nav .sns {
	display: flex;
	margin-left: 10px;
}

header .innr .links nav .sns li {
	list-style: none;
	font-size: 24px;
	letter-spacing: 2px;
	margin: 0 8px;
}



@media screen and (max-width: 767px) {
	header {
		position: fixed;
		z-index: 99999;
		top: 0;
		margin: 0;
		padding: 0;
		text-align: center;
	}

	header .innr {
		width: 100%;
		height: 14vw;
		background-color: #ece9e2;
	}

	header .innr .logo {
		width: 56vw;
		height: 14vw;
		border-bottom: solid 2px #d3d3c9;
		box-sizing: border-box;
		text-align: left;
	}

	header .innr .logo img {
		width: 40vw;
		margin-top: 3vw;
		margin-left: 3vw;
	}

	header .innr .sp_btn {
		display: inline;
		border-left: solid 1px #3b520c;
		border-bottom: solid 2px #d3d3c9;
		width: 15vw;
		height: 14vw;
		box-sizing: border-box;
		position: relative;
	}

	header .innr .sp_btn a {
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		font-size: 6vw;
		color: #3a510b;
		line-height: 0.3em;
		padding-top: 2vw;
		box-sizing: border-box;
	}

	header .innr .sp_btn a span {
		font-size: 2.5vw;
	}

	header nav {
		position: fixed;
		z-index: 10;
		top: 0;
		right: -101vw;
		bottom: 0;
		overflow-y: auto;
		width: 56vw;
		height: 100vw;
		margin-top: 14vw;
		padding-top: 0;
		padding-bottom: 0;
		transition: .5s;
		border: none;
		opacity: 0;
		background: #fff;
	}

	header nav.active {
		right: 0;
		opacity: 1;
	}

	header .innr .links nav {
		display: block;
		text-align: left;
	}

	header .innr .links nav .page {
		display: block;
		margin: 0 6vw;
	}

	header .innr .links nav .page li {
		font-size: 5vw;
		letter-spacing: 2px;
		margin: 0;
		height: 13vw;
		border-bottom: solid 1px #d0cdc6;
		position: relative;
	}

	header .innr .links nav .page li a {
		position: absolute;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		display: block;
		padding: 4vw 0 4vw 2vw;
		box-sizing: border-box;
	}

	header .innr .links nav .sns {
		display: block;
		margin-left: 8vw;
		margin-top: 4vw;
	}

	header .innr .links nav .sns p {
		font-family: 'Lato', sans-serif;
		font-weight: 700;
		font-style: italic;
		font-size: 3.5vw;
		letter-spacing: 2px;
	}

	header .innr .links nav .sns li {
		font-size: 3.5vw;
		font-weight: bold;
		letter-spacing: 2px;
		margin: 2vw 0 0;
	}
}



/* ハンバーガーメニュー ボタン */
.panel-wrap {
	display: none;
}

@media screen and (max-width: 767px) {
	.panel-wrap {
		display: block;
		cursor: pointer;
		width: 14vw;
		height: 14vw;
		color: #fff;
		transition: .5s;
		padding: 0;
		background-color: #3b520c;
	}

	#panel-btn {
		position: relative;
		width: 8vw;
		height: 8vw;
		margin: 0;
		padding: 0;
		list-style: none;
		cursor: pointer;
	}

	#panel-btn li {
		margin: 0;
		padding: 0;
	}

	#panel-btn-icon {
		display: block;
		position: absolute;
		top: 6.5vw;
		left: 3vw;
		width: 8vw;
		height: 0.5vw;
		margin: 0;
		background: #fff;
		transition: .4s;
	}

	#panel-btn-icon:before,
	#panel-btn-icon:after {
		display: block;
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		width: 8vw;
		height: 0.5vw;
		background: #fff;
		transition: .3s;
	}

	#panel-btn-icon:before {
		margin-top: -2.5vw;
	}

	#panel-btn-icon:after {
		margin-top: 2vw;
	}

	#panel-btn.closepanel #panel-btn-icon {
		background: transparent;
	}

	#panel-btn.closepanel #panel-btn-icon:before,
	#panel-btn.closepanel #panel-btn-icon:after {
		margin-top: 0;
	}

	#panel-btn.closepanel #panel-btn-icon:before {
		transform: rotate(-45deg);
		-webkit-transform: rotate(-45deg);
		background: #fff;
	}

	#panel-btn.closepanel #panel-btn-icon:after {
		transform: rotate(-135deg);
		-webkit-transform: rotate(-135deg);
		background: #fff;
	}
}




/*========================================

  footer

========================================*/

footer .box {
	width: 1000px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	row-gap: 60px;
	margin: 0 auto;
	padding-bottom: 50px;
}

footer .box .tel {
	text-align: center;
	width: 475px;
	background-color: #fff;
	border-radius: 10px;
	padding: 10px;
	box-sizing: border-box;
}

footer .box .tel .innr {
	border: 2px dotted #9ca58a;
	border-radius: 8px;
	min-height: 140px;
	box-sizing: border-box;
}


footer .box .tel p {
	margin-top: 30px;
	font-size: 28px;
	font-weight: bold;
	letter-spacing: 4px;
}

footer .box .tel small {
	font-size: 14px;
}

footer .box .logo {
	padding: 10px;
}

footer .box .address {
	width: 240px;
}

footer .box .address h3 {
	font-size: 22px;
	font-weight: bold;
	margin-bottom: 12px;
}

footer .box .address p {
	font-size: 16px;
	margin-top: 5px;
	letter-spacing: 1px;
}

footer .box .links {
	width: 440px;
	display: flex;
	justify-content: space-between;
	margin-top: 40px;
}

footer .box .links ul {
	margin-left: 20px;
}

footer .box .links ul li {
	list-style: none;
	font-size: 16px;
	font-weight: bold;
	margin: 6px 0;
	position: relative;
}

footer .box .links ul li::before {
	position: absolute;
	content: "";
	width: 0.3em;
	height: 0.3em;
	border-top: solid #333 2px;
	border-right: solid #333 2px;
	transform: rotate(45deg);
	top: 0.6em;
	left: -1em;
}

footer .box .links div {
	margin-top: 10px;
}

footer .box .links div p {
	font-family: 'Lato', sans-serif;
	font-weight: 700;
	font-style: italic;
	font-size: 14px;
	letter-spacing: 2px;
}

footer .box .links div a {
	display: block;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 2px;
	margin-top: 5px;
}

footer .box .txt {
	font-size: 14px;
}

footer .copyright {
	background-color: #3a510b;
	text-align: center;
	font-size: 14px;
	color: #fff;
	letter-spacing: 1px;
	padding: 30px;
}



@media screen and (max-width: 767px) {
	footer .box {
		width: 88vw;
		display: block;
		text-align: center;
		padding-bottom: 5vw;
	}

	footer .box .tel {
		width: 86vw;
		margin: 3vw auto;
		border-radius: 2vw;
		padding: 1vw;
	}

	footer .box .tel .innr {
		border: 2px dotted #9ca58a;
		border-radius: 1.5vw;
		min-height: 25vw;
		box-sizing: border-box;
	}

	footer .box .tel p {
		margin-top: 5vw;
		font-size: 6vw;
		line-height: 1.3em;
	}

	footer .box .tel small {
		font-size: 3vw;
	}

	footer .box .logo {
		padding: 0;
		width: 38vw;
		margin-top: 7vw;
	}

	footer .box .address {
		width: auto;
	}

	footer .box .address h3 {
		font-size: 5vw;
		margin-top: 5vw;
		margin-bottom: 3vw;
	}

	footer .box .address p {
		font-size: 4vw;
		margin-top: 1vw;
		letter-spacing: 1px;
	}

	footer .box .links {
		width: 88vw;
		text-align: left;
		margin-top: 7vw;
		border-top: solid 1px #363531;
		border-bottom: solid 1px #363531;
		padding-top: 3vw;
		padding-bottom: 3vw;
		box-sizing: border-box;
	}

	footer .box .links ul {
		margin-left: 6vw;
	}

	footer .box .links ul li {
		font-size: 3.4vw;
		margin: 1.5vw 0;
	}

	footer .box .links div {
		margin-top: 2vw;
		margin-right: 10vw;
	}

	footer .box .links div p {
		font-size: 3.4vw;
	}

	footer .box .links div a {
		font-size: 3.4vw;
		margin-top: 1vw;
	}

	footer .box .txt {
		text-align: left;
		font-size: 3vw;
		margin-top: 3vw;
	}

	footer .copyright {
		font-size: 2.5vw;
		padding: 4vw;
	}
}