@charset "utf-8";

/*==========
リセット用
==========*/
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6,
 pre, form, fieldset, input, select, textarea, p, blockquote, th, td, img{
    margin: 0;
    padding: 0;
}

ol, ul{
    list-style:none;
}

fieldset, img{
     border:0;
}

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

caption, th{
    text-align: left;
}

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

img {
  vertical-align: bottom;
}

a{
    text-decoration: none;
        color: #333;
}

a:hover{
    text-decoration: underline;
}

p,h1,h2,h3,h4,h5{/*Android端末での途中改行回避用*/
    background: url("images/common/blank.png");
}

/*ベースフォントサイズ 100%=10px*/
body {
    font-size: 62.5%; /* IE */
}
html>/**/body {
    font-size: 10px; /* Except IE */
}

body{
font-family: Helvetica , Arial , Verdana , "游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" , "メイリオ" , Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif;
    color: #666666;
}


h1, h2, h3, h4, h5, h6{
    font-size: 100%;
    font-weight: normal;
}

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

/* exclude MacIE5 */
*html .clearfix{height: 1%;}
*+html .clearfix{height: 1%;}
.clearfix {display: block;}
/* end MacIE5 */

/*テキスト*/
.txt_c{
    text-align: center;
}

a:hover{
    text-decoration: none;
}


/*レイアウト*/
.fl_l{
    float: left;
}
.fl_r{
    float: right;
}

.flex{
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-wrap:  wrap;
}

.flex_sb{justify-content:  space-between;}

.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}

.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
  border: 0;
}

/* コンテンツ設定
===================*/
#main p{
    line-height: 1.5;
}

#footer .copy{
    font-size: 12px;
}
/*===============================================
画面の横幅が641px以上(PC tablet)
===============================================*/
@media screen and (min-width: 641px){

#wrapper,.wrap{
    min-width: 1000px;
}

.sponly{
    display: none;
}

img{
max-width: 100%;
height: auto;
width /***/:auto;
}

#container{
width:100%;
}
/*～以下、画面の横幅が641px以上の場合のスタイル記入～*/
a:hover{
    opacity: 0.7;
    transition: 0.8s;
}

a{
    opacity: 1;
    transition: 0.4s;
}

.inner{
    width: 870px;
    margin: 0 auto;
}

/*メインナビ*/
#gnav_wrap{
  background-color: #000;
}

#gnav a{
  color: #fff;
  text-align: center;
  display: block;
  padding: 15px 40px;
  border-left: 1px solid #fff;
  box-sizing: border-box;
  font-size: 16px;
}

#gnav ul li:last-child a{
  border-right: 1px solid #fff;
}

#gnav a:hover{
  background-color: #ccc;
}

/*ヘッダー*/
#header_wrap{
  padding: 20px 0;
}

.site_desc{
    font-size: 12px;
}


}/* __for pc*/

/*===============================================
画面の横幅が640pxまで(mobile)
===============================================*/
@media screen and (max-width:640px){
.pconly{
    display: none;
}

img{
max-width: 100%;
height: auto;
width /***/:auto;
}
#container{
width:100%;
}

.drawer-hamburger{
    margin-right: 3vw;
}

.drawer-hamburger-icon, .drawer-hamburger-icon:after, .drawer-hamburger-icon:before {
    background-color: #000;
}

.drawer-nav {
    z-index: 1;
    width: 70vw;
    height: 100%;
    color: #222;
    background-color: rgba(0,0,0,0.5);
}

.drawer-menu{
    text-align: left;

}

ul.drawer-menu  {
    padding-left: 5vw;
    padding-top: 20vw;
}

.drawer-menu li{
    margin-bottom: 8vw;
}
.drawer-menu li a{
    color: #fff;
    font-size: 4.5vw;
    font-weight: bold;
}

/*～以下、画面の横幅が640pxまでの場合のスタイル記入～*/

#main p{
    line-height: 1.7;
}

#header{
  padding-top: 4vw;
}

.inner{
  padding: 0 3vw;
}

#top_logo{
  width: 60%;
}

}/* __for mobile */