@charset "UTF-8";

:root {
	--main: #50b488;
	--wt: #fff;
	--bk: #333;
	--bg1: #fde9de;
	--pink: #f29772;
	--main2: #ed8f25;
	--yugo: "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
	--letter1: 1;
	--letter80: 1.92px;
	--letter20: 0.28px;
}

html {
	visibility: hidden;
}

html.wf-active,
html.loading-delay {
	visibility: visible;
}

body {
	-webkit-text-size-adjust: 100%;
	padding: 0;
	margin: 0;
	font-family: "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
	font-feature-settings: "palt" 1;
	-webkit-font-feature-settings: "palt" 1;
}

/* default */
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
textarea,
p,
blockquote,
th,
td {
	margin: 0;
	padding: 0;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	word-break: break-all;
	font-size: inherit;
	width: 100%;
}

fieldset,
img {
	border: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
	font-style: normal;
	font-weight: normal;
}

li {
	list-style: none;
}

caption,
th {
	text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: 100%;
	font-weight: normal;
}

q::before,
q::after {
	content: '';
}

abbr {
	border: 0;
	font-variant: normal;
}

sup {
	vertical-align: text-top;
}

sub {
	vertical-align: text-bottom;
}

input,
textarea,
select {
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
}

input,
textarea,
select {
	*font-size: 100%;
}

legend {
	color: #000;
}

select,
input,
button,
textarea {
	font: 99% arial, helvetica, clean, sans-serif;
}

pre,
code,
kbd,
samp {
	font-family: monospace;
	*font-size: 108%;
	line-height: 100%;
}

.aligncenter {
	text-align: center;
}

img {
	vertical-align: bottom;
	line-height: 1;
}

a img {
	transition: all .5s ease;
}

a img:hover {
	opacity: 0.7;
}

a:hover {
	text-underline-offset: 5px;
}

/* pagetop ----------------*/
.pagetop {
	display: none;
	position: fixed;
	bottom: 0;
	right: 0;
	z-index: 1;
}

.pagetop a::before {
	content: '';
	width: 20px;
	height: 20px;
	border: 0px;
	border-top: solid 1px #fff;
	border-right: solid 1px #fff;
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	transform: rotate(-45deg);
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	top: 11px;
	bottom: 0px;
	opacity: 1;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

.pagetop a {
	display: block;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	zoom: 1;
	width: 68px;
	height: 68px;
	text-align: center;
	/* font-size: 24px; */
	text-decoration: none;
	line-height: 50px;
	/* border: 1px solid #fbfbfb; */
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-ms-transition: all 0.2s;
	-o-transition: all 0.2s;
	transition: all 0.2s;
	opacity: 0.8;
	color: #1d1d1c;
	background: #524740;
}

.pagetop a span {
	top: 22px;
	position: relative;
	font-size: 0.1rem;
}

.pagetop a:hover {
	opacity: 0.6;
}

/* common item ---------------------------------------*/
.clearfix::after,
.inner::after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
	height: 0;
}

.sp {
	display: none;
}

.spbr {
	display: none;
}

@media all and (-ms-high-contrast:none) {

	*::-ms-backdrop,
	.foo {
		color: red
	}

	/* IE11 */
}

@media all and (-ms-high-contrast:none) {
	.foo {
		color: green
	}

	/* IE10〜Edge */
}

/* header ---------------------------------------*/
.sptel {
	display: none;
}

header {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 91px;
	background: #f0f0f0;
	z-index: 100;
}

.header-inner {
	margin: 0 auto;
	position: relative;
	display: flex;
	align-items: center;
}

.header-logo {
	display: block;
	background: url(../img/common/logo.png) #ed8f25 center center no-repeat;
	background-size: 200px;
	width: 287px;
	height: 91px;
	text-indent: -999em;
	overflow: hidden;
	/*	position: absolute;*/
	left: 0px;
	top: 0px;
}

.header-menu {
	width: calc(100% - 390px);
	/*	position: absolute;*/
	left: 327px;
	top: 0px;
}

.header-menu-list {
	font-size: 0px;
	width: fit-content;
	margin-right: calc(36vw - 280px);
	margin-left: auto;

}

.header-menu-list-item {
	font-size: 19px;
	display: inline-block;
	line-height: 1.0;
	vertical-align: top;
	letter-spacing: 1px;
	border-right: 1px solid rgb(82 71 65 / 33%);
}

.header-menu-list-item:first-child {
	border-left: 1px solid rgb(82 71 65 / 33%);
}

.header-menu-list-item a {
	display: block;
	padding: 15px clamp(15px, 2vw, 32px) 15px;
	text-decoration: none;
	text-align: center;
	max-height: 90px;
	font-family: fot-tsukuardgothic-std, sans-serif;
	transition: 0.4s cubic-bezier(0.55, 0.085, 0.68, 0.53);
	font-weight: bold;
	color: #231815;
}

.header-menu-list-item a small {
	display: block;
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
	font-size: 12px;
	color: #ec8e25;
	font-weight: normal;
	padding-top: 8px;
}

.header-menu-list-item a:hover {
	opacity: 0.7;
}

/* アコーディオンメニュー */
.header-menu-list-item.has-submenu {
	position: relative;
}

.header-menu-list-item.has-submenu .submenu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	background: #fff;
	min-width: 200px;
	z-index: 1000;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.header-menu-list-item.has-submenu:hover .submenu {
	display: block;
}

.header-menu-list-item.has-submenu .submenu li {
	display: block;
	border-bottom: 1px solid #f9f9f9;
}

.header-menu-list-item.has-submenu .submenu li:last-child {
	border-bottom: none;
}

.header-menu-list-item.has-submenu .submenu li a {
	padding: 12px 20px;
	font-size: 16px;
	text-align: left;
	border: none;
}

.header-menu-list-item.has-submenu .submenu li a:hover {
	background-color: #f5f5f5;
	opacity: 1;
}

/*add 20251114*/
.headinfo {
	width: clamp(180px, 50vw, 280px);
	position: absolute;
	right: 0;
	top: 33px;
}

.headinfo dl {}

.headinfo dl dt {
	background: var(--main);
	color: var(--wt);
	font-size: clamp(11px, 1.2vw, 15px);
	border-radius: 5px 0 0 0;
	padding: 8px 10px;
}

.headinfo dl dt p {
	width: fit-content;
	margin: auto;
	line-height: 1.4;
}

.headinfo dl dd {
	background: var(--main2);
	color: var(--wt);
	border-radius: 0 0 0 5px;
	text-align: center;
	padding: 15px 10px;
	font-size: clamp(15px, 2.6vw, 30px);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 400;
	line-height: 1;
	letter-spacing: 0.02em;
}

.headinfo dl dd i {
	line-height: 1;
	margin-right: 0.2em;
	position: relative;
	top: -1px;

}

.headinfo dl dd a:link,
.headinfo dl dd a:visited {
	color: var(--wt);
	text-decoration: none;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}

/* gnav ---------------------------------------*/
.gnav {
	position: fixed;
	right: 0;
	top: 0;
	width: 590px;
	height: 100vh;
	background: rgba(255, 255, 255, 0.9);
	z-index: 150;
	display: none;
	padding: 20px 0px 20px;
}

.gnav-list {
	position: absolute;
	left: 80px;
	top: 50%;
	transform: translate(0%, -50%);
}

.gnav-list-item {
	font-size: 21px;
	line-height: 1.0;
	vertical-align: top;
	letter-spacing: 1px;
}

.gnav-list-item>a {
	display: block;
}

.gnav-list-item>a {
	display: block;
	color: #000;
	text-decoration: none;
	font-family: fot-tsukuardgothic-std, sans-serif;
	transition: 0.4s cubic-bezier(0.55, 0.085, 0.68, 0.53);
	font-weight: bold;
	color: #231815;
	padding: 15px 0 10px 0;
}

.gnav-list-item>a small {
	display: block;
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
	font-size: 12px;
	color: #ec8e25;
	font-weight: normal;
	padding-top: 8px;
}

.gnav-list-item>a:hover {
	opacity: 0.7;
}

.gnav-sublist {
	padding-bottom: 20px;
}

.gnav-sublist-item {
	font-size: 16px;
	line-height: 1.0;
}

.gnav-sublist-item>a {
	display: block;
	color: #000;
	text-decoration: none;
	font-family: fot-tsukuardgothic-std, sans-serif;
	transition: 0.4s cubic-bezier(0.55, 0.085, 0.68, 0.53);
	font-weight: bold;
	color: #231815;
	padding: 8px 0;
	transition: 0.4s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

.gnav-sublist-item>a:hover {
	opacity: 0.7;
}

#openmenu {
	display: none;
}

#openmenu {
	/*	display: block;*/
	width: 90px;
	height: 91px;
	background: #524740;
	overflow: hidden;
	position: fixed;
	right: 0px;
	top: 0px;
	color: #fff;
	cursor: pointer;
	z-index: 200;
}

#openmenu span {
	content: '';
	display: block;
	width: 40px;
	height: 2px;
	background: #fff;
	position: absolute;
	left: 25px;
	transition: 0.4s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

#openmenu span:nth-child(1) {
	top: 23px;
}

#openmenu span:nth-child(2) {
	top: 34px;
}

#openmenu span:nth-child(3) {
	top: 46px;
}

#openmenu.open span:nth-child(1) {
	transform: rotate(45deg);
	width: 50px;
	top: 35px;
	left: 20px;
}

#openmenu.open span:nth-child(2) {
	opacity: 0;
	left: -55px;
}

#openmenu.open span:nth-child(3) {
	transform: rotate(-45deg);
	width: 50px;
	top: 35px;
	left: 20px;
}

#openmenu p {
	position: absolute;
	left: 0;
	top: 60px;
	line-height: 1.0;
	font-size: 13px;
	text-align: center;
	width: 100%;
	color: #fff;
}

.menuopen {
	position: fixed;
	width: 100%;
	height: 100%;
}

/* kv ---------------------------------------*/
.kv {
	text-align: center;
}

/* layout ---------------------------------------*/
.inner {
	max-width: 1000px;
	margin: 0 auto;
}

/* text ---------------------------------------*/
.font-tsukushi {
	font-family: fot-tsukuardgothic-std, sans-serif;
	font-style: normal;
}

.font-helveticaneue {
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
	font-style: normal;
}

.font-helvetica {
	font-family: Helvetica, Arial, sans-serif;
	font-style: normal;
}

/* footer ---------------------------------------*/
footer {
	background-color: #524741;
	padding: 20px 0;
}

.footer-inner {
	max-width: 800px;
	margin: 0 auto;
}

.footernav-list {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	margin-bottom: 60px;
}

.footernav-list li:first-child a {
	border-left: 1px solid #fff;
}

.footernav-list li:first-child ul>li>a {
	border: none;
}

.footernav-list li a {
	border-right: 1px solid #fff;
}

.footernav-list>li>ul>li a,
.footernav-list>li>ul>li:first-child a,
.footernav-list>li>ul>li {
	border: none;
}

.footernav-list-item>a {
	color: #fff;
	font-size: 18px;
	text-decoration: none;
	padding-bottom: 0;
	display: inline-block;
	width: 100%;
	margin-bottom: 5px;
	box-sizing: border-box;
	text-align: center;
}

.footernav-list-item>a:hover {
	text-decoration: underline;
}

.footernav-innerlist {
	padding: 0 0.5rem;
	margin: auto;
	width: 7.5em;
}

.footernav-innerlist-item {}

.footernav-innerlist-item a {
	color: #fff;
	text-decoration: none;
	line-height: 1.8;
	font-size: 13px;
}

.footernav-innerlist-item a:hover {
	text-decoration: underline;
}

.footer-logo {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1em;
}

.footer-logo a {
	text-underline-offset: 5px;
}

.footer-logo a:link,
.footer-logo a:visited {
	color: #fff;
}

.footer-logo a:hover {
	text-decoration: none;
}

.footer-logo img {
	width: 213px;
}

.copyright {
	color: #fff;
	font-size: 11px;
	line-height: 1;
}

.kijyun {
	font-size: 15px;
}

/* form area ---------------------------------------*/
.form-area .submit {
	text-align: center;
}

.form-select {
	width: 100%;
	padding: 8px 10px;
	font-size: 13px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 1px solid #999;
	background: url('../img/icon_select.png') 97% 50% no-repeat, -webkit-linear-gradient(top, #fff 0%, #fff 50%, #eee 100%);
	background: url('../img/icon_select.png') 97% 50% no-repeat, linear-gradient(to bottom, #fff 0%, #fff 50%, #eee 100%);
	background-size: 8px 36px;
	border-radius: 0;
	outline: none;
}

select::-ms-expand {
	display: none;
}

.form-text[type="text"] {
	padding: 13px 5px;
	border: 1px solid #999;
	width: 100%;
	box-sizing: border-box;
	-webkit-appearance: none;
	outline: none;
	border-radius: 0;
}

.form-radio {
	display: inline-block;
	line-height: 1;
	margin-right: 5px;
	font-size: 12px;
}

.form-radio label {
	background: url('../img/radio.png') left 1px no-repeat;
	box-sizing: border-box;
	cursor: pointer;
	display: inline-block;
	line-height: 1.4;
	min-height: 23px;
	margin: 0px 0;
	padding: 3px 0 0 28px;
	position: relative;
	vertical-align: top;
}

.form-radio input[type="radio"] {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
}

.form-radio input:checked+label {
	background-image: url('../img/radio_on.png');
}

.form-radio input:disabled+label {
	opacity: 0.7;
}

.form-checkbox {
	display: inline-block;
	line-height: 1;
	margin-right: 5px;
	font-size: 12px;
}

.form-checkbox label {
	background: url('../img/check.png') left 1px no-repeat;
	box-sizing: border-box;
	cursor: pointer;
	display: inline-block;
	line-height: 1.4;
	min-height: 23px;
	margin: 0px 0;
	padding: 3px 0 0 28px;
	position: relative;
	vertical-align: top;
}

.form-checkbox input[type="checkbox"] {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
}

.form-checkbox input:checked+label {
	background-image: url('../img/check_on.png');
}

.form-checkbox input:disabled+label {
	opacity: 0.7;
}

.form-textarea {
	padding: 13px 5px;
	border: 1px solid #999;
	width: 100%;
	box-sizing: border-box;
	height: 80px;
	-webkit-appearance: none;
	outline: none;
	border-radius: 0;
}

::placeholder {
	color: #eee;
}

/* error ---------------------------------------*/
select.error,
input.error {
	border: 1px solid #c80000;
}

p.error {
	color: #c80000;
	padding-top: 8px;
	line-height: 1.1;
}

/* animation ---------------------------------------*/
.animation {
	transition: all 1.2s ease;
	transform: translate(0, 80px);
	opacity: 0;
}

.animation.on {
	transform: translate(0, 0);
	opacity: 1;
}

.error404 .blog_wrapper.blog_wrapper {
	background: #fceedc;
	padding: 30px;
}

/*privacy*/
.privacy-policy .arhiciveblock h2 {
	font-size: 1.8rem;
	margin-bottom: 2rem;
}

.privacy-policy .arhiciveblock h3 {
	font-size: 1.4rem;
	margin-bottom: 1rem;
	margin-top: 2rem;
}

.privacy-policy .arhiciveblock ul {
	margin: 1rem auto 1rem 2rem;
}

.privacy-policy .arhiciveblock ul li {
	list-style: circle;
}

.privacy-policy .arhiciveblock ol li ol {
	margin: 1rem auto 1rem 2rem;
}

.privacy-policy .arhiciveblock ol li ol li {
	list-style: decimal;
}

.privacy-policy .arhiciveblock .content {
	padding: 30px;
}

/* pc */
@media screen and (min-width: 769px) {
	.sp {
		display: none !important;
	}

	.spbr {
		display: none;
	}
}

/* middle pc */
@media (1083px <=width <=1300px) {

	/*add 20251114*/
	.headinfo {
		width: clamp(100px, 50vw, 180px);
		position: absolute;
		right: 0;
		top: 52px;
	}

	.headinfo dl dt {
		background: var(--main);
		color: var(--wt);
		font-size: 10px;
		border-radius: 5px 0 0 0;
		padding: 5px;
	}

	.headinfo dl dd {
		background: var(--main2);
		color: var(--wt);
		border-radius: 0 0 0 5px;
		text-align: center;
		padding: 5px 10px;
		font-size: 20px;
	}

	.headinfo dl dd i img {
		width: 12px;
	}

	.header-menu-list {
		font-size: 0px;
		width: fit-content;
		margin-right: calc(25vw - 180px);
		margin-left: auto;
	}
}

@media(max-width:1083px) {
	.headinfo {
		display: none;
	}

	.header-menu-list {
		margin: auto;
	}

}

@media screen and (min-width: 1083px) and (max-width: 1250px) {
	.header-menu-list-item a {
		padding: 15px clamp(10px, 1.7vw, 30px);
	}

	.header-menu-list {
		margin: auto;
	}

	.header-menu-list {
		margin: auto calc(10% - 30px);
	}

	.header-menu-list-item {
		letter-spacing: 0px;
	}

}

@media screen and (min-width: 769px) and (max-width: 1250px) {
	.header-menu {
		left: 300px;
		width: 100%;
	}

}

/* small pc */
@media screen and (min-width: 769px) and (max-width: 1030px) {
	.header-menu {
		display: none;
	}

	#openmenu {
		display: block;
	}
}

@media screen and (max-width: 768px) {
	.error404 .kasou-title {
		top: 75px !important;
	}

	/* default */
	img {
		max-width: 100%;
		height: auto;
	}

	a img {
		opacity: 1;
	}

	* {
		box-sizing: border-box;
	}

	/* common item */
	.pc {
		display: none !important;
	}

	.pcbr {
		display: none;
	}

	.sp {
		display: block;
	}

	.headerInner,
	.footerInner,
	.inner {
		min-width: 0;
		width: 100%;
	}

	/* header ---------------------------------------*/
	.sptel {
		display: block;
		position: absolute;
		left: 135px;
		bottom: 13px;
	}

	header {
		height: 66px;
		background: #ed8f25;
	}

	.header-logo {
		display: block;
		background: url(../img/common/logo_sp.png) #ed8f25 center center no-repeat;
		background-size: 180px;
		width: 180px;
		height: 66px;
		left: 25px;
		top: 0px;
		margin-left: 10px;
	}

	.header-menu {
		display: none
	}

	/* gnav ---------------------------------------*/
	.gnav {
		width: 100%;
		height: 100%;
		background: rgba(255, 255, 255, 1);
		padding: 0px 0px 0px;
		overflow: auto;
	}

	.gnav-list {
		position: static;
		left: 0px;
		top: 0%;
		transform: translate(0%, 0%);
		text-align: center;
		padding: 40px 0;
	}

	.gnav-list-item {
		font-size: 20px;
	}

	.gnav-list-item>a {
		padding: 30px 0 10px 0;
	}

	.gnav-list-item>a::before {
		display: none
	}

	.gnav-list-item>a small {
		font-size: 11px;
		padding-top: 8px;
	}

	.gnav-list-item>a:hover {
		opacity: 1;
	}

	.gnav-sublist {
		padding-bottom: 15px;
	}

	.gnav-sublist-item {
		font-size: 15px;
	}

	.gnav-sublist-item>a {
		padding: 10px 0;
		font-weight: normal;
	}

	.gnav-sublist-item>a:hover {
		opacity: 1;
	}

	.gnav-contact {
		text-align: center;
		padding: 10px 0 100px;
	}

	.gnav-contact-address {
		line-height: 1.5;
		font-size: 14px;
		margin-bottom: 7px;
	}

	.gnav-contact-tel {
		display: inline-block;
		color: #ec8e25;
		font-size: 26px;
		padding-left: 25px;
		background: url(../img/common/icon_tel.png) no-repeat left center;
		background-size: 17px 25px;
		font-weight: bold;
		letter-spacing: 0.04em;
		line-height: 1.5;
		margin-bottom: 2px;
		text-decoration: none;
	}

	#openmenu {
		display: block;
		width: 65px;
		height: 66px;
	}

	#openmenu.open {
		background: #E2E3E3;
	}

	#openmenu span {
		width: 30px;
		height: 1px;
		left: 18px;
	}

	#openmenu span:nth-child(1) {
		top: 19px;
	}

	#openmenu span:nth-child(2) {
		top: 27px;
	}

	#openmenu span:nth-child(3) {
		top: 35px;
	}

	#openmenu.open span {
		background: #524740
	}

	#openmenu.open span:nth-child(1) {
		transform: rotate(45deg);
		width: 30px;
		top: 27px;
		left: 19px;
	}

	#openmenu.open span:nth-child(2) {
		opacity: 0;
		left: -25px;
	}

	#openmenu.open span:nth-child(3) {
		transform: rotate(-45deg);
		width: 30px;
		top: 27px;
		left: 19px;
	}

	#openmenu p {
		top: 42px;
		font-size: 10px;
	}

	#openmenu.open p {
		color: #524740;
	}

	.menuopen {
		position: fixed;
		width: 100%;
		height: 100%;
	}

	/* footer ---------------------------------------*/
	footer {
		padding-bottom: 12px;
		padding-top: 0;
	}

	.footer-logo {
		text-align: center;
		padding: 15px 0 2px;
		flex-direction: column;
		gap: 7px;
	}

	.footer-logo img {
		width: 180px;
	}

	.copyright {
		font-size: 8px;
		text-align: center;
		letter-spacing: 0.01em;
	}

	.kijyun {
		font-size: 11px;
	}
}