@charset 'UTF-8';

* {
margin: 0px;
padding: 0px;
word-break: normal !important;
word-wrap: break-word;
line-break:normal;
border: 0;
outline: 0;
box-sizing: border-box;
hanging-punctuation: force-end;
}

html {
scroll-padding-top: 100px;
overflow: auto;
font-size: 62.5%;
}
body {
position: relative;
max-height: 100%;
margin: 0;
padding: 0;
font-style: normal;
font-family: "Cardo","Kaisei Tokumin", sans-serif;
font-size: 1.6rem;
font-optical-sizing: auto;
font-weight: 500;
line-height: 1.6;
color: #17101c;
background-color: #f3f2ed;
-webkit-text-size-adjust: 100%;
}
@media (max-width: 1023px) {
	html {
	}
}
@media (max-width: 767px) {
	html {
	scroll-padding-top: 70px;
	}
	body {
	width: 100%;
	}
}
@media (max-width: 374px) {
	html {
	}
}

section {
position: relative;
}
section:after {
clear:both;
display:block;
content:"";
}
table {
border-collapse: collapse;
border-spacing: 0;
}
table th {
font-weight: normal;
text-align: inherit;
}
nav, ol, ul {
list-style: none;
}

h1, h2, h3, h4, h5, h6 {
font-size: inherit;
font-weight: 500;
}
h1, h2, h3 {
line-height: 1.4;
}
@media (min-width: 768px) {
	h1, h2, h3, h4, h5, h6 {
	letter-spacing: 1px;
	}
}

a {
text-decoration: none;
color: inherit;
}
a:hover {
text-decoration: none;
}
@media (min-width: 768px) {
	a[href^="tel:"] {
	pointer-events: none;
	}
}

/*-------------------------
 フォームパーツ
-----------------------*/
button {
cursor: pointer;
font-family: inherit;
font-size: inherit;
background-color: transparent;
border: 0;
}
input,
select,
textarea {
display: block;
font-family: inherit;
font-size: inherit;
color: #252525;
border: 1px solid #252525;
}
input[type="button"],
input[type="text"],
input[type="tel"],
input[type="submit"],
input[type="image"],
textarea {
-webkit-appearance: none;
}
input[type="text"],
input[type="tel"],
input[type="password"],
input[type="date"],
input[type="email"],
textarea {
-webkit-appearance: none;
width: 100%;
padding: 15px;
background-color: #fff;
border-radius: 6px;
}
select {
width: 100%;
padding: 15px;
background-color: #fff;
border-radius: 6px;
}
input[type="file"] {
-webkit-appearance: none;
background-color: transparent;
border: 0;
}
input[type="checkbox"],
input[type="radio"] {
display: inline-block;
margin-left: 2px;
margin-right: 0.5em;
transform: scale(1.1, 1.1);
}
.select {
position: relative;
}
.select::after {
position: absolute;
content: "";
width: 12px;
height: 10px;
top: 50%;
transform: translateY(-50%);
right: 10px;
background-color: #888;
clip-path: polygon(0 0, 50% 100%, 100% 0);
}
.select select {
-webkit-appearance: none;
}
textarea {
width: 100%;
height: 250px;
}
::placeholder {
}
.contact_submit_flex {
display: flex;
justify-content: center;
margin: 3em auto 0;
}
.contact_previous,
.contact_submit {
display:flex;
justify-content: center;
align-items: center;
width: fit-content;
width: 300px;
height: 60px;
margin: 0 10px;
color: #252525;
border-radius: 100px;
}
.contact_previous {
background-color: #aaa;
}
.contact_submit {
background-color: #c70019;
}
.contact_submit .wpcf7-spinner {
display: none;
}
.contact_previous input[type="button"],
input[type="reset"],
input[type="submit"] {
-webkit-appearance: none;
cursor: pointer;
cursor: hand;
width: 100%;
height: 100%;
font-weight: bold;
letter-spacing: 1px;
background-color: transparent;
border-color: transparent;
border-radius: 0;
}
.contact_previous input[type="button"],
.contact_previous input[type="reset"],
.contact_previous input[type="submit"] {
color: #fff;
}
input[readonly="readonly"] {
border-width: 0;
}
.privacy_check {
margin-top: 20px;
text-align: center;
}
.privacy_check a {
text-decoration: underline;
}
.hissu {
display: inline-block;
margin-left: 1em;
padding: 5px;
font-size: 1.4rem;
font-weight: normal;
line-height: 1;
color: #ed0000;
background-color: #fff;
border: 1px solid;
}
@media (max-width:1023px) {
	.select::after {
	width: 10px;
	height: 8px;
	right: 8px;
	}
}
@media (min-width:768px) {
	/* focus */
	input[type="text"]:focus,
	input[type="tel"]:focus,
	input[type="password"]:focus,
	input[type="date"]:focus,
	input[type="email"]:focus,
	select:focus,
	textarea:focus {
	background-color: #fbfcd6;
	transition: .5s;
	}
	input[readonly="readonly"]:focus {
	background-color: #fff;
	}
	/* hover */
	.privacy_check a:hover {
	opacity: .5;
	transition: .5s;
	}
	.contact_previous:hover {
	color: #fff;
	background-color: #252525;
	transition: .5s;
	}
	.contact_submit:hover {
	background-color: #c70019;
	transition: .5s;
	}
	.contact_submit:hover input {
	/*color: #fff;*/
	transition: .5s;
	}
}
@media (max-width:767px) {
	input[type="text"],
	input[type="tel"],
	input[type="password"],
	input[type="date"],
	input[type="email"],
	select,
	textarea {
	padding: 10px;
	border-radius: 4px;
	}
	.select::after {
	width: 10px;
	height: 6px;
	right: 7px;
	}
	textarea {
	height: 200px;
	}
	.contact_submit,
	.contact_previous {
	width: 200px;
	height: 42px;
	margin: 0 2px;
	font-size: inherit !important;
	}
}

/*-----------------------
 slick
-----------------------*/
.slick-slider {
overflow: hidden;
position: relative;
display: block;
margin: 0;
padding: 0;
line-height: 0;
box-sizing: border-box;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
-webkit-touch-callout: none;
-khtml-user-select: none;
-ms-touch-action: pan-y;
touch-action: pan-y;
-webkit-tap-highlight-color: transparent;
}
.slick-list {
position: relative;
display: block;
overflow: hidden;
margin: 0;
padding: 0;
}
.slick-list:focus {
outline: none;
}
.slick-list.dragging {
cursor: pointer;
cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list {
-webkit-transform: translate3d(0, 0, 0);
-moz-transform: translate3d(0, 0, 0);
-ms-transform: translate3d(0, 0, 0);
-o-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
}
.slick-track {
position: relative;
top: 0;
left: 0;
display: block;
margin-left: auto;
margin-right: auto;
}
.slick-track:before,
.slick-track:after {
display: table;
content: '';
}
.slick-track:after {
clear: both;
}
.slick-loading .slick-track {
visibility: hidden;
}
.slick-slide {
overflow: hidden;
display: none;
float: left;
height: 100%;
min-height: 1px;
margin: 0 10px;
}
[dir='rtl'] .slick-slide {
float: right;
}
.slick-slide img {
display: block;
object-fit: cover;
aspect-ratio: 3 / 2;
width: 100%;
height: 100%;
margin: 0;
padding: 0;
vertical-align: middle;
}
.slick-slide.slick-loading img {
display: none;
}
.slick-slide.dragging img {
pointer-events: none;
}
.slick-initialized .slick-slide {
display: block;
}
.slick-loading .slick-slide {
visibility: hidden;
}
.slick-vertical .slick-slide {
display: block;
height: auto;
border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
display: none;
}
.slick-prev,
.slick-next {
z-index: 2;
position: absolute;
width: 50px;
height: 80px;
top: 50%;
transform: translateY(-50%);
font-size: 0;
background-repeat: no-repeat;
background-size: contain;
background-color: rgba(255,255,255,.4);
}
.slick-prev {
left: 0;
}
.slick-next {
right: 0;
}
.slick-prev::before,
.slick-next::before {
opacity: .5;
position: absolute;
content: "";
width: calc(16px * .7);
height: calc(25px * .7);
top: 50%;
left: 50%;
transform: translateY(-50%) translateX(-50%);
background-repeat: no-repeat;
background-size: contain;
}
.slick-prev::before {
background-image: url(./common/img/arrow_prev@2x.png);
}
.slick-next::before {
background-image: url(./common/img/arrow_next@2x.png);
}
.slick-prev button,
.slick-next button {
}
.slick-prev button {
}
.slick-next button {
}
@media (max-width:1023px) {
	.slick-slide {
	margin: 0 5px;
	}
	.slick-prev,
	.slick-next {
	width: 40px;
	height: 50px;
	}
	.slick-prev::before,
	.slick-next::before {
	width: calc(16px * .6);
	height: calc(25px * .6);
	}
}
@media (max-width:767px) {
	.slick-prev,
	.slick-next {
	width: 40px;
	height: 50px;
	}
	.slick-prev::before,
	.slick-next::before {
	width: calc(16px * .4);
	height: calc(25px * .4);
	}
}

/*-----------------------
 共通設定
-----------------------*/
.body_wrap {
overflow: hidden;
}

.right { text-align: right !important; }
.left { text-align: left !important; }
.center { text-align: center !important; }
.fit { width: fit-content;margin-right: auto;margin-left: auto; }
@media (max-width: 767px) {
	.fit_sp {
	width: fit-content;
	margin-right: auto;
	margin-left: auto;
	text-align: left;
	}
}
.normal { font-weight: normal;}
.font_small { font-size: 1.4rem; }
.font_large { font-size: 1.8rem; }
.red { color: #e10915; }
.underline { text-decoration: underline; }
.bold { font-weight: bold; }

.txtlink a {
text-decoration: underline;
}
@media (min-width:768px) {
	.txtlink a:hover {
	opacity: .5;
	transition: .5s;
	}
}

img {
display: block;
width: 100%;
max-width: 100%;
width: auto;
height: auto;
margin-right: auto;
margin-left: auto;
vertical-align:top;
}

.mb1 {
margin-bottom: 1em;
}
.mt1 {
margin-top: 1em;
}

@media (min-width:768px) {
	.sp {
	display: none;
	}
}
@media (max-width: 767px) {
	.pc {
	display: none;
	}
}

/*-----------------------
 ヘッダー
-----------------------*/
html.active {
overflow: hidden;
}
header {
z-index: 9;
position: absolute;
width: 100%;
padding: 30px;
top: 0;
left: 0;
}
.header_wrap {
margin: auto;
}
.head_box {
position: relative;
width: fit-content;
text-align: center;
}
.head_box a {
}
h1 {
margin-bottom: 10px;
font-size: 1.8rem;
text-shadow: 0 0 10px #000;
line-height: 1;
color: #e4dede;
}
.head_logo {
width: 250px;
}
.toggle {
z-index: 99999;
cursor: pointer;
position: fixed;
display: block;
width: 106px;
height: 106px;
top: 20px;
right: 20px;
background-image: url(./common/img/bg01.jpg);
background-repeat: no-repeat;
background-size: cover;
}
html.active .toggle {
}
.toggle::before {
position: absolute;
content: "Menu";
width: 100%;
bottom: 12px;
left: 0;
right: 0;
margin: auto;
font-size: 1.6rem;
font-weight: bold;
text-align: center;
letter-spacing: 1px;
color: #17101c;
}
.toggle div {
position: absolute;
width: 50px;
top: 23px;
left: 50%;
transform: translateX(-50%);
}
.toggle span {
display: block;
position: absolute;
width: 100%;
height: 2px;
left: 0;
background-color: #17101c;
border-radius: 100px;
border-radius: 100px;
transition: .35s ease-in-out;
-webkit-transition: .35s ease-in-out;
-moz-transition: .35s ease-in-out;
}
.toggle span:nth-child(1) {
top: 0;
}
.toggle span:nth-child(2) {
top: 14px;
}
.toggle span:nth-child(3) {
top: 28px;
}
html.active .toggle {
z-index: 99999;
}
html.active .toggle::before {
content: "Close";
}
html.active .toggle span {
top: 12px;
}
html.active .toggle span:nth-child(1) {
transform: translateY(0) rotate(-45deg);
}
html.active .toggle span:nth-child(2) {
transform: translateY(0) rotate(45deg);
}
html.active .toggle span:nth-child(3) {
opacity: 0;
}
.spmenu {
display: none;
}
html.active .spmenu {
overflow-x: hidden;
overflow-y: auto;
display: flex;
align-items: center;
z-index: 9999;
position: fixed;
width: 100%;
height: 100vh;
top: 0;
right: 0;
padding: 40px 30px;
line-height: 1;
background-color: #17101c;
animation: spmenu-open .3s ease-out forwards;
box-shadow: 0 0 30px rgba(0,0,0,.2);
}
html.closing .spmenu {
animation: spmenu-close .3s ease-out forwards;
}
@keyframes spmenu-open {
	from {
		transform: translateY(-100%);
	}
	to {
		transform: translateY(0);
	}
}
@keyframes spmenu-close {
	from {
		transform: translateY(0);
	}
	to {
		transform: translateY(-100%);
	}
}
.head_nav_box {
margin-bottom: 50px;
text-align: center;
}
.head_nav_logo {
max-width: 200px;
margin: 0 auto 30px;
font-size: 0;
}
.head_nav_logo a {
}
.head_nav_tel {
width: fit-content;
margin: auto;
font-size: 2.8rem;
line-height: 1;
letter-spacing: 2px;
color: #fff;
}
.head_nav_tel a {
}
.head_nav_tel a::before {
content: "Tel.";
margin-right: 10px;
font-size: 2.0rem;
letter-spacing: 0;
}
.head_nav {
width: 100%;
max-width: 500px;
margin: auto;
}
.head_nav nav {
}
.head_nav_list {
position: relative;
}
.head_nav_list_li {
margin-bottom: 10px;
font-size: 2.4rem;
font-style: italic;
font-weight: 600;
text-align: center;
letter-spacing: 2px;
}
.head_nav_list_li>a {
position: relative;
display: block;
padding: 22px;
background-image: url(./common/img/bg01.jpg);
background-repeat: no-repeat;
background-size: cover;
}
.head_nav_list_li>a::before {
opacity: .5;
position: absolute;
content: "";
width: calc(100% - 10px);
height: calc(100% - 10px);
top: 50%;
left: 50%;
transform: translateY(-50%) translateX(-50%);
border: 1px solid #fff;
}
.head_nav_sns {
display: flex;
justify-content: center;
}
.head_nav_sns_li {
margin: 0 10px;
}
.head_nav_sns_li img {
width: 40px;
height: 40px;
}
/* is-fixed */
html.is-fixed .toggle {
top: 0;
right: 0;
transition: all 0.1s ease-in-out;
}
@media (max-width:1023px) {
	header {
	padding: 15px 20px;
	}
	.head_logo {
	width: 200px;
	}
	.toggle {
	width: 80px;
	height: 80px;
	top: 10px;
	right: 10px;
	}
	.toggle div {
	width: 40px;
	top: 15px;
	}
	.toggle span:nth-child(2) {
	top: 12px;
	}
	.toggle span:nth-child(3) {
	top: 24px;
	}
	.toggle::before {
	bottom: 5px;
	}
	html.active .spmenu {
	display: block;
	}
	.head_nav_box {
	margin-bottom: 30px;
	}
	.head_nav_logo {
	max-width: 180px;
	margin-bottom: 20px;
	}
	.head_nav_list {
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
	}
	.head_nav_list_li {
	font-size: 2.0rem;
	}
	.head_nav_list_li>a {
	padding: 18px;
	}
}
@media (min-width:768px) {
	/* hover */
	.head_box:hover,
	.head_nav_logo a:hover,
	.toggle:hover,
	.head_nav_list_li:hover {
	opacity: .5;
	transition: .5s;
	}
}
@media (max-width:767px) {
	header {
	padding: 15px 10px;
	}
	h1 {
	margin-bottom: 4px;
	font-size: inherit;
	}
	.head_logo {
	width: 150px;
	}
	.toggle {
	width: 60px;
	height: 60px;
	top: 0;
	right: 0;
	}
	.toggle div {
	width: 32px;
	top: 12px;
	}
	.toggle span:nth-child(2) {
	top: 9px;
	}
	.toggle span:nth-child(3) {
	top: 18px;
	}
	html.active .toggle span {
	top: 10px;
	}
	.toggle::before {
	font-size: 1.4rem;
	bottom: 3px;
	letter-spacing: 0;
	}
	.head_nav_box {
	margin-bottom: 30px;
	}
	.head_nav_logo {
	max-width: 120px;
	margin-bottom: 20px;
	}
	.head_nav_tel {
	font-size: 2.2rem;
	}
	.head_nav_tel a::before {
	margin-right: 5px;
	font-size: 1.6rem;
	}
	.head_nav_list {
	max-width: 250px;
	}
	.head_nav_list_li {
	font-size: 1.8rem;
	}
	.head_nav_list_li>a {
	}
}

/*-----------------------
 TOP
-----------------------*/
/*--メインビジュアル--*/
.mv {
position: relative;
}
.mv_wrap {
position: relative;
margin: auto;
}
.mv_img {
height: 100vh;
}
.mv_img img {
object-fit: cover;
width: 100%;
height: 100%;
}
.mv_txt {
z-index: 1;
position: absolute;
bottom: 100px;
right: 150px;
font-style: italic;
text-shadow: 0 0 10px #000;
color: #fff;
}
.mv_txt_1 {
margin-bottom: 20px;
font-size: 4.0rem;
font-family: "Great Vibes";
line-height: 1.4;
letter-spacing: 4px;
}
.mv_txt_2 {
font-size: 4.0rem;
font-weight: 400;
letter-spacing: 4px;
}
.mv_txt_2 span {
font-size: 3.0rem;
}
@media (max-width:1440px) {
	.mv_txt {
	bottom: 80px;
	right: 80px;
	}
}
@media (max-width:1260px) {
	.mv_txt {
	right: 50px;
	}
}
@media (max-width:1023px) {
	.mv_txt {
	right: 30px;
	}
	.mv_txt_1 {
	margin-bottom: 18px;
	font-size: 3.0rem;
	letter-spacing: 2px;
	}
	.mv_txt_2 {
	font-size: 3.0rem;
	letter-spacing: 2px;
	}
	.mv_txt_2 span {
	font-size: 2.4rem;
	}
}
@media (max-width:767px) {
	.mv_txt {
	right: 10px;
	bottom: 50px;
	}
	.mv_txt_1 {
	font-size: 1.8rem;
	}
	.mv_txt_2 {
	font-size: 2.0rem;
	letter-spacing: 1px;
	}
	.mv_txt_2 span {
	font-size: 1.8rem;
	}
}

/*--top共通--*/
.top_sec {
padding: 120px 30px;
}
.top_wrap {
max-width: 1200px;
margin: auto;
}
.mainbg {
position: relative;
}
.mainbg::after {
z-index: -9;
position: absolute;
content: "";
width: 100%;
height: 100%;
top: 0;
left: 0;
background-image: url(./common/img/mainbg.jpg);
}
.bg01 {
position: relative;
}
.bg01::after {
opacity: .2;
z-index: -8;
position: absolute;
content: "";
width: 100%;
height: 100%;
top: 0;
left: 0;
background-color: #05001f;
}
.top_ttl {
position: relative;
max-width: 250px;
margin: 0 auto 60px;
text-align: center;
line-height: 1.4;
}
.top_ttl::before,
.top_ttl::after {
position: absolute;
content: "";
width: calc(186px * .35);
height: calc(319px * .35);
top: 50%;
transform: translateY(-50%);
background-repeat: no-repeat;
background-size: contain;
}
.top_ttl::before {
left: -120px;
background-image: url(./common/img/top_ttl_bg1.png);
}
.top_ttl::after {
right: -120px;
background-image: url(./common/img/top_ttl_bg2.png);
}
.bg01 .top_ttl::before,
.bg01 .top_ttl::after {
opacity: .4;
filter: brightness(0) invert(0);
}
.top_ttl_1 {
font-family: "Great Vibes";
font-size: 7.0rem;
letter-spacing: 2px;
background-image: url(./common/img/bg02.jpg);
background-size: 100% auto;
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
}
.bg01 .top_ttl_1 {
background-image: url(./common/img/bg03.jpg);
}
.top_ttl_2 {
font-size: 2.6rem;
letter-spacing: 1px;
}
.top_txt {
line-height: 2;
letter-spacing: 1px;
}
.top_txt p + p {
margin-top: 1em;
}
@media (max-width:1260px) {
	.top_sec {
	padding: 100px 30px;
	}
	.top_wrap {
	max-width: 964px;
	}
}
@media (max-width:1023px) {
	.top_sec {
	padding: 80px 30px;
	}
	.top_wrap {
	max-width: 708px;
	}
	.top_ttl {
	max-width: 240px;
	margin-bottom: 50px;
	}
	.top_ttl::before,
	.top_ttl::after {
	width: calc(186px * .3);
	height: calc(319px * .3);
	}
	.top_ttl::before {
	left: -80px;
	}
	.top_ttl::after {
	right: -80px;
	}
	.top_ttl_1 {
	font-size: 6.0rem;
	}
	.top_ttl_2 {
	font-size: 2.4rem;
	}
	.top_txt {
	line-height: inherit;
	letter-spacing: 0;
	}
}
@media (max-width:767px) {
	.top_sec {
	padding: 70px 15px;
	}
	.top_wrap {
	max-width: 330px;
	}
	.top_ttl {
	max-width: 200px;
	margin-bottom: 30px;
	}
	.top_ttl::before,
	.top_ttl::after {
	width: calc(186px * .22);
	height: calc(319px * .22);
	}
	.top_ttl::before {
	left: -50px;
	}
	.top_ttl::after {
	right: -50px;
	}
	.top_ttl_1 {
	font-size: 4.0rem;
	}
	.top_ttl_2 {
	font-size: 2.0rem;
	}
	.mainbg::after {
	background-size: 500px auto;
	}
}

/*-- コンセプト --*/
.top_concept {
background-image: url(./common/img/concept_bg.jpg);
background-repeat: no-repeat;
background-position: top center;
background-size: cover;
}
.top_concept_txt {
z-index: 1;
position: relative;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
max-width: 1000px;
margin: auto;
padding: 90px 30px;
font-size: 1.8rem;
background-color: rgba(255,255,255,.6);
box-shadow: 0 0 15px rgba(0,0,0,.2);
}
.top_concept_txt::before {
z-index: -1;
opacity: .5;
position: absolute;
content: "";
width: calc(100% - 20px);
height: calc(100% - 20px);
top: 50%;
left: 50%;
transform: translateY(-50%) translateX(-50%);
border: 1px solid #bf9324;
}
.top_concept_txt_wrap {
}
.top_concept_txt p.top_concept_txt_name {
margin-top: 30px;
text-align: right;
}
.top_concept_txt_name_1 {
margin-right: 1em;
font-size: 1.8rem;
}
.top_concept_txt_name_2 {
font-size: 2.2rem;
letter-spacing: 2px;
}
@media (max-width:1260px) {
	.top_concept_txt {
	padding: 50px 30px;
	}
}
@media (max-width:1023px) {
	.top_concept_txt {
	padding: 30px;
	font-size: inherit;
	}
	.top_concept_txt::before {
	width: calc(100% - 10px);
	height: calc(100% - 10px);
	}
	.top_concept_txt p.top_concept_txt_name {
	margin-top: 20px;
	}
	.top_concept_txt_name_1 {
	font-size: inherit;
	}
	.top_concept_txt_name_2 {
	font-size: 2.0rem;
	}
}
@media (max-width:767px) {
	.top_concept {
	background-position: top right -250px;
	}
	.top_concept_txt {
	padding: 20px;
	}
	.top_concept_txt_name_2 {
	font-size: 1.8rem;
	}
}

/*-- ギャラリー --*/
.top_gallery {
padding-right: 0;
padding-left: 0;
}
.top_gallery_wrap {
max-width: 100%;
}
.top_gallery_list {
margin: 0 -10px;
}
.top_gallery_list img {
}
@media (max-width:1260px) {
}
@media (max-width:1023px) {
}
@media (max-width:767px) {
	.top_gallery {
	padding-bottom: 0;
	}
}

/*-- 料金システム --*/
.top_system {
}
.top_system_box {
max-width: 1000px;
margin: auto;
padding: 60px;
background-color: rgba(255,255,255,.7);
}
.top_system_box_in {
}
.top_system_box_in + .top_system_box_in {
margin-top: 50px;
}
.top_system_box_ttl {
margin-bottom: 10px;
padding: 10px 20px;
font-size: 1.8rem;
font-weight: bold;
letter-spacing: 1px;
color: #17101c;
background-image: linear-gradient(to right,#dcd0b1,transparent);
}
.top_system_box_dl {
max-width: calc(100% - 30px);
margin: auto;
}
.top_system_box_dl dl {
display: flex;
flex-wrap: wrap;
align-items: center;
padding: 15px;
font-size: 1.8rem;
border-bottom: 1px solid #aba8a8;
}
.top_system_box_dl dt {
width: 150px;
}
.top_system_box_dl dd {
width: calc(100% - 150px);
}
.tax {
font-size: 1.4rem;
}
.top_system_box_txt {
max-width: calc(100% - 30px);
margin: 20px auto 0;
}
.top_system_box_txt ul {
max-width: calc(100% - 20px);
}
.top_system_box_txt ul li {
position: relative;
margin: 8px 0;
padding-left: 1em;
line-height: 1.4;
}
.top_system_box_txt ul li::before {
position: absolute;
content: "";
width: 6px;
height: 1px;
top: 10px;
left: 2px;
background-color: #838080;
}
@media (max-width:1260px) {
}
@media (max-width:1023px) {
	.top_system_box {
	padding: 30px;
	}
}
@media (max-width:767px) {
	.top_system_box {
	padding: 20px;
	}
	.top_system_box_in + .top_system_box_in {
	margin-top: 40px;
	}
	.top_system_box_ttl {
	margin-bottom: 5px;
	padding: 10px 15px;
	font-size: 1.7rem;
	}
	.top_system_box_dl {
	max-width: 100%;
	}
	.top_system_box_dl dl {
	padding: 12px;
	font-size: 1.6rem;
	line-height: 1.4;
	}
	.top_system_box_dl dt {
	width: 90px;
	}
	.top_system_box_dl dd {
	width: calc(100% - 90px);
	}
	.tax {
	font-size: 1.3rem;
	}
	.top_system_box_txt {
	max-width: 100%;
	}
	.top_system_box_txt ul {
	max-width: calc(100% - 20px);
	}
	.top_system_box_txt ul li {
	margin: 6px 0;
	font-size: 1.5rem;
	}
	.top_system_box_txt ul li span {
	font-size: 1.4rem;
	}
	.top_system_box_txt ul li::before {
	width: 5px;
	top: 7px;
	}
}

/*-- リクルート --*/
.top_recruit {
}
.top_recruit_box {
width: fit-content;
margin: auto;
font-size: 1.8rem;
}
.top_recruit_txt1 {
margin-bottom: 30px;
font-size: 2.7rem;
text-align: center;
letter-spacing: 1px;
}
.top_recruit_txt2 {
margin-bottom: 60px;
font-size: 2.0rem;
}
.top_recruit_list1 {
width: fit-content;
margin: 0 auto 50px;
}
.top_recruit_list1 ul {
}
.top_recruit_list1 li {
position: relative;
margin: 15px 0;
padding-left: 40px;
font-style: italic;
}
.top_recruit_list1 li::before {
opacity: .5;
position: absolute;
content: "";
width: 23px;
height: 23px;
top: 50%;
transform: translateY(-50%);
left: 0;
background-image: url(./common/img/marker01.png);
background-repeat: no-repeat;
background-size: contain;
filter: brightness(0) invert(0);
}
.top_recruit_list1 li span {
font-size: 2.4rem;
color: #900707;
}
.top_recruit_list2 {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
width: calc(500px);
height: calc(349px);
margin: 0 auto 60px;
padding: 20px;
background-image: url(./common/img/recruit_list02_bg.png);
background-repeat: no-repeat;
background-size: contain;
}
.top_recruit_list2_txt {
width: 100%;
max-width: 250px;
margin: 0 auto 15px;
padding: 8px 30px;
font-size: 2.2rem;
text-align: center;
color: #e4dede;
background-color: #900707;
border-radius: 100px;
}
.top_recruit_list2 ul {
}
.top_recruit_list2 li {
margin: 12px 0;
font-size: 2.0rem;
text-align: center;
}
.top_recruit_txt3 {
font-size: 2.0rem;
}
@media (max-width:1260px) {
}
@media (max-width:1023px) {
	.top_recruit_txt1 {
	margin-bottom: 20px;
	font-size: 2.4rem;
	}
	.top_recruit_txt2 {
	margin-bottom: 40px;
	font-size: inherit;
	}
	.top_recruit_list1 {
	margin-bottom: 30px;
	}
	.top_recruit_list1 li {
	margin: 10px 0;
	padding-left: 30px;
	font-size: 1.7rem;
	}
	.top_recruit_list1 li::before {
	width: 18px;
	height: 18px;
	}
	.top_recruit_list1 li span {
	font-size: 2.0rem;
	}
	.top_recruit_list2 {
	margin-bottom: 30px;
	width: calc(500px * .9);
	height: calc(349px * .9);
	}
	.top_recruit_list2 li {
	font-size: inherit;
	}
	.top_recruit_txt3 {
	font-size: inherit;
	}
}
@media (max-width:767px) {
	.top_recruit_box {
	font-size: inherit;
	}
	.top_recruit_txt1 {
	margin-bottom: 15px;
	font-size: 2.0rem;
	}
	.top_recruit_txt2 {
	margin-bottom: 30px;
	font-size: inherit;
	}
	.top_recruit_list1 {
	margin-bottom: 20px;
	}
	.top_recruit_list1 li {
	margin: 8px 0;
	padding-left: 22px;
	font-size: 1.5rem;
	}
	.top_recruit_list1 li::before {
	width: 13px;
	height: 13px;
	}
	.top_recruit_list1 li span {
	font-size: 1.8rem;
	}
	.top_recruit_list2 {
	margin-bottom: 30px;
	width: calc(500px * .65);
	height: calc(349px * .65);
	padding: 10px;
	}
	.top_recruit_list2_txt {
	max-width: 180px;
	padding: 5px 20px;
	font-size: 1.8rem;
	}
	.top_recruit_list2 li {
	margin: 5px 0;
	font-size: 1.6rem;
	}
	.top_recruit_txt3 {
	font-size: inherit;
	}
}

/*-- 店舗情報・アクセス --*/
.top_access {
padding-right: 0 !important;
padding-left: 0 !important;
padding-bottom: 0 !important;
}
.top_access_box1,
.top_access_box2 {
width: fit-content;
margin: auto;
font-size: 1.8rem;
text-align: center;
}
.top_access_box1 {
margin-bottom: 30px;
}
.top_access_box2 {
margin-bottom: 80px;
}
.top_access_name {
max-width: 200px;
margin: 0 auto 30px;
}
.top_access_txt_1 {
}
.top_access_txt_2 {
margin-bottom: 1em;
}
.top_access_tel {
margin-bottom: 1em;
font-size: 2.4rem;
font-weight: 600;
letter-spacing: 1px;
}
.top_access_tel a {
}
.top_access_tel a::before {
margin-right: 4px;
content: "Tel.";
font-size: 1.8rem;
}
.top_access_img {
display: flex;
justify-content: center;
max-width: 700px;
margin: 0 auto 30px;
}
.top_access_img li {
width: calc(50% - 24px);
margin: 0 12px;
}
.top_access_txt_3 {
}
.top_access_txt_4 {
}
.gmap {
height: 500px;
}
.gmap iframe {
display: block;
width: 100%;
height: 100%;
}
@media (max-width:1260px) {
}
@media (max-width:1023px) {
	.top_access_box2 {
	margin-bottom: 50px;
	}
	.top_access_name {
	max-width: 150px;
	}
}
@media (max-width:767px) {
	.top_access_box1,
	.top_access_box2 {
	font-size: inherit;
	}
	.top_access_box1 {
	}
	.top_access_box2 {
	margin-bottom: 40px;
	}
	.top_access_name {
	max-width: 120px;
	margin-bottom: 20px;
	}
	.top_access_txt_2 {
	margin-bottom: 10px;
	}
	.top_access_tel {
	margin-bottom: 10px;
	}
	.top_access_img {
	margin: 0 -6px 10px -6px;
	}
	.top_access_img li {
	width: calc(50% - 12px);
	margin: 0 6px;
	}
}

/*-----------------------
 フッター
-----------------------*/
footer {
padding: 40px 15px;
color: #ebebeb;
background-color: #17101c;
}
.footer_wrap {
}
.copyright {
text-align: center;
letter-spacing: 1px;
}
@media (max-width:1023px) {
}
@media (max-width:767px) {
}

