@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700;900&display=swap');

/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
}

html {
	font-size: 62.5%;
}

body,
table,
input,
textarea,
select,
option {
	font-family: 'Noto Serif JP', serif;
}

article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary {
	display: block;
}

ol,
ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

:focus {
	outline: 0;
}

ins {
	text-decoration: none;
}

del {
	text-decoration: line-through;
}

img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
}

a,
a:link {
	color: #111;
	text-decoration: none;
}

a:visited {
	color: #111;
}

a:hover {
	color: #111;
}

a:active {
	color: #111;
}

/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	min-width: 1280px;
	color: #111;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.71;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #eaebe1;
}

#container {
	position: relative;
	text-align: left;
	overflow: hidden;
}

#main {
	display: block;
}

a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}

@media all and (min-width: 897px) {
	.sp {
		display: none !important;
	}
}

@media all and (max-width: 896px) {
	body {
		min-width: inherit;
		font-size: 1.3rem;
	}

	a:hover,
	a:hover img {
		opacity: 1 !important;
	}

	.pc {
		display: none !important;
	}

	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}
}

/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#g-header {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 20;
}

#g-header .h-box {
	padding: 30px 55px;
	display: flex;
	justify-content: space-between;
}

#g-navi ul {
	display: flex;
	justify-content: space-between;
}

#g-navi li:not(:last-of-type) {
	margin-right: 20px;
}

#g-navi li a {
	font-size: 1.6rem;
	font-feature-settings: "palt";
	-moz-font-feature-settings: "palt";
}

#g-navi li a:hover {
	opacity: 0.7;
}

#g-navi li:not(:last-of-type) a {
	padding-right: 12px;
}

@media all and (max-width: 896px) {
	#g-header {
		position: static;
	}

	#g-header .h-box {
		padding: 45px 32px 39px;
		display: block;
	}

	#g-navi {
		display: none;
	}

	.menu {
		position: absolute;
		right: 3px;
		width: 55px;
		height: 55px;
	}

	.menu span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
		position: absolute;
		right: 12px;
		width: 31px;
		height: 2px;
		background-color: #000;
	}

	.menu span:nth-of-type(1) {
		top: 19px;
	}

	.menu span:nth-of-type(2) {
		top: 27px;
	}

	.menu span:nth-of-type(3) {
		top: 35px;
	}

	.menu.on span:nth-of-type(1) {
		-webkit-transform: translateY(8px) rotate(-45deg);
		transform: translateY(8px) rotate(-45deg);
	}

	.menu.on span:nth-of-type(2) {
		opacity: 0;
	}

	.menu.on span:nth-of-type(3) {
		-webkit-transform: translateY(-8px) rotate(45deg);
		transform: translateY(-8px) rotate(45deg);
	}

	.menu-box {
		padding: 24px 31px 80px;
		width: 100%;
		height: 100%;
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		background: #958626;
		overflow: auto;
		box-sizing: border-box;
		z-index: 51;
	}

	.menu-box .close {
		position: absolute;
		top: 31px;
		right: 30px;
	}

	.menu-box .logo {
		margin-bottom: 31px;
	}

	.menu-box .tab-list {
		margin-bottom: 85px;
		display: flex;
		justify-content: space-between;
	}

	.menu-box .tab-list li {
		width: 46.94%;
	}

	.menu-box .tab-list li a {
		padding: 12px 0;
		display: flex;
		align-items: center;
		justify-content: center;
		color: #FFF;
		font-size: 1.3rem;
		font-weight: 500;
		border: 1px solid #FFF;
		border-radius: 100px;
	}

	.menu-box .tab-list li.on a {
		padding: 10px 0;
		color: #958626;
		font-size: 1.5rem;
		background-color: #FFF;
	}

	.menu-box .link-list {
		margin: 0 30px;
		height: 200px;
		display: flex;
		justify-content: flex-end;
	}

	.menu-box .link-list>li {
		display: flex;
	}

	.menu-box .link-list>li>a {
		display: block;
		height: 200px;
		width: 38px;
		color: #FFF;
		font-size: 1.5rem;
		line-height: 2.4;
		letter-spacing: 0.05em;
		writing-mode: tb-rl;
		-webkit-writing-mode: vertical-rl;
		direction: ltr;
		text-align: left;
	}

	.menu-box .sub-list {
		margin-right: -8px;
		display: flex;
	}

	.menu-box .sub-list li a {
		padding-top: 21px;
		position: relative;
		width: 36px;
		display: block;
		height: 100%;
		color: #FFF;
		font-size: 1.5rem;
		line-height: 2.4;
		letter-spacing: 0.05em;
		writing-mode: tb-rl;
		-webkit-writing-mode: vertical-rl;
		direction: ltr;
		text-align: left;
		box-sizing: border-box;
	}

	.menu-box .link-list li a {
		position: relative;
	}

	.menu-box .link-list li a::after {
		width: 10px;
		height: 10px;
		position: absolute;
		top: -30px;
		left: calc(50% - 5px);
		background: url("../img/icon06.png") no-repeat center top / 10px;
		content: '';
	}

	.menu-box .sub-list li a::after {
		width: 10px;
		height: 10px;
		position: absolute;
		top: -9px;
		left: calc(50% - 5px);
		background: url("../img/icon06.png") no-repeat center top / 10px;
		content: '';
	}

	.menu-box .link-ul {
		margin-bottom: 17px;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		border-top: 1px solid #c8c6b7;
	}

	.menu-box .link-ul li {
		width: 50%;
	}

	.menu-box .link-ul li a {
		padding: 21px 0 26px 22px;
		display: flex;
		align-items: center;
		color: #FFF;
		font-size: 1.3rem;
		letter-spacing: 0.05em;
		border-bottom: 1px solid #c8c6b7;
	}

	.menu-box .link-ul li a img {
		margin-right: 10px;
	}

	.menu-box .link-ul li:nth-of-type(2n-1) a {
		border-right: 1px solid #c8c6b7;
	}

	.menu-box .link {
		margin-bottom: 17px;
	}

	.menu-box .link a {
		color: #FFF;
		display: flex;
		align-items: center;
		text-decoration: underline;
	}

	.menu-box .link a img {
		margin-left: 5px;
	}

	.menu-box .sns-list {
		display: flex;
	}

	.menu-box .sns-list li:not(:last-of-type) {
		margin-right: 22px;
	}

	.menu-box .sns-list li a {
		display: flex;
		align-items: center;
		color: #FFF;
		font-size: 1.1rem;
		font-weight: 500;
		letter-spacing: 0.05em;
	}

	.menu-box .sns-list li a img {
		margin-right: 16px;
	}

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

	.menu-box .tab-box01 {
		display: none;
	}

	.menu-box .link-list_w {
		margin: 0 15px;
	}
}

@media all and (max-width: 410px) {

	/* フォトウェディング */
	.menu-box .link-ul li a.twolines {
		padding: 12px 0 13px 22px
	}
}

@media all and (max-width: 374px) {
	.menu-box .link-list {
		margin: 0 auto;
	}

	.menu-box .link-ul {
		margin: 0 auto 17px;
		max-width: 320px;
	}

	.menu-box .link-ul li a {
		padding: 20px 0 20px 10px;
	}


}

/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#g-footer .f-navi {
	padding: 34px 0 24px;
	background-color: #fff;
	box-sizing: border-box;
}

#g-footer .f-inner {
	margin: 0 auto;
	padding: 0 25px;
	max-width: 1060px;
	box-sizing: border-box;
}

#g-footer .f-navi .link-list {
	display: flex;
	justify-content: space-between;
}

#g-footer .f-navi .link-list .title {
	margin-bottom: 10px;
}

#g-footer .f-navi .link-list .title p {
	margin-bottom: 5px;
	padding: 0 0 10px 15px;
	border-bottom: 1px solid #eaebe1;
}

#g-footer .f-navi .link-list>li {
	margin-right: 20px;
	width: 26%;
}

#g-footer .f-navi .link-list>li:last-of-type {
	margin-right: 0;
}

#g-footer .f-navi .sub-list li {
	margin-bottom: 5px;
}

#g-footer .f-navi .sub-list li:last-of-type {
	margin-bottom: 0;
}

#g-footer .f-navi .sub-list li a {
	padding-left: 1em;
	text-indent: -1em;
	font-size: 1.3rem;
	letter-spacing: 0.05em;
}

#g-footer .f-navi .sub-list li a:hover {
	opacity: 0.7;
}

#g-footer .f-sns-box {
	margin: 0 auto;
	padding: 38px 0 49px;
	max-width: 1100px;
	display: flex;
	flex-direction: row-reverse;
	align-items: flex-end;
	justify-content: space-between;
}

#g-footer .f-sns-box address {
	font-style: normal;
	font-size: 1rem;
	letter-spacing: 0.05em;
}

#g-footer .f-sns-box li {
	margin-bottom: 8px;
}

#g-footer .f-sns-box li:last-of-type {
	margin-bottom: 0;
}

#g-footer .f-sns-box li a {
	display: block;
	font-size: 1.2rem;
	letter-spacing: 0.05em;
}

#g-footer .f-sns-box li a span {
	padding-left: 25px;
	display: inline-block;
	vertical-align: top;
}

#g-footer .f-sns-box li a:hover {
	opacity: 0.7;
}

#g-footer .f-sns-box li .ins span {
	background: url("../img/icon05.png") no-repeat left center / 14px auto;
}

#g-footer .f-sns-box li .face span {
	background: url("../img/icon04.png") no-repeat left center / 14px auto;
}

#g-footer a.toTop {
	display: none;
	right: 55px;
	bottom: 20px;
	position: fixed;
	z-index: 30;
}

@media all and (max-width: 896px) {
	#g-footer .f-navi {
		padding: 0;
		background-color: #FFF;
		box-sizing: border-box;
	}

	#g-footer .f-inner {
		margin: 0 auto;
		padding: 0;
		max-width: inherit;
	}

	#g-footer .f-navi .link-list {
		display: block;
	}

	#g-footer .f-navi .link-list .title {
		margin-bottom: 0;
		border-bottom: 1px solid #eaebe1;
	}

	#g-footer .f-navi .link-list .title p {
		margin-bottom: 0;
		padding: 24px 30px 23px;
		border: 0;
		background: url("../img/icon14.png") no-repeat right 30px center;
	}

	#g-footer .f-navi .link-list .title p.on {
		background: url("../img/icon15.png") no-repeat right 30px center;
	}

	#g-footer .f-navi .link-list>li {
		width: 100%;
	}

	#g-footer .f-navi .link-list>li a {
		padding: 25px 0;
		display: block;
	}

	#g-footer .f-navi .link-list>li:last-of-type {
		margin-right: 0;
	}

	#g-footer .f-navi .sub-list {
		margin-top: -15px;
		padding-bottom: 20px;
		display: none;
	}

	#g-footer .f-navi .sub-list li {
		margin-bottom: 0;
	}

	#g-footer .f-navi .sub-list li a {
		padding: 8px 30px;
		text-indent: 0;
		font-size: 1.3rem;
		letter-spacing: 0;
	}

	#g-footer .f-sns-box {
		margin: 0 auto;
		padding: 27px 0 30px;
		max-width: inherit;
		display: block;
	}

	#g-footer .f-sns-box address {
		text-align: center;
	}

	#g-footer .f-sns-box ul {
		margin: 0 auto 37px;
		width: 100px;
	}

	#g-footer .f-sns-box li {
		margin-bottom: 10px;
	}

	#g-footer .f-sns-box li:last-of-type {
		margin-bottom: 0;
	}

	#g-footer .f-sns-box li a {
		font-size: 1.1rem;
		letter-spacing: 0.1em;
	}

	#g-footer a.toTop {
		right: 10px;
		bottom: 10px;
		width: 55px;
		height: 55px;
	}
}

/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* clearfix */
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}

/* flex */
.flex,
.flexA,
.flexB,
.flexC {
	display: flex;
	flex-wrap: wrap;
}

.flexA {
	justify-content: space-around;
}

.flexB {
	justify-content: space-between;
}

.flexC {
	justify-content: center;
}

.att {
	color: #c03c3f;
}

.alignC {
	text-align: center;
}

/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
	margin: 0 auto;
	max-width: 1100px;
}

@media all and (max-width: 896px) {
	.content {
		margin: 0 30px;
	}
}

/*------------------------------------------------------------
	page-title
------------------------------------------------------------*/
.page-title-wrap {
	display: flex;
	justify-content: flex-end;
	position: relative;
	z-index: 0;
	background-color: #fff;
}

.page-title-wrap::before {
	content: '';
	width: 85%;
	height: 91px;
	background: #a5b3a1;
	position: absolute;
	z-index: -10;
	top: 0;
	right: 0;
}

.page-title-wrap::after {
	content: '';
	background: url(../img/bg01n.jpg) no-repeat 0 0;
	background-size: 100%;
	position: absolute;
	width: 15%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: -10;
}

.page-title {
	display: flex;
	padding-top: 90px;
	width: 92.2%;
}

.page-title .photo {
	width: calc(100% - 192px);
	overflow: hidden;
}

.page-title .photo img {
	width: 100%;
}

.page-title .text {
	height: 100%;
	width: 192px;
	background-color: #ffffff;
	position: relative;
}

.page-title .text .sub {
	position: absolute;
	top: 110px;
	left: 30px;
	z-index: 10;
	-webkit-writing-mode: vertical-rl;
	direction: ltr;
	writing-mode: tb-rl;
	font-size: 6.5rem;
	letter-spacing: 15px;
}

.page-title .text-sml .sub {
	/* top: 50px; */
	font-size: 4.4rem;
}

.page-title .text .sub h2{
	line-height: 1.3;
	margin-left: 10px;
}


.page-title .text .sub .en {
	-webkit-writing-mode: vertical-rl;
	direction: ltr;
	font-size: 1.7rem;
	letter-spacing: 3px;
	padding-top: 5px;
}

.page-title .text .sub .sml {
	font-size:0.8em;
	margin: 1rem;
}

@media all and (max-width: 1400px){
	.page-title .text-sml .sub {
		top: 50px;
	}
}


@media all and (max-width: 896px) {

	.page-title-sp{
		padding-top: 80px;
	}

	.page-title-sp img{
		width: 100%;
	}

	.page-title-sp .sub{
		-webkit-writing-mode: vertical-rl;
		direction: ltr;
		writing-mode: tb-rl;
		font-size: 4.5rem;
		letter-spacing: 15px;
		line-height: 1.2;
		margin:70px auto 70px;
		width: 70px;
	}

	.page-title-sp .sub .sml{
		font-size: 3rem;
		text-align: center;
		display: block;
		letter-spacing: 0.3em;
	}

	.page-title-sp .sub .en {
		-webkit-writing-mode: vertical-rl;
		direction: ltr;
		font-size: 1.4rem;
		letter-spacing: 3px;
		padding-top: 5px;
	}

	.page-title-sp span.txt{
		margin: 15px;
		display: block;
		font-size: 1.7rem;
		font-weight: 500;
		letter-spacing: 0.05em;
	}
}

/*------------------------------------------------------------
	comTextBox
------------------------------------------------------------*/
.comTextBox {
	margin: 0 auto;
	text-align: left;
	writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	direction: ltr;
}

.comTextBox p {
	margin-left: 20px;
	font-size: 2.4rem;
}

.comTextBox ul {
	margin-top: 18px;
}

.comTextBox li {
	margin: 0 23px 0 3px;
	padding-top: 18px;
	font-size: 1.8rem;
	background: url("../../img/icon01.png") no-repeat left 50% top / 9px auto;
}

@media all and (max-width: 896px) {}

/*------------------------------------------------------------
	head-line01 
------------------------------------------------------------*/
.head-line01 {
	margin-bottom: 19px;
	position: relative;
	font-size: 6rem;
	letter-spacing: 0.2em;
	font-weight: 500;
	text-align: center;
	line-height: 1.33;
	box-sizing: border-box;
	z-index: 10;
}

.head-line01::before {
	width: 100%;
	height: 160px;
	position: absolute;
	left: 0;
	top: 50%;
	margin-top: -95px;
	background: url(../img/h2_bgn.png) no-repeat center center;
	content: "";
	z-index: -10;
}

.head-line01 span {
	-webkit-writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

@media all and (max-width: 896px) {
	.head-line01 {
		margin-bottom: 33px;
		font-size: 3.1rem;
	}

	.head-line01::before {
		height: 94px;
		margin-top: -54px;
		background-image: url(../img/sp_bgn.png);
	}
}

/*------------------------------------------------------------
	com-shop-box
------------------------------------------------------------*/
.com-shop-box {
	position: relative;
}

.com-shop-box .shop-inner:not(:last-child) {
	margin-bottom: 116px;
}

.com-shop-box .pho-box {
	width: 566px;
	margin-left: 22px;
	position: relative;
}

.com-shop-box .pho-box .name {
	display: inline-block;
	position: absolute;
	left: 0;
	top: 0;
	min-width: 264px;
	padding: 8px 5px 9px 15px;
	color: #FFF;
	font-size: 2.2rem;
	letter-spacing: 0.1em;
	font-weight: 700;
	line-height: 1.4;
	box-sizing: border-box;
	background-color: #958626;
}

.com-shop-box .pho-box .name .sml {
	display: block;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: 0.1em;
}

.com-shop-box .txt-box {
	position: relative;
	margin-left: -40px;
	width: 535px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	box-sizing: border-box;
}

.com-shop-box .txt-box .sub-box {
	width: 100%;
	padding: 41px 48px 45px;
	background-color: #FFF;
	box-sizing: border-box;
}

.com-shop-box .txt-box p {
	min-height: 72px;
	margin-bottom: 28px;
	letter-spacing: 0.05em;
}

.com-shop-box .txt-box table {
	max-width: 390px;
	margin-bottom: 40px;
	width: 100%;
	border-collapse: collapse;
}

.com-shop-box .txt-box td,
.com-shop-box .txt-box th {
	padding: 14px 0 10px 14px;
	vertical-align: middle;
	text-align: left;
	word-break: break-all;
	box-sizing: border-box;
	line-height: 1.5;
	border-bottom: 1px solid #e1ded8;
}

.com-shop-box .txt-box td {
	letter-spacing: 0.1em;
}

.com-shop-box .txt-box td .tel {
	display: block;
	margin: -22px 0 -5px;
	font-size: 3.2rem;
	letter-spacing: 0.1em;
}

.com-shop-box .txt-box th {
	padding: 14px 23px 10px 0;
	width: 24.5%;
	text-align: right;
	font-weight: 500;
	border-color: #FFF;
}

@media all and (max-width: 896px) {
	.com-shop-box .shop-inner {
		display: block;
	}

	.com-shop-box .shop-inner:not(:last-child) {
		margin-bottom: 40px;
	}

	.com-shop-box .pho-box {
		width: auto;
		margin: 0 0 -20px;
		z-index: 1;
	}

	.com-shop-box .pho-box img {
		width: 100%;
	}

	.com-shop-box .pho-box .name {
		min-width: 196px;
		padding: 13px 10px 14px;
		font-size: 1.7rem;
	}

	.com-shop-box .pho-box .name .sml {
		display: none;
		font-size: 1.2rem;
	}

	.com-shop-box .txt-box {
		margin: 0 -30px;
		width: auto;
		display: block;
	}

	.com-shop-box .txt-box .sub-box {
		padding: 42px 30px 40px;
	}

	.com-shop-box .txt-box p {
		min-height: 65px;
		margin-bottom: 21px;
	}

	.com-shop-box .txt-box table {
		max-width: inherit;
		margin-bottom: 30px;
	}

	.com-shop-box .txt-box td,
	.com-shop-box .txt-box th {
		padding-bottom: 11px;
		font-size: 1.3rem;
	}

	.com-shop-box .txt-box td .tel {
		margin: -17px 0 -5px;
		font-size: 2.9rem;
	}

	.com-shop-box .txt-box th {
		width: 75px;
	}
}

@media all and (max-width: 374px) {
	.com-shop-box .txt-box td .tel {
		margin-top: -7px;
		font-size: 2rem;
	}

	.com-shop-box .txt-box td,
	.com-shop-box .txt-box th {
		font-size: 1rem;
	}

	.com-shop-box .txt-box td,
	.com-shop-box .txt-box th {
		padding-left: 5px;
	}
}

.com-shop-box h3.head-line02 {
	font-size: 5rem;
	text-align: center;
	margin-bottom: 1rem;
	font-weight: 500;
}

.com-shop-box .name span.sub {
	font-size: 1.8rem;
	letter-spacing: 0;
}

/*------------------------------------------------------------
	com-link
------------------------------------------------------------*/
.com-link a {
	margin: 0 auto;
	padding: 13px 5px 11px;
	width: 240px;
	display: block;
	color: #FFF;
	text-align: center;
	border-radius: 30px;
	box-sizing: border-box;
	background-color: #c03c3f;
}

.com-link a:hover {
	opacity: 0.7;
}

@media all and (-ms-high-contrast:none) {
	.com-link a {
		padding: 10px 5px 14px;
	}
}

@media all and (max-width: 896px) {
	.com-link a {
		font-size: 1.4rem;
	}
}

/*------------------------------------------------------------
	com-text-box
------------------------------------------------------------*/
.com-text-box {
	margin: 0 auto;
	/* width: 260px; */
	height: 320px;
	writing-mode: horizontal-tb;
	writing-mode: vertical-rl;
	writing-mode: tb-rl;
	-webkit-writing-mode: horizontal-tb;
	-webkit-writing-mode: vertical-rl;
	-webkit-writing-mode: tb-rl;
	text-align: left;
}

.com-text-box p {
	margin-left: 15px;
	font-size: 2.4rem;
}

.com-text-box ul {
	margin-top: 18px;
}

.com-text-box li {
	padding-top: 18px;
	font-size: 1.8rem;
	line-height: 3.22;
	letter-spacing: 0.05em;
	background: url("../img/icon01.png") no-repeat right 10px top / 9px auto;
	background-position: center top;
}

@media all and (max-width: 896px) {
	.com-text-box {
		padding: 0 30px;
		width: auto;
		height: auto;
		writing-mode: lr-tb;
		-webkit-writing-mode: horizontal-tb;
		box-sizing: border-box;
	}

	.com-text-box p {
		margin: 0 0 5px 0;
		font-size: 1.7rem;
	}

	.com-text-box ul {
		margin-top: 0;
	}

	.com-text-box li {
		margin: 0 0 14px;
		padding: 0 0 0 46px;
		font-size: 1.51rem;
		line-height: 1.5;
		background-position: left 23px top 6px;
	}

	.com-text-box li:last-of-type {
		margin-bottom: 0;
	}
}

/*------------------------------------------------------------
	shop 店舗紹介 (shop.css)
------------------------------------------------------------*/
.shop_page #main .shop {
	padding: 80px 25px 50px;
}

.shop_page #main .top-sec .content {
	padding: 0 25px;
	position: relative;
	display: flex;
	align-items: center;
}

.shop_page #main .top-sec h2 {
	position: absolute;
	right: 15px;
	top: 0;
	font-size: 2.8rem;
	letter-spacing: 0.05em;
	writing-mode: horizontal-tb;
	writing-mode: vertical-rl;
	writing-mode: tb-rl;
	-webkit-writing-mode: horizontal-tb;
	-webkit-writing-mode: vertical-rl;
	-webkit-writing-mode: tb-rl;
}

.shop_page #main .com-text-box li {
	background-position: center top;
}

.shop_page #main .shop {
	padding: 80px 25px 50px;
	background-color: #eaebe1;
}

.shop_page #main .content {
	padding: 0 25px;
}

.shop_page #main .inner {
	display: flex;
	align-items: center;
}


/* 店舗情報  お休み情報*/

.shop .holiday{
	color:#c03c3f;
	text-indent: -1.4rem;
	display: block;
	font-weight: bold;
}

.shop .holiday li{
	text-indent: -1.4rem;
    padding-left: 1rem;
    display: inline-block;
}

@media all and (max-width: 896px) {
	.shop_page .page-title {
		margin-bottom: -9%;
	}

	.shop_page #main .top-sec {
		margin-bottom: 0;
		padding-bottom: 26px;
	}

	.shop_page #main .top-sec .content {
		margin: 0;
		padding: 0;
		position: relative;
		display: block;
	}

	.shop_page #main .top-sec h2 {
		writing-mode: horizontal-tb;
		-webkit-writing-mode: horizontal-tb;
		-moz-writing-mode: horizontal-tb;
		-ms-writing-mode: lr-tb;
	}

	.shop_page #main .com-text-box li {
		background-position: left 23px top 6px;
	}

	.shop_page #main .content {
		margin: 0;
		padding: 0;
	}

	.shop_page #main .shop {
		padding: 31px 0;
	}

	.shop_page #main .inner {
		display: block;
	}

	/* リンク先修正 */
	#main #shop_amelia,
	#main #shop_haradamachi,
	#main #shop_mandm,
	#main #shop_yakushi {
		display: block;
		position: relative;
		top: -100px;
		visibility: hidden;
	}
}

/*------------------------------------------------------------
	com-img-box
------------------------------------------------------------*/
.com-img-box {
	margin: 0 4px 60px 0;
	display: flex;
}

.com-img-box .photo-box {
	width: 579px;
	position: relative;
	z-index: 1;
}

.com-img-box .photo-box .photo {
	position: relative;
	z-index: 1;
}

.com-img-box .photo-box .photo p {
	padding: 13px 0 9px 14px;
	width: 264px;
	position: absolute;
	top: 0;
	left: 0;
	font-size: 2.3rem;
	letter-spacing: 0.01em;
	line-height: 1;
	color: #fff;
	background-color: #958626;
	box-sizing: border-box;
}

.com-img-box .photo-box p span {
	display: block;
	font-size: 1.4rem;
	letter-spacing: 0.025em;
	line-height: 1.7;
}

.com-img-box .text-box {
	margin: 28px 0 0 -25px;
	padding: 26px 80px 34px 67px;
	width: 560px;
	position: relative;
	background-color: #fff;
	z-index: 2;
	box-sizing: border-box;
}

.com-img-box .text-box table {
	width: 100%;
	border-collapse: collapse;
}

.com-img-box .text-box th,
.com-img-box .text-box td {
	padding: 17px 18px 18px 0;
	width: 19.5%;
	text-align: right;
	font-weight: inherit;
	vertical-align: middle;
	word-break: break-all;
	box-sizing: border-box;
}

.com-img-box .text-box td {
	padding: 8px 0 7px 18px;
	width: 80.5%;
	text-align: left;
	border-bottom: 1px solid #eaebe1;
}

.com-img-box .text-box tr:last-of-type td {
	padding-bottom: 0;
	border-bottom: none;
}

.com-img-box .text-box td .tel a {
	font-size: 3.7rem;
	line-height: 0.64;
}

.com-img-box .text-box td .com-btn {
	padding: 2px 0 3px;
}

.com-img-box .text-box td .add {
	padding: 4px 0 0;
	font-size: 1.4rem;
	line-height: 1.71;
	box-sizing: border-box;
}

.com-img-box .text-box td .com-btn.style01 {
	padding-top: 18px;
}

@media all and (max-width: 896px) {
	.com-img-box {
		margin: 0 0 32px 0;
		display: block;
	}

	.com-img-box .photo-box {
		padding: 0 30px;
		width: auto;
		text-align: center;
		z-index: 2;
	}

	.com-img-box .photo-box .photo p {
		padding: 10px 0 10px 9px;
		width: 187px;
		text-align: left;
		font-size: 1.8rem;
	}

	.com-img-box .photo-box .photo img {
		width: 100%;
	}

	.com-img-box .text-box {
		margin: -20px 0 0;
		padding: 45px 30px 30px 20px;
		width: auto;
		z-index: 1;
	}

	.com-img-box .text-box th,
	.com-img-box .text-box td {
		padding: 18px 20px 18px 0;
		width: 25.6%;
		font-size: 1.4rem;
		line-height: 1.7;
		letter-spacing: 0.025em;
	}

	.com-img-box .text-box td {
		padding: 3px 0 5px 15px;
		width: 74.4%;
	}

	.com-img-box .text-box td .tel a {
		margin-right: -10px;
		font-size: 3.6rem;
	}

	.com-img-box .text-box td .add {
		margin-right: -5px;
		min-height: 52px;
		display: flex;
		align-items: center;
	}

	.com-img-box01 {
		margin-bottom: 25px !important;
	}

	.com-img-box .text-box td .com-btn {
		padding: 2px 0 3px;
		position: relative;
		left: calc(50% - 121px);
	}
}

@media all and (max-width: 374px) {
	.com-img-box .text-box td .tel a {
		font-size: 3rem;
	}

	.com-img-box .text-box th,
	.com-img-box .text-box td {
		padding: 18px 14px 8px 0;
		width: 25.6%;
		font-size: 1.2rem;
	}

	.com-img-box .text-box td .add {
		font-size: 1.4rem;
	}

	.com-img-box .photo-box .photo p {
		font-size: 1.6rem;
	}

	.com-img-box .text-box td .com-btn {
		left: calc(50% - 90px);
	}
}

/*------------------------------------------------------------
	com-btn
------------------------------------------------------------*/
.com-btn,
.com-btn.style01 {
	margin-left: -14px;
	width: 240px;
	box-sizing: border-box;
}

.com-btn a,
.com-btn.style01 a {
	padding: 11px;
	display: block;
	text-align: center;
	color: #fff;
	letter-spacing: 0.025em;
	border-radius: 24px;
	box-sizing: border-box;
	background-color: #c03c3f;
}

.com-btn a:hover,
.com-btn.style01 a:hover {
	opacity: 0.7;
}

.com-btn.style01 a {
	color: #958626;
	letter-spacing: normal;
	border: 1px solid #958626;
	background-color: inherit;
}

.com-btn a.disable,
.com-link a.disable {
	opacity: 0.5;
	pointer-events: none;
}

@media all and (max-width: 896px) {

	.com-btn,
	.com-btn.style01 {
		margin-left: -50px;
		width: 242px;
	}

	.com-btn a,
	.com-btn.style01 a {
		padding: 12px;
	}
}

/*------------------------------------------------------------
	com-img-area
------------------------------------------------------------*/
.com-img-area {
	padding: 113px 0 140px;
}

.com-img-area .img-box {
	margin: 0 auto 116px;
	width: 1000px;
	height:300px;
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
	background-color: #fff;
}

.com-img-area .img-box .photo-box {
	padding-right: 14px;
	width: 50%;
	text-align: right;
	box-sizing: border-box;
}

.com-img-area .img-box .photo-box .sub {
	margin-top: -38px;
}

.com-img-area .img-box .text-box {
	padding: 40px 0 50px;
	width: 50%;
	text-align: center;
}

.com-img-area .img-box .text-box h2 {
	margin-bottom: 30px;
	color: #c03c3f;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}

.com-img-area .img-box .text-box p {
	margin-bottom: 37px;
	font-size: 1.6rem;
	line-height: 1.8;
	letter-spacing: 0.05em;
}

.com-img-area .head-line01 {
	margin-bottom: 2px;
	position: relative;
	z-index: 1;
	left: 50%;
	transform: translateX(-50%);
}

.com-img-area .com-shop-box {
	position: relative;
}

.com-img-area .com-shop-box::after {
	width: calc(50% + 430px);
	height: calc(100% + 132px);
	position: absolute;
	top: -80px;
	right: 0;
	background-color: #cbcead;
	content: '';
}

.com-img-area .com-shop-box>div {
	position: relative;
	z-index: 1;
}

.com-img-area .com-shop-box table {
	max-width: 460px;
}

.com-img-area .com-shop-box .txt-box td,
.com-img-area .com-shop-box .txt-box th {
	padding: 14px 0 14px 14px;
}

.com-img-area .com-shop-box .txt-box td .tel {
	margin: -12px 0 -9px;
}

.com-shop-box .txt-box .sub-box {
	padding: 20px 48px 40px;
}

.com-img-area .com-shop-box .txt-box th {
	padding: 14px 14px 14px 0;
}

@media all and (max-width: 896px) {
	.com-img-area {
		padding: 61px 0 21px;
	}

	.com-img-area .img-box {
		margin: 0 15px 128px;
		width: auto;
		height:auto;
		display: block;
	}

	.com-img-area .img-box .photo-box {
		padding: 0 30px;
		width: auto;
		text-align: right;
		box-sizing: border-box;
		transform: translateY(35px);
	}

	.com-img-area .img-box .photo-box .sub {
		margin-top: 0;
	}

	.com-img-area .img-box .photo-box .sub img {
		width: 100%;
	}

	.com-img-area .img-box .text-box {
		padding: 28px 10px 8px;
		width: auto;
	}

	.com-img-area .img-box .text-box h2 {
		margin-bottom: 21px;
		font-size: 1.5rem;
		letter-spacing: 0.2em;
	}

	.com-img-area .img-box .text-box p {
		margin-bottom: 23px;
		font-size: 1.3rem;
		line-height: 1.7;
		letter-spacing: 0.2em;
	}

	.com-img-area .com-shop-box::after {
		width: calc(50% + 430px);
		height: calc(100% + 120px);
		position: absolute;
		top: -120px;
		right: 0;
		background-color: #cbcead;
		content: '';
	}

	.com-img-area .com-shop-box table {
		max-width: inherit;
	}

	.com-img-area .com-shop-box .txt-box td,
	.com-img-area .com-shop-box .txt-box th {
		padding: 14px 0 14px 14px;
		vertical-align: middle;
	}

	.com-img-area .com-shop-box .txt-box td .tel {
		/* margin: -12px 0 -9px; */
	}

	.com-shop-box .txt-box .sub-box {
		padding: 20px 30px 31px;
	}

	.com-img-area .com-shop-box .txt-box th {
		padding: 14px 10px 14px 0;
	}

	.com-shop-box h3.head-line02{
		font-size: 2.9rem;
		margin-bottom: 3rem;
	}
}

/*------------------------------------------------------------
	商品ラインナップ_共通
------------------------------------------------------------*/
#main .sec_product .item_group {
	position: relative;
	font-size: 2.8rem;
	letter-spacing: 0.05em;
	margin-bottom: 1em;
	border-left: 1px solid #333333;
	padding-left: 1em
}

#main .sec_product {
	padding-bottom: 111px;
	background-color: #FFF;
}

#main .sec_product .img-box {
	display: flex;
	justify-content: space-between;
}

#main .sec_product .img-box .photo-box {
	width: 490px;
}

#main .sec_product .img-box .text-box {
	width: calc(100% - 490px);
	display: flex;
	align-items: center;
}

#main .sec_product .img-box .text-box .sub {
	margin-left: -31px;
	padding: 23px 34px;
	min-height: 291px;
	background-color: #cbcead;
	box-sizing: border-box;
	position: relative;
	z-index: 1;
}

#main .sec_product .img-box .text-box h3 {
	margin-bottom: -5px;
	margin-right: -20px;
	font-size: 2.6rem;
	letter-spacing: 0.05em;
	text-align: left;
}

#main .sec_product .img-box .text-box .price {
	margin-bottom: 9px;
}

#main .sec_product .img-box .text-box .price span {
	font-size: 2.8rem;
	font-weight: 700;
	vertical-align: -2px;
}

#main .sec_product .img-box .text-box p {
	font-size: 1.6rem;
	line-height: 1.75;
	letter-spacing: 0.05em;
	color: #333333;
}

#main .sec_product .img-box01 {
	margin: 50px 0;
	flex-direction: row-reverse;
}

#main .sec_product .img-box01 .text-box .sub {
	margin: 0 -31px 0 0;
}

#main .sec_product .img-box .h3-ttl {
	margin-bottom: -15px !important;
}

#main .sec_product .img-box .notes {
	margin: -13px 0 7px;
}

#main .sec_product .img-area {
	margin-top: 101px;
	padding: 31px 0 40px;
	position: relative;
	background-color: #FFF;
}

#main .sec_product .img-area::after {
	width: calc(50% + 550px);
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	background-color: #cbcead;
	content: '';
}

#main .sec_product .img-area .content {
	padding: 0 61px;
	box-sizing: border-box;
}

#main .sec_product .img-area .h2-ttl {
	margin-bottom: 34px;
	width: auto;
	height: auto;
	position: relative;
	z-index: 1;
	left: 0;
	font-size: 2.6rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: center;
	transform: translateY(0);
}

#main .sec_product .img-area .img-inner {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: space-between;
	margin-top: 39px;
}

#main .sec_product .img-area .img-inner .photo-box {
	width: 490px;
}

#main .sec_product .img-area .img-inner .text-box {
	width: calc(100% - 490px);
	display: flex;
	align-items: center;
	position: relative;
	z-index: 1;
}

#main .sec_product .img-area .img-inner .text-box .sub {
	margin: 0 0 0 -31px;
	padding: 0 40px;
	width: calc(100% + 31px);
	height: 261px;
	display: flex;
	justify-content: center;
	flex-direction: column;
	background-color: #FFF;
	box-sizing: border-box;
}

#main .sec_product .img-area .img-inner .text-box h3 {
	margin-bottom: 16px;
	font-size: 2.6rem;
	letter-spacing: 0.05em;
}

#main .sec_product .img-area .img-inner .text-box p {
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.05em;
}

#main .sec_product .img-area .img-inner01 {
	/* margin-top: 39px; */
	flex-direction: row-reverse;
}

#main .sec_product .img-area .img-inner01 .sub {
	margin: 0 -31px 0 0 !important;
}

#main .sec_product .title .small{
	font-size: 0.8em;
	font-weight: normal;
}

@media all and (max-width: 896px) {
	#main .sec_product {
		padding-bottom: 0;
	}

	#main .sec_product .img-box {
		display: block;
	}

	#main .sec_product .img-box .photo-box {
		width: auto;
		position: relative;
		z-index: 2;
	}

	#main .sec_product .img-box .photo-box img {
		width: 100%;
	}

	#main .sec_product .img-box .text-box {
		width: auto;
		display: block;
	}

	#main .sec_product .img-box .text-box .sub {
		margin: -32px -30px 0;
		padding: 44px 30px 28px;
		min-height: inherit;
	}

	#main .sec_product .img-box .text-box h3 {
		margin-bottom: 3px;
		margin-right: -20px;
		font-size: 1.7rem;
	}

	#main .sec_product .img-box .text-box .price {
		margin-bottom: 5px;
	}

	#main .sec_product .img-box .text-box .price span {
		font-size: 1.8rem;
	}

	#main .sec_product .img-box .text-box p {
		font-size: 1.2rem;
		line-height: 1.75;
	}

	#main .sec_product .img-box01 {
		margin: 38px 0;
	}

	#main .sec_product .img-box01 .text-box .sub {
		margin: -32px -30px 0;
	}

	#main .sec_product .img-box .h3-ttl {
		margin-bottom: 4px !important;
	}

	#main .sec_product .img-box .notes {
		margin: -6px 0 7px;
	}

	#main .sec_product .img-area {
		margin-top: 60px;
		padding: 41px 0 43px;
		position: relative;
		background-color: #FFF;
	}

	#main .sec_product .img-area::after {
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		right: 0;
		background-color: #cbcead;
		content: '';
	}

	#main .sec_product .img-area .content {
		margin: 0 15px;
		padding: 0;
	}

	#main .sec_product .img-area .h2-ttl {
		margin-bottom: 22px;
		font-size: 1.7rem;
		left: 0;
		writing-mode: lr-tb;
		-webkit-writing-mode: horizontal-tb;
		line-height: 1;
	}

	#main .sec_product .img-area .img-inner {
		padding: 32px 15px;
		display: block;
		background-color: #FFF;
	}

	#main .sec_product .img-area .img-inner .photo-box {
		margin-bottom: 12px;
		width: auto;
	}

	#main .sec_product .img-area .img-inner .photo-box img {
		width: 100%;
	}

	#main .sec_product .img-area .img-inner .text-box {
		width: auto;
		display: block;
	}

	#main .sec_product .img-area .img-inner .text-box .sub {
		margin: 0;
		padding: 0;
		width: auto;
		height: auto;
		display: block;
	}

	#main .sec_product .img-area .img-inner .text-box h3 {
		margin-bottom: 9px;
		font-size: 1.7rem;
	}

	#main .sec_product .img-area .img-inner .text-box p {
		font-size: 1.3rem;
		line-height: 1.7;
	}

	#main .sec_product .img-area .img-inner01 {
		margin-top: 30px;
	}

	#main .sec_product .img-area .img-inner01 .sub {
		margin: 0 !important;
	}
}

/*------------------------------------------------------------
	common
------------------------------------------------------------*/
@media all and (max-width: 896px) {}


/* ----------
20220328追加 
-----------*/
/* common */
.mt10 {
	margin-top: 10px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mt30 {
	margin-top: 30px !important;
}

.mt50 {
	margin-top: 50px !important;
}

.mt90 {
	margin-top: 90px !important;
}

.mt100 {
	margin-top: 100px !important
}

.mt-100 {
	margin-top: 100px;
}

.pb30 {
	padding-bottom: 30px !important
}

.pb50 {
	padding-bottom: 50px !important
}

span.tate {
	text-combine-upright: all;
}

.h240 {
	height: 240px !important;
}

.ls-1 {
	letter-spacing: -1px;
}

.ml0 {
	margin-left: 0px !important;
}

@media all and (min-width: 897px) {
	.fspc-16 {
		font-size: 1.6rem;
	}
}

@media all and (max-width: 896px) {
	.fssp-11 {
		font-size: 1.1rem;
	}
}
/*------------------------------------------------------------
	リスト黒丸
------------------------------------------------------------*/
#main .b-dot li::before {
	content: ' ';
	margin-right: 1em;
	background-color: #333333;
	border-radius: 50%;
	height: 5px;
	width: 5px;
}

/*------------------------------------------------------------
	衣裳ギャラリー系
------------------------------------------------------------*/
.sec_gallery .note01 {
	text-align: right;
	margin-bottom: 10px;
}

.sec_gallery .note01 span {
	background-color: #958626;
	color: #fff;
	padding: 2px 4px;
	margin-right: 5px;
}

#main .sec_gallery .imgList {
	margin-top: -30px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: 40px;
}

#main .sec_gallery .imgList li {
	margin-top: 30px;
	width: 24%;
	position: relative;
}

.sec_gallery ul.imgList .new-icon img {
	position: absolute;
	top: 5px;
	left: 5px;
	display: inline-block;
	width: 48px;
	margin: 0;
	padding: 0;
	border: none;
}

.sec_gallery span.no-icon {
	position: absolute;
	right: 2%;
	bottom: 2%;
	display: inline-block;
	width: 20px;
	height: 20px;
	background-color: #958626;
	color: #fff;
	text-align: center;
	line-height: 20px;
	font-family: 'Meiryo', 'メイリオ', 'Hiragino Gothic Pro', 'ヒラギノ丸ゴ Pro', 'MS PGothic', 'MS Pゴシック', sans-serif;
}

.sec_gallery span.store-icon {
	position: absolute;
	right: 3%;
	bottom: 3%;
	display: inline-block;
	width: 20px;
	height: 20px;
	background-color: #958626;
	color: #fff;
	text-align: center;
	line-height: 20px;
}

.sec_gallery span.store-icon_2 {
	right: 12%;
}

.sec_gallery span.icon_box {
	position: absolute;
	bottom: 2%;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	display: inline-block;
	width: 50px;
	background-color: #FFF;
	color: #000;
	text-align: center;
	letter-spacing: 3px;
}

@media all and (max-width: 896px) {
	#main .sec_gallery .imgList {
		margin: -20px 30px 0;
	}

	#main .sec_gallery .imgList li {
		margin-top: 20px;
		width: 47.5%;
		width: 49%;
	}

	#main .sec_gallery .imgList li img {
		width: 100%;
	}

	#main .sec_gallery .note {
		margin: 0 30px;
	}

	#main .sec_gallery ul.imgList .new-icon img {
		width: 48px;
	}

	.sec_gallery span.no-icon,
	.sec_gallery span.no-icon2 {
		font-size: 13px;
		/* bottom: 10%; */
	}

	.sec_gallery span.store-icon_2 {
		right: 18%;
	}

	.sec_gallery .note01 {
		text-align: left;
	}

	.sec_gallery span.icon_box {
		font-size: 12px;
		line-height: 1.3;
	}
}

/*------------------------------------------------------------
	商品の特徴
------------------------------------------------------------*/
#main section.bg_W {
	background-color: #fff;
}

#main .sec_product .imgList {
	margin-top: -52px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	position: relative;
	z-index: 1;
}

#main .sec_product .imgList li {
	margin-top: 52px;
	width: 520px;
}

#main .sec_product .imgList li .photo-box {
	margin-bottom: 18px;
	position: relative;
}

#main .sec_product .imgList li .photo-box::after {
	width: 1px;
	height: 69px;
	position: absolute;
	bottom: -50px;
	left: 20px;
	background-color: #958626;
	content: '';
}

#main .sec_product .imgList li .title {
	margin-bottom: 13px;
	color: #333333;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.32;
	letter-spacing: 0.05em;
}

#main .sec_product .imgList li p {
	padding-left: 36px;
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.05em;
}

#main .sec_product .sub-list {
	margin: -37px 0 0 31px;
	display: flex;
	justify-content: space-between;
}

#main .sec_product .sub-list li {
	margin-bottom: 12px;
	width: 224px;
}

#main .sec_product .sub-list li span {
	margin-top: 6px;
	display: block;
	font-size: 1.6rem;
	line-height: 1.75;
}

@media all and (max-width: 896px) {
	#main .sec_product .sub-list {
		margin: 27px 30px 0 0;
		display: flex;
		justify-content: space-between;
	}

	#main .sec_product .imgList .sub-list li {
		margin-bottom: 7px !important;
		width: 47.6%;
	}

	#main .sec_product .sub-list li img {
		width: 100%;
	}

	#main .sec_product .sub-list li span {
		margin-top: 8px;
		font-size: 1.3rem;
		line-height: 1.54;
	}
}

/* トップページ内メニュー */
#main .top-sec {
	padding: 5% 0 78px;
	background-color: #fff;
}

#main .top-sec .content {
	padding: 0 25px;
	position: relative;
	display: flex;
	align-items: center;
}

#main .top-sec h2 {
	position: absolute;
	right: 15px;
	top: 0;
	font-size: 2.8rem;
	letter-spacing: 0.05em;
	writing-mode: horizontal-tb;
	writing-mode: vertical-rl;
	writing-mode: tb-rl;
	-webkit-writing-mode: horizontal-tb;
	-webkit-writing-mode: vertical-rl;
	-webkit-writing-mode: tb-rl;
}

@media all and (max-width: 896px) {

	#main .top-sec {
		padding:45px 0
	}

	#main .top-sec .content {
		margin: 0;
		padding: 0;
		position: relative;
		display: block;
	}

	#main .top-sec h2 {
		writing-mode: horizontal-tb;
		-webkit-writing-mode: horizontal-tb;
		-moz-writing-mode: horizontal-tb;
		-ms-writing-mode: lr-tb;
	}
}

/* SP時のヘッダー固定 */
@media (max-width: 896px) {

	/* SP表示時ヘッダー固定 */
	#g-header .h-box {
		position: fixed;
		padding: 25px 32px;
	}

	#g-header {
		position: fixed;
		background-color: #a5b3a1;
		height:80px
		/* transition: 0.5s; */
	}

	/* ハンバーガーメニュ－ */
	.menu {
		position: fixed;
		top: 10px;
		z-index: 30;
	}

	/* スクロールして「scroll-navクラス」がついたときのヘッダーデザイン */
	#g-header.scroll-nav {
		background-color: rgba(255, 255, 255, 0.9);
		background-color: #a5b3a1;
		box-shadow: 0 2px 4px rgb(0 0 0 / 30%);
		padding-bottom: 0px;
		z-index: 20;
	}
}

/* 家族写真メニュー２行 */
@media (max-width: 896px) {
	.menu-box .link-list .line_w a {
		line-height: 1.8;
		width: 40px;
		padding-right: 5px;
	}
}

/* サービス内店舗紹介ボタン追加 */
.shop .com-link-wrap {
	display: flex;
	justify-content: space-around;
}

.shop .com-link-wrap .com-link {
	width: 45%
}

.shop .com-link-wrap .com-link a {
	width: 100%
}

/* 店舗とお問い合わせ修正 */
.shop .dog-box .com-link-wrap {
	justify-content: left;
}

.shop .dog-box .com-link-wrap .com-link {
	width: 240px;
}

.shop .dog-box .com-btn.style01 {
	margin-left: 0
}

@media (max-width:399px) {
	.shop .dog-box .com-link-wrap .com-link {
		width: 100%;
	}
}

/* shop_info.phpをインクルード */
.com-img-area .show-common {
	display: block
}

.com-img-area .show-baby {
	display: none
}

.com-img-area .show-753 {
	display: none
}

.page-baby .com-img-area .show-common {
	display: none
}

.page-baby .com-img-area .show-baby {
	display: block
}

.page-753 .com-img-area .show-753 {
	display: table-row
}

/* 店舗情報マップコード */
.com-img-box .text-box td.mapc,
.com-img-area .com-shop-box .txt-box td.mapc{
	display:flex;
	align-items: center;
	width:100%!important;
}

.com-img-box .text-box td.mapc span:first-child,
.com-img-area .com-shop-box .txt-box td.mapc span:first-child{
	margin-right: 30px;
}

.shop_page .com-img-box .text-box th{
	width:25%;
}

.shop_page .com-img-box .text-box td{
	width:75%;
}

/* ----------
新規デザイン 共通パーツ
------------- */

/* おすすめ */

#main .sec_recommend .img-box {
	display: flex;
	justify-content: space-between;
}

#main .sec_recommend .img-box .text-box {
	padding-bottom: 72px;
	width: 50%;
	position: relative;
}

#main .sec_recommend .img-box .text-box::after {
	width: calc(100% + 204px);
	height: calc(100% + 200px);
	position: absolute;
	top: -163px;
	left: 0;
	background-color: #FFF;
	content: '';
}

#main .sec_recommend .img-box .text-box .sub {
	margin: 0 0 0 auto;
	width: 550px;
	position: relative;
	z-index: 1;
}

#main .sec_recommend .img-box .text-box .sub:not(:last-of-type) {
	margin-bottom: 58px;
}

#main .sec_recommend .img-box .text-box .sub .ttl {
	display: flex;
	align-items: center;
}

#main .sec_recommend .img-box .text-box .sub .ttl .title {
	font-size: 2rem;
	line-height: 1.4;
	font-weight: 700;
	letter-spacing: 0.05em;
}

#main .sec_recommend .img-box .text-box .sub .ttl .title span {
	color: #c03c3f;
}

#main .sec_recommend .img-box .text-box .sub .text {
	margin: 9px 0 0 auto;
	width: calc(100% - 120px);
	font-size: 1.6rem;
	line-height: 1.75;
	box-sizing: border-box;
}

#main .sec_recommend .img-box .text-box .sub .text ul {
	margin-top: -17px;
}

#main .sec_recommend .img-box .text-box .sub .text li {
	padding-left: 25px;
	position: relative;
	font-size: 1.4rem;
	line-height: 2.1;
}

#main .sec_recommend .img-box .text-box .sub .text li span {
	color: #c03c3f;
}

#main .sec_recommend .img-box .text-box .sub .text li::after {
	width: 6px;
	height: 6px;
	position: absolute;
	top: calc(50% - 3px);
	left: 9px;
	background-color: #958626;
	border-radius: 50%;
	content: '';
}

#main .sec_recommend .img-box .text-box .sub .text .btn {
	margin: 20px 0 0 26px;
}

#main .sec_recommend .img-box .text-box .sub .text .btn a {
	padding-bottom: 4px;
	position: relative;
	color: #333333;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	border-bottom: 1px solid #333;
}

#main .sec_recommend .img-box .text-box .sub .text .btn a::after {
	width: 4px;
	height: 8px;
	position: absolute;
	top: calc(50% - 4px);
	left: -17px;
	background: url("../img/icon16.png") no-repeat left center;
	content: '';
}

#main .sec_recommend .img-box .photo-box {
	padding: 104px 0 100px;
	width: 50%;
	position: relative;
}

#main .sec_recommend .img-box .photo-box::after {
	width: calc(100% - 20px);
	height: 100%;
	position: absolute;
	top: 24px;
	right: 0;
	background: url("../img/bg02.jpg") no-repeat right top;
	content: '';
}

#main .sec_recommend .img-box .photo-box ul {
	position: relative;
	z-index: 1;
}

#main .sec_recommend .img-box .photo-box li:not(:last-of-type) {
	margin-bottom: 40px;
}

#main .sec_recommend .img-box .text-box .sub .ttl .num_wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 80px;
	margin-right: 27px;
    width: 80px;
    background: url(../img/ttl_bgn.png) no-repeat center/ 80px;
  }

  #main .sec_recommend .img-box .text-box .sub .ttl .num {
    display: flex;
    align-items: center;
    justify-content: center;
	font-weight: 700;
    font-size: 18px; 
	color: #c03c3f;
    height: 100%;
    margin: 0;
	padding-bottom: 2px;
  }

  @media all and (min-width: 897px) {
	#main .sec_recommend .img-box .photo-box ul{
		max-width: 550px;
	}
  }

  @media all and (max-width: 896px) {	
	
	#main .sec_recommend .img-box {
	display: block;
	}

	#main .sec_recommend .img-box .text-box {
		padding-bottom: 54px;
		width: auto;
	}

	#main .sec_recommend .img-box .text-box::after {
		width: 100%;
		height: calc(100% + 96px);
		position: absolute;
		top: -96px;
		left: 0;
		background-color: #FFF;
		content: '';
	}

	#main .sec_recommend .img-box .text-box .sub {
		margin: 0 25px;
		width: auto;
	}

	#main .sec_recommend .img-box .text-box .sub:not(:last-of-type) {
		margin-bottom: 32px;
	}

	#main .sec_recommend .img-box .text-box .sub .ttl .num_wrap {
		margin-right: 15px;
		width: 50px;
		height: 50px;
		background: url("../img/ttl_bgn.png") no-repeat center / 50px;
	}

	#main .sec_recommend .img-box .text-box .sub .ttl .num {
		width: 100%;
		height:100%;
		font-size: 1.08rem;
		padding:0;
	}

	#main .sec_recommend .img-box .text-box .sub .ttl .title {
		width: calc(100% - 62px);
		font-size: 1.7rem;
		line-height: 1.4;
	}

	#main .sec_recommend .img-box .text-box .sub .text {
		margin: 15px 0 0 auto;
		width: auto;
		font-size: 1.3rem;
		line-height: 1.75;
	}

	#main .sec_recommend .img-box .text-box .sub .text ul {
		margin-top: 0px;
	}

	#main .sec_recommend .img-box .text-box .sub .text li {
		font-size: 1.3rem;
		line-height: 1.7;
	}

	#main .sec_recommend .img-box .text-box .sub .text li:not(:last-of-type) {
		margin-bottom: 16px;
	}

	#main .sec_recommend .img-box .text-box .sub .text li::after {
		width: 6px;
		height: 6px;
		position: absolute;
		top: calc(50% - 3px);
		left: 9px;
		background-color: #958626;
		border-radius: 50%;
		content: '';
	}

	#main .sec_recommend .img-box .text-box .sub .text .btn {
		margin: 12px 0 0 26px;
	}

	#main .sec_recommend .img-box .text-box .sub .text .btn a {
		padding-bottom: 4px;
		font-size: 1.3rem;
	}

	#main .sec_recommend .img-box .photo-box {
		padding: 0 0 68px;
		width: auto;
		background-color: #FFF;
	}

	#main .sec_recommend .img-box .photo-box::after {
		width: auto;
		height: 90.6%;
		top: 23px;
		right: 30px;
		left: 30px;
		background: #71714b;
	}

	#main .sec_recommend .img-box .photo-box ul {
		margin: 0 50px;
	}

	#main .sec_recommend .img-box .photo-box li:not(:last-of-type) {
		margin-bottom: 20px;
	}

	#main .sec_recommend .img-box .photo-box li img {
		width: 100%;
	}
  }

/* h2.h3 左赤ライン */

#main h3.bdr_left .line::after,
#main h2.bdr_left .line::after {
	width: 2px;
	height: 90px;
	position: absolute;
	top: -25px;
	left: -10px;
	background-color: #c03c3f;
	content: '';
}

#main h3.bdr_left .line::before,
#main h2.bdr_left .line::before {
	content: '';
	position: absolute;
	top: -25px;
	font-size: 1.8rem;
	color: #b9ad92;
}
#main h3.bdr_left,
#main h2.bdr_left {
	margin-bottom: 50px;
	padding-right: 24px;
	color: #937a4b;
	font-size: 3.6rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: right;
}

#main h2.bdr_left .line,
#main h3.bdr_left .line {
	position: relative;
}

#main h2.bdr_left .line::before,
#main h3.bdr_left .line::before
 {
	content: 'price';
}

#main h2.bdr_left .line span,
#main h3.bdr_left .line span {
	position: relative;
	z-index: 1;
}

#main h2.bdr_left .line .cor,
#main h3.bdr_left .line .cor {
	color: #111111;
}

@media (max-width: 896px) {
	#main h3.bdr_left .line::after,
	#main h2.bdr_left .line::after {
		height: 60px;
	}

	#main h3.bdr_left .line::before,
	#main h2.bdr_left .line::before {
	font-size: 1.2rem;
	}
}

/* お客様の声 */

#main .sec_voice {
	margin-bottom: 30px;
}

#main .sec_voice .head-line01 {
	margin-bottom: -180px;
	padding: 0 52px;
	writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	direction: ltr;
	text-align: left;
	left: 50%;
	top:-240px;
	transform: translateX(-50%);
}

#main .sec_voice .text-area {
	padding: 0 32px 33px;
	box-sizing: border-box;
	background-color: #FFF;
}

#main .sec_voice li::before {
	content: "";
	left: 20px;
	z-index: 1;
	position: absolute;
	/* background-color: #c03c3f; */
	height: 3px;
	width: 63px;
	top: -2px;
	background:url(../img/bdr01.png) no-repeat top/cover;
}

#main .sec_voice li {
	padding: 5px 40px 10px 24px;
	padding: 5px 40px 81px 24px;
	border-top: 1px solid #d9d5d0;
	box-sizing: border-box;
	position: relative;
}

#main .sec_voice li:nth-child(odd) {
	border-right: 1px solid #d9d5d0;
}

#main .sec_voice li .ttl {
	margin-bottom: 14px;
	font-weight: bold;
}

#main .sec_voice li .title {
	margin-bottom: 23px;
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}

#main .sec_voice li p span {
	font-size:1.3em;
}

@media all and (max-width: 896px) {
	#main .sec_voice {
		margin-bottom: 56px;
	}

	#main .sec_voice .text-area.content {
		margin: 0;
	}

	#main .sec_voice .text-area {
		padding: 92px 15px 10px;
		box-sizing: border-box;
		background-color: #FFF;
	}

	#main .sec_voice .head-line01 {
		top: -220px;
		margin-bottom: -150px;
	}

	#main .sec_voice .head-line01::before {
		margin-top: -49px;
	}

	#main .sec_voice ul {
		display: block;
		margin-top: 47px;
	}

	#main .sec_voice li {
		padding: 20px 20px 40px 24px;
		width: auto;
	}

	#main .sec_voice li:not(:nth-of-type(2n)) {
		border-right: none;
	}

	#main .sec_voice li .title {
		margin-bottom: 20px;
		font-size: 1.5rem;
	}

	#main .sec_voice li .title span {
		font-size: 2.1rem;
	} 
}

/* 周辺神社のご案内 */

#main .sec_guide::after {
	width: 100%;
	height: 1300px;
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: #cbcead;
	content: '';
}

#main .sec_guide .map-box {
	margin-bottom: 65px;
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#main .sec_guide .head-line01 {
	padding: 0 86px;
	writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	direction: ltr;
	text-align: center;
	margin-bottom:0;
}

#main .sec_guide .map-box .map {
	width: 752px;
	height: 512px;
	position: relative;
	overflow: hidden;
}

#main .sec_guide .map-box .map iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

#main .sec_guide ul {
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 1;
	flex-wrap: wrap;
}

#main .sec_guide li {
	width: 348px;
	margin-bottom: 25px;
}

#main .sec_guide li .photo {
	margin-bottom: 20px;
}

#main .sec_guide li .text {
	display: flex;
}

#main .sec_guide li .text .title {
	width: 40px;
}

#main .sec_guide li .text .title .num {
	margin-bottom: 40px;
	width: 40px;
	height: 40px;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #FFF;
	border-radius: 50%;
	background-color: #c03c3f;
}

#main .sec_guide li .text .title .num::after {
	width: 1px;
	height: 30px;
	position: absolute;
	bottom: -30px;
	left: 50%;
	background-color: #c03c3f;
	content: '';
}

#main .sec_guide li .text .title .txt {
	padding-left: 5px;
	font-size: 1.6rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	direction: ltr;
	text-align: left;
}

#main .sec_guide li .text .sub {
	padding: 2px 5px 0 25px;
}

#main .sec_guide li .text .sub .txt {
	margin-bottom: 19px;
}

#main .sec_guide li .text .sub .ttl {
	margin-bottom: 13px;
}

#main .sec_guide li .text .sub .address span {
	color: #c03c3f;
}

/* 撮影の流れ */
#main .sec_flow dl {
	display: flex;
	flex-wrap: wrap;
	position: relative;
	border-top: 1px solid #d8d5cf;
	border-bottom: 1px solid #d8d5cf;
	padding: 20px 0
}

#main .sec_flow dt {
	width: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	letter-spacing: 0.1em;
	background: url(../img/bg04.png) no-repeat center center;
	background-size: 100px;
	text-align: center;
	line-height: 1.2;
	position: relative;
}

#main .sec_flow dt span.txt {
	margin-top: -10px
}

#main .sec_flow dt span.txt::after {
	content: '';
	width: 10px;
	height: 80px;
	background-color: #eaebe1;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	z-index: -10;
}

#main .sec_flow dl::after {
	width: 1px;
	height: 80%;
	position: absolute;
	top: 50%;
	left: 100px;
	background-color: #a9a78c;
	transform: translateY(-50%);
	content: '';
	z-index: -20;
}

#main .sec_flow dt .num {
	font-size: 1.4rem;
}

#main .sec_flow dd {
	padding: 40px 0 40px;
	width: calc(100% - 200px);
	display: flex;
	align-items: center;
}

#main .sec_flow dd .ttl {
	margin-right: 11px;
	width: 188px;
	font-size: 2rem;
	letter-spacing: 0.2em;
}

#main .sec_flow dd .text {
	width: 640px;
}

#main .sec_flow dd .sub-list {
	margin-top: 25px;
}

#main .sec_flow dd .sub-list li {
	padding-left: 15px;
	position: relative;
	line-height: 2;
}

#main .sec_flow dd .sub-list li span {
	color: #c03c3f;
}

#main .sec_flow dd .sub-list li::after {
	width: 6px;
	height: 6px;
	position: absolute;
	top: calc(50% - 3px);
	left: 0;
	border-radius: 50%;
	background-color: #958626;
	content: '';
}

#main .sec_flow dl {
		border-bottom: 1px solid #d8d5cf;
	}

@media all and (max-width: 896px) {

	#main .sec_flow dt {
		width: 100px;
		background-size: 90px 90px;
		font-size: 1.5rem;
		height: 100px;
	}

	#main .sec_flow dt span.txt::after {
		height: 65px;
	}

	#main .sec_flow dl::after {
		left: 50px;
	}

	#main .sec_flow dd {
		padding: 15px 0 20px;
		width: calc(100% - 100px);
	}

	#main .sec_flow dd .ttl {
		margin-right: 11px;
		margin-bottom: 13px;
		width: auto;
		font-size: 1.5rem;
	}

	#main .sec_flow dd .text {
		width: auto;
		font-size: 1.3rem;
		line-height: 1.46;
		padding-left: 15px
	}

	#main .sec_flow dd .sub-list {
		margin-top: 20px;
	}

	#main .sec_flow dd .sub-list li {
		padding-left: 15px;
		line-height: 1.7;
	}

	#main .sec_flow dd .sub-list li:not(:last-of-type) {
		margin-bottom: 15px;
	}

	#main .sec_flow dd .sub-list li::after {
		top: 8px;
	}
}