@charset "utf-8";

@import url("https://unpkg.com/sanitize.css");
@import url("https://cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.css");
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css");
@import url('https://fonts.googleapis.com/css2?family=BIZ+UDPGothic&display=swap');

@import url("inview.css");

html,body {
	margin: 0;padding: 0;
	height: 100%;
	font-size: 13px;
}

body {
	font-family: 'BIZ UDPGothic', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	-webkit-text-size-adjust: none;
	background: #fff;
	color: #777;
	line-height: 2;
	overflow-x: hidden;
}

.main_div{
	height: 100%;
}

figure {margin: 0, 0, 2em, 0;}
dd {margin: 0;}
nav {margin: 0;padding: 0;}

table {border-collapse:collapse;}

img {border: none;max-width: 100%;height: auto;vertical-align: middle;}

video {max-width: 100%;}
iframe {width: 100%;}

ul, ol {margin-bottom: 30px;}


a {
	color: #57524b;
	transition: 0.3s;
}

a:hover {
	opacity: 0.8;
}


section,
main > article {
	margin: 0 auto;
	max-width: 1300px;
	padding: 2% 5%;
}


#container {
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

header {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	background: #808587;
	color: #fff;
	position: relative; z-index: 1;
}

header a {
	color: #fff;
}

header #logo_company img {display: block;}
header #logo_company {
	margin: 0;
	background: linear-gradient(150deg, #FFBBBB, #FF8BBB);
	width: 100px;
	padding: 20px 20px;
	position: absolute;
	left: 75%;
	top: 0px;
	box-shadow: 0px 0px 30px rgba(119,0,0,0.2);
}

main {	
	flex: 1;
}

body:not(.home) main {
	padding-top: 80px;
}

main h2 {
	margin-bottom: 30px;
	position: relative;
	letter-spacing: 0.1em;
	border-bottom: 3px solid #FFBBBB;
}

main h2 .uline {
	display: inline-block;position: relative;
	padding: 10px 20px;
	bottom: -3px;
}
main h2 .uline::before {
	content: "";position: absolute;bottom: 0px;left: 0px;width: 100%;
	height: 3px;
	background: #FF8BBB;
	transition: 1s 0.5s;
	transform: scaleX(0);
	transform-origin: left top;
}
main h2.linestyle .uline::before {
	transform: scaleX(1);
}

main p {
	margin: 0 20px 30px;
}


footer small {font-size: 100%;}

footer {
	font-size: 0.7rem;
	text-align: center;
	padding: 20px;
	background: #808587;
	color: #fff;
}


footer .pr {display: block;}

.top_img {
	position: relative;
	background: #ebf0f0;
}

.top_img img{
	margin: auto;
}

ul.slick-dots {
	margin:0;padding: 0;
	line-height: 1;
	width: 100%;
	text-align: center;
	position: absolute;
	bottom: 10px;
}

ul.slick-dots li {
	display: inline-block;
	margin: 0 10px;
	cursor: pointer;
}

ul.slick-dots li button {
	border: none;padding: 0;
	display: block;
	text-indent: -9999px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	cursor: pointer;
	background: #fff;
}

ul.slick-dots li.slick-active button {
	background: #9ddbf8;
}

.menu_store{
	display: flex;
	overflow: auto;
	margin-top: -10px;
}
.menu_store div{
	border-radius: 0;
	border: solid 2px;
	color: inherit;
	display: block;
	outline: 0;
	padding: 0 0.5em;
	font-size: 0.5em;
	margin: 0 0.2em 0.5em 0;
	cursor: pointer;
	white-space: nowrap;
}

#store {
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	padding: 0 20px;
}

#store dt,
#store dd {
	padding: 5px 0;
}

#store dt {
	width: 8em;
}

#store dt span {
	display: none;
}

#store dd {
	width: calc(100% - 8em);
}

.list {
	margin-bottom: 30px;
	padding: 20px;
	background: #fff;
	color: #999;
	box-shadow: 5px 5px 20px rgba(0,0,0,0.1);
	position: relative;
	width: 100%;
}

.list h3 {
	margin: 0;
	color: #777;
}
.list h3 a {
	color: #777;
}

.list p {
	margin: 0;
	font-size: 0.8em;
}

.list .new_store {
	font-size: 0.6em;
	background: #ff0000;
	color: #fff;
	width: 50px;
	line-height: 50px;
	border-radius: 50%;
	text-align: center;
	position: absolute;
	left: -10px;
	top: -10px;
	transform: rotate(-30deg);
}

.store_info{
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	padding: 0 20px;
}
.store_info dt{
	width: 5em;
	display: flex;
	justify-content: space-between;
}
.store_info dd {
	width: calc(100% - 5em);
}
.store_info .sat {
	color: #00439b;
}
.store_info .sun {
	color: #e0280f;
}

.main_div {
	background: #ebf0f0;
}

.menu_select {
	display: flex;
	text-align: center;
}
.menu_button {
	width: 30%;
	overflow: hidden;
	margin: 0 16px;
	border-radius: 6px;
	-webkit-box-shadow: 0 2px 6px 0 rgba(0, 0, 0, .09);
	box-shadow: 0 2px 6px 0 rgba(0, 0, 0, .09);
}
.menu_button img {
	width: 50%;
}
.menu_button a {
	text-decoration: none;
}

#top_about_us {
	background: #FF8BBB;
	padding: 20px 20px;
}
.top_about_us_detail p{
	margin: 0 20px 10px;
	color: #333333;
}
#top_about_us_detail_title {
	font-size: 1.2em;
	font-weight: bold;

}

#top_info_app_exp > p {
	margin: 10px 20px 5px !important;
	line-height: 1.2;
	font-size: 1.2em;
}
#top_info_app {
	margin-top: 15px;
	padding: 10px;
	height: 120px;
}
#top_info_app > img {
	float: left;
	border-radius: 10%;
	overflow: hidden;
	margin: 0 3% 0 0 !important;
	width: 25% !important;
	max-width: 120px !important;
}
#top_info_app_title {
	font-size: 16px  !important;
	display: inline-block;
	font-size: 20px;
	line-height: 1.5;
	width: 72%;
	max-width: 72%;
}
.top_info_app_link {
	float: left;
	height: 40px;
	margin-top: 8px;
	white-space: nowrap;
}
.top_info_app_link a {
	text-decoration: none;
	color: #539ad5;
	cursor: pointer;
}
.top_info_app_link img {
	margin-right: 10px;
	height: 40px;
	width: 135px;
}

.info_date {
	margin: 0 20px 5px;
	font-size: 0.8em;
	color: #000000;
}

.clearfix::after {content: "";display: block;clear: both;}
.color-theme, .color-theme a {color: #9ddbf8 !important;}
.color-check, .color-check a {color: #f00 !important;}
.c {text-align: center !important;}
.ws {width: 100%;display: block;}
.wl {width: 100%;display: block;}
.mb30 {margin-bottom: 30px !important;}
.mt30 {margin-top: 30px !important;}
.look {display: inline-block;padding: 0px 10px;background: #666; color: #fff; border-radius: 3px;margin: 5px 0; word-break: break-all;}
.look .color-check {color: #ffcc00 !important;}
.small {font-size: 0.6em;}


#contact_div{
	display:block;
}
#contact .fields {
	width: 100%;
}
#contact .fields > .field {
	-moz-flex-grow: 0;
	-webkit-flex-grow: 0;
	-ms-flex-grow: 0;
	flex-grow: 0;
	-moz-flex-shrink: 0;
	-webkit-flex-shrink: 0;
	-ms-flex-shrink: 0;
	flex-shrink: 0;
	padding: 1.5rem 0 0 1.5rem;
}
#contact label {
	display: block;
	font-family: "Source Sans Pro", Helvetica, sans-serif;
	font-weight: 900;
	line-height: 1.5;
	letter-spacing: 0.075em;
	font-size: 0.8rem;
	text-transform: uppercase;
	margin: 0 0 0.75rem 0;
}
#contact input[type="text"], #contact textarea {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
	background: transparent;
	border-radius: 0;
	border: solid 2px;
	color: inherit;
	display: block;
	outline: 0;
	padding: 0 1rem;
	text-decoration: none;
}

#contact input[type="text"] {
	height: 3rem;
	width: 100%;
}

#contact textarea {
	padding: 0.75rem 1rem;
	width: 100%;
	height: 15rem;
}
#privacy_policy {
	padding: 0.75rem 1rem;
	width: 100%;
	height: 28rem;
	overflow: auto;
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
	background: transparent;
	border-radius: 0;
	border: solid 2px;
	color: inherit;
	display: block;
	outline: 0;
	padding: 0 1rem;
	text-decoration: none;
}

.field_row{
	display: flex;
}
.field_half{
	display: inline-block;
	width: 100%;
}
#pp_chk{
	display: block;
	float: left;
	margin: 0 10px 0 2rem;
	width: 1rem;
}
#send_msg {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
	-moz-transition: background-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, color 0.2s ease-in-out;
	-webkit-transition: background-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, color 0.2s ease-in-out;
	-ms-transition: background-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, color 0.2s ease-in-out;
	transition: background-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, color 0.2s ease-in-out;
	border: 0;
	border-radius: 0;
	cursor: pointer;
	display: inline-block;
	font-family: "Source Sans Pro", Helvetica, sans-serif;
	font-size: 0.8rem;
	font-weight: 900;
	letter-spacing: 0.075em;
	height: 3rem;
	line-height: 3rem;
	padding: 0 2rem;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	white-space: nowrap;
	background-color: transparent;
	box-shadow: inset 0 0 0 2px #717981;
	color: #717981 !important;
	margin-left: 1rem;
}

.recruit_section {
	margin: 10px 20px 45px;
}
.recruit_box {
	display: flex;
}
.recruit_title {
	width: 120px;
}
#recruit_section_space {
	height: 250px;
}

@media screen and (min-width:600px) {
	header #logo_company {
		width: 150px;
		padding: 30px 20px;
	}
	.list {
		display: flex;
		justify-content: space-between;
	}

	.list figure {
		width: 45%;
		margin-right: 2em;
	}

	.list .text {
		flex: 1;
		margin-right: 0;
	}

	.menu_store div{
		font-size: 1em;
	}
}

@media screen and (min-width:900px) {
	html, body {
		font-size: 15px;
	}
	header {
		position: fixed;
		width: 100%;
	}
	header #logo_company {
		width: 150px;
		padding: 40px 20px;
	}
	#store dt {
		width: 14em;
		display: flex;
		justify-content: space-between;
	}
	#store dt span {
		display: inline-block;
		width: 6em;
		background: #999;
		color: #fff;
		font-size: 0.8em;
		text-align: center;
		margin-right: 1em;
		align-self: flex-start;
		line-height: 1.8;
		position: relative;top: 0.4em;
	}

	#store dd {
		width: calc(100% - 14em);
	}

	.list-container {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.list figure {
		width: 50%;
		margin-right: 2em;
	}
	.list .text {
		margin-right: 0;
	}
	.list h3 {
		margin: 10px 0;
	}


	.ws {width: 48%;display: inline;}

	#contact_div{
		display:flex;
	}
	#contact .fields {
		width: 50%;
	}
	#pp_chk{
		margin: 2px 10px 0 2rem;
	}

}

@keyframes animation1 {
	0% {left: -200px;}
	100% {left: 0px;}
}


@keyframes opa1 {
	0% {opacity: 0;}
	100% {opacity: 1;}
}

