@charset "UTF-8";
/* 標準可変メディア
   メモ : 可変メディアでは、HTML からメディアの高さおよび幅の属性を削除する必要がある
   http://www.alistapart.com/articles/fluid-images/ 
*/
img, object, embed, video {
	max-width: 100%;
}
/* IE 6 では最大幅がサポートされていないため、デフォルトで幅 100% に設定される */
.ie6 img {
	width:100%;
}

/*
	Dreamweaver 可変グリッドプロパティ
	----------------------------------
	dw-num-cols-mobile:		4;
	dw-num-cols-tablet:		8;
	dw-num-cols-desktop:	12;
	dw-gutter-percentage:	25;
	
	以下からヒントを入手 : Ethan Marcotte 氏の「レスポンシブ Web デザイン」 
	http://www.alistapart.com/articles/responsive-web-design
	
	および Joni Korpi 氏の「Golden Grid System」
	http://goldengridsystem.com/ 
*/

/*CSS Reset*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:50%;
    vertical-align:baseline;
    background:transparent;
    font-weight: normal;

}
/*CSS Reset end*/


body {
  margin: 0;
  font-family: Meiryo,
  "Helvetica Neue",
  Arial,
  "Hiragino Kaku Gothic ProN",
  "Hiragino Sans",
  sans-serif;
}

p {
    margin: 0;
}

h1 {
  font-size: 80%;
    font: 
  }

h2 {
  font-size: 150%;
  text-height: 250%;
  }

h3, h4 {
  font-size: 120%;
  }

h5, h6 {
    font-size: 100%;
    text-height: 300%;

  }
  

.fluid {
	clear: both;
	margin-left: auto;
  margin-right: auto;
	width: 100%;
	float: left;
	display: block;
}

.fluidList {
    list-style:none;
    list-style-image:none;
    margin:0;
    padding:0;
}



/* Mobile Layout: 480px and below. */
  

.gridContainer {
    margin-left: auto; /*auto*/
    margin-right: auto;
    width: 90%; /*86.45%*/
    padding-left: 0;
    padding-right: 0;
    clear: none;
    float: none;
}

.header {
    position: relative;/*相対位置*/
    width: 100%;
    height: 60px;
    margin-left: 0; /*auto*/
    margin-right: 0;
    margin-bottom: 1em;
}
.header img {
    width:100%;
    height: 75px;
}

.header1 {
    position: absolute;
    top:20%;
    left:5%;
}

.header1 img {
    width:200px;
    height: auto;
}

.header2 {
    position: absolute;
    text-align: center;
    width: 100%;
    margin-left: 0; /*auto*/
    margin-right: 0;
    top:90%;
    left:0;
}


.header2 p {
    position: relative;/*相対位置*/
    color: #000;/*文字は黒に*/
    font-size: 10px;
    margin-left: 0px;
    margin-bottom: 0;
    /*    top: 50%;
    right: 10%;
    transform: translate(0, -50%)*/
}

.header2 span {
    font-size: 10px;
}
.header2 a {
    text-decoration: none; 
}



.topimg {
    width: 100%;
    height: auto;
    margin-top: 20px;
    margin-bottom: 30px;
    margin-left: auto;
    margin-right: auto;
}

.topimg img {
    
        margin-top: 30px;

}


/*メニュー*/
nav{
    border-top: 1px solid #FFF;
    border-bottom: 1px solid #FFF;
    background-color:#E4E4E4;
}
nav ul{
    display: table;
    margin: 0 auto;
    padding: 0;
    width: 90%;
    text-align: center;
}
nav ul li{
    display: table-cell;
    width: 20%;
    border-right: 1px solid #FFF;
    background-color:#CCC;
}
nav ul li:first-child{
    border-left: 1px solid #FFF;
}
nav ul li a{
    display: block;
    font-size: 10px;
    width: 100%;
    padding: 10px 0 9px 0;
    text-decoration: none;
    color: #666;/*#aaa*/
}
nav ul li a:hover{
    background-color:#FFFF66;/*#F8E750*/
    /*border-bottom: 5px solid #F8E750;*/
}
nav ul li.current{
    font-weight: bold;
}
nav ul li.current a{
    border-bottom: 5px solid #00B0F0;
    color: #00B0F0;
}
/*メニューここまで*/


.main1 {
      width: 80%;
      margin-top: 20px;
      margin-bottom: 10px;
      margin-right:auto;
      margin-left:auto;
  }

.main1 h1 {
    width: 40%;
    
    font-size: 18px;
    color: #333;
    text-align: center;
    border-bottom: 2px solid #333;
          margin-right:auto;
      margin-left:auto;
        margin-bottom: 6px;

}

.main2 {
    position: relative;  /*相対位置*/
    width: 80%;
    height: 50px;
    margin-top: 40px;
    margin-bottom: 20px;
    margin-right: auto;
    margin-left: auto;
    clear:none;

}

.main2 img {
    /*position: absolute;  /*絶対配置*/
    width: 110px;
    height: auto;
    top: 100%;
}

.main2 h3 {
    position: absolute;  /*絶対配置*/
    width: 100%;
    font-size: 15px;
    color: #333;
    text-align: left;
    top: -30%;
    left: 3%;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 6px;

}

.main2 p {
    position: absolute;  /*絶対配置*/
    width: 100%;
    font-size: 12px;
    color: #000000;
    text-align: left;
    line-height: 1.8;
    top: 40%;
    left: 3%;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 10px;

}

#main3 {
    position: relative;  /*相対位置*/
    width: 80%;
    height: 40px;
    margin-top: 80px;
    margin-bottom: 5px;
    margin-right: auto;
    margin-left: auto;
    clear:none;

}

#main3 img {
    position: absolute;  /*絶対配置*/
    width: 110px;
    height: auto;
    top: 25px;
}

#main3 h3 {
    position: absolute;  /*絶対配置*/
    width: 100%;
    font-size: 15px;
    color: #333;
    text-align: left;
    top: 20%;
    left: 3%;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 6px;
}


.gmap {
    position: relative;
    width: 80%;
    margin: 10px auto 30px auto;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
    border:  solid 1px #00A2E7;

}

.gmap iframe,
.gmap object,
.gmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


.imap {
    width: 80%;
    height: auto;
    border:  solid 1px #00A2E7;
    margin: 5px auto 0px auto;
    padding: 0;
    
}

.imap img {
    width: 100%;
    height: 100%;
    vertical-align:top;
}

.imap2 {
    width: 80%;
    height: auto;
    border:  solid 0px #00A2E7;
    margin: 8px auto 20px auto;
    padding: 0;

}

.imap2 p {
    font-size: 11px;
    text-align: left;
    line-height: 1.5;
}

.foot {
   position: relative;/*相対位置*/
    top: 10px;
    margin-top: 25px;
    margin-left: 0; /*auto*/
    margin-right: 0;
    clear: none;
}

.foot img {
    width: 100%;
    height: 100px;
}

.foot h3 {
  position: absolute;/*絶対配置*/
  color: #333;/*文字は濃いグレーに*/
  font-size: 18px;
  width: 100%;
  text-align: center;
  top: 15%;
  font-weight: normal;
}

.foot h5 {
  position: absolute;/*絶対配置*/
  color: #333;/*文字は濃いグレーに*/
  font-size: 12px;
  width: 100%;
  text-align: center;
  top: 50%;
  font-weight: normal;
  margin-bottom: 10px;
}

.foot p {
  position: absolute;/*絶対配置*/
  color: #333;/*文字は黒に*/
  width: 100%;
  font-size: 8px;
  line-height: 1.3;
  text-align: center;
  text-height:35px;
  top: 75%;
  right: auto;
  left:auto;
  margin-top: -5px;
}

.hover1 {
  transition: all 0.6s ease 0s;
}
.hover1:hover {
  cursor: pointer;
  transform: scale(1.03, 1.03);
}


.zeroMargin_mobile {
margin-left: 0;
}
.hide_mobile {
display: none;
}


/* タブレットレイアウト : 481 px ～ 768 px。モバイルレイアウトからスタイルを継承。 */


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

.gridContainer {
	width: 90%;/*90.675%*/
	padding-left: 2%;/*1.1625%*/
	padding-right: 2%;
	clear: none;
	float: none;
	margin-left: auto;/*auto*/
  margin-right: auto;
}


.header {
    position: relative;/*相対位置*/
    width: 100%;
    height: 60px;
    margin-left: 0; /*auto*/
    margin-right: 0;
    margin-bottom: 1em;
}
    
.header img {
    width:100%;
    height: 60px;
}

.header1 {
    position: absolute;
    top:20%;
    left:5%;
}

.header1 img {
    width:200px;
    height: auto;
}

.header2 {
    position: absolute;
    top:40%;
    right:5%;
    margin-right: 8px;
}

.header2 p {
    position: relative;/*相対位置*/
    color: #000;/*文字は黒に*/
    font-size: 12px;
    text-align: right;
    margin-left: 0;
    margin-right: 12px;
    margin-bottom: 0;
/*    top: 50%;
    right: 10%;
    transform: translate(0, -50%)*/
} 
    
    .header2 span {
        font-size: 12px;
    }
    
    

    
    
    /*メニュー*/
    nav{
        border-top: 1px solid #FFF;
        border-bottom: 1px solid #FFF;
        background-color:#E4E4E4;
    }
    nav ul{
        display: table;
        margin: 0 auto;
        padding: 0;
        width: 80%;
        font-size: 25px;
        text-align: center;
    }
    nav ul li{
        display: table-cell;
        width: 20%;
        border-right: 1px solid #FFF;
        background-color:#CCC;
    }
    nav ul li:first-child{
        border-left: 1px solid #FFF;
    }
    nav ul li a{
        display: block;
        font-size: 13px;
        width: 100%;
        padding: 15px 0 14px 0;
        text-decoration: none;
        color: #666;/*#aaa*/
    }
    nav ul li a:hover{
        background-color:#FFFF66;/*#F8E750*/
        /*border-bottom: 5px solid #F8E750;*/
    }
    nav ul li.current{
        font-weight: bold;
    }
    nav ul li.current a{
        border-bottom: 5px solid #00B0F0;
        color: #00B0F0;
    }
    /*メニューここまで*/
    
    .main1 {
        margin-top: 30px;
        width: ;
    }
    
    .main1 h1 {
        width: 30%;
        font-size: 22px;
        text-height: 80px;
        margin-bottom: 10px;
    }



    .main2 {
        width: 80%;
        height: 50px;
        margin-top: 50px;
        margin-bottom: 30px;
        margin-right: auto;
        margin-left: auto;
        clear:none;

    }

    .main2 img {
        width: 200px;
        height: auto;
        top: 100%;
    }

    .main2 h3 {
        position: absolute;  /*絶対配置*/
        width: 100%;
        font-size: 20px;
        color: #333;
        text-align: left;
        top: -35%;
        left: 3%;
        margin-right: auto;
        margin-left: auto;
        margin-bottom: 20px;

    }

    .main2 p {
        position: absolute;  /*絶対配置*/
        width: 100%;
        font-size: 16px;
        color: #000000;
        text-align: left;
        top: 55%;
        left: 3%;
        margin-right: auto;
        margin-left: auto;
        margin-bottom: 10px;

    }

    #main3 {
        position: relative;  /*相対位置*/
        width: 80%;
        height: 40px;
        margin-top: 140px;
        margin-bottom: 25px;
        margin-right: auto;
        margin-left: auto;
        clear:none;

    }

    #main3 img {
        position: absolute;  /*絶対配置*/
        width: 200px;
        height: auto;
        top: 25px;
    }

    #main3 h3 {
        position: absolute;  /*絶対配置*/
        width: 100%;
        font-size: 18px;
        color: #333;
        text-align: left;
        top: 20%;
        left: 3%;
        margin-right: auto;
        margin-left: auto;
        margin-bottom: 6px;
    }
    
    
    .imap2 {
        margin: 18px auto 20px auto;
    }

    .imap2 p {
        font-size: 16px;
    }
    
    

    
    .foot {
        clear: both;
        margin-left: 0;
        margin-right: 0;
        }
    
    .foot h3 {
        position: absolute;/*絶対配置*/
        color: #333;/*文字は濃いグレーに*/
        font-size: 20px;
        width: 100%;
        text-align: center;
        top: 12%;
        font-weight: normal;
    }

.foot h5 {
    font-size: 14px;
    top: 43%;

}

.foot p {
    position: absolute;/*絶対配置*/
    color: #000;/*文字は黒に*/
    width: 100%;
    font-size: 10px;
    line-height: 1.8;
    text-align: center;
    text-height:35px;
    top: 75%;
    right: auto;
    left:auto;
    margin-top: -5px;
}


.access_wide {
    font-size: 36px;
    margin: 20px auto;
    padding: 12px;/*1em*/
    /*width: 90%;*/
    background-color: #fff; /* 背景色 */
    border: 1px solid #ccc; /* 枠線 */
    text-align:center;
    transition: all 0.6s ease 0s;
}
    
    
.hide_tablet {
display: none;
}
.zeroMargin_tablet {
margin-left: 0;
}
}

/* デスクトップレイアウト : 769 px ～最大 1232 px。モバイルレイアウトとタブレットレイアウトからスタイルを継承。 */

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

.gridContainer {
	width: 88.5%;
    max-width: 1000px;/*1232px*/
	padding-left: 0.75%;
	padding-right: 0.75%;
	margin: auto;
	clear: none;
	float: none;
	margin-left: auto;
}


.header {
    position: relative;/*相対位置*/
    width: 100%;
    height: 60px;
    margin-left: 0; /*auto*/
    margin-right: 0;
    margin-bottom: 1em;
}
.header img {
    width:100%;
    height: 80px;
}

.header1 {
    position: absolute;
    top:30%;
    left:5%;
}

.header1 img {
    width:250px;
    height: auto;
}

.header2 {
    position: absolute;
    top:50%;
    left:0;
}


.header2 p {
    position: relative;/*相対位置*/
    color: #000;/*文字は黒に*/
    font-size: 17px;
    margin-left: 20px;
    margin-bottom: 0;
/*    top: 50%;
    right: 10%;
    transform: translate(0, -50%)*/
}

.header2 span {
        font-size: 16px;
    }



/*メニュー*/

nav ul{
    font-size: 30px;
}

nav ul li a{
    font-size: 20px;

    padding: 15px 0 14px 0;
}

/*メニューここまで*/
    
    .main1 {
        margin-top: 60px;
        width: ;
    }

    .main1 h1 {
        width: 30%;
        font-size: 32px;
        text-height: 80px;
        margin-bottom: 10px;
    }



    .main2 {
        width: 80%;
        height: 65px;
        margin-top: 110px;
        margin-bottom: 30px;

    }

    .main2 img {
        width: 200px;
        height: auto;
        top: 200px;/*100%;*/
    }

    .main2 h3 {
        font-size: 26px;
        color: #333;
        top: -35%;
        left: 3%;
        margin-bottom: 20px;

    }

    .main2 p {
        width: 100%;
        font-size: 19px;
        line-height: 1.8;
        top: 55%;
        left: 3%;
        margin-right: auto;
        margin-left: auto;
        margin-bottom: 10px;

    }

    #main3 {
        width: 80%;
        height: 40px;
        margin-top: 200px;
        margin-bottom: 25px;

    }

    #main3 img {
        width: 200px;
        height: auto;
        top: 30px;
    }

    #main3 h3 {
        font-size: 26px;
        color: #333;
        text-align: left;
        top: 20%;
        left: 3%;
        margin-bottom: 6px;
    }
    
    .gmap {
    margin: 10px auto 40px auto;
}
    
    
/*
    .imap {
    margin: 5px auto 0px auto;
    
}*/

    .imap2 {
        margin: 18px auto 30px auto;
    }

    .imap2 p {
        font-size: 16px;
    }



.foot {
 }

.foot img {
    height: 120px;
}

.foot h3 {
  font-size: 24px;
  top: 15%;
}

.foot h5 {
  font-size: 14px;
  top: 48%;
}

.foot p {
  font-size: 10px;
  top: 80%;
}


.zeroMargin_desktop {
margin-left: 0;
}
.hide_desktop {
display: none;
}
}
