@charset "UTF-8";

 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
base
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

html, body {
	height: 100%;
	min-width: 1016px;
	-webkit-text-size-adjust: none;
}
#wrapper {
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	min-height: 100%;
}

a { text-decoration: none; }
a:hover { text-decoration: underline; }
a > img {
	transition-duration: 0.3s;
	-o-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
	-moz-transition-duration: 0.3s;
	-webkit-transition-duration: 0.3s;
}
img { vertical-align: middle; }
a:hover > img {
	opacity: 0.6;
	filter: alpha(opacity=60);
}

.inner {
	width: 960px;
	margin-left: auto;
	margin-right: auto;
}

.pageTitle {
	color: #000;
	font-size: 30px;
	font-weight: bold;
	text-align: center;
	padding: 87px 0 10px;
	letter-spacing: 0.19em;
}

#container { padding-bottom: 92px; }
#main {
	font-size: 18px;
	text-align: center;
}
#main .text {
	padding: 30px 0 82px;
	letter-spacing: 0.09em;
}
.ipad #main .text { letter-spacing: 0.02em; }

.column:after {
	content: "";
	display: block;
	clear: both;
}
.fl { float: left; }
.fr { float: right; }
.fl, .fr { width: 455px; }

.sTitle {
	color: #069;
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 3px;
}

#instagram {
	max-width: 960px;
	margin: 0 auto;
	overflow: hidden;
}
.home #instagram {
	margin-top: 50px;
}
.repair #instagram {
	margin-top: 1.5em;
}
#instagram iframe {
	vertical-align: top;
}

#bnr_contact {
	top: 569px;
	left: calc(50vw + 295px);
	position: fixed;
	z-index: 1;
}
#bnr_contact a {
	display: block;
}
#bnr_contact img {
	width: 276px;
	height: 276px;
}

 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
header
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

#wrapper > header {
	text-align: center;
	background: #e5ecec;
}
#wrapper > header h1 {
	padding: 15px 0;
}
#wrapper > header nav {
	font-size: 0;
	line-height: 1;
	background: #000;
}
/*****#wrapper > header nav div {
	position: relative;
	display: inline-block;
}
#wrapper > header nav p {
	width: 0;
	height: 0;
	position: absolute;
	top: 0;
	left: 0;
	display: none;
	margin-left: -5px;
	border: solid transparent;
	border-width: 7px 5px 0;
	border-top-color: #e5ecec;
	letter-spacing: 0;
}
#wrapper > header nav p.move {
	display: block;
	transition-duration: .5s;
	-moz-transition-duration: .5s;
	-webkit-transition-duration: .5s;
}*****/
#wrapper > header nav li {
	font-size: 16px;
	/*****display: inline-block;*****/
}
/*****#wrapper > header nav a {
	color: #fff;
	display: block;
	padding: 22px 20px 23px;
	transition-duration: .3s;
	-moz-transition-duration: .3s;
	-webkit-transition-duration: .3s;
}
#wrapper > header nav a:hover {
	color: #3cf;
	text-decoration: none;
}*****/
#wrapper > header nav a span {
	display: block;
	color: #3cf;
	font-size: 12px;
	margin-top: 7px;
}


/*****20240318-start************************************************************/

/*========= ナビゲーションドロップダウンのためのCSS ===============*/

/*==ナビゲーション全体の設定*/
#wrapper > header nav {
	
	background:#000;
	color:#fff;
	text-align: center;
}
/*ナビゲーションを横並びに*/
#wrapper > header nav ul{
	list-style: none;
	display: flex;
	justify-content: center;
}
/*2階層目以降は横並びにしない*/
#wrapper > header nav ul ul{
	display: block;
}

/*下の階層のulや矢印の基点にするためliにrelativeを指定*/
#wrapper > header nav ul li{
	position: relative;
}

/*ナビゲーションのリンク設定*/
#wrapper > header nav ul li a{
	display: block;
	text-decoration: none;
	color: #fff;
	padding:23px 30px ;
	transition:all .3s;
}

#wrapper > header nav ul li li a{
	padding:15px 15px ;
}

#wrapper > header nav ul li a:hover{
	color:#3cf;	
}

/*==矢印の設定*/

/*2階層目を持つliの矢印の設定*/
#wrapper > header nav ul li.has-child::before{
	content:'';
	position: absolute;
	left:0px;
	top:25px;
	width:6px;
	height:6px;
	border-top: 2px solid #fff;
	border-right:2px solid #fff;
	transform: rotate(135deg);
}

/*3階層目を持つliの矢印の設定*/
#wrapper > header nav ul ul li.has-child::before{
	content:'';
	position: absolute;
	left:6px;
	top:17px;
	width:6px;
	height:6px;
	border-top: 2px solid #fff;
	border-right:2px solid #fff;
	transform: rotate(45deg);
}

/*== 2・3階層目の共通設定 */

/*下の階層を持っているulの指定*/
#wrapper > header nav li.has-child ul{
	/*絶対配置で位置を指定*/
	position: absolute;
	left:0;
	top:81px;
	z-index: 4;
	/*形状を指定*/
	background:#3cf;
	width:200px;
	/*はじめは非表示*/
	visibility: hidden;
	opacity: 0;
	/*アニメーション設定*/
	transition: all .3s;
}

/*hoverしたら表示*/
#wrapper > header nav li.has-child:hover > ul,
#wrapper > header nav li.has-child ul li:hover > ul,
#wrapper > header nav li.has-child:active > ul,
#wrapper > header nav li.has-child ul li:active > ul{
  visibility: visible;
  opacity: 1;
}

/*ナビゲーションaタグの形状*/
#wrapper > header nav li.has-child ul li a{
	color: #fff;
	border-bottom:solid 1px rgba(255,255,255,0.6);
}

#wrapper > header nav li.has-child ul li:last-child > a{
 border-bottom:none;
 }

#wrapper > header nav li.has-child ul li a:hover,
#wrapper > header nav  li.has-child ul li a:active{
	background:#3577CA;
}

/*==768px以下の形状*/

@media screen and (max-width:768px){
	nav{
		padding: 0;
	}
	
	nav ul{
		display: block;
	}
	
	nav li.has-child ul,
	nav li.has-child ul ul{
	position: relative;
	left:0;
	top:0;
	width:100%;
	visibility:visible;/*JSで制御するため一旦表示*/
	opacity:1;/*JSで制御するため一旦表示*/
	display: none;/*JSのslidetoggleで表示させるため非表示に*/
	transition:none;/*JSで制御するためCSSのアニメーションを切る*/
}
	
nav ul li a{
	border-bottom:1px solid #ccc;
}

/*矢印の位置と向き*/

nav ul li.has-child::before{
	left:20px;	
}

nav ul ul li.has-child::before{
	transform: rotate(135deg);
	left:20px;
}
	
nav ul li.has-child.active::before{
	transform: rotate(-45deg);
}

}

/*****20240318-end************************************************************/




 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
footer
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
#wrapper > footer {
	color: #000;
	font-size: 14px;
	font-weight: bold;
	text-align: center;
	background: #e5ecec;
}
#wrapper > footer .logo { padding: 92px 0 13px; }
#wrapper > footer .tel { padding: 12px 0 15px; }
#wrapper > footer .time { font-size: 12px; }
#wrapper > footer > div {
	color: #6e6e6e;
	background: #000;
	margin-top: 89px;
	padding: 26px 0 33px;
	line-height: 2;
	font-weight: normal;
}
#wrapper > footer > div a { color: #6e6e6e; }
#wrapper > footer > div ul {
	overflow: hidden;
	vertical-align: top;
	display: inline-block;
}
#wrapper > footer > div li { float: left; }
#wrapper > footer > div li:after {
	content: "｜";
	margin: 0 0.5em;
}
#wrapper > footer > div li:first-child:before {
	content: "｜";
	margin: 0 0.5em;
}
#wrapper > footer > div p {
	margin-top: 2em;
}