@charset "utf-8";

html {
	overflow-y: scroll;
	-webkit-text-size-adjust: none;
	-webkit-tap-highlight-color: transparent;
	font-size: 62.5%;
}

body {
	margin: 0;
	padding: 0;
	background: #f7f4ed;
	color: #000;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-size: 1.0rem;
	font-weight: normal;
	line-height: 1.5;
	overflow-wrap: anywhere;
	word-break: normal;
	line-break: strict;
}

article, aside, dialog, figure, footer, header, hgroup, nav, section, main {
	display: block;
}

body, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, article, aside, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

address,caption,cite,code,dfn,em,strong,th,var {
	font-weight: normal;
	font-style: normal;
}

ul, ol, li {
	list-style: none;
}

dt {
	font-weight: normal;
}

h1, h2, h3, h4, h5, h6 {
	font-size: inherit;
	font-weight: inherit;
}

hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
	border-top-width: 1px;
	margin: 0;
	clear: both;
	color: inherit;
}

pre {
	font-family: monospace, monospace;
	font-size: inherit;
}

address {
	font-style: inherit;
}

abbr[title] {
	text-decoration: underline dotted;
}

b,
strong {
	font-weight: bolder;
}

code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: inherit;
}

small {
	font-size: 100%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

svg,
img,
embed,
object,
iframe {
	vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
	-webkit-appearance: none;
	appearance: none;
	vertical-align: middle;
	color: inherit;
	font: inherit;
	background: transparent;
	padding: 0;
	margin: 0;
	border-radius: 0;
	text-align: inherit;
	text-transform: inherit;
}

[type="checkbox"] {
	-webkit-appearance: checkbox;
	appearance: checkbox;
}

[type="radio"] {
	-webkit-appearance: radio;
	appearance: radio;
}

input:focus,
textarea:focus,
select:focus {
	outline: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
	cursor: pointer;
}

button:disabled,
[type="button"]:disabled,
[type="reset"]:disabled,
[type="submit"]:disabled {
	cursor: default;
}

:-moz-focusring {
	outline: auto;
}

select:disabled {
	opacity: inherit;
}

option {
	padding: 0;
}

fieldset {
	margin: 0;
	padding: 0;
	min-width: 0;
}

legend {
	padding: 0;
}

progress {
	vertical-align: baseline;
}

textarea {
	overflow: auto;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

[type="search"] {
	outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

label[for] {
	cursor: pointer;
}

details {
	display: block;
}

summary {
	display: list-item;
}

[contenteditable]:focus {
	outline: auto;
}

table {
	border-color: inherit;
	border-collapse: collapse;
}

caption {
	text-align: left;
}

td,
th {
	vertical-align: top;
	padding: 0;
}

th {
	text-align: left;
	font-weight: bold;
}

img {
	width: 100%;
	height: auto;
	border-style: none;
	vertical-align: top;
	font-size: 0;
	line-height: 0;
}

a {
	text-decoration: none;
	color: inherit;
	outline: none;
}

a:focus {
	outline: none;
}

a {
	transition-property: opacity;
	transition-duration: 0.5s;
}

a:hover {
	opacity: 0.6;
}

/*----- .clearfix -----*/

.clearfix::after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
	height: 0;
}

.container {
	margin: 0 auto;
	width: 100%;
	max-width: 1000px;
	text-align: left;
	z-index: 20;
	position: relative;
}

@media screen and (max-width: 767px) {

	.container {
		padding: 0 14px;
		width: auto;
	}
}

header,
footer,
main > section {
	padding: 0 80px;
	width: 100%;
	box-sizing: border-box;
}

/*----- header -----*/

header {
	background: #fff;
	border-bottom: 2px #1e2a54 solid;
	left: 0;
	top: 0;
	z-index: 100;
	position: fixed;
}

header a:hover {
	opacity: 1;
}

header .container {
	padding: 10px 0;
	height: 80px;
	align-items: flex-end;
	display: flex;
}

header h1 {
	margin: 0 26px 5px 0;
	color: #1e2a54;
	font-size: 1.2rem;
	font-weight: bold;
	line-height: 1.5;
	text-align: left;
}

header h1 a {
	color: #1e2a54;
	display: block;
}

header h1 img {
	width: 70px;
}

header h1 span {
	display: none;
}

header #hamburger {
	width: 40px;
	height: 34px;
	display: none;
}

header #hamburger a {
	width: 100%;
	height: 100%;
	background: url("../img/hamburger.svg") no-repeat center center / 20px auto;
	display: block;
	font-size: 0;
	line-height: 0;
	text-indent: -9999px;
}

header nav {
	align-items: flex-end;
	justify-content: space-between;
	display: flex;
	flex: 1;
}

header nav #hLang {
	align-items: flex-start;
	display: flex;
}

header nav #hLang li {
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.5;
	position: relative;
}

header nav #hLang li:not(:last-of-type) {
	margin: 0 6px 0 0;
	padding: 0 6px 0 0;
}

header nav #hLang li:not(:last-of-type)::after {
	content: " ";
	width: 0;
	height: 21px;
	border-right: 2px #000 solid;
	display: block;
	right: 0;
	top: 0;
	z-index: 0;
	position: absolute;
}

header nav #hLang li a {
	padding: 0 8px 16px;
	color: #000;
	display: block;
	position: relative;
}

body header nav #hLang li a::after {
	content: " ";
	width: 30px;
	height: 0;
	border-top: 6px #c7e227 solid;
	display: block;
	left: 50%;
	bottom: 0;
	position: absolute;
	transform: translateX(-50%);
}
	
body header nav #hLang li a::after {
	opacity: 0;
	transition-property: opacity;
	transition-duration: 0.5s;
}

body.jp header nav #hLang li.jp a::after,
body.en header nav #hLang li.en a::after,
body header nav #hLang li a:hover::after {
	opacity: 1;
}

body header nav #hNav {
	align-items: flex-start;
	justify-content: flex-end;
	flex-wrap: wrap;
	display: flex;
	gap: 6px;
}

header nav #hNav li {
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
	position: relative;
}

header nav #hNav li a {
	padding: 0 8px 16px;
	color: #1e2a54;
	display: block;
	position: relative;
}

header nav #hNav li a::after {
	content: " ";
	width: 30px;
	height: 0;
	border-top: 6px #c7e227 solid;
	display: block;
	left: 50%;
	bottom: 0;
	position: absolute;
	transform: translateX(-50%);
}
	
body header nav #hNav li a::after {
	opacity: 0;
	transition-property: opacity;
	transition-duration: 0.5s;
}

body.top header nav #hNav li.top a::after,
body.guide header nav #hNav li.guide a::after,
body.kimonolist header nav #hNav li.kimonolist a::after,
body.reserve header nav #hNav li.reserve a::after,
body.column header nav #hNav li.column a::after,
body.terms header nav #hNav li.terms a::after,
body header nav #hNav li a:hover::after {
	opacity: 1;
}

header nav #hNav li a .jp {
	color: #1e2a54;
	display: block;
}

header nav #hNav li a .en {
	margin: 0 0 8px;
	color: #ceae55;
	font-size: 1.2rem;
	font-weight: bold;
	line-height: 1.2;
	text-align: center;
	display: block;
}

.inPoint {
	width: 100%;
	position: relative;
}

.inPoint > div {
	position: absolute;
	left: 0;
	top: -102px;
}

@media screen and (max-width: 999px) {
	
	header {
		padding: 0;
	}
	
	header .container {
		padding: 2px 14px 0;
		width: auto;
		height: 50px;
		align-items: center;
		justify-content: space-between;
		display: flex;
	}
	
	header h1 {
		margin: 0;
		align-items: center;
		display: flex;
	}
	
	header h1 img {
		margin-right: 8px;
		width: 35px;
	}
	
	header h1 span {
		display: block;
	}
	
	header #hamburger {
		display: block;
	}
	
	header nav {
		padding: 16px 14px 8px 8px;
		width: 166px;
		background: rgba(247,244,237,0.9);
		display: block;
		flex: auto;
		right: 0;
		top: 54px;
		position: absolute;
	}
	
	header nav {
		transform: translateX(9999px);
		opacity: 0;
		transition: transform 0s 0.2s, opacity 0.1s 0s;
	}
	
	header.open nav {
		transform: translateX(0);
		opacity: 1;
		transition: transform 0s, opacity 0.3s;
	}
	
	header nav #hLang {
		margin: 0 0 8px;
		align-items: flex-start;
		justify-content: flex-end;
		display: flex;
	}
	
	header nav #hLang li {
		font-size: 1.2rem;
		font-weight: bold;
		line-height: 1.5;
		position: relative;
	}
	
	header nav #hLang li:not(:last-of-type) {
		margin: 0 8px 0 0;
		padding: 0 9px 0 0;
	}
	
	header nav #hLang li:not(:last-of-type)::after {
		height: 18px;
	}
	
	header nav #hLang li a {
		padding: 0 10px 8px;
	}
	
	body header nav #hLang li a::after {
		width: 18px;
		border-top-width: 4px;
	}
		
	header nav #hNav {
		padding: 6px 8px;
		background: #fff;
		align-items: flex-start;
		justify-content: flex-start;
		flex-direction: column;
		display: flex;
		gap: 6px;
	}
	
	header nav #hNav li {
		font-size: 1.6rem;
		border-left-width: 5px;
		border-left-style: solid;
		text-align: left;
	}
	
	header nav #hNav .top {
		border-left-color: #f9d4d2;
	}
	
	header nav #hNav .guide {
		border-left-color: #c7eaac;
	}
	
	header nav #hNav .kimonolist {
		border-left-color: #ede0ab;
	}
	
	header nav #hNav .reserve {
		border-left-color: #c3d2db;
	}
	
	header nav #hNav .column {
		border-left-color: #c3e5d8;
	}
	
	header nav #hNav .terms {
		border-left-color: #d1d3d2;
	}
	
	header nav #hNav li a {
		padding: 10px;
	}
	
	header nav #hNav li a::after {
		display: none;
	}
		
	header nav #hNav li a .en {
		margin: 0;
		font-size: 1.2rem;
		text-align: left;
	}

	.inPoint > div {
		top: -54px;
	}

}

/*----- footer -----*/

footer {
	width: 100%;
	background: #1E2A54;
	z-index: 90;
	position: relative;
}

footer .container {
	height: 72px;
	align-items: center;
	justify-content: space-between;
	display: flex;
}

footer .link {
	color: #fff;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 2rem;
	display: block;
}

footer .link a {
	color: #fff;
}

footer .copy {
	color: #E6E6E6;
	font-size: 1.4rem;
	font-weight: normal;
	line-height: 2rem;
	align-items: center;
	justify-content: flex-end;
	display: flex;
}

footer .copy small {
	margin-right: 28px;
	font-size: 1em;
	display: block;
}

footer .copy a {
	width: 138px;
	display: block;
}

@media screen and (max-width: 767px) {

	footer {
		padding: 0;
	}

	footer .container {
		padding: 14px 14px 10px;
		height: auto;
		align-items: flex-start;
		justify-content: flex-start;
		flex-direction: column;
		display: flex;
	}
	
	footer .link {
		margin-bottom: 30px;
		color: #fff;
		font-size: 1.4rem;
		font-weight: bold;
		line-height: 2rem;
		display: block;
	}
	
	footer .copy {
		width: 100%;
		font-size: 1.6rem;
		text-align: center;
		display: block;
	}
	
	footer .copy small {
		margin: 0 0 8px;
	}
	
	footer .copy a {
		margin: 0 auto;
	}
	
}

#pageTop {
	padding: 0;
	width: 100%;
	z-index: 99;
	position: relative;
}

#pageTop #pageTopIn {
	width: 100%;
	right: 0;
	bottom: 0;
	position: fixed;
}

#pageTop.noFixed #pageTopIn {
	position: absolute;
}

#pageTop p {
	width: 79px;
	right: 10px;
	bottom: 10px;
	position: absolute;
}

#pageTop p a {
	width: 100%;
	height: 90px;
	background: url("../img/pagetop.svg") no-repeat center center / contain;
	font-size: 0;
	line-height: 0;
	text-indent: -9999px;
	display: block;
	position: relative;
}

/*----- common -----*/

main {
	overflow: hidden;
}

.link {
	align-items: center;
	display: flex;
}

.link a {
	color: #000;
	align-items: center;
	display: flex;
}

.link a::after {
	content: " ";
	margin-left: 20px;
	width: 24px;
	height: 24px;
	background: url("../img/icon_arr.svg") no-repeat center center / contain;
	display: block;
}

.link a span {
	flex: 1;
	display: block;
}

.boxSec {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 12px rgba(0,0,0,.08);
}

@media screen and (max-width: 767px) {

	.link a::after {
		margin-left: 12px;
		width: 16px;
		height: 16px;
	}
	
	.boxSec {
		border-radius: 0;
		box-shadow: none;
	}

}

/*----- TOP -----*/

#topMain {
	padding: 102px 0 72px;
}

#topMain .container {
	overflow: hidden;
}

#topIndex {
	margin-bottom: 32px;
}

#topIndex1 {
	z-index: 2;
	position: relative;
}

#topIndex2 {
	z-index: 1;
	position: relative;
}

#topIndex1::after,
#topIndex2::after {
	content: " ";
	width: 494px;
	height: 240px;
	background: url("../img/pat01.png") no-repeat center center / cover;
	display: block;
	z-index: 5;
	position: absolute;
}

#topIndex1::after {
	right: 0;
	bottom: -23px;
}

#topIndex2::after {
	left: 0;
	bottom: -20px;
}

#topIndex1 h1,
#topIndex2 h1 {
	padding: 50px;
	height: 340px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	color: #fff;
	font-size: 2.8rem;
	font-weight: bold;
	line-height: 1.75;
	box-sizing: border-box;
	align-items: center;
	display: flex;
}

#topIndex1 h1 {
	background-image: url("../img/bg_top_h01.jpg");
}

#topIndex2 h1 {
	background-image: url("../img/bg_top_h02.jpg");
}

#topIndex1 h1 span,
#topIndex2 h1 span {
	display: block;
}

#topIndex1 .topIndexMain,
#topIndex2 .topIndexMain {
	padding: 32px 45px;
	z-index: 10;
	position: relative;
}

#topIndex1 .topIndexMain {
	text-align: left;
}

#topIndex2 .topIndexMain {
	text-align: right;
}

#topIndex1 .topIndexMain p,
#topIndex2 .topIndexMain p {
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.75;
}

#topIndex1 .topIndexMain .link,
#topIndex2 .topIndexMain .link {
	margin-top: 1.75em;
}

#topIndex1 .topIndexMain .link,
#topIndex1 .topIndexMain .link a {
	justify-content: flex-start;
}

#topIndex2 .topIndexMain .link,
#topIndex2 .topIndexMain .link a {
	justify-content: flex-end;
}

@media screen and (max-width: 999px) {

	#topMain {
		padding: 54px 0 64px;
	}
}

@media screen and (max-width: 767px) {

	#topMain .container {
		padding: 0;
	}
	
	#topIndex {
		margin-bottom: 24px;
	}
	
	#topIndex1::after,
	#topIndex2::after {
		width: 197px;
		height: 118px;
		background-size: 100% 100%;
	}
	
	#topIndex1::after {
		bottom: -5px;
	}
	
	#topIndex2::after {
		bottom: -4px;
	}
	
	#topIndex1 h1,
	#topIndex2 h1 {
		padding: 13px;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: cover;
		color: #fff;
		font-size: 1.6rem;
		font-weight: bold;
		line-height: 1.75;
		box-sizing: border-box;
		align-items: center;
		display: flex;
	}
	
	#topIndex1 h1 {
		height: 196px;
		background-image: url("../img/bg_top_h01sp.jpg");
	}
	
	#topIndex2 h1 {
		height: 202px;
		background-image: url("../img/bg_top_h02sp.jpg");
	}
	
	#topIndex1 .topIndexMain,
	#topIndex2 .topIndexMain {
		padding: 15px 15px 16px;
	}
	
	#topIndex1 .topIndexMain p,
	#topIndex2 .topIndexMain p {
		font-size: 1.6rem;
		line-height: 1.5;
	}
	
	#topIndex1 .topIndexMain .link,
	#topIndex2 .topIndexMain .link {
		margin-top: 1.5em;
	}
	
}

#topList {
	margin-bottom: 36px;
	padding: 30px;
	background: #5175a5;
	border-radius: 10px;
	box-shadow: 0 2px 12px rgba(0,0,0,.08);
	position: relative;
}

#topListMain {
	padding: 26px 16px 16px;
	background: url("../img/pat02.png") no-repeat center center / 840px auto;
}

#topList h1 {
	color: #fff;
	font-size: 3rem;
	font-weight: bold;
	line-height: 1.8;
	text-align: center;
}

#topList .link {
	margin: 30px auto 0;
	width: 270px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2.6rem;
	text-align: center;
	justify-content: center;
}

#topList .link a {
	padding: 20px;
	width: 100%;
	background: #1e2a54;
	border-radius: 5px;
	box-sizing: border-box;
	color: #fff;
	justify-content: center;
}

#topList .link a span {
	flex: none;
}

@media screen and (max-width: 767px) {

	#topList {
		margin-bottom: 50px;
		padding: 16px 12px 12px;
		border-radius: 0;
		box-shadow: none;
	}
	
	#topListMain {
		padding: 5px 10px 30px;
		background-size: 352px auto;
	}
	
	#topList h1 {
		font-size: 1.6rem;
		line-height: 1.75;
	}
	
	#topList .link {
		margin: 0;
		width: 250px;
		font-size: 1.6rem;
		line-height: 2.6rem;
		left: 50%;
		bottom: -20px;
		position: absolute;
		transform: translateX(-50%);
	}
	
	#topList .link a {
		padding: 16px;
	}
	
}

#topPlan h1,
#topFlow h1 {
	padding: 32px 0;
	width: 100%;
	background-color: #f9d4d2;
	background-image: url("../img/arabesque.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
}

#topPlan h2,
#topFlow h2,
#topItem h1,
#topGallery h1 {
	padding: 0 0 20px;
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.6;
	text-align: center;
	position: relative;
}

#topPlan h2::after,
#topFlow h2::after,
#topItem h1::after,
#topGallery h1::after {
	content: " ";
	width: 280px;
	height: 10px;
	background: #f4a053;
	display: block;
	left: 50%;
	bottom: 0;
	position: absolute;
	transform: translateX(-50%);
}

#topFlow .link,
#topItem .link {
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2.6rem;
	text-align: right;
}

#topFlow .link,
#topFlow .link a,
#topItem .link,
#topItem .link a {
	justify-content: flex-end;
}

@media screen and (max-width: 767px) {
	#topPlan h1,
	#topFlow h1 {
		padding: 24px 0;
		font-size: 1.8rem;
	}
	
	#topPlan h2,
	#topFlow h2,
	#topItem h1,
	#topGallery h1 {
		padding: 0 0 10px;
		font-size: 1.6rem;
	}
	
	#topPlan h2::after,
	#topFlow h2::after,
	#topItem h1::after,
	#topGallery h1::after {
		width: 118px;
		height: 4px;
	}

	#topFlow .link,
	#topItem .link {
		font-size: 1.6rem;
		line-height: 2.6rem;
	}
		
}

#topPlan {
	margin-bottom: 35px;
}

#topPlan #topPlanMain {
	padding: 40px 50px 25px;
}

#topPlan h2 {
	margin-bottom: 24px;
}

#topPlan .topPlanSec {
	padding: 0 0 20px;
	position: relative;
}

#topPlan .topPlanSec figure {
	width: 250px;
	left: 0;
	top: 5px;
	position: absolute;
}

#topPlan .topPlanSec .topPlanInfo {
	padding: 0 0 0 280px;
}

#topPlan .topPlanSec .topPlanInfo h3 {
	margin-bottom: 12px;
	font-size: 3.6rem;
	font-weight: bold;
	line-height: 1.2;
}

#topPlan .topPlanSec .topPlanInfo h4 {
	margin-bottom: 6px;
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.75;
}

#topPlan .topPlanSec .topPlanInfo h5 {
	margin-bottom: 12px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.75;
}

#topPlan .topPlanSec .topPlanInfo p {
	font-size: 1.6rem;
	font-weight: normal;
	line-height: 1.75;
}

#topPlan .topPlanSec .topPlanInfo h3,
#topPlan .topPlanSec .topPlanInfo h5 {
	color: #bb9221;
}

#topPlan .topPlanSec:first-of-type .topPlanInfo h3,
#topPlan .topPlanSec:first-of-type .topPlanInfo h5 {
	color: #f45c4b;
}

@media screen and (max-width: 767px) {

	#topPlan {
		margin: 0 14px 24px;
	}
	
	#topPlan #topPlanMain {
		padding: 20px 10px 0;
	}
	
	#topPlan h2 {
		margin-bottom: 10px;
	}
	
	#topPlan .topPlanSec {
		padding: 0;
	}
	
	#topPlan .topPlanSec figure {
		margin: 0 auto 6px;
		width: 250px;
		left: auto;
		top: auto;
		position: relative;
	}
	
	#topPlan .topPlanSec .topPlanInfo {
		padding: 10px 0 20px;
	}
	
	#topPlan .topPlanSec .topPlanInfo h3 {
		margin-bottom: 6px;
		font-size: 2.4rem;
		text-align: center;
	}
	
	#topPlan .topPlanSec .topPlanInfo h4 {
		margin-bottom: 10px;
		font-size: 1.6rem;
		text-align: center;
	}
	
	#topPlan .topPlanSec .topPlanInfo h5 {
		margin-bottom: 6px;
		font-size: 1.6rem;
		line-height: 2.2rem;
		text-align: center;
	}
	
	#topPlan .topPlanSec .topPlanInfo p {
		font-size: 1.6rem;
		line-height: 1.75;
	}
	
}

#topFlow {
	margin-bottom: 35px;
}

#topFlow #topFlowMain {
	padding: 40px 48px 40px;
}

#topFlow h2 {
	margin-bottom: 32px;
}

#topFlow #topFlowList {
	padding-bottom: 30px;
	justify-content: center;
	flex-wrap: wrap;
	display: flex;
	gap: 32px;
}

#topFlow #topFlowList > div {
	background-color: #f7f4ed;
	width: 280px;
}

#topFlow #topFlowList > div dt {
	background-color: #fff;
	border-bottom: 1px solid #fff;
	display: flex;
}

#topFlow #topFlowList > div dt > div {
	margin: 0 1px 0 0;
	padding: 30px 0;
	width: 74px;
	background: #f99f95 url("../img/pat01.png") no-repeat left -5px top / auto 210px;
	color: #fff;
	font-size: 3.6rem;
	font-weight: bold;
	line-height: 4rem;
	text-align: center;
}

#topFlow #topFlowList > div dt > h3 {
	padding-top: 18px;
	border: 2px solid #f4a053;
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 3rem;
	text-align: center;
	flex: 1;
}

#topFlow #topFlowList > div dt > h3 span {
	font-size: 1.8rem;
	display: block;
}

#topFlow #topFlowList > div dt > h3 .min {
	font-size: 1.6rem;
}

#topFlow #topFlowList > div dd {
	padding: 14px 8px 20px;
	font-size: 1.6rem;
	line-height: 2.8rem;
}

@media screen and (max-width: 767px) {

	#topFlow {
		margin: 0 14px 24px;
	}
	
	#topFlow #topFlowMain {
		padding: 20px 10px 20px;
	}
	
	#topFlow h2 {
		margin-bottom: 16px;
	}
	
	#topFlow #topFlowList {
		padding-bottom: 4px;
		display: block;
		gap: 0;
	}
	
	#topFlow #topFlowList > div {
		margin-bottom: 16px;
		width: 100%;
	}
	
}

#topItem {
	margin-bottom: 0;
}

#topItem #topItemMain {
	padding: 40px 48px 40px;
}

#topItem h1 {
	margin-bottom: 20px;
}

#topItem h2 {
	margin-bottom: 18px;
	padding: 5px 0 5px 56px;
	background: url("../img/sq_pt_item.svg") no-repeat left top / 40px auto;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 3rem;
}

#topItem h3 {
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.75;
}

#topItem ul {
	padding-bottom: 20px;
}

#topItem li {
	padding-left: 1em;
	font-size: 1.6rem;
	font-weight: normal;
	line-height: 1.75;
	text-indent: -1em;
}

#topItem li::before {
	content: "\25CF";
	font-size: 1.6rem;
	font-weight: normal;
	line-height: 1.75;
}

@media screen and (max-width: 767px) {

	#topItem {
		margin: 0 14px 0;
	}
	
	#topItem #topItemMain {
		padding: 20px 10px 20px;
	}
	
	#topItem h1 {
		margin-bottom: 12px;
	}

	#topItem h2 {
		margin-bottom: 24px;
		padding: 4px 0 4px 42px;
		background-size: 32px auto;
		font-size: 1.6rem;
		line-height: 2.4rem;
	}
	
	#topItem h3 {
		font-size: 1.6rem;
	}
		
}

#topGallery {
	padding: 40px 0 48px;
	background-color: #ded6ce;
}

#topGallery h1 {
	margin-bottom: 16px;
}

#topGallery .sns {
	margin: 0 auto 32px;
	justify-content: center;
	display: flex;
	gap: 20px;
}

#topGallery .sns li {
	width: 34px;
}

#topGallery #topGalleryList {
	justify-content: center;
	flex-wrap: wrap;
	display: flex;
	gap: 30px 32px;
}

#topGallery #topGalleryList li {
	width: 280px;
}

@media screen and (max-width: 767px) {

	#topGallery {
		padding: 20px 0 48px;
	}
	
	#topGallery h1 {
		margin-bottom: 16px;
	}
	
	#topGallery .sns {
		margin: 0 auto 24px;
	}
	
	#topGallery #topGalleryList {
		align-items: center;
		flex-direction: column;
		gap: 20px;
	}
	
	#topGallery #topGalleryList li {
		width: 213px;
	}
	
}


/*----- under -----*/

#underHead {
	padding-top: 102px;
	background-color: #fff;
}

#underHead h1 {
	padding: 50px 0 50px;
	color: #1f2b55;
	font-size: 3rem;
	font-weight: bold;
	line-height: 1.5;
	text-align: left;
	align-items: center;
	display: flex;
}

#underHead h1::before {
	content: " ";
	margin-right: 36px;
	width: 130px;
	height: 154px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	display: block;
}

body.guide #underHead h1::before {
	background-image: url("../img/sq_h_guide.svg");
}

body.kimonolist #underHead h1::before {
	background-image: url("../img/sq_h_kimonolist.svg");
}

body.reserve #underHead h1::before {
	background-image: url("../img/sq_h_reserve.svg");
}

body.column #underHead h1::before {
	background-image: url("../img/sq_h_column.svg");
}

body.terms #underHead h1::before {
	background-image: url("../img/sq_h_terms.svg");
}

#underHead h1 span {
	display: block;
}

#topicPath {
	background-color: #1e2a54;
}

#topicPath ul {
	padding: 20px 0 20px;
	flex-wrap: wrap;
	display: flex;
}

#topicPath ul li {
	margin-right: 0.5em;
	color: #fff;
	font-size: 1.8rem;
	font-weight: normal;
	line-height: 2.4rem;
	text-align: left;
}

#topicPath ul li:not(:last-child)::after {
	content: "\FF1E";
	margin-left: 0.5em;
	font-size: 1.8rem;
	font-weight: normal;
	line-height: 2.4rem;
	display: inline-block;
}

#topicPath ul li a {
	color: #fff;
	text-decoration: none;
}

#underMain {
	padding: 20px 0 40px;
}

#underMain .container {
	overflow: hidden;
}

#underMain .container > .dsc {
	margin-bottom: 18px;
	font-size: 1.6rem;
	font-weight: normal;
	line-height: 1.75;
	text-align: center;
}

#underMain .boxSec {
	margin-bottom: 32px;
}

#underMain .boxCalSec {
	margin-bottom: 32px;
}

#underMain .boxCalSec .note {
	margin-top: 18px;
	margin-bottom: 24px;
	text-align: center;
}

#underMain .boxCalSec .calBox {
	background-color: #fff;
	border: 1px #a29f9f solid;
}

#underMain .hBar {
	padding: 32px 0;
	width: 100%;
	background-image: url("../img/arabesque.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
}

body.guide #underMain .hBar {
	background-color: #c7eaac;
}

body.kimonolist #underMain .hBar {
	background-color: #ede0ab;
}

body.reserve #underMain .hBar {
	background-color: #cee8f4;
}

body.column #underMain .hBar {
	background-color: #c3e5d8;
}

body.terms #underMain .hBar {
	background-color: #d1d3d2;
}

#underMain .hBdr {
	padding: 0 0 20px;
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.6;
	text-align: center;
	position: relative;
}

#underMain .hBdr::after {
	content: " ";
	width: 280px;
	height: 10px;
	background: #f4a053;
	display: block;
	left: 50%;
	bottom: 0;
	position: absolute;
	transform: translateX(-50%);
}

body.guide #underMain .hBdr::after {
	background-color: #8381c9;
}

body.kimonolist #underMain .hBdr::after {
	background-color: #a09770;
}

body.reserve #underMain .hBdr::after {
	background-color: #ea869c;
}

body.column #underMain .hBdr::after {
	background-color: #895809;
}

body.terms #underMain .hBdr::after {
	background-color: #43aa9d;
}

#underMain .hPt {
	padding: 5px 0 5px 56px;
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 40px auto;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 3rem;
}

body.guide #underMain .hPt {
	background-image: url("../img/sq_pt_guide.svg");
}

body.kimonolist #underMain .hPt {
	background-image: url("../img/sq_pt_kimonolist.svg");
}

body.reserve #underMain .hPt {
	background-image: url("../img/sq_pt_reserve.svg");
}

body.column #underMain .hPt {
	background-image: url("../img/sq_pt_column.svg");
}

body.terms #underMain .hPt {
	background-image: url("../img/sq_pt_terms.svg");
}

#underMain .hBdr {
	padding: 0 0 20px;
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.6;
	text-align: center;
	position: relative;
}

#underMain .underBoxMain {
	padding: 5px 48px 40px;
}

#underMain p {
	font-size: 1.6rem;
	font-weight: normal;
	line-height: 1.75;
}

#underMain .center {
	text-align: center;
}

#underMain .bold {
	font-weight: bold;
}

#underMain .mt {
	margin-top: 18px;
}

#underMain .large {
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.6;
	text-align: center;
}

#underMain ul li {
	padding-left: 1em;
	font-size: 1.6rem;
	font-weight: normal;
	line-height: 1.75;
	text-indent: -1em;
}

#underMain ul li::before {
	content: "\30FB";
	font-size: 1.6rem;
	font-weight: normal;
	line-height: 1.75;
}

#underMain .hBdr {
	margin-top: 36px;
	margin-bottom: 28px;
}

#underMain .hPt {
	margin-top: 28px;
	margin-bottom: 18px;
}

#underMain .link {
	margin-top: 1.75em;
	margin-bottom: 1.75em;
}

@media screen and (max-width: 767px) {

	#underHead {
		padding-top: 54px;
	}
	
	#underHead h1 {
		padding: 20px 0 20px;
		font-size: 1.6rem;
	}
	
	#underHead h1::before {
		content: " ";
		margin-right: 18px;
		width: 65px;
		height: 77px;
	}

	#topicPath ul {
		padding: 10px 0 10px;
	}
	
	#topicPath ul li {
		margin-right: 0.5em;
		font-size: 1.2rem;
		line-height: 1.8rem;
	}
	
	#topicPath ul li:not(:last-child)::after {
		margin-left: 0.5em;
		font-size: 1.2rem;
		line-height: 1.8rem;
	}

	#underMain {
		padding: 20px 0 40px;
	}

	#underMain .container > .dsc {
		font-size: 1.6rem;
	}
	
	#underMain .boxSec {
		margin-bottom: 24px;
	}

	#underMain .boxCalSec {
		margin-bottom: 24px;
	}

	#underMain .boxCalSec .note {
		margin-top: 10px;
		margin-bottom: 12px;
	}
	
	#underMain .hBar {
		padding: 24px 0;
		font-size: 1.8rem;
	}
	
	#underMain .hBdr {
		padding: 0 0 10px;
		font-size: 1.6rem;
	}
	
	#underMain .hBdr::after {
		width: 118px;
		height: 4px;
	}

	#underMain .hPt {
		padding: 4px 0 4px 42px;
		background-size: 32px auto;
		font-size: 1.6rem;
		line-height: 2.4rem;
	}
	
	#underMain .underBoxMain {
		padding: 5px 10px 20px;
	}

	#underMain p {
		font-size: 1.6rem;
	}

	#underMain .large {
		font-size: 1.6rem;
	}

	#underMain .mt {
		margin-top: 10px;
	}
	
	#underMain ul li {
		font-size: 1.6rem;
	}
	
	#underMain ul li::before {
		font-size: 1.6rem;
	}
	
	#underMain .hBdr {
		margin-top: 36px;
		margin-bottom: 14px;
	}
	
	#underMain .hPt {
		margin-top: 28px;
		margin-bottom: 9px;
	}
	
}

.kimonolistList {
	margin: 0 auto;
	padding: 28px 0 0;
	width: 100%;
	max-width: 898px;
	display: flex;
	flex-wrap: wrap;
	gap: 40px 30px;
}

.kimonolistList article {
	width: 202px;
}

.kimonolistList article a {
	display: block;
}

.kimonolistList article figure {
	width: 100%;
}

.kimonolistList article p {
	height: 46px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.2;
	align-items: center;
	justify-content: space-between;
	display: flex;
}

.kimonolistList article p::after {
	content: " ";
	margin-left: 20px;
	width: 24px;
	height: 24px;
	background: url("../img/icon_arr.svg") no-repeat center center / contain;
	display: block;
}

.kimonolistList article p span {
	display: block;
}

@media screen and (max-width: 999px) {
	.kimonolistList {
		max-width: 666px;
	}
}

@media screen and (max-width: 767px) {

	.kimonolistList {
		justify-content: center;
	}

}


#underMain .kimonoBoxMain {
	padding: 48px;
	flex-direction: row-reverse;
	display: flex;
}

#underMain .kimonoBoxMain .kimonoBoxInfo {
	flex: 1;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .hBdr {
	margin-top: 0;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoRec {
	margin: 26px 0 32px;
	display: flex;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoRec::before {
	content: " ";
	margin: 0 1px 0 0;
	width: 74px;
	background: #ddca1d url("../img/pat01.png") no-repeat left -5px top / auto 210%;
	display: block;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoRec dl {
	padding: 10px 16px;
	background-color: #f7f4ed;
	flex: 1;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoRec dl dt {
	margin: 0 0 10px;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.2;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoRec dl dd {
	font-size: 1.6rem;
	font-weight: normal;
	line-height: 1.75;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoIcon {
	padding: 0 0 26px;
	flex-wrap: wrap;
	display: flex;
	gap: 12px;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoIcon li {
	padding: 5px;
	min-width: 100px;
	background-color: #a09770;
	border-radius: 5px;
	box-sizing: border-box;
	color: #fff;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 2rem;
	text-align: center;
	text-indent: 0;
}

#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoIcon li::before {
	display: none;
}

#underMain .kimonoBoxMain .kimonoSwiper {
	margin-right: 32px;
	width: 435px;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider {
	width: 100%;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider .swiper-button-prev,
#underMain .kimonoBoxMain .kimonoSwiper .slider .swiper-button-next {
	margin-top: -12px;
	width: 24px;
	height: 24px;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider .swiper-button-prev {
	background: url("../img/arr_list_l.svg") no-repeat center center / contain;
	left: 12px;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider .swiper-button-next {
	background: url("../img/arr_list_r.svg") no-repeat center center / contain;
	right: 12px;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider .swiper-button-prev::after,
#underMain .kimonoBoxMain .kimonoSwiper .slider .swiper-button-next::after {
	display: none;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider-thumbnail {
	padding: 32px 0 0;
	width: 100%;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider-thumbnail .swiper-wrapper {
	flex-wrap: wrap;
	gap: 15px;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider-thumbnail .swiper-slide {
	width: 87px !important;
	cursor: pointer;
}

#underMain .kimonoBoxMain .kimonoSwiper .slider-thumbnail .swiper-slide:not(.swiper-slide-thumb-active) {
	opacity: 0.5;
}

@media screen and (max-width: 999px) {

	#underMain .kimonoBoxMain .kimonoSwiper {
		width: 261px;
	}
	
}

@media screen and (max-width: 767px) {

	#underMain .kimonoBoxMain {
		padding: 20px 10px;
		display: block;
	}

	#underMain .kimonoBoxMain .kimonoBoxInfo {
		margin-bottom: 40px;
		flex: auto;
	}

	#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoRec {
		margin: 13px 0 16px;
	}

	#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoRec dl dt {
		margin: 0 0 10px;
		font-size: 1.4rem;
	}

	#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoRec dl dd {
		font-size: 1.4rem;
	}

	#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoIcon {
		padding: 0 0 13px;
	}

	#underMain .kimonoBoxMain .kimonoBoxInfo .kimonoIcon li {
		width: 100px;
		font-size: 1.2rem;
	}

	#underMain .kimonoBoxMain .kimonoSwiper {
		margin: 0 auto;
		max-width: 435px;
		width: 100%;
	}

	#underMain .kimonoBoxMain .kimonoSwiper .slider-thumbnail {
		padding: 16px 0 0;
	}

}

/*----- flg -----*/

.flgP {
	display: block;
}

.flgS {
	display: none;
}

@media screen and (max-width: 767px) {

	.flgP {
		display: none;
	}

	.flgS {
		display: block;
	}
}

.fade {
	opacity: 0;
	transform: translate(0,40px);
}

.fade.fadeOn {
	opacity: 1;
	transform: translate(0,0);
	transition-property: opacity,transform;
	transition-timing-function: linear,cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-duration: 0.6s;
}

