@charset "utf-8";

/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */

:focus{
outline:0;
}

ol, ul{
list-style:none;
}

table{
border-collapse:separate;
border-spacing:0;
}

caption,th,td{
font-weight:normal;
text-align:left;
}

blockquote:before,blockquote:after,q:before,q:after{
content:"";
}

blockquote,q{
quotes:"" "";
}

a img{
border: 0;
}

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

body{
font:15px/2.0;
font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
-webkit-text-size-adjust:100%;
color:#000;
}

@media only screen and (min-width:810px){
body{
font:12px/2.0;
}
}

#space{
clear:both;
height:30px;
}



/* リンク設定
------------------------------------------------------------*/

a{
margin:0;
padding:0;
text-decoration:none;
outline:0;
vertical-align:baseline;
background:transparent;
font-size:100%;
color:#000;
}

a:hover, a:active{
outline:none;
color:#cdcdcd;
}

a:hover img.link {
	opacity:0.5;
	filter: alpha(opacity=80);
	-ms-filter: "alpha(opacity=80)";
}

/**** Clearfix ****/

.nav .panel:before,nav .panel:after, #mainNav:before,#mainNav:after, .newsTitle:before,.newsTitle:after{
content:"";
display:table;
}

nav.panel:after,#mainNav:after,.newsTitle:after{
clear: both;
}

nav.panel,#mainNav,.newsTitle{
zoom: 1;
}



/* ヘッダー
------------------------------------------------------------*/



/* タイポグラフィ
------------------------------------------------------------*/


/* メインメニュー　PC用
------------------------------------------------------------*/

@media only screen and (min-width:810px){

#header{
margin-top:20x;
position:fixed;
width:100%;
z-index: 999900;
background-color:rgba(255,255,255,0.95);	/* マスクは半透明 */
height:70px;
}

#headerWrap_l{
position:relative;
width:425px;
height:38px;
float:left;
padding-top:15px;
padding-left:50px;
}

#headerWrap_l img{
position:relative;
width:100%;
}

#headerWrap_r{
position:relative;
width:470px;
height:20px;
float:right;
padding-top:2px;
padding-left:40px;
}

nav#mainnav{
position:relative;
margin-top:10px;
}

nav#mainnav ul{
display:flex;
justify-content:center;
align-items:center;
float:right;
}

nav#mainnav ul li{
float:left;
text-align:center;
}

nav#mainnav ul li a{
display:block;
text-align:center;
float:left;
height:14px;
padding:5px 0 12px;
line-height:1.5;
font-size:16px;
}

nav#mainnav ul li a:hover{
color:#999999;
}

nav#mainnav ul ul{
width:120px;
margin:0 auto;
border-top:0;
margin-left:-20px;
}

nav#mainnav ul li ul{
display: none;
}

nav#mainnav ul li:hover ul{
display: block;
position: absolute;
top:32px;
text-align:center;
z-index:500;
border:1px solid #666666;
border-radius:5px;
}

nav#mainnav ul li li{
background:#FFFFFF;
border-bottom:1px dotted #cdcdcd;
float: none;
width:120px;
height:40px;
line-height:40px;
margin:0;
font-size:14px;
}

nav#mainnav ul li li.none_mn{
display:none;
}

.mn100p{
width:85px;
}

.mn110p{
width:85px;
}

.mn120p{
width:100px;
}



.mn_shop{background:#3B3B3B; padding:0 54px 2px 20px;}

.mn_shop a{ color:#FFFFFF;}

nav#mainnav ul li li:last-child{
border:0;
}

nav#mainnav ul li li a{
width:100%;
height:40px;
padding:0;
line-height:40px;
font-size:95%;
text-align:center;
}

nav#mainnav ul li li a:hover{
color:#FFF;
background:#3B3B3B;
}

nav div.panel{
display:block !important;
}

a#menu{
display:none;
}

#space_sp{
height:0;
}

.sp_mn_copy{
display:none;
}

}


@media only screen and (max-width:1100px){
#headerWrap_l{
position:relative;
width:39%;
float:left;
padding-top:15px;
padding-left:25px;
}

#headerWrap_r{
padding-left:0;
}

.mn100p{
width:65px;
}

.mn110p{
width:65px;
}

.mn120p{
width:90px;
}
}

@media only screen and (max-width:950px){
#headerWrap_l{
position:relative;
width:38%;
float:left;
padding-top:15px;
padding-left:20px;
}
}

/* iPadサイズ以下（1024px）からアコーディオンメニュー
------------------------------------------------------------*/

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

#headerWrap_l{
position:relative;
width:70%;
float:left;
padding-top:10px;
padding-left:14px;
z-index:99999;
}

#headerWrap_l img{
width:100%;
}

.blue{
background:none;
margin-top:0;
}

#space_sp{
height:60px;
}

#header{
margin-top:20x;
position:fixed;
width:100%;
z-index:5000;
background-color:rgba(255,255,255,0.95);	/* マスクは半透明 */
height:50px;
}
	
#headerWrap{
position:relative;
width:100%;
height:10px;
background:#333
border-bottom:1px solid #444444;
}


#header h2{
padding-top:20px;
}
	
#header h2 img{
max-height:60px;
margin-top:-4px;
width:auto !important;
}

#header .pnav ul{
display:none;
}


a#menu{
display:inline-block;
position:relative;
width:50px;
height:50px;
background:#000000;
margin-bottom:-5px;
}

#menuBtn{
display:block;
position:absolute;
top:70%;
left:45%;
width:18px;
height:2px;
margin:-11px 0 0 -7px;
background:#FFF;
color:#333333;
transition:.2s;
}

#menuBtn:before, #menuBtn:after{
display:block;
content:"";
position:absolute;
top:50%;
left:0;
width:18px;
height:2px;
background:#FFF;
transition:.3s;
}

#menuBtn:before{
margin-top:-7px;
}

#menuBtn:after{
margin-top:5px;
}

a#menu .close{
background:transparent;
}

a#menu .close:before, a#menu .close:after{
margin-top:0;
}

a#menu .close:before{
transform:rotate(-45deg);
-webkit-transform:rotate(-45deg);
}

a#menu .close:after{
transform:rotate(-135deg);
-webkit-transform:rotate(-135deg);
}

.panel{
width:100%;
display:none;
position:fixed;
left:0;
top:30;
z-index:100;
overflow-y: scroll;
height:100%;
-ms-overflow-style: none;  /* これを追加 */
}

.panel::-webkit-scrollbar {
    display:none;
}

#mainnav{
position:absolute;
top:0;
width:100%;
text-align:right;
z-index:500;
margin-top:-3px;
}


#mainnav ul{
background-color:rgba(59,59,59,1);	/* マスクは半透明 */
text-align:left;
padding:30px 0 30px;
}

#mainnav li a{
position:relative;
display:block;
padding-top:16px;
padding-left:8%;
padding-right:8%;
color: #FFF;
font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
font-weight:bold;
font-size:48px;
line-height:1;
clear:both;
}

#mainnav ul li ul{
border:0;
width:86%;
clear:both;
margin:-28px auto -20px;
height: auto;
display: flex;
justify-content: center;
flex-wrap: wrap;
}

#mainnav ul li ul li{
border:0;
width: 50%;
margin: 0;
display: table-cell;
}

#mainnav ul li ul li a{
color: #FFF;
font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
font-weight:normal;
font-size:15.36px;
letter-spacing:-0.04em;
}

nav#mainnav ul li li.none_mn{
display:block;
}

.sp_mn_copy{
padding-top:80px;
padding-left:10%;
padding-right:10%;
padding-bottom:30px;
font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
font-size:11.52px;
color:#FFFFFF;
display:block;
}

h2.title{
font-size:130%;
}

.mn100p{
width:100%;
}

.mn110p{
width:100%;
}

.mn120p{
width:100%;
}


#wrapper, .inner{
width:100%;
}

.contact{
display:none;
}

#header h1{
display:none;
}

#mainImg img{
display:none;
}

#sp_mainImg img{
padding-top:60px;
width:100%;
height:auto;
display:block;
}

h2.first{
margin-top:45px;
}

h2.title{
padding-top:35px;
}

.thumbWrap{
width:100%;
}

.thumbWrap ul.thumbUnder li{
width:30%;
display:inline-block;
vertical-align:top;
margin:0 1% 0 1.5%;
}

.thumbWrap ul.thumbUnder li img{
width:100%;
}

.thumbWrap ul.thumb li{
width:30%;
float:left;
margin:0 1% 0 2%;
}

#content, #sidebar{
clear:both;
width:95%;
float:none;
margin:0 auto;
padding:10px 0;
}

#banners{
width:100%;
text-align:center;
}

#banners p{
width:30%;
float:left;
margin:0 1% 0 1.5%;
}

#banners p img{
width:100%;
height:auto;
}

#contactBanner{
margin:0 auto;
}

#footer{
margin:0;
border:0;
text-align:center;
}

#footerLogo, #footer ul{
float:none;
width:auto;
padding-bottom:20px;
text-align:center;
}

#footer ul{
padding-top:20px;
}

}


