@charset "utf-8";

/*----------------------------------*/
/*------------- common -------------*/
/*----------------------------------*/
.relative {
	position: relative;
}

.absolute {
	position: absolute;
}

.top_slider img {
	width: 100%;
}

.kizuna_contents section {
	box-sizing: border-box;
	margin-bottom: 80px;
}

.kizuna_contents section.store2 {
	margin-bottom: 140px;
}

.font_s {
	line-height: 1.3;
}

.store__staff .font_s, .store__staff-post--ja .font_s {
	font-size: 18px;
}

.show_640 {
	display: none !important;
}
@media only screen and (max-width: 640px) {
	.show_640 {
		display: inline-block !important;
	}

	.hide_640 {
		display: none !important;
	}
}

.flex {
	display: flex;
	justify-content: space-between;
}

.store__access-text a i {
	color: #FF3333;
}

/*----------------------------------*/
/*----------- AdobeFonts -----------*/
/*----------------------------------*/
.tsukushiR {
	font-family: 'Zen Maru Gothic', sans-serif;
	font-weight: 400;
	font-style: normal;
	letter-spacing: normal;
}

.tsukushiB {
	font-family: 'Zen Maru Gothic', sans-serif;
	font-weight: 700;
	font-style: normal;
	letter-spacing: normal;
}

.ryomin {
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-style: normal;
}


/*----------------------------------*/
/*-------------- body --------------*/
/*----------------------------------*/
body {
	font-feature-settings: "palt";
	letter-spacing: 0.5px;
}

img {
	width: 100%;
	display: block;
	vertical-align: bottom;
}
.footer_area img{
	width:auto;
	vertical-align:auto;
}

.greenback {
	background: url('../img/p3/bg9.gif');
	padding-bottom: 50px;
	margin-bottom: 60px;
	overflow: hidden;
}

.caption {
	font-size: 11px;
	margin-top: 1em;
	line-height: 1.6;
}

.caption span {
	background: linear-gradient(transparent 0px, #fff 0%);
	display: inline;
	padding: 0 2px;
}

.slick-slide .cap{
	position: absolute;
	bottom: 0.2em;
    left: 1em;
    color: #fff;
    text-shadow: 1px 1px 3px BLACK, 0 0 2px BLACK;
    font-size: .88rem;
}

.atc {
	font-size: 11px;
	text-align: left;
	background: #fff;
	line-height: 1.5;
	padding: 5px 10px;
	border: 1px solid #005952;
	color: #005952;
	width: 100%;
	max-width: 550px;
	margin: 20px auto 0 auto;
}

ruby[data-ruby]{
	position: relative;
}
ruby[data-ruby]::before{
	content: attr(data-ruby);
	position: absolute;
    line-height: 100%;
    text-align: center;
    left: -3em;
    right: -3em;
    transform-origin: bottom center;
    transform: scale(0.4);
    bottom: 80%;
}
ruby[data-ruby] rt{
	display: none;
}

#lead {
	margin: 0 auto;
	padding: 20px 0 80px;
	text-align: center;
	width: 85%;
	max-width: 720px;
	font-size: 1.5rem;
}

#lead img {
	display: block;
	margin: 0 auto 20px;
}

.color_text {
	color: #248a66;
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 25px;
	line-height: 1.2;
}

/********メインイメージ*********/
.slick-slide {
	margin: 0;
}
.mainimage {
	position: relative;
	width: 100%;
	margin: 0 auto;
	text-align: center;
	background: url('../img/p3/bg9.gif');
}

.mainimage img {
	display: inline-block;
	width: 100%;
	max-width: 1600px;
}


/********ページング*********/
#pageing {
	text-align: center;
	margin: 40px 0 0;
}

#pageing .wrapper {
	text-align: center;
}

#pageing .pageing a,
#pageing .pageing span {
	width: 36px;
	height: 36px;
	border: 1px solid #005952;
	color: #005952;
	line-height: 36px;
	text-align: center;
	font-size: 16px;
	display: inline-block;
	margin: 0 3px;
	box-sizing: border-box;
	cursor: pointer;
	font-weight: bold;
}

#pageing .pageing span.nowpage {
	background: #005952;
	color: #fff;
	cursor: auto;
}

#pageing .pageing span.hide {
	opacity: 0.5;
	cursor: auto;
}

/********店舗情報*********/
.icondetail li {
	padding-left: 1.6em;
	position: relative;
	font-size: 0.9em;
	padding-bottom: 0.3em;
	line-height: 1.5;
}

.icondetail a i {
	color: #FF3333;
}

.icondetail li.icon1green::before,
.icondetail li.icon2green::before,
.icondetail li.icon3green::before,
.icondetail li.icon4green::before,
.icondetail li.icon1orange::before,
.icondetail li.icon2orange::before,
.icondetail li.icon3orange::before,
.icondetail li.icon4orange::before,
.icondetail li.icon5green::before,
.icondetail li.icon5orange::before,
.icondetail li.icon6green::before,
.icondetail li.icon6orange::before {
	content: '';
	position: absolute;
	top: 0.1em;
	left: 0;
	width: 1.3em;
	height: 1.3em;
}

.icondetail li.icon1green::before {
	background: url(../img/p3/icon1.gif)no-repeat center center;
	background-size: contain;
}

.icondetail li.icon2green::before {
	background: url(../img/p3/icon2.gif)no-repeat center center;
	background-size: contain;
}

.icondetail li.icon3green::before {
	background: url(../img/p3/icon3.gif)no-repeat center center;
	background-size: contain;
}

.icondetail li.icon4green::before {
	background: url(../img/p3/icon4.gif)no-repeat center center;
	background-size: contain;
}

.icondetail li.icon5green::before {
	background: url(../img/p3/icon5.gif)no-repeat center center;
	background-size: contain;
}

.icondetail li.icon6green::before {
	background: url(../img/p3/icon6.gif)no-repeat center center;
	background-size: contain;
}

.st_name {
	font-weight: bold;
	line-height: 1.4;
	margin-bottom: 0.5em;
	font-size: 1.1em;
}

.store {
	background: #fff;
	position: relative;
	width: 100%;
	padding: 50px 30px 30px;
	border-radius: 15px;
}

.store__title {
	position: absolute;
	left: -20px;
	width: auto;
	top: -40px;
	max-height: 75px;
}

.store__title2 {
	position: absolute;
	left: -20px;
	width: auto;
	top: -50px;
	max-height: 105px;
}

.roundimg {
	border-radius: 10px;
}

/*----------------------------------*/
/*---------- slider 番号付き -----------*/
/*----------------------------------*/
.slider_num .slick-dots{
	bottom: -35px;
}
.slider_num .slick-dots li{
	width: 20px;
    height: 20px;
    margin: 0 4px;
    padding: 0;
    cursor: pointer;
    border: 1px solid #025851;
}
.slider_num .slick-dots li.slick-active{
	background: #87caac;
}
.slider_num .slick-dots li button{
	font-size:initial;
    background:initial;
	width: 100%;
	height: 100%;
	color: #025851;
}
.slider_num .slick-dots li button:before{
    content:none;
}
@media only screen and (max-width: 768px) {
	#block1,#block2,#block3,#block4 {
		margin-bottom: 100px;
	}
	#section2 .lead {
		margin-bottom: 100px;
	}
}


@media only screen and (max-width: 860px) {
	.storetitle {
		left: -10px;
	}
}

@media only screen and (max-width: 768px) {
	.pagelogo {
		top: 10px;
		right: 10px;
		width: 32%;
	}
}

@media only screen and (max-width: 640px) {
	#lead {
		padding: 20px 0 70px;
		width: 100%;
		font-size: 14px;
	}

	#lead img {
		width: 80%;
	}

	.greenback {
		padding-bottom: 40px;
		margin-bottom: 40px;
	}
}

@media only screen and (max-width: 540px) {
	.storetitle {
		width: 100%;
		top: -30px;
	}

	.color_text {
		font-size: 18px;
	}
}

@media only screen and (max-width: 480px) {
	.stores {
		padding: 40px 20px 20px;
	}

	#lead img {
		width: 100%;
	}

	#lead {
		padding: 20px 0 50px;
		font-size: 14px;
		text-align: left;
	}

	.stores {
		padding: 30px 20px 20px;
	}

	.googlelink {
		text-decoration: underline;
	}

	.googlelink i {
		display: inline-block;
		color: #EA4335;
	}

	.hbabsolute {
		width: 50%;
		right: -30px;
		top: -20px;
	}

	.hbtitle {
		width: 90%;
	}
}




/*----------------------------------------*/
/*------------- 各コンテンツ -------------*/
/*----------------------------------------*/

.store__box {
	display: flex;
}

.store__head {
	color: #248a66;
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 1em;
}

.store__text {
	background: #efefef;
	padding: 15px 20px;
	border-radius: 10px;
	font-size: 15px;
	line-height: 1.8;
	position: relative;
}

.store__staff {
	font-family: 'Zen Maru Gothic', sans-serif;
	font-weight: bold;
	line-height: 1.5;
}

.store__text::after {
	content: '';
	position: absolute;
	width: 0;
	height: 0;
	border-style: solid;
}

.store1 .corner__left::after {
    top: 50%;
    right: 99%;
    transform: scale(-1, 1);
    border-width: 20px 30px 0px 0px;
	border-color: #efefef transparent transparent transparent;
}
.store2 .corner__left::after {
    top: 50%;
    left: 99%;
    transform: scale(-1, 1);
	border-width: 20px 0px 20px 30px;
	border-color: #efefef transparent transparent transparent;
}

.corner__right::after {
	top: 50%;
	right: 99%;
	transform: scale(-1, 1);
	border-width: 20px 25px 0 0;
	border-color: #efefef transparent transparent transparent;
}

.store__staff-post {
	font-size: 12px;
    width: fit-content;
    margin: 0.5em 0 0 0;
}
.ownerimg{
	border-radius: 10px;
}

.store__ippin {
	position: absolute;
	max-width: 200px;
	min-width: 100px;
}

.store__img-icon {
	font-size: 20px;
	padding-right: 5px;
	vertical-align: bottom;
}

.store__access-wrapper {
	display: flex;
	align-items: flex-start;
	gap: 10px 20px;
}
.store__access-img{
	width: 250px;
}

.store__access-icon {
	margin-right: 7px;
	vertical-align: middle;
}

.store__access-text {
	font-size: 12px;
	white-space: nowrap;
	margin-bottom: 4px;
	display: flex;
	align-items: flex-start;
	word-break: break-all;
}

.store__access-text span {
	display: block;
}

.store__access-text a {
	text-decoration: underline;
}

.store__access-text img {
	width: 18px;
	display: inline-block;
}

.store__head {
	margin-right: 24px;
	line-height: 1.4;
}

.store__message {
	display: flex;
}

.store__card {
	font-family: 'Zen Maru Gothic', sans-serif;
	font-weight: bold;
}

.store__card img {
	margin-bottom: 8px;
}

.store__staff-post .sage {
	display: block;
}

/*----------------------------------------*/
/*---------------- store1 ----------------*/
/*----------------------------------------*/

.store1 .store__box {
	justify-content: space-between;
}

.store__text-wrapper {
	position: relative;
}

/*--box-1--*/
.store1 .box-1{
	gap: 10px 30px;
	flex-wrap: wrap;
	margin-bottom: 40px;
}

.store1 .box-1 .store__staff {
	width: 250px;
}

.store1 .box-1 .comment {
	width: calc(100% - 280px);
	max-width: 600px;
	margin-right: auto;
}

.store__card-wrapper .store__staff-post--ja {
	white-space: nowrap;
}

.store__staff-post--attribute{
	display: inline-block;
}

.store__staff-post--state{
	display: block;
	margin-top: 10px;
}

.store__staff-post--state .sep{
	display: inline-block;
}

.store__staff-post--kana {
	margin-top: 8px;
	display: block;
}

.store__staff-post--ja {
	display: block;
	font-size: 24px;
	line-height: 1;
	margin-top: 12px;
}

.store__coupon{
	margin-bottom: 30px;
}

.store__coupon img{
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}

.space {
	padding-left: 20px;
}
.space_s {
	padding-left: 10px;
}
.space_l {
	padding-left: 30px;
}

/*--box-2--*/
.store1 .box-2{
	justify-content: space-between;
    align-items: flex-end; 
    margin-left: auto;
    /* margin-top: clamp(-80px,-5vw,-60px); */
}

.store1 .box-2 .f-item:first-of-type {
	width: 55%;
    order: 2;
}

.store1 .box-2 .f-item:last-of-type {
	width: 43%;
    order: 1;
}

.store1 .store__mainimg{
	display: block;
	margin: 0 auto;
	width: 100%;
	max-width: 280px;
}

/*--box-3--*/
.store1 .box-3{
    gap: 10px 30px;
	margin-bottom: 40px;
}

/*--box-4--*/
.store1 .box-4{
	margin-bottom: 20px;
	gap: 10px 30px;
}
.store1 .box-4 .store__staff{
	width: 200px;
}
.store1 .box-4 .comment{
	width: calc(100% - 250px);
}

/*--box-5--*/
.store1 .box-5{
	width: calc(100% - 0px);
    margin-top: -17%;
    justify-content: flex-end;
}

/*--box-6--*/
.store1 .box-6{
	width: 70%;
	margin: auto;
	text-align: center;
	max-width: 700px;
	margin-top: 2rem;
}


/*----------------------------------------*/
/*---------------- store2 ----------------*/
/*----------------------------------------*/

/*--box-1--*/
.store2 .box-1 {
    gap: 10px 30px;
	flex-wrap: wrap;
}
.store2 .box-1 .store__staff {
    width: 250px;
}
.store2 .box-1 .comment {
    width: calc(100% - 280px);
	max-width: 600px;
    margin-right: auto;
}

/*--box-2--*/
.store2 .box-2{
	margin-top: 20px;
    margin-left: auto;
	align-items: flex-end;
	margin-bottom: calc(4% + 10px);
	position: relative;
	gap: 10px 30px;
}
.store2 .box-2 .f-item{
	text-align: left;
}
.store2 .box-2 .f-item:first-of-type{
	width: 60%;
	margin-right: 0%;
}
.store2 .box-2 .f-item:last-of-type{
	width: 40%;
    margin-bottom: 4%;
}
.store2 .box-2 .f-item{
	position: relative;
}
.store2 .box-2 .f-item .ab{
	position: absolute;
	left: 25%;
	bottom: 0;
}
.store2 .store__ippin {
    z-index: 10;
    left: 10%;
    width: 32%;
    top: 0;
}

/*--box-2_5--*/
.store2 .box-2_5 {
    margin-bottom: 40px;
    gap: 10px 30px;
	margin-top: 30px;
}

.store2 .box-2_5 .f-item{
	width: calc(50% - 15px);
}

/*--box-3--*/
.store2 .box-3 {
    margin-bottom: 20px;
    gap: 10px 30px;
}
.store2 .box-3 .store__staff{
	width: 230px;
}
.store2 .box-3 .store__staff img{
	width: 80%;
}
.store2 .box-3 .comment {
    width: calc(100% - 150px);
	padding-top: 2%;
}

/*--box-4--*/
.store2 .box-4{
	width: calc(100% - 190px);
	margin-top: -10%;
}

.caption .lump{
	display: inline-block;
}

.store2 .box-5{
	width: 70%;
	margin: auto;
	text-align: center;
	max-width: 700px;
	margin-top: 2rem;
}

@media only screen and (max-width: 980px) {
	.store__access-text {
		white-space: normal;
	}
	.store__message-wrapper .store__text {
		font-size: 13px;
	}
	.store1 .box-2{
		margin-top: 10px;
	}
	/*--box-5--*/
	.store1 .box-5{
		margin-top: 0%;
	}
	/*--box-4--*/
	.store2 .box-4{
		margin-top: -14%;
	}
	.store1 .box-5{
		justify-content: flex-start;
	}
}
@media only screen and (max-width: 840px) {
	.store {
		padding-top: 40px;
	}
	.store__text-wrapper {
		width: 100%;
	}
	.store__text {
		font-size: 13px;
	}

	.store__access-img{
		width: 180px;
	}
	/*--box-5--*/
}

@media only screen and (max-width: 768px) {
	.store__head {
		margin-bottom: 0.5em;
	}
	.store1 .box-6,
	.store2 .box-5{
		width: 100%;
	}
	.store2 .box-4{
		width: 100%;
		margin-top: 0%;
	}
}

@media only screen and (max-width: 640px) {
	.store__access-wrapper {
		flex-direction: row;
		justify-content: flex-start;
		width: 100%;
		margin-left: 0;
	}
	.store__bottom {
		align-items: flex-start;
	}
	.store__card {
		width: 100%;
		display: flex;
		align-items: center;
		margin-top: 20px;
		margin-right: 0;
	}
	.corner__right::after{
		right: 60%;
		top: 99%;
		transform: none;
	}
	.branch {
		display: block;
	}
    .store1 .box-5 {
        margin-top: 7%;
		width: 100%;
    }
	.store1 .box-5 .store__access-wrapper {
        flex-direction:row;
    }


	.store1 .box-2,
	.store1 .box-3,
	.store1 .box-4,
	.store2 .box-2,
	.store2 .box-2_5,
	.store2 .box-3{
		flex-wrap: wrap;
		gap: 10px;
	}
	.store1 .box-1 .comment,
	.store2 .box-1 .comment,
	.store1 .box-4 .comment,
	.store2 .box-3 .comment{
		width: 100%;
		order: 1;
	}
	.store1 .box-1 .store__staff,
	.store2 .box-1 .store__staff,
	.store1 .box-4 .store__staff,
	.store2 .box-3 .store__staff{
		width: 100%;
		display: flex;
		align-items: center;
		order: 2;
	}
	.store1 .box-1 .store__staff,
	.store2 .box-1 .store__staff{
		gap: 10px;
	}
	.store1 .box-4 .store__staff,
	.store2 .box-3 .store__staff{
		gap: 20px;
	}
	.store1 .box-1 .store__staff img,
	.store2 .box-1 .store__staff img{
		width: 43%;
	}
	.store1 .box-4 .store__staff img,
	.store2 .box-3 .store__staff img{
		width: 28%;
	}
	.store1 .box-2 .f-item:first-of-type{
		order: 1;
		width: 100%;
	}
	.store1 .box-2 .f-item:last-of-type{
		order: 2;
		width: 80%;
		margin-left: auto;
	}
	.store1 .box-3{
		margin-top: 15%;
		margin-bottom: 20px;
		justify-content: flex-end;
	}
	.store1 .box-3 .f-item {
		text-align: left;
	}
	.store1 .box-3 .f-item:first-of-type{
		width: 100%;
		margin-right: 0;
		margin-top: -10%;
	}
	.store1 .box-3-5{
		flex-wrap: wrap;
		gap: 20px;
	}
	.store1 .corner__left::after {
		top: 100%;
		right: auto;
		left: 32%;
		border-width: 20px 0px 0px 20px;
	}
	.store1 .box-3 .f-item:last-of-type {
		width: 100%;
		margin-bottom: 0;
		margin-left: auto;
		margin-top: 5%;
	}
	.store1 .box-3 .f-item:last-of-type .caption{
		text-align: center;
	}
	.store2 .box-3 .store__staff{
		flex-direction: row-reverse;
	}

	.store2 .box-2{
		/* margin-top: 20px; */
		gap: 20px;
	}
	.store2 .box-2 .f-item:first-of-type,
	.store2 .box-2 .f-item:nth-of-type(2),
	.store2 .box-2_5 .f-item{
		width: 100%;
	}
	.store2 .box-2_5 .f-item:first-of-type{
		margin-bottom: 15px;
	}
	.store2 .box-2 .store__ippin{
		top: 5%;
		left: 3%;
	}
	.store2 .corner__left::after{
		top: 100%;
		left: auto;
		right: 34%;
		border-width: 20px 20px 0 0;
	}
	.store2 .box-6{
		width: 100%;
	}
	.store2 .box-2 .f-item .ab{
		position: initial;
		text-align: center;
	}
}

@media only screen and (max-width: 540px) {
	/*--box-2_5--*/
	.store2 .box-2_5 {
		gap: 10px;
		flex-wrap: wrap;
	}
	.store {
		padding: 40px 15px 20px;
	}
	.store__title {
		top: -29px;
		max-height: 60px;
	}
}

@media only screen and (max-width: 480px) {
	.store__access-wrapper {
		width: 100%;
		flex-direction: column!important;
		margin-right: auto;
		margin-left: auto;
	}
	.store__access-img,
	.store__access{
		width: 100%;
	}
	.store2 .box-2_5{
		padding-top: 3%;
	}
	.store1 .store__ippin {
		width: 30%;
		top: -5%;
		left: 0;
	}
}