@charset "UTF-8";
/* Scss Document */
@import url("reset.css");
/* ---------------------------------------------------------- */
/*     shared  */
/* ---------------------------------------------------------- */
/*::: shared ::::::::::::::::::::::::::::::::::::::::::::::::::*/
body {
	font: 14px Meiryo, 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', 'ＭＳ Ｐゴシック', 'MS PGothic', 'Lucida Grande', Verdana, sans-serif;
}
a {
	color: #2E3C3D;
	text-decoration: underline;
	outline: none;
}
a:hover {
	color: #7C8688;
	-webkit-transition: .5s;
	-o-transition: .5s;
	transition: .5s;
}
@media (min-width: 767px) {
	.container {
		max-width: 1130px;
	}
}
.w-center{
	margin: 0 auto;
}
/*::: #header ::::::::::::::::::::::::::::::::::::::::::::::::::*/
#header {
	border-top: 4px solid #333333;
	border-bottom: 1px solid #333333;
	text-align: center;
	height: 100px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
@media (max-width: 767px) {
	#header {
		border-top: none;
		height: 55px;
		overflow: hidden;
	}
}
#header h1 {
	width: 320px;
	margin: 14px auto 0 auto;
	padding: 0;
	-webkit-transition: .8s;
	-o-transition: .8s;
	transition: .8s;
}
@media (max-width: 767px) {
	#header h1 {
	width: 240px;
	}
	#header h1 {
		margin: 0 0 0 3%;
		/*width: 100% !important;*/
		position: absolute;
		top: 50%;
		-ms-transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
	}
}
#header h1 a {
	display: block;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
#header h1 a .logo {}
@media (max-width: 767px) {
	#header h1 a .logo {
		width: 180px;
		height: auto;
		margin-right: 9px;
	}
}
@media (max-width: 767px) {
	#header h1 a .logo-kobe {
		height: auto;
		width: 75px;
	}
}
#header .btn-map {
	position: absolute;
	top: 50%;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 83px;
}
@media (max-width: 767px) {
	#header .btn-map {
		width: 25px;
		height: auto;
		right: 16%;
	}
}
#header .btn-map a {
	display: block;
	font-size: 0;
	line-height: 0;
}
@media (min-width: 767px) {
	#header .btn-map a img {
		width: 32px;
		height: 32px;
	}
}
@media (max-width: 767px) {
	#header .btn-map a img {
		width: 100%;
		height: auto;
	}
}
#header .btn-header {
	position: absolute;
	top: 50%;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 31px;
	-webkit-transition: .8s;
	-o-transition: .8s;
	transition: .8s;
}
@media (max-width: 767px) {
	#header .btn-header {
		right: 5%;
	}
}
#header .btn-header a {
	display: block;
	font-size: 0;
	line-height: 0;
}
@media (max-width: 767px) {
	#header .btn-header a {
		width: 25px;
		height: 25px;
	}
}
@media (min-width: 767px) {
	#header .btn-header a img {
		width: 33px;
		height: 32px;
	}
}
@media (max-width: 767px) {
	#header .btn-header a img {
		width: 25px;
		height: auto;
	}
}
#header.site-header {
	background: #fff;
	padding: 0;
	position: fixed;
	top: 0;
	-webkit-transition: .8s;
	-o-transition: .8s;
	transition: .8s;
	width: 100%;
	z-index: 999;
}
@media (min-width: 767px) {
	#header.site-header.style2 {
		height: 70px;
	}
	#header.site-header.style2 h1 {
		margin-top: 8px;
		margin-right: 0;
		margin-left: 1.5rem;
		-webkit-transform: scale(0.77, 0.77) translate(-30px, -11px);
		-ms-transform: scale(0.77, 0.77) translate(-30px, -11px);
		transform: scale(0.77, 0.77) translate(-30px, -11px);
	}
	#header.site-header.style2 .btn-map, #header.site-header.style2 .btn-header {
		-webkit-transform: translateY(-12px);
		-ms-transform: translateY(-12px);
		transform: translateY(-12px);
	}
}
/*::: #nav-pc ::::::::::::::::::::::::::::::::::::::::::::::::::*/
#nav-pc {
	display: block;
	position: fixed;
	top: 0;
	padding-top: 100px;
	width: 100%;
	background-color: #FFF;
	z-index: 998;
	-webkit-box-shadow: 0 3px 6px rgba(180, 180, 180, 0.2);
	box-shadow: 0 3px 6px rgba(180, 180, 180, 0.2);
	-webkit-transition: .8s;
	-o-transition: .8s;
	transition: .8s;
}
@media (max-width: 767px) {
	#nav-pc {
		display: none;
	}
}
#nav-pc ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
#nav-pc ul li {
	height: 49px;
	padding: 0 10px;
	font-size: 93% !important;
	line-height: 1em;
	letter-spacing: 0.06rem;
	white-space: nowrap;
}
@media (max-width: 992px) {
	#nav-pc ul li {
		padding: 0 12px;
	}
}
@media (max-width: 767px) {
	#nav-pc ul li {
		padding: 0;
	}
}
#nav-pc ul li a {
	border-top: 3px solid #fff;
	display: block;
	padding: 17px 0 19px;
	-webkit-transition: .8s;
	-o-transition: .8s;
	transition: .8s;
	height: 49px;
	color: #6A6A6A;
	text-decoration: none;
}
#nav-pc ul li a:hover {
	border-top: 3px solid #333333;
	color: #333333;
}
#nav-pc ul li.menu06 {
	letter-spacing: -0.03rem;
}
#nav-pc.style2 {
	-webkit-transform: translateY(0);
	-ms-transform: translateY(0);
	transform: translateY(0);
}
#nav-pc.style2 {
	-webkit-transform: translateY(-30px);
	-ms-transform: translateY(-30px);
	transform: translateY(-30px);
}
#nav-pc.style3 {
	-webkit-transform: translateY(-150px);
	-ms-transform: translateY(-150px);
	transform: translateY(-150px);
}
#nav {
	position: fixed;
	height: 100%;
	overflow-y: scroll;
	top: 0;
	background: #fff;
	padding: 40px 2rem 10px 2rem;
	z-index: 9999;
	width: 350px;
	display: none;
}
@media (max-width: 767px) {
	#nav {
   width: 85%;
  padding: 40px 0.5rem 10px 1rem;
	}
}
#nav li {
	text-align: left;
}
#nav .btn-navClose {
	position: fixed;
	height: 30px;
	width: 30px;
	top: 15px;
	right: 15px;
}
#nav .btn-navClose a {
	display: block;
	width: 30px;
	height: 30px;
	font-size: 0;
	line-height: 0;
}
#nav a {
	text-decoration: none;
	display: block;
}
@media (max-width: 767px) {
	#nav a:hover {
		color: #2E3C3D !important;
	}
}
#nav .nav-main {
	margin-top: 15px;
	border-top: 2px solid #333333;
}
#nav .nav-main > li {
	border-top: 1px solid #BCBCBC;
}
#nav .nav-main > li:first-child {
	border-top: none;
}
#nav .nav-main > li img {
	width: 1.8rem;
	height: auto;
	margin-right: 0.5rem;
}
#nav .nav-main > li > a {
	padding: 0.7rem 0.5rem;
}
#nav .nav-main > li ul {
	margin-left: 3rem;
	margin-bottom: 0.7rem;
}
#nav .nav-main > li ul li {
	line-height: 2.5em;
}
#nav .nav-sub {
	border-top: 2px solid #333333;
}
#nav .nav-sub > ul {
	border-top: 1px solid #BCBCBC;
	padding: 0.5rem;
}
#nav .nav-sub > ul:first-child {
	border-top: none;
}
#nav .nav-sub > ul li {
	line-height: 2.5em;
}
#nav .nav-sub > ul li ul {
	margin-left: 4rem;
	margin-bottom: 0.7rem;
}
#nav .nav-sub > ul li ul li {
	line-height: 2.5em;
}
#nav ul li.sub ul {
	display: none;
}
/*::: #contents ::::::::::::::::::::::::::::::::::::::::::::::::*/
#contents {
	margin: 150px 0 160px 0;
}
@media (max-width: 767px) {
	#contents {
		margin: 55px 0 30px 0;
	}
}


/*::: #footer ::::::::::::::::::::::::::::::::::::::::::::::::::*/
#footer {
	background: #333333;
	padding-bottom: 10px;
	color: #fff;
	text-align: center;
}
@media (min-width: 767px) {
	#footer {
		padding: 7px 0 10px;
		margin-top: auto;
	}
}
#footer a {
	color: #fff;
}
#footer #f-nav {
	margin-bottom: 32px;
	background: #fff;
}
#footer .f-tel{
	margin-left: 10px;
}
@media (min-width: 767px) {
	#footer #f-nav {
		display: none;
	}
}
#footer #f-nav a {
	display: block;
	background: #fff;
	padding: 13px 15px;
}
#footer #f-nav li {
	padding: 0;
	border-top: #D3D3D3 1px solid;
}
#footer #f-nav li:nth-child(even) {
	border-left: #D3D3D3 1px solid;
}
#footer h1 {
	margin: 0 auto 20px;
	width: 254px;
}
@media (min-width: 767px) {
	#footer h1 {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}
}
@media (max-width: 767px) {
	#footer h1 .logo {
		margin: 0 auto 0.5rem;
	}
}
@media (max-width: 767px) {
	#footer h1 .logo img {
		width: 71%;
		height: auto;
	}
}
@media (max-width: 767px) {
	#footer h1 .company img {
		width: 50%;
		height: auto;
	}
}
@media (max-width: 767px) {
	#footer h1 {
		display: block;
	}
}
#footer .f-address {
	margin-bottom: 10px;
}
@media (min-width: 767px) {
	#footer .f-address {
		font-size: 100%;
		line-height: 1em;
	}
}
@media (max-width: 767px) {
	#footer .f-address {
		font-weight: bold;
		font-size: 86%;
		line-height: 2em;
		margin-bottom: 20px;
	}
}
@media (min-width: 767px) {
	#footer .f-address a {
		text-decoration: none;
		margin-left: 20px;
	}
}
#footer .f-switch {
	margin-bottom: 20px;
}
@media (min-width: 767px) {
	#footer .f-switch {
		display: none;
	}
}
#footer .f-operation {
	font-size: 79%;
	margin-bottom: 10px;
}
@media (max-width: 767px) {
	#footer .f-operation {
		font-size: 72%;
		line-height: 1.8em;
	}
}
#footer .f-operation a:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
}
#footer .copy {
	font-size: 86%;
	line-height: 1em;
}
@media (max-width: 767px) {
	#footer .copy {
		font-size: 60%;
		display: block;
		transform: scale(0.8);
		line-height: 1.3;
	}
	
}
#footer .copy span {
	font-size: 75%;
}
/* //////// .f-link  //////// */
/* #footer .f-link {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 20px;
}
#footer .f-link li {
	padding: 5px;
}
#footer .f-link li a {
	border: solid 2px #FFF;
	display: inline-block;
	min-width: 105px;
	padding: 10px 18px;
	line-height: 1em;
	text-align: center;
	text-decoration: none;
	white-space: nowrap;
}

@media (min-width: 767px) {
	#footer .f-link li a:hover {
		background: #ffffff;
		color: #333333;
	}
}

@media (max-width: 767px) {
	#footer .container {
	padding-top: 32px;
	padding-right: 0px;
    padding-left: 0px;
    margin-right: auto;
    margin-left: auto;
}
	#footer .f-link {
		margin: 0 0px 34px;
	}
	#footer .f-link li {
		padding: 5px 5px !important;
	}
	#footer .f-link li {
		padding: 4px;
	}
	#footer .f-link li a {
		border: solid 2px #FFF;
		min-width: inherit;
		padding: 6px 12px;
		font-size: 86%;
	}
} */


.o-divider {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap
}
.o-divider__item {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center
}
.o-divider__item::after {
	content: "";
	display: inline-block;
	width: 1px;
	height: 1em;
	background-color: #efefef;
	margin-left: 1em;
	margin-right: 1em
}
.o-divider__item--sp-none::after {
	display: none
}
@media screen and (min-width: 769px) {
	.o-divider__item--sp-none::after {
		display: inline-block
	}
}
.o-divider__item--pc-none::after {
	display: inline-block
}
@media screen and (min-width: 769px) {
	.o-divider__item--pc-none::after {
		display: none
	}
}
.o-divider__item--none::after {
	display: none
}

.l-footer {
	width: 100%;
	background-color: #333
}
.l-footer__inner {
	max-width: 1040px;
	margin-right: auto;
	margin-left: auto;
	padding: 9.333vw 5.333vw
}
@media screen and (min-width: 1041px) {
	.l-footer__inner {
		width: 1040px;
		padding: 75px 0
	}
}
.o-footer>*:not(:last-child) {
	margin-bottom: 7.4%
}
@media screen and (min-width: 769px) {
	.o-footer>*:not(:last-child) {
		margin-bottom: 45px
	}
}
.o-footer__link {
	color: #efefef;
	text-decoration: none;
	font-size: 3.2vw;
	margin-bottom: .75em
}
.o-footer__link:hover {
	text-decoration: none;
	color: #efefef;
}
@media screen and (min-width: 769px) {
	.o-footer__link {
		font-size: 14px
	}
}
.o-footer__link>span {
	font-size: .5em
}
@media screen and (min-width: 769px) {
	.o-footer__button {
		width: 464px
	}
}
.o-footer__logo {
	width: 23.333vw;
	height: 10.933vw;
	margin-right: auto;
	margin-left: auto
}
@media screen and (min-width: 769px) {
	.o-footer__logo {
		width: 154px;
		height: 72px
	}
}
.o-footer__copy {
	text-align: center;
	white-space: nowrap;
	font-size: 2.666vw;
	color: #efefef;
	-webkit-transform: scale(0.85);
	transform: scale(0.85);
	margin-right: -5.334vw;
	margin-left: -5.334vw
}
@media screen and (min-width: 769px) {
	.o-footer__copy {
		font-size: 12px;
		-webkit-transform: scale(1);
		transform: scale(1);
		margin-right: 0;
		margin-left: 0
	}
}
.o-footer__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center
}
.o-footer__list-break-sp {
	width: 100%;
	display: block
}
@media screen and (min-width: 769px) {
	.o-footer__list-break-sp {
		display: none
	}
}
.o-footer__list-break-pc {
	display: none
}
@media screen and (min-width: 769px) {
	.o-footer__list-break-pc {
		width: 100%;
		display: block
	}
}
.o-footer__list-break {
	width: 100%
}

.o-button {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-ms-flex-negative: 0;
	flex-shrink: 0;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	position: relative;
	width: 100%;
	height: 12.266vw;
	font-size: 3.733vw;
	text-decoration: none;
	-webkit-transition: color .25s, border .25s, background-color .25s;
	transition: color .25s, border .25s, background-color .25s;
	color: #333;
	border: 1px solid #ccc;
	background-color: #efefef;
	cursor: pointer
}
.o-button:hover {
	text-decoration: none;
}	
@media screen and (min-width: 769px) {
	.o-button {
		max-width: 464px;
		height: 64px;
		font-size: 16px
	}
}

@media screen and (min-width: 769px) {
	.o-breadcrumb__item:not(:last-child)::after {
		width: 5px;
		height: 12px
	}
}

@media screen and (min-width: 769px) {
    .o-button-ico--arrow-white::after {
        width: 5px;
        height: 12px;
    }
}
.o-button-ico--arrow-white::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 4%;
    width: 5px;
    height: 12px;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-image: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6.035" height="12.64" viewBox="0 0 6.035 12.64"><path d="M595.884,1945.143l-.768-.64,4.733-5.68-4.733-5.68.768-.64,5.267,6.32Z" transform="translate(-595.116 -1932.502)" fill="%23EFEFEF"/></svg>');
}
.o-button-ico--arrow-white:hover::after {
	background-image: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6.035" height="12.64" viewBox="0 0 6.035 12.64"><path d="M595.884,1945.143l-.768-.64,4.733-5.68-4.733-5.68.768-.64,5.267,6.32Z" transform="translate(-595.116 -1932.502)" fill="%23333333"/></svg>');
}


.o-button__text {
	line-height: 1.3
}
.o-button__text--bold {
	font-weight: 700
}
.o-button__text--subtitle {
	font-size: 3.2vw
}
@media screen and (min-width: 769px) {
	.o-button__text--subtitle {
		font-size: 14px
	}
}
.o-button--center {
	margin-right: auto;
	margin-left: auto
}
.o-button--inline {
	height: auto;
	padding: 1em 2em;
	-ms-flex-item-align: start;
	align-self: flex-start;
	width: auto
}
.o-button--large {
	height: 16vw
}
@media screen and (min-width: 769px) {
	.o-button--large {
		height: 75px
	}
}
.o-button--short {
	width: 68vw
}
@media screen and (min-width: 769px) {
	.o-button--short {
		width: 100%
	}
}
.o-button--mini {
	width: 68vw;
	height: 8.666vw
}
@media screen and (min-width: 769px) {
	.o-button--mini {
		width: 350px;
		height: 43px
	}
}
.o-button--skeleton-black {
	border: 1px solid #333;
	color: #333;
	background-color: transparent
}
.o-button--skeleton-black:hover {
	border: 1px solid #efefef;
	color: #efefef
}
.o-button--skeleton-white {
	border: 1px solid #efefef;
	color: #efefef;
	background-color: transparent
}
.o-button--skeleton-white:hover {
	border: 1px solid #333;
	color: #333
}
.o-button--black {
	color: #efefef;
	border: 1px solid #efefef;
	background-color: #333
}
.o-button--black:hover {
	color: #333;
	border: 1px solid #333;
	background-color: #efefef
}
.o-button--sidebar {
	color: #efefef;
	border: 1px solid #efefef;
	background-color: transparent
}
.o-button--sidebar:hover {
	color: #333;
	border: 1px solid #333;
	background-color: #efefef
}
.o-button--border {
	border-color: #333
}

.o-storeinfo {
	text-align: center
}
.o-storeinfo__text {
	color: #efefef;
	font-size: 3.2vw;
	margin-block-end: 0;
}
@media screen and (min-width: 769px) {
	.o-storeinfo__text {
		font-size: 14px
	}
}
.o-storeinfo__text--name {
	margin-bottom: 1em;
	font-size: 3.466vw;
	font-weight: 700
}
@media screen and (min-width: 769px) {
	.o-storeinfo__text--name {
		font-size: 16px
	}
}
.o-storeinfo__tel {
	text-decoration: underline;
	color: #efefef;
	font-size: 3.2vw
}
@media screen and (min-width: 769px) {
	.o-storeinfo__tel {
		font-size: 14px;
		text-decoration: none;
		pointer-events: none;
	}
}
.o-storeinfo__address {
	line-height: 1.5;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center
}
.o-storeinfo__address .o-divider__item {
    width: 100%;
    justify-content: center;
}
@media screen and (min-width: 769px) {
    .o-storeinfo__address .o-divider__item {
        width: auto;
    }
}
.o-storeinfo__text--name {
	font-size:19.2px;
	font-weight: normal;
	font-family: 'Noto Sans JP', sans-serif;
	letter-spacing:0.2em;
}

.o-pagetop {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 999;
}
.o-pagetop.o-pagetop--upper {
	bottom: 136px;
}
@media screen and (min-width:769px) {
	.o-pagetop.o-pagetop--upper {
		bottom: 150px;
	}
}
.o-pagetop button {
	cursor: pointer;
	display: block;
	background: #fff;
	width: 50px;
	height: 50px;
	border-radius: 100px;
	position: relative;
	border: none;
}
.o-pagetop button::after {
	position: absolute;
	content: '';
	right: 0;
	left: 0;
	top: auto;
	bottom: 20px;
	margin: auto;
	width: 12px;
	height: 12px;
	border-right: solid 1px #333;
	border-bottom: solid 1px #333;
	transition: .3s;
	transform: rotate(-140deg) skew(-10deg) translate(0, 0%) scale(1, 1);
}
.o-pagetop button::before {
	position: absolute;
	content: 'TOP';
	right: 0;
	left: 0;
	top: auto;
	bottom: 5px;
	margin: auto;
	color: #333;
	transform: scale(0.7);
}
@media screen and (min-width:769px) {
	.o-pagetop {
		right: 40px;
		bottom: 40px;
	}
	.o-pagetop button {}
	.o-pagetop button::after {}
}



/* //////// h1 //////// */
#footer h1 {
	margin: 0 auto 20px;
	width: 254px;
}
/* ---------------------------------------------------------- */
/*::: 共通 :::*/
/* ---------------------------------------------------------- */
/* 　幅
-----------------------------------*/
@media (min-width: 767px) {
	.w-720 {
		max-width: 750px;
	}
}
/*%*/
@media (max-width: 767px) {
	.w-45-sp {
		width: 45% !important;
	}
	.w-55-sp {
		width: 55% !important;
	}
	.w-90-sp {
		width: 90% !important;
	}
}
/* 　見出しスタイル
-----------------------------------*/
.h-type01 {
	text-align: center;
	padding: 91px 0 53px;
}
@media (max-width: 767px) {
	.h-type01 {
		padding-top: 9.9%;
		padding-bottom: 8.2%;
		margin: 0 10%;
	}
}
.h-type01 img {
	width: auto;
}
@media (min-width: 767px) {
	.h-type01 img {
		height: 41px;
	}
}
@media (max-width: 767px) {
	.h-type01 img {
		height: 35px;
	}
}
.h-type02 {
	color: #333333;
	font-size: 122%;
	font-weight: bold;
	letter-spacing: 0.1em;
}
/*黒太文字 */
.h-type03 {
	font-size: 186%;
	font-weight: bold;
}
@media (max-width: 576px) {
	.h-type03 {
		font-size: 40px;
	}
}
/*青太文字16px */
.h-type04 {
	color: #EC7248;
	font-weight: bold;
	margin-bottom: 20px;
}
@media (max-width: 767px) {
	.h-type04 {
		margin-bottom: 30px;
	}
}
@media (max-width: 576px) {
	.h-type04 {
		margin-bottom: 15px;
	}
}
.h-type05 {
	font-size: 115%;
	font-weight: bold;
	margin-bottom: 10px;
}
.h-type05:before {
	content: '◆';
	margin-right: 3px;
}
.h-type06 {
	font-size: 115%;
}
.h-type06:before {
	content: '■';
	margin-right: 3px;
}
.h-type07 {
	color: #EC7248;
	font-size: 129%;
	background: url(../../fl/img/fl_bg_line01.png) bottom repeat-x;
	background-size: 3px;
	padding-bottom: 10px;
	margin-bottom: 10px;
}
@media (max-width: 767px) {
	.h-type07 {
		font-size: 172%;
		background-size: 2px;
	}
}
.h-type08 {
	color: #223033;
	font-weight: bold;
	line-height: 1em;
	border-bottom: 1px solid #E1E1E1;
}
@media (min-width: 767px) {
	.h-type08 {
		font-size: 108%;
		margin-bottom: 2px;
		padding: 0 20px 11px;
	}
}
@media (max-width: 767px) {
	.h-type08 {
		font-size: 93%;
		margin-bottom: 0.78rem;
		padding: 0 6.5% 0.5rem;
	}
}
/*　文字サイズ
-----------------------------------*/
.font10 {
	font-size: 72% !important;
}
.font11 {
	font-size: 79% !important;
}
.font12 {
	font-size: 86% !important;
}
.font13 {
	font-size: 93% !important;
}
.font15 {
	font-size: 108% !important;
}
.font16 {
	font-size: 115% !important;
}
.font17 {
	font-size: 122% !important;
}
.font18 {
	font-size: 129% !important;
}
.font19 {
	font-size: 136% !important;
}
.font20 {
	font-size: 143% !important;
}
.font21 {
	font-size: 150% !important;
}
.font22 {
	font-size: 158% !important;
}
.font23 {
	font-size: 165% !important;
}
.font24 {
	font-size: 172% !important;
}
.font25 {
	font-size: 179% !important;
}
.font26 {
	font-size: 186% !important;
}
.font27 {
	font-size: 193% !important;
}
.font28 {
	font-size: 200% !important;
}
.font29 {
	font-size: 207% !important;
}
.font30 {
	font-size: 214% !important;
}
@media (max-width: 767px) {
	.font12-xs {
		font-size: 86% !important;
	}
	.font13-xs {
		font-size: 93% !important;
	}
	.font15-xs {
		font-size: 108% !important;
	}
	.font16-xs {
		font-size: 115% !important;
	}
	.font17-xs {
		font-size: 122% !important;
	}
	.font18-xs {
		font-size: 129% !important;
	}
	.font19-xs {
		font-size: 136% !important;
	}
	.font20-xs {
		font-size: 143% !important;
	}
	.font22-xs {
		font-size: 158% !important;
	}
	.font24-xs {
		font-size: 172% !important;
	}
	.font25-xs {
		font-size: 179% !important;
	}
	.font26-xs {
		font-size: 186% !important;
	}
	.font48-xs {
		font-size: 343% !important;
	}
	.font30-xs {
		font-size: 214% !important;
	}
	.space60b-xs {
		margin-bottom: 60px !important;
	}
	.space90b-xs {
		margin-bottom: 90px !important;
	}
}
@media (max-width: 576px) {
	.font12-xxs {
		font-size: 86% !important;
	}
	.font13-xxs {
		font-size: 93% !important;
	}
	.font15-xxs {
		font-size: 108% !important;
	}
	.font14-xxs {
		font-size: 100% !important;
	}
	.font16-xxs {
		font-size: 115% !important;
	}
	.font17-xxs {
		font-size: 122% !important;
	}
	.font18-xxs {
		font-size: 129% !important;
	}
	.font19-xxs {
		font-size: 136% !important;
	}
	.font20-xxs {
		font-size: 143% !important;
	}
	.font22-xxs {
		font-size: 158% !important;
	}
	.font24-xxs {
		font-size: 172% !important;
	}
	.font48-xxs {
		font-size: 343% !important;
	}
}
/*  カラー
----------------------------------*/
.blue {
	color: #EC7248;
}
/*　テキスト
-----------------------------------*/
.l-150 {
	line-height: 1.5em !important;
}
@media (max-width: 767px) {
	.l-100-sp {
		line-height: 1em !important;
	}
	.l-120-sp {
		line-height: 1.2em !important;
	}
	.l-150-sp {
		line-height: 1.5em !important;
	}
}
.bold {
	font-weight: bold;
}
.u-line {
	text-decoration: underline;
}
.nowrap {
	white-space: nowrap;
}
/*  文頭アイコン
----------------------------------*/
.icon-type01:before {
	content: '●';
	margin-right: 3px;
}
.icon-type02:before {
	content: '・';
	margin-right: 5px;
}
/*文頭に※*/
.i-kome {
	font-size: 100% !important;
	padding-left: 25px;
}
@media (max-width: 767px) {
	.i-kome {
		padding-left: 15px;
	}
}
.i-kome:before {
	content: '※ ';
	font-size: 90% !important;
	display: block;
	float: left;
	line-height: 16px;
	margin-left: -20px;
	margin-top: 5px;
}
@media (max-width: 767px) {
	.i-kome:before {
		margin-left: -25px;
		margin-top: 10px;
	}
}
@media (max-width: 576px) {
	.i-kome:before {
		margin-left: -15px;
		margin-top: 3px;
	}
}
/*リスト
-----------------------------------*/
/* ※ */
.list-type01 {
	margin-left: 1.0em;
}
.list-type01 li {
	text-indent: -1.0em;
}
.list-type02 li {
	background: url(../../img/sp_icon_square.png) left 0.5em no-repeat;
	padding-left: 20px;
}
@media (max-width: 577px) {
	.list-type02 li {
		background: url(../../img/sp_icon_square.png) left 0.3em no-repeat !important;
	}
}
.list-type03 li {
	margin-left: 18px;
}
.list-type03 li:before {
	content: '※';
	margin-left: -18px;
}
.list-type04 li {
	margin-left: 18px;
}
.list-type04 li:before {
	content: '・';
	margin-left: -18px;
}
/*:::丸数字リスト:::*/
ol.ol-style01 {
	counter-reset: my-counter;
	list-style: none;
	padding: 0;
}
ol.ol-style01 li {
	margin-bottom: 10px;
	padding-left: 20px;
	position: relative;
}
@media (max-width: 767px) {
	ol.ol-style01 li {
		padding-left: 30px;
	}
}
@media (max-width: 576px) {
	ol.ol-style01 li {
		padding-left: 20px;
	}
}
ol.ol-style01 li::before {
	content: counter(my-counter);
	counter-increment: my-counter;
	background-color: #FFF;
	border: 1px #000 solid;
	color: #2B3336;
	display: block;
	float: left;
	font-size: 86%;
	line-height: 16px;
	margin-left: -20px;
	text-align: center;
	height: 16px;
	width: 16px;
	border-radius: 50%;
	margin-top: 5px;
}
@media (max-width: 767px) {
	ol.ol-style01 li::before {
		margin-left: -30px;
		line-height: 20px;
		font-size: 79%;
		height: 24px;
		width: 24px;
		margin-top: 10px;
	}
}
@media (max-width: 576px) {
	ol.ol-style01 li::before {
		margin-left: -20px;
		line-height: 14px;
		height: 16px;
		width: 16px;
		margin-top: 5px;
	}
}
/*　テーブル
-----------------------------------*/
.table-type01 {
	border: 1px solid #E3E3E3;
	border-collapse: collapse;
	font-size: 93%;
	line-height: 1.5em;
}
.table-type01 th {
	background: #F2F2F2;
	border: 1px solid #E3E3E3;
	text-align: center;
	padding: 10px;
	font-weight: bold;
}
.table-type01 td {
	border: 1px solid #E3E3E3;
	padding: 10px;
	vertical-align: top;
	font-size: 100%;
}
/*　ボックス
-----------------------------------*/
.box-type01 {
	background: #CCE3F1;
	padding: 20px;
}
.box-type02 {
	padding-left: 20px;
	padding-right: 20px;
}
.box-type03 {
	background: #F8F8F8;
	border: 1px #D9D9D9 solid;
	padding: 40px 30px;
}

.box-type04 {
  background: #F8F8F8;
  border: 1px #D9D9D9 solid;
  padding: 20px; }

.bg-gray {
	background: #F5F5F5;
}
/*　ボタン
-----------------------------------*/
.link-type01 {
	max-width: 300px;
	margin: 0 auto 0;
}
.link-type02 {
	max-width: 300px;
	margin: 0 auto 0;
}
.link-type03 {
	max-width: 260px;
	margin: 0 auto 0;
}
@media (max-width: 767px) {
	.link-type01 {
		max-width: 480px;
	}
	.link-type02 {
		max-width: 480px;
	}
	.link-type03 {
		max-width: 480px;
	}
}
.link-type01 a {
	background: #333333;
	display: block;
	padding: 15px 20px;
	text-align: center;
}
.link-type02 a {
	background: #EC7248;
	display: block;
	padding: 15px 20px;
	text-align: center;
}
.link-type03 a {
	background: #EC7248;
	display: block;
	padding: 15px 20px;
	text-align: center;
}
@media (max-width: 767px) {
	.link-type01 a {
		padding: 30px 40px;
	}
}
@media (max-width: 576px) {
	.link-type01 a {
		padding: 5.52174% 5%;
	}
}
@media (min-width: 767px) {
	.link-type01 a:hover {
		opacity: 0.7;
		filter: alpha(opacity=70);
	}
}
@media (min-width: 767px) {
	.link-type02 a:hover {
		opacity: 0.7;
		filter: alpha(opacity=70);
	}
}
@media (min-width: 767px) {
	.link-type03 a:hover {
		opacity: 0.7;
		filter: alpha(opacity=70);
	}
}
/*　スペース
-----------------------------------*/
.space05b {
	margin-bottom: 5px !important;
}
.space10b {
	margin-bottom: 10px !important;
}
.space20b {
	margin-bottom: 20px !important;
}
.space30b {
	margin-bottom: 30px !important;
}
.space40b {
	margin-bottom: 40px !important;
}
.space50b {
	margin-bottom: 50px !important;
}
.space60b {
	margin-bottom: 60px !important;
}
.space70b {
	margin-bottom: 70px !important;
}
.space80b {
	margin-bottom: 80px !important;
}
.space90b {
	margin-bottom: 90px !important;
}
.space30l {
	margin-left: 30px !important;
}
@media (max-width: 767px) {
	.space70b-xs {
		margin-bottom: 70px !important;
	}
}
/*　アコーディオン
-----------------------------------*/
.accordionbox {
	width: 100%;
	margin: 10px auto 40px;
	overflow: hidden;
}
.accordionbox .accordionlist {
	border-bottom: 1px solid #DFDFDF;
}
.accordionbox .accordionlist dt {
	display: block;
	background: #fff;
	padding: 15px 0 10px 5px;
	border-top: 1px solid #DFDFDF;
	cursor: pointer;
	overflow: hidden;
	position: relative;
}
.accordionbox .accordionlist dt .title {
	padding-left: 10px;
	font-size: 115%;
	color: #333333 !important;
}
.accordionbox .accordionlist dt .accordion_icon {
	display: inline-block;
	-webkit-transition: all .4s;
	-o-transition: all .4s;
	transition: all .4s;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 25px;
	height: 26px;
	margin-top: 7px;
	margin-right: 15px;
	position: absolute;
	top: 50%;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 0;
}
.accordionbox .accordionlist dt .accordion_icon span {
	display: inline-block;
	-webkit-transition: all .4s;
	-o-transition: all .4s;
	transition: all .4s;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: absolute;
	left: 5px;
	width: 50%;
	height: 1px;
	background-color: #333333;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-ms-border-radius: 5px;
	-moz-border-radius: 5px;
	-o-border-radius: 5px;
}
.accordionbox .accordionlist dt .accordion_icon span:nth-of-type(1) {
	top: 5px;
	transform: rotate(0deg);
	-webkit-transform: rotate(0deg);
	-moz-transform: rotate(0deg);
	-ms-transform: rotate(0deg);
	-o-transform: rotate(0deg);
}
.accordionbox .accordionlist dt .accordion_icon span:nth-of-type(2) {
	top: 5px;
	transform: rotate(90deg);
	-webkit-transform: rotate(90deg);
	-moz-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	-o-transform: rotate(90deg);
}
.accordionbox .accordionlist dt .accordion_icon.active span:nth-of-type(1) {
	display: none;
}
.accordionbox .accordionlist dt .accordion_icon.active span:nth-of-type(2) {
	top: 5px;
	transform: rotate(180deg);
	-webkit-transform: rotate(180deg);
	-moz-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
	-o-transform: rotate(180deg);
}
.accordionbox .accordionlist dd {
	display: none;
	margin: 0 20px;
	padding: 10px 20px 10px 20px;
	line-height: 2em;
}
/*　トップへ戻る
-----------------------------------*/
.backtotop {
	position: fixed;
	right: 15px;
	bottom: 20px;
	z-index: 9000;
	display: none;
}
.backtotop a {
	display: block;
	margin: 0;
}
.backtotop:hover {
	opacity: 0.8;
}
/*　表示・非表示
-----------------------------------*/
.visible-xs, .visible-sm, .visible-md, .visible-lg, .visible-xl, .visible-xs-block, .visible-xs-inline, .visible-xs-inline-block, .visible-sm-block, .visible-sm-inline, .visible-sm-inline-block, .visible-md-block, .visible-md-inline, .visible-md-inline-block, .visible-lg-block, .visible-lg-inline, .visible-lg-inline-block, .visible-xl-block, .visible-xl-inline, .visible-xl-inline-block {
	display: none !important;
}
/*SP*/
@media (max-width: 576px) {
	.visible-xs {
		display: block !important;
	}
	.visible-xs-block {
		display: block !important;
	}
	.visible-xs-inline {
		display: inline !important;
	}
	.visible-xs-inline-block {
		display: inline-block !important;
	}
}
/*Fabret*/
@media (min-width: 577px) and (max-width: 766px) {
	.visible-sm {
		display: block !important;
	}
	.visible-sm-block {
		display: block !important;
	}
	.visible-sm-inline {
		display: inline !important;
	}
	.visible-sm-inline-block {
		display: inline-block !important;
	}
}
/*Tabret*/
@media (min-width: 767px) and (max-width: 991px) {
	.visible-md {
		display: block !important;
	}
	.visible-md-block {
		display: block !important;
	}
	.visible-md-inline {
		display: inline !important;
	}
	.visible-md-inline-block {
		display: inline-block !important;
	}
}
/*NotePC*/
@media (min-width: 992px) {
	.visible-lg {
		display: block !important;
	}
	.visible-lg-block {
		display: block !important;
	}
	.visible-lg-inline {
		display: inline !important;
	}
	.visible-lg-inline-block {
		display: inline-block !important;
	}
}
/*DesktopPC*/
@media (min-width: 1200px) {
	.visible-xl {
		display: block !important;
	}
	.visible-xl-block {
		display: block !important;
	}
	.visible-xl-inline {
		display: inline !important;
	}
	.visible-xl-inline-block {
		display: inline-block !important;
	}
}
@media (max-width: 576px) {
	.hidden-xs {
		display: none !important;
	}
}
@media (min-width: 577px) and (max-width: 766px) {
	.hidden-sm {
		display: none !important;
	}
}
@media (min-width: 767px) and (max-width: 991px) {
	.hidden-md {
		display: none !important;
	}
}
@media (min-width: 992px) {
	.hidden-lg {
		display: none !important;
	}
}
@media (min-width: 1200px) {
	.hidden-xl {
		display: none !important;
	}
}