@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Noto+Serif+JP:wght@400;700&display=swap');

@font-face {
	font-family: number;
	src: local('Helvetica');
	unicode-range: U+0021-003F;
}

:root {
	--key-font-color:#333;
	--key-font-link-color:#666;
	--key-font-hover-color:#CAA846;
	--key-font-reverse-color:#fff;
	--form-common-fontsize:1.0rem;
	--small-spacing:10px;
	--line-spacing:20px;
	--common-margin:50px;
	--common-marginX2:100px;
	--font-sanz:'Helvetica Neue','Noto Sans JP', "游ゴシック", YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN", sans-serif;
	--font-serif:'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}


/*
var(--key-******)
calc(var(--common-******) * 1.5)
*/

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 100; }
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 200; }
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 300; }
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 400; }
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Bold"); font-weight: bold; }
@font-face { font-family: "Helvetica Neue"; src: local("Helvetica Neue Regular"); font-weight: 100; }
@font-face { font-family: "Helvetica Neue"; src: local("Helvetica Neue Regular"); font-weight: 200; }

*{
	margin:0;
	padding:0;
	border:0;
}
*, *:after, *:before {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}
html,body { height: 100%; }
html { font-size: 62.5%; }
body{ width:100%; font-family:-apple-system, BlinkMacSystemFont,'Helvetica Neue','Noto Sans JP', "游ゴシック", YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN", sans-serif; font-size:16px; line-height:1.8; color: var(--key-font-color); background-color:#FAF7F0; position: relative; left: 0; overflow-x: hidden; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-feature-settings: "palt" 1, "trad" 0; }

.font-serif{ font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }

a{
	outline:none;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
}
a:link{ color: var(--key-font-link-color); }
a:visited{ color: var(--key-font-link-color); }
a:hover{ color: var(--key-font-hover-color); }
a:active{ color: var(--key-font-hover-color); }

::selection { background:var(--key-font-color); color:var(--key-font-reverse-color); text-shadow: none; }
::-moz-selection { background:var(--key-font-color); color:var(--key-font-reverse-color); text-shadow: none; }

a:link,a:visited,a:active{text-decoration:none;}
a:hover, a:active { outline: 0; text-decoration: none; cursor: pointer;}
a:focus { outline:none; }
a img{border:none;text-decoration:none;}

a.fit { display: block; width: 100%; height: 100%; }

/* */

picture source,
picture img,
.img-responsive { width: 100%; max-width: 100%; height: auto; }
.img-responsive-overwrite { margin: 0 auto; }

figure {
	-webkit-margin-before: 0 !important; 
	-webkit-margin-after: 0 !important; 
	-webkit-margin-start: 0 !important; 
	-webkit-margin-end: 0 !important;
}

/*  */

header{
	
}

main{}
aside{
	background-color: #F1EEE7;
	padding: var(--common-margin) 0;
}
article{
	position: relative;
}
section{
	width: 90%;
	max-width: 630px;
	margin: 0 auto;
}
footer{
	color:var(--key-font-reverse-color);
	background-color: #444444;
	padding: var(--line-spacing) var(--line-spacing) 150px;
	text-align: center;
}
#archive footer{
	padding: var(--line-spacing) var(--line-spacing);
}
@media screen and (min-width: 900px){
	footer{
		padding: var(--line-spacing);
	}
}

h1{ font-size:3.6rem; }
h2{ font-size:2.4rem; }
h3{ font-size:1.8rem; }
h4{ font-size:1.6rem; }
h5{ font-size:1.6rem; }
h6{ font-size:1.6rem; }

h1,h2,h3,h4,h5,h6{
	color:#000;
	font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	margin: 0;
	padding: 0;
}

p{
	margin-bottom: var(--line-spacing);
}
q{
	padding: var(--small-spacing);
}
q:before,
q:after{
	content:"";
}
span{}
blockquote{}

strong{
	font-size: 12px;
}
ul,
ol{
}
ul{ font-weight: 700; }
ol{	font-size: 12px; }
ul li,
ol li{
	list-style-position: inside;
}
ol li{
	line-height: 12px;
	margin-bottom: var(--small-spacing);
}
ol li:last-child{
	margin-bottom: 0;
}

table{
	width: 100%;
	border-collapse: collapse;
}
table tr{}
table th{}
table td{}

/*  */

#home{}
#archive{}

#home header{
	width: 100%;
	height: 100vh;
	display: flex;
	justify-content: center;
	align-items: center;
	background: no-repeat center url(../img/main-sp.jpg);
	background-size: cover;
	position: relative;
}
@media screen and (min-width: 900px){
	#home header{
		background: no-repeat center url(../img/main.jpg);
		background-size: cover;
	}
}
#home header::after{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background-color: rgba(255,255,255,0.7);
}


#archive header{
	text-align: center;
}

#wrap{}

header div{
	z-index: 2;
	text-align: center;
	background:rbga(255,255,255,0.5);
}
header div h1{
	margin-bottom: var(--common-margin);
}
header div h2{
	text-align: center;
	font-size:2.4rem;
}
@media screen and (min-width: 900px){
	header div h2{
		font-size:3.6rem;
	}
}
#archive header h1{
	width: 80px;
	margin: var(--common-margin) auto 0;
}
#archive header h1 img{
	width: 100%;
}
@media screen and (min-width: 900px){
	#archive header h1{
		width: 124px;
		position: absolute;
		top:var(--common-margin);
		left:var(--common-margin);
	}
}


#reedtext{
	padding: var(--common-margin) 0;
}
#archive #reedtext{
	padding: var(--common-margin) 0;
}
#archive #reedtext p span{
	color: #990000;
	font-weight: 700;
}
@media screen and (min-width: 900px){
	#archive #reedtext{
		padding: var(--common-marginX2) 0;
	}
}
#reedtext section{
}
#reedtext h1{
	font-size: 2.0rem;
	text-align: center;
	margin-bottom: var(--line-spacing);
}
#archive #reedtext h1{
	margin-bottom: var(--common-margin);
}
#reedtext p{}
@media screen and (min-width: 900px){
	#reedtext h1{
		font-size: 2.4rem;
	}
}

#menu{
	width: 90%;
	max-width: 980px;
	margin: 0 auto;
	padding: var(--common-margin) 0;
}
.category{
	text-orientation: upright;
	font-family: var(--font-serif);
	font-weight: 700;
	color: #000;
	text-align: center;
	font-size: 36px;
	line-height: 36px;
	margin-bottom: var(--common-margin);
}
@media screen and (min-width: 900px){
	.category{
		margin-bottom:0;
		text-align: left;
		writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
		position: absolute;
		font-size: 36px;
		line-height: 36px;
		left: 0;
		margin-left: -56px;
	}
	#menu .category{
		left: 0;
		margin-left: -56px;
	}
}

#menu-box{
	display: flex;
	flex-direction:column;
	flex-wrap:wrap;
	justify-content:flex-start;
	align-items:flex-start;
}
#menu section{
	width: auto;
	max-width: auto;
	margin-bottom:var(--line-spacing);
	flex: 0 1 100%;
	background-color: #FFF;
}
@media screen and (min-width: 900px){
	#menu-box{
		display: flex;
		flex-direction:row;
		flex-wrap:wrap;
		justify-content:space-between;
		align-items:stretch;
		gap:var(--line-spacing);
	}
	#menu section{
		margin:0;
		flex: 0 1 47.5%;
	}
}
#menu section div{
	padding: var(--small-spacing);
}
#menu section div h1{
	font-family:var(--font-sanz);
	font-size: 2.2rem;
	line-height: 3.2rem;
	margin-bottom: var(--small-spacing);
}
#menu section div span{
	font-size: 18px;
	display: block;
	font-weight: 700;
	margin-bottom: var(--small-spacing);
}
#menu section div q{
	display: block;
	background-color: #F1EEE7;
}
#menu section div q h2{
	font-size:1.4rem;
	text-align: center;
	font-family:var(--font-sanz);
}
#menu section div q p{
	font-size: 12px;
	margin-bottom: 0;
}
#menu section div strong{
	display: inline-block;
	background-color: #583822;
	color: #FFF;
	padding: 0 5px;
	margin-bottom: var(--small-spacing);
}
#menu section div ol{
	margin-bottom: var(--small-spacing);
}
#menu section div ol + strong + ol{
	margin-bottom: var(--line-spacing);
}
#menu section div ol li{}

#supplement{
	width: 90%;
	max-width: 630px;
	margin: 0 auto;
	padding: var(--common-margin) 0;
}
#supplement section{
	width: 100%;
	margin-bottom: var(--common-marginX2);
}
#supplement section h1{
	font-size:2.4rem;
	text-align: center;
	margin-bottom: var(--line-spacing);
}
#supplement section p{
	margin-bottom: var(--line-spacing);
}
#supplement section blockquote{
	color:#990000;
	border: solid 2px #990000;
	background-color: #F8E6DC;
	padding: var(--line-spacing);
}
#supplement section blockquote ul{}
#supplement section blockquote ul li{
	margin-left:1.0rem;
	text-indent:-1.0rem;
}
#supplement section blockquote ul li::marker{
	margin:0;
}

#supplement section blockquote ul li a{
	color:#990000;
}
#supplement section blockquote + p{
	font-size: 12px;
	margin-top: var(--small-spacing);
}

#supplement section table{
	border: solid 1px #ccc;
	font-size: 12px;
}
#supplement section table tr{
	border-bottom: solid 1px #ccc;
}
#supplement section table th{
	width: 20%;
	border-right: solid 1px #ccc;
	background-color: #FAF7F0;
	padding: var(--small-spacing);
	text-align: left;
}
#supplement section table td{
	width: 80%;
	border-left: solid 1px #ccc;
	padding: var(--small-spacing);
}
#supplement section table td a{
	color:var(--key-font-color);
}
#supplement section table td ul{
	margin-bottom: var(--small-spacing);
	font-weight: 400;
}
footer h1{
	color: #FFF;
	font-size: 2.4rem;
	margin-bottom: var(--line-spacing);
}
footer p{
	margin-bottom: var(--line-spacing);
}

footer ul{
	margin-bottom: var(--line-spacing);
}
footer ul li{
	list-style: none;
}
footer ul li a{
	color: #FFF !important;
}
footer ul li:first-child{}
footer ul li:nth-child(2){}
footer ul li:nth-child(3){}
footer ul li:first-child:before,
footer ul li:nth-child(2):before,
footer ul li:nth-child(3):before{
	display: inline-block;
	vertical-align: middle;
	margin-right: var(--small-spacing);
}
footer ul li:first-child:before{
	content: url("../img/phone_icon.svg");
	transform: scale(0.8);
}
footer ul li:nth-child(2):before{
	content: url("../img/fax.svg");
	transform: scale(0.8);
}
footer ul li:nth-child(3):before{
	content: url("../img/email_icon.svg");
	transform: scale(0.6);
}

footer ul + p{
	margin-bottom: 0 !important;
}
footer p a{
	color: #FFF !important;
}

footer small{}


/*  */

#navi{
	width: 80%;
	position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	filter: drop-shadow(3px 3px 3px rgba(0,0,0,0.2));
}
#navi ul{
	overflow: hidden;
	border-radius:8px;
}
#navi ul li{
	list-style: none;
	position: relative;
	font-size: 22px;
	height: 50px;
	line-height: 50px;
	text-align: justify;
}
#navi ul li:first-child{
	background-color: rgba(200,0,0,0.95);
}
#navi ul li:nth-child(2){
	background-color: rgba(153,0,0,0.95);
}
#navi ul li:nth-child(3){
	background-color: rgba(6,199,85,0.95);
}
#navi ul li:first-child:before,
#navi ul li:nth-child(2):before,
#navi ul li:nth-child(3):before{
	content:"";
	display: inline-block;
	background-repeat:no-repeat;
	background-position: center;
	width: 50px;
	height: 50px;
	vertical-align: top;
}
#navi ul li:first-child:before{
	background-image:url("../img/phone_icon.svg");
	background-color: rgba(181,0,0,0.95);
}
#navi ul li:nth-child(2):before{
	background-image:url("../img/email_icon.svg");
	background-color: rgba(115,0,0,0.95);
	background-size:50%;
}
#navi ul li:nth-child(3):before{
	background-image:url("../img/line_icon.svg");
	background-color: rgba(73,163,99,0.95);
	background-size:50%;
}
#navi ul li:first-child a,
#navi ul li:nth-child(2) a,
#navi ul li:nth-child(3) a{
	font-weight: 700;
	margin: 0 15px;
	color: #FFF;
}
#navi ul li:first-child a{
	letter-spacing: 5px;
}
#navi ul li:nth-child(2) a{
	font-size: 18px;
	letter-spacing: 4px;
}
#navi ul li:nth-child(3) a{
	font-size: 18px;
	letter-spacing: 4px;
}
@media screen and (min-width: 900px){
	#navi{
		width: 200px;
		position: fixed;
		top: 20px;
		bottom: auto;
		left: auto;
		right: 20px;
		transform: translateX(0);
		-webkit-transform: translateX(0);
		-ms-transform: translateX(0);
	}
	#navi ul li{
		font-size: 20px;
		height: 35px;
		line-height: 35px;
	}
	#navi ul li:first-child{
		padding: 5px 0;
	}
	#navi ul li:first-child:before,
	#navi ul li:nth-child(2):before,
	#navi ul li:nth-child(3):before{
		width: 35px;
		height: 35px;
	}
	#navi ul li:first-child:before{
		width: 35px;
		height: 45px;
		margin-top: -5px;
	}
	#navi ul li:first-child a,
	#navi ul li:nth-child(2) a,
	#navi ul li:nth-child(3) a{
	margin: 0 5px;
}
	#navi ul li:first-child a{
		letter-spacing: 1px;
	}
	#navi ul li:nth-child(2) a{
		font-size: 16px;
		letter-spacing: 0;
	}
	#navi ul li:nth-child(3) a{
		font-size: 16px;
		letter-spacing: 0;
	}
}

/*  */

.form-wrap{
	width:90%;
	max-width: 980px;
	margin:0 auto 50px;
	padding:0;
	text-align: left;
}

button, input, select, textarea {
	font-family:inherit;
	font-size:100%;
	box-sizing: border-box;
	display: block;
}

.form-group label{
	display: block;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	margin-bottom:var(--line-spacing) ;
}

.form-group label span{
	color: #990000;
}


.form-imputarea input[type="hidden"]{}

.form-imputarea input[type="text"],.form-imputarea input[type="email"],.form-imputarea input[type="date"],.form-imputarea input[type="tel"],.form-imputarea textarea,.form-imputarea select{
	padding:var(--form-common-fontsize);
	border: 1px solid #ccc;
	width: 100%;
	margin-bottom:calc(var(--form-common-fontsize) * 1.5) ;
	color: #000;
	background-color: #fff;
	border-radius: 4px;
}

.form-imputarea input[type="text"]{}
.form-imputarea input[type="email"]{}
.form-imputarea input[type="date"]{}
.form-imputarea input[type="tel"]{}

.form-imputarea input[type="radio"],
.form-imputarea input[type="checkbox"],
.form-imputarea label{ display: inline-block; }

.form-imputarea input[type="radio"],
.form-imputarea input[type="checkbox"]{
	margin-right:var(--form-common-fontsize);
}

.form-imputarea label + input[type="radio"],
.form-imputarea label + input[type="checkbox"]{
	margin-left:var(--form-common-fontsize);
}

.form-imputarea textarea{
	width: 100% !important;
	height: 10.0rem !important;
}

.select-wrap {
	position: relative;
}
.select-wrap::before {
	content: "";
	display: block;
	position: absolute;
	top: var(--form-common-fontsize);
	right: var(--form-common-fontsize);
	width: var(--form-common-fontsize);
	height: var(--form-common-fontsize);
	transform: rotate(45deg);
	background: transparent;
	border-bottom: 3px solid #ccc;
	border-right: 3px solid #ccc;
	pointer-events: none;
}

.form-imputarea select{
	outline:none;
	-moz-appearance: none;
	text-overflow: '';
	vertical-align: middle;
	-webkit-appearance: button;
	-moz-appearance: button;
	appearance: button;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
}

.form-imputarea select::-ms-expand {
	display: none;
}

select:-moz-focusring { 
	color: transparent; 
}

.form-group section{
	width: 100%;
	max-width: 100%;
}

.form-group.finish{
	text-align: center;
	padding: var(--common-margin) 0;
}
.form-group.finish input[type="submit"],
.form-group.finish input[type="reset"]{
	display:inline-block;
	padding: var(--form-common-fontsize);
	text-decoration: none;
	text-align: center;
	background-color: #990000;
	border-radius: 4px;
	transition: all 0.5s;
}

.form-group.finish input[type="submit"]:hover,
.form-group.finish input[type="reset"]:hover{
	cursor: pointer;
}

.form-group.finish input[type="submit"]{
	padding-left: calc(var(--form-common-fontsize) * 2);
	padding-right: calc(var(--form-common-fontsize) * 2);
	margin-right: calc(var(--form-common-fontsize) * 1);
}

#policy{
	width: 100%;
	height: calc(var(--common-marginX2) * 2);
	margin: 0;
	margin-bottom:calc(var(--form-common-fontsize) * 1.5) ;
	padding: var(--form-common-fontsize);
	color: #888;
	background-color: #fff;
	border: 1px solid #ccc;
	border-radius: 4px;
	overflow-y: scroll;
}

#policy h2{ 
	margin-bottom:calc(var(--form-common-fontsize) * 1) ;
	font-weight: 700;
}
#policy p{
	text-align: left !important;
	margin-bottom:calc(var(--form-common-fontsize) * 0.8) ;
}

#mfp_loading,
#mfp_loading_screen,
#mfp_overlay_background,
#mfp_overlay,
#mfp_hidden{
	display: none;
}

.mfp_err[style]{
	margin: 0 0 20px;
	font-size: 10px;
	font-weight: 700;
}

.mfp_element_submit, .mfp_element_reset, .mfp_element_button, button.mfp_next, button.mfp_prev {
    text-shadow:none;
}

#instgram-btn{
	position: fixed;
	top:20px;
	left: 20px;
	width: 60px;
	z-index: 99999;
}