@charset "UTF-8";

/* http://meyerweb.com/eric/tools/css/reset/
v2.0 | 20110126
License: none (public domain)
*/
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, 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,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
line-height: 26px;
letter-spacing: 1.4px;
font-family: "ryo-gothic-plusn";
}
ol, ul {
list-style: none;
}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}

.sp {
	display: none;
}
.pc {
	display: block;
}
a {
	transition: 0.5s;
}
a:hover {
	opacity: 0.7;
	transition: 0.5s;
	cursor: pointer;
}


/* header */
header {
    background: #222;
}
header nav ul {
    float: right;
    color: white;
}
header nav {
    max-width: 960px;
    width: 100%;
    margin: 0 auto;
	content: "";
    display: table;
    clear: both;
}
header nav ul a {
    color: white;
}
header nav img:nth-of-type(1) {
	width: 140px;
}
header nav img:nth-of-type(2) {
	width: 14px;
}
header nav ul li {
	display: inline-block;
	margin: 30px 0;
	font-size: 14px;
	position: relative;
}
header nav ul li:first-child {
	border-right: 1px solid white;
	padding: 0 26px;
}
header nav ul li:last-child {
    padding: 0 26px;
}
header nav ul li:before{
  position: absolute;
  top: 1.9em;
  left: 0;
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background: #00ae3c;
  transition: 0.6s;
}
header nav ul li:first-child {
	border-right: 1px solid white;
	padding: 0 26px;
}
header nav ul li:last-child {
    padding: 0 26px;
}
header nav ul li:before{
  position: absolute;
  top: 1.9em;
  left: 0;
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background: #00ae3c;
  transition: 0.6s;
}
header nav ul li:hover:before{
  width: 100%;
}
h1 {
    margin-top: 34px;
    color: white;
    font-size: 13px;
    float: left;
}
h1 a {
    color: white;
    text-decoration: none;
}

/* mainVisual */
.mainVisual {
	position: relative;
    padding-bottom: 40px;
    background: #f0f0f0;
}
.mainVisual img {
    width: 100%;
}
.mainTitle {
    position: absolute;
    top: 0;
    width: 100%;
    font-size: 21px;
}
.mainTitle .background {
	background: white;
	opacity: 0.5;
	height: 70px;
}
.mainTitle h2 {
    position: absolute;
    right: 0;
    left: 0;
    margin: auto;
    margin-top: 7px;
    z-index: 1;
    max-width: 960px;
    width: 100%;
    background: #d40a0a;
    text-align: center;
}
.mainTitle-shop h2 {
	position: static;
	margin: 0 auto;
	margin-top: 7px;
    z-index: 1;
    max-width: 960px;
    width: 100%;
    background: #d40a0a;
    text-align: center;
}
.mainTitle h2 a,.mainTitle-shop h2 a {
	text-decoration: none;
    color: white;
    display: block;
    padding: 15px 0;
}

/*  */
section {
	max-width: 960px;
	width: 100%;
	margin: 0 auto;
	content: "";
    display: table;
    clear: both;
    position: relative;
}
h4 {
	text-align: center;
	margin-bottom: 90px;
}
section h3,section p {
	text-align: center;
}
section h3 {
	font-size: 24px;
	margin-bottom: 38px;
}
section h3:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-bottom: 1px solid #333;
    height: 30px;
    width: 70px;
    margin: 0 auto;
    padding-bottom: 16px;
}
section .title {
	margin-bottom: 70px;
}
section ul {
    margin-bottom: 120px;
}
section ul li {
    display: inline-block;
    max-width: 294px;
}
section ul li:not(:nth-child(3n)) {
	margin-right: 32px;
}
section ul li:nth-child(1) {
    margin-bottom: 10px;
}
section ul li img {
	width: 100%;
}
.map {
	margin-bottom: 70px;
}
dl {
	width: 100%;
	max-width: 440px;
	float: left;
    margin-bottom: 44px;
}
dt {
	float: left;
	clear: left;
	width: 100%;
	max-width: 140px;
    margin-bottom: 36px;
    font-weight: bold;
}
dd {
	float: left;
	width: 100%;
	max-width: 300px;
    margin-bottom: 36px;
}
/* company */
.company-top {
	width: 100%;
	margin-bottom: 70px;
}
.company-top img {
	width: 100%;
}
/* footer */
.banner {
	background: #737373;
	margin
}
.banner ul li {
	float: left;
    margin: 43px 0;
}
.banner ul li:not(:last-child) {
	margin-right: 33px;
}
.banner ul li img {
	max-width: 165px;
}
.banner ul {
	max-width: 960px;
    width: 100%;
    margin: 0 auto;
    content: "";
    display: flex;
    clear: both;
    justify-content: center;
}
footer {
	background: #222222;
	text-align: center;
	color: white;
	padding: 20px 0;
	font-size: 11px;
}

/* shop__header */
.mainTitle-shop {
	position: static;
    font-size: 21px;
}
#breadcrumbs {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
}
#breadcrumbs ul li {
    display: inline-block;
}
h2.tk-futura-pt {
    margin: 80px 0;
    font-size: 50px;
    text-align: center;
}
.shop-img {
	margin-bottom: 23px;
}
.shop-img img {
	width: 100%;
	display: block;
}
#box01,#box02,#box03,#box04,#box05,#box06 {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    padding-bottom: 50px;
}
ul.tab-list {
    margin-bottom: 50px;
}

main {
    background: #f0f0f0;
    display: block;
}
.tab-hidden {
	display: none;
}
.hide {
	display: none;
}
.tab-list li {
    display: inline-block;
    width: 24%;
    background: black;
    color: white;
    text-align: center;
    padding: 10px 0;
}
.tab-list li.select {
	background: white;
	color: black;
	border: 1px solid black;
}
.shop-box {
    width: 100%;
    max-width: 455px;
    max-height: 165px;
    float: left;
    background: white;
    position: relative;
    margin-bottom: 12px;
}
.shop-box figure img {
    width: 100%;
}
.shop-box figure {
    margin: 10px;
    background: white;
    max-width: 145px;
    float: left;
}
.shop-box figcaption {
    float: left;
    margin: 10px;
}
.shop-box h3 {
	font-size: 15px;
    margin-bottom: 20px;
    text-align: left;
    font-weight: bold;
}
.shop-box figcaption dl dt,
.shop-box figcaption dl dd {
    font-size: 12px;
    margin-bottom: 18px;
}
#tab-01:checked ~ #tab-01-box {
	display: block;
	opacity: 1;
}
.shop-box dt {
	float: left;
	width: 70px;
}
.shop-box dd {
	float: left;
	width: 170px;
}
.shop-box dl {
	margin-bottom: 0;
}
.shop-box .map {
	margin-bottom: 0;
    position: absolute;
    right: 10px;
    bottom: 20px;
}
.shop-box .map a {
	color: white;
	text-decoration: none;
    background: #00ae3c;
    padding: 10px 4px;
}
.shop-box figcaption dl dt:nth-of-type(3),
.shop-box figcaption dl dd:nth-of-type(3) {
    margin-bottom: 0;
}
.shop figcaption p {
    font-size: 12px;
    text-align: left;
}
.shop-box:nth-child(odd) {
    margin-right: 50px;
}
.shop .shop-img {
	margin-bottom: 50px;
}
#box01 section h3:after,
#box02 section h3:after,
#box03 section h3:after {
	content: none;
}
.shop-box h3 span {
    font-size: 10px;
    font-weight: normal;
}
.sp {
	display: none;
}
.sp-se {
	display: none;
}
#box03 .shop-box h3 {
	font-size: 15px;
}
#box03 .shop-box {
	max-height: 190px;
}
.shop figcaption p {
    text-indent: -40px;
    padding-left: 40px;
}

#breadcrumbs ul li a {
	color: black;
	font-size: 11px;
}
#breadcrumbs ul li:first-child a {
    text-decoration: none;
}

/* sp */
@media screen and (max-width: 320px)  {
	dd {
		max-width: 210px!important;
	}
	.sp-se {
		display: block;
	}
	.shop-box .map {
	    margin-bottom: 0;
	    position: absolute;
	    left: 10px;
	    top: 90px!important;
	}
}
@media screen and (max-width: 768px)  {
	#box01, #box02, #box03, #box04, #box05, #box6 {
		padding-bottom: 20px;
	}
	.shop .shop-img {
		margin-bottom: 30px;
	}
	/*.shop-box:nth-of-type(9),
	.shop-box:nth-of-type(10),
	.shop-box:nth-of-type(11),
	.shop-box:nth-of-type(12),
	.shop-box:nth-of-type(13),*/
	#box02 .shop-box {
	    /*max-height: 190px;*/
			max-height: 100%;
	}
	#box03 .shop-box {
		max-height: 210px;
	}
	.swiper-container {
	    background: #737373;
	    padding-top: 10px!important;
	}
	.shop-box .map {
	    margin-bottom: 0;
	    position: absolute;
	    left: 10px;
	    top: 100px;
	}
	.sp {
		display: block;
	}
	.pc {
		display: none;
	}
	h1 {
	    margin-top: 20px;
	    margin-left: 5%;
        line-height: 20px;
	}
	header nav ul {
		margin: 0;
	    margin-right: 10px;
	}
	header nav ul li {
		font-size: 12px;
	    margin: 26px 0;
	}
	header nav ul li:first-child,header nav ul li:last-child {
		padding: 0 12px;
	    margin: 20px 0 10px 0;
	}
	header nav img:nth-of-type(1) {
		width: 80px;
	}
	.mainTitle {
		font-size: 14px;
	}
	.mainTitle h2,
	.mainTitle-shop h2 {
		width: 90%;
	}
	.mainTitle h2 a {
		padding: 5px 0;
	}
	.mainTitle .background {
		height: 52px;
	}
	body {
		font-size: 12px;
	}
	h4 {
		padding: 5%;
	    margin-bottom: 0;
	}
	section .title {
		margin: 5%;
	}
	section h3:after {
		top: 15px;
	}
	section ul {
	    text-align: center;
	    margin: 5%;
	}
	section ul li {
		max-width: 30%;
	}
	section ul li:not(:nth-child(3n)) {
		margin-right: 10px;
	}
	.company-top {
		margin-bottom: 5%;
	}
	dt {
		margin-bottom: 0;
		width: 80px;
	    margin-left: 5%;
	}
	dd {
		margin-bottom: 2%;
		max-width: 240px;
	}
	.map {
		margin-bottom: 5%;
	}
	.banner ul li:not(:last-child) {
		margin-right: 0;
	}
	.banner ul li {
    float: left;
    margin: 0;
    width: 30%;
	}
	.banner ul li img {
		width: 100%;
		display: block;
	}
	.banner ul {
    padding: 5%;
    width: auto;
	}
	h2.tk-futura-pt {
    margin: 5% 0;
    font-size: 30px;
    text-align: center;
	}
	#breadcrumbs {
	padding: 0 5%;
	width: auto;
	}
	.mainTitle-shop {
		position: static;
	    font-size: 14px;
	}
	.mainTitle-shop h2 a {
		padding: 5px 0;
	}
	.shop-box dt {
		font-size: 11px;
	}
	.shop-box dd {
		max-width: 210px;
	}
	.shop-box dl {
		margin: 0 auto;
	}
	.shop-box figure {
		width: 20%;
		float: none;
	}
	.shop-box figcaption {
		float: none;
	}
	.mainVisual {
		padding-bottom: 20px;
	}
	.shop-box {
		display: flex;
		max-height: 100%;
	}
	.shop-box.ttl {
    justify-content: center;
	}
	.banner ul li:nth-child(4) {
    	margin-left: 5%;
	}
	.banner ul li:first-child {
    	margin-left: 5%;
	}
	.shop-box h3 {
	    font-size: 13px;
	    margin-bottom: 12px;
	}
	.shop figcaption p {
	    font-size: 10px;
	    text-indent: -36px;
    	padding-left: 36px;
	}
	header nav ul li:hover:before,
	header nav ul li:before{
  		display: none;
  		pointer-events: none;
	}
	li.swiper-slide {
    	text-align: center;
	}

}
@media screen and (min-width: 768px) and (max-width: 960px) {
	.shop-box {
		max-width: 100%;
		max-width: none;
    	width: 90%;
    	margin-left: 5%;
    	content: "";
    	display: table;
    	clear: both;
	}
	section ul li {
		max-width: 210px;
	}
	section ul {
		text-align: center;
	}
	dl {
		float: none;
		margin: 0 auto;
	}
	.banner {
		padding-left: 5%;
	}

}

.shop-box h3.m-btm {
	line-height: 1.3;
    margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
	.shop-box h3.m-btm {
	    line-height: 1;
    	padding-top: 7px;
	    margin-bottom: 10%;
	}
}

p.p-f {
    font-size: 12px;
    margin-bottom: -40px;
    padding-top: 40px;
}
.shopTitle p.p-f {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    margin-top: -25px;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 10px;
}
@media screen and (max-width: 768px) {
	p.p-f {
	    padding-top: 5%;
	    width: 90%!important;
	    margin: 0 auto;
	    margin-bottom: 3%;
	    font-size: 10px;
        line-height: 1.8;
        margin-bottom: -25px!important;
	}
	.shopTitle p.p-f {
		width: 90%;
	    margin-top: 0;
	    margin-bottom: 0;
	    padding-top: 3%;
	    padding-bottom: 5%;
	    text-align: left;
	}
}

.shop-img p.p-f {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    margin-top: 0;
    margin-bottom: -40px;
    padding-top: 0;
    padding-bottom: 10px;
    margin-top: 25px;
}


/* topMV削除 一時的な修正 */
.hp_pt {
	padding-top: 110px;
}
@media screen and (max-width: 768px) {
	.hp_pt {
		padding-top: 10%;
	}
}

/* 240509 */
.shop-box.ttl {
	background: none;
	max-width: fit-content;
}
.shop-box.ttl img {
    width: 100%;
    max-width: 165px;
}
.shop-box.ttl + .shop-box {
    max-width: 745px;
}
@media screen and (max-width: 768px) {
	.shop-box.ttl img {
			width: 100%;
			max-width: 120px;
	}
	.shop-box.ttl {
    text-align: center;
		        max-width: 100%;
	}
}

/* 250602 */
	#box04 section h3:after,
	#box05 section h3:after,
	#box06 section h3:after {
		display: none;
	}
