@charset "utf-8";
/*
Theme Name: theme008green
Theme URI: http://theme.o2gp.com/
Description: theme008
Version: 1.0
Author: o2 Group
Author URI: http://theme.o2gp.com/
Tags: simple

	o2 Group v1.0
	 http://theme.o2gp.com/

	This theme was designed and built by o2 Group,
	whose blog you will find at http://theme.o2gp.com/

	The CSS, XHTML and design is released under GPL:
	http://www.opensource.org/licenses/gpl-license.php

*/

@import "custom.css";

*{margin:0;padding:0;}

body{
font: 14px/1.4 "メイリオ","Meiryo",arial,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
color:#252525;
background: #ffffff url(images/bg.png) no-repeat center top;
}

a{color:#33ce7c;text-decoration:none;}
a:hover{color:#33ce7c;}
a:active, a:focus {outline: 0;}
img{border:0;}
.clear{clear:both;}


/*************
全体
*************/
#wrapper{
margin: 0 auto;
padding-left: 20px;
width: 930px;
}
* html #wrapper { zoom:100%; }/*IE6*/
*+html #wrapper { zoom:100%; }/*IE7*/
/*************
/* ヘッダー
*************/
#header{
/*background: url(images/header.png) no-repeat 100% 0;*/
height: 80px;
}

#header h1 {
padding: 7px 0 10px;
font-size: 12px;
font-weight: normal;
}


/*************
/* トップナビゲーション
*************/
/*
ul#topnav{
margin: 15px 0;
width: 910px;
height: 46px;
}

ul#topnav li{float:left;list-style:none;width:130px;}

ul#topnav a{
display: block;
width: 130px;
height: 46px;
}
*/

#mainnavi {
margin: 15px 0 15px;
width: 910px;
height: 46px;
}
* html #mainnavi { zoom:100%; }/*IE6*/
*+html #mainnavi { zoom:100%; }/*IE7*/
#mainnavi .mainnaviBtn { float: left; height: 46px; }
#mainnavi .mainnaviBtn img { height: 46px; }

/*************
メイン（右側）コンテンツ
*************/
#main {
float: right;
width: 618px;
padding: 20px 0;
display: inline;
}

#mainImg { margin-left: -8px; }

#main .bannerM img{
padding-right: 10px;
padding-bottom: 15px;
}
#main .bannerM img.last{padding-right:0;}

#main h2{
margin-bottom: 10px;
padding: 0 10px 0px 40px;
line-height: 40px;
font-size: 15px;
font-weight: normal;
color: #333333;
background: #0b82be url(images/heading.png) no-repeat;
}
#main h2 a { color: #333; }

#main h3 {
font-size: 14px;
line-height: 30px;
background: url(images/h3.png) no-repeat ;
padding-left: 15px;
padding-bottom: 10px;
margin-top: 20px;
letter-spacing: 0.2em;
color: #333333;
}

#main p {
padding: 15px 15px 15px 20px;
}

/* 画像を右に回りこみ */
#main p.withImage{
width: 598px;
margin: 20px 0 10px 10px;
padding: 5px 0;
}

#main p.withImage img{
float: right;
margin-left: .5em;
}

#date {
text-align: right;
padding-right: 15px;
padding-top: 15px;
padding-bottom: 10px;
font-weight:bold;
color:#4c9f01;
}

#next {
text-align: center;
padding-top: 30px;
padding-bottom: 30px;
}

img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}
img.alignright {
    padding: 4px;
    margin: 0 0 2px 7px;
    display: inline;
}
img.alignleft {
    padding: 4px;
    margin: 0 7px 2px 0;
    display: inline;
}
.alignright {
    float: right;
}
.alignleft {
    float: left;
}

/* フッター共通 */
.box{
float: left;
width: 195px;
margin: 20px 15px 10px 0;
line-height: 20px;
}

.box_img{
padding: 0px 0px 10px 0px;
}

.last{margin-right:0;}


/* ボタン */
p.button{
text-align: center;
font-weight:bold;
padding: 10px 0;
}

p.button a{
display:block;
line-height: 32px;
background: #ffffff url(images/button.png) no-repeat;
margin: 0 -20px;
}

p.button a{color:#fff;}
p.button a:hover{color:#cee6b6;}

p.button a:hover{
cursor:pointer;
background-position: 0 -32px;
}

/* メインとフッターのリスト位置調節 */
#main ul, #footer ul{margin-left: 20px;}
#main li, #footer li{margin-bottom: 3px;}


/*************
サイド（左側）コンテンツ
*************/
#sidebar {
float: left;
width: 265px;
padding: 20px 0;
}

#sidebar p{margin-bottom: 20px;}

#sidebar h3 {
margin-top: 5px;
padding: 0 10px 0 33px;
line-height: 40px;
font-size: 15px;
font-weight: normal;
color: #333333;
background: #0b82be url(images/heading2.png) no-repeat;
}

#sidebar ul{
margin-left: 5px;
padding: 10px 0;
}

#sidebar li{
margin: 0 10px 10px 5px;
list-style: none;
border-bottom: 1px dashed #4c9f01;
}

#sidebar li a{
background: url(images/list.png) no-repeat 0 50%;
display: block;
padding-left:15px;
}

#sidebar li a:hover{background-position: 3px 50%;}




/*************
/* フッター
*************/
#footer{
clear:both;
padding: 10px 0 10px;
border-top: 1px solid #33ce7c;
}

#footer .inner{
overflow: hidden;
}

* html #footer .inner{height:1%;}

#footer #logo{
float:left;
padding: 10px 0 5px;
width: 292px;
}

address{
padding: 20px 0 3px;
text-align: center;
font-style:normal;
font-size: 12px;
clear:both;
display:block;
}
#footer ul.foot li { float: left; margin-right: 30px; }


/*************
/* 追加分
*************/
#topCont01 { margin-bottom: 15px; border-left: #CCC 1px solid; border-right: #CCC 1px solid; }
#topCont01 td { background: #FFF; }
#topCont01 td.centerTd { border-left: #CCC 1px solid; border-right: #CCC 1px solid; width: 10px; background: none; }
#topCont01 td.topTd { border-top: #CCC 1px solid; width: 302px; height: 5px; }
#topCont01 td.bottomTd { border-bottom: #CCC 1px solid; height: 5px; }
#topCont01 td.docL { border-right: #CCC 1px dotted; width: 140px; padding: 5px; }
#topCont01 td.docR { padding: 10px; width: 131px; }
#main #topCont01 h2 { border-left: #BBB 3px solid; padding: 0 0 0 7px; color: #33ce7c; font-weight: bold; height: 20px; font-size: 14px; line-height: 20px; background: none; margin-bottom: 0; }

#container { padding-right: 20px; }
.sideBnr { border: #DFECFC 3px solid; }
.topCmtL { margin-right: 15px; line-height: 20px; }
.clear { clear: both; }
.mrgT20 { margin-top: 20px; }
.mrgB10 { margin-bottom: 10px; }
.mrgB20 { margin-bottom: 20px; }
.mrgR15 { margin-right: 15px; }
.mrgR20 { margin-right: 20px; }


/*************
/* SP追加分
*************/
.only_sp{ display: none; }
#mainnavi_sp {
  background: #33ce7c;
}


/* Media Queries ================================================== */
/*896*/
@media screen and (max-width: 896px) {

  .only_pc{ display: none !important; }
  .only_sp{ display: block !important; }

  body{
    background: #FFF;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
  }


  body.fixed {
    position: fixed;
    width: 100%;
    height: 100%;
  }

    img{
      max-width: 100%;
      height: auto;
      image-rendering: -webkit-optimize-contrast;
    }


    img[src$=".svg"] {
        width: 100%;
        height: auto;
        image-rendering: -webkit-optimize-contrast;
    }

    #header, #container, #wrapper, .inner {
      margin: 0 auto;
      width: auto;
    }


    #wrapper {
      width: 100%;
      padding: 0;
    }


    #header_sp {
      background: #33ce7c;
      position: fixed;
      top: 0;
      height: 40px;
      width: 96%;
      padding: 10px;
      z-index: 9999;
      border-bottom: 1px solid #33ce7c;
    }

    #header_sp_inner{
      display: flex;
      justify-content: space-between;
      align-items: center;    
    }    

    .companyName{
        font-size: 1.6rem;
        color:#fff;
    }

    .logo_sp img{
        max-height: 40px;
    }


    .spMenuBtn {
      position: relative;
      width: 40px;
      height: 40px;
      background: none;
      z-index: 10000;
      right: 10px;
      top: 0;
      border: none;
    }

    .spMenuBtn span {
      position: absolute;
      left: 10px;
      width: 22px;
      height: 2px;
      background-color: #fff;
      border-radius: 2px;
      margin-top: 11px;
      right: 9px;
    }

    .spMenuBtn span:nth-of-type(1) {
      top: 0px;
    }

    .spMenuBtn span:nth-of-type(2) {
      top: 8px;
    }

    .spMenuBtn span:nth-of-type(3) {
      top: 16px;
    }

    .spMenuBtn.action span:nth-of-type(1) {
        -webkit-transform: translateY(6px) rotate(-45deg);
        transform: translateY(6px) rotate(-45deg);
    }

    .spMenuBtn.action span:nth-of-type(2) {
      opacity: 0;
    }

    .spMenuBtn.action span:nth-of-type(3) {
        -webkit-transform: translateY(-9px) rotate(45deg);
        transform: translateY(-9px) rotate(45deg);
    }





    #container{
        margin-top: 60px;
        padding: 0;
        max-width: 100vw;
        overflow-x: hidden;
    }

    #container.on_main{
        margin-top: 0;
        padding: 0;
    }


    #mainnavi_sp ul{
        padding: 2%;
    }

    #mainnavi_sp li{
        list-style: none;
    }

    #mainnavi_sp li a {
      color: #fff;
      display: block;
      border-bottom: 1px solid #fff;
      position: relative;
      height: 50px;
      line-height: 50px;
      padding-left: 10px;
      text-decoration: none;
    } 


    #mainnavi_sp li a::after {
      content: "";
      position: absolute;
      display: inline-block;
      width: 10px;
      height: 10px;
      margin: auto;
      border-top: 2px solid #fff;
      border-right: 2px solid #fff;
      transform: rotate(45deg);
      right: 10px;
      top: 18px;
    }


    #globalTel{
        width: 96%;
        padding: 2%;
    }



    #main {
      float: none;
      width: 96%;
      padding: 2%;
      display: block;
    }

    #main td {
      display: block;
      width: auto;
      margin: 0 auto 10px;
    }

    #main td img{
        margin:0 auto;
        display: block;
    }    


    .box {
      width: 80%;
      float: none;
      margin: 20px auto 10px;
    }

    .box img{
        text-align: center;
        margin:0 auto;
        display: block;
     }   


    #sidebar,#sidebarR {
      float: none;
      width: 96%;
      padding: 20px 2% 0;
      clear: both;
      border-top: 1px solid #33ce7c;
      margin-bottom: 20px;
    }

    #sidebar p,#sidebarR p{
     text-align: center;
    }
    .sideBnr {
        border: none;
    } 


    .sideBnr a{
        display: block;
    }

    .sideBnr a img{
        display: block;
        border: #DFECFC 3px solid;
        margin: 0 auto;
    }

/*--------footer------------*/

    #footer {
      padding: 20px 20px 10px;
    }

    #footerUpper{
      clear: both;
      padding: 20px;      
    }



    #globalTel{
        display: block;
        line-height: 45px;
        height: 45px;
        color: #fff!important;
        font-size: 1.6rem;
        font-weight: bold;
        text-align: center;
        border-radius: 10px;
        background-color:#33ce7c;
        margin:0 auto 20px;
        text-decoration: none; 
    }


    #footer ul {
      margin-left: 0;
    }

    #footer ul.foot li,
    #footerUpper ul.foot li,
    #footerUpper ul#footNavi li {
        display: block;
        float: none;
        margin:0;
        background-image: none;
    }

    .foot li a,#footNavi li a{
      color: #33ce7c;
      display: block;
      margin-bottom: 10px;
      padding-bottom: 10px;
      border-bottom: 1px solid #33ce7c;
      position: relative;
      text-decoration: none;
    }  


    .foot li a::after,
    #footNavi li a::after{
      content: "";
      position: absolute;
      display: inline-block;
      width: 10px;
      height: 10px;
      margin: auto;
      border-top: 2px solid #33ce7c;
      border-right: 2px solid #33ce7c;
      transform: rotate(45deg);
      right: 10px;
      top: 6px;
    }

/*--------main------------*/

  #mainImage,#mainImg{
      margin-top: 60px;
      padding: 0;
  }

   #main.on_contact{
    margin-top: 60px;
   } 

  #main h2 {
    line-height: 1.5;
    background: none;
    border-left: 5px solid #33ce7c;
    padding: 2px 10px;
  }

  #main h3 {
    padding: 10px;
    margin-bottom: 10px;
    line-height: 1.5;
    background: url(images/h3.png) repeat;
  }



  .boxContainer {
    width: 100%;
    margin: 0 auto 15px;
    background: none;
  }


.box1, .box3, .box4 {
  width: auto;
  margin: 0 auto 20px;
  border-top: 1px solid #dadada;
}



  .box11,.box12 {
    background: none;
    border:1px solid #ccc;
    float: none;
    width: auto;
    margin: 0 auto 20px;
    padding: 10px;  
  }

  .box11 img,.box12 img{
    display: block;
    margin:0 auto 10px;
  }  


.box13Wrap h4 {
  background-image: none;
  background-color:#EAECEB; 
  height: auto;
  border-top:1px solid #ccc;
  border-bottom:3px solid #000; 
  padding: 10px;
}

.box4 h4 {
  float: none;
  background: url(images/h3.gif) repeat-x 0 100%;;
  height: auto;
  padding: 10px;
  border-top:3px solid #026c93;
}

.box4 td {
  padding: 10px;
}

#topCont01 {
  width: 100%;
  border: none;
  margin-top: 20px;
}

#topCont01 td.topTd,
#topCont01 td.centerTd {
display: none;
}

#topCont01 tr{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}  


#topCont01 td.docL {
  border-right: none;
  width: auto;
  padding: 0;
  margin: 0 0 20px;
  flex-basis: 40%;
}

#topCont01 td.docL img{
  margin:0;
}  

#topCont01 td.docR {
  padding: 30px 0 0;
  margin: 0;
  width: auto;
  flex-basis: 58%;
}

#main #topCont01 h2 {
    border-left: none;
    color: #33ce7c;
    padding-left: 0;
}


/*--------contactForm------------*/

    #contactForm {
      border-top: none;
      border-left: none;
      box-sizing: border-box;
      display: block;
      width: 96vw;
    }

    #contactForm th {
      display: block;
      padding: 2vw;
      width: 92vw;
    }

    #contactForm td {
      border: none;
      display: block;
      background: none;
      padding: 2vw;
      width: 92vw;
      margin: 0;
    }

    #contactForm td div:not(.formErrorArrow,.line1,.line2,.line3,.line4,.line5,.line6,.line7,.line8,.line9,.line10):nth-of-type(2n){
        margin-bottom: 20px;
    }    

    #contactForm td input,#contactForm td select{
        height: 30px;
        list-style: 30px;
        max-width: 100%;
        font-size:16px;
    }    

    #contactForm textarea{
        width: 100%;
        font-size:16px;
    }

    button[type="submit"]{
        background-color: transparent;
        border: none;
        cursor: pointer;
        outline: none;
        padding: 0;
        appearance: none;
        display: block;
        border-radius: 10px;
        width: 300px;
        background-color:#488FC5;
        height: 45px;
        line-height: : 45px;
        color: #fff;
        position: relative; 
        margin-bottom: 10px;
    }    

    button[type="submit"]::after {
      content: "";
      position: absolute;
      display: inline-block;
      width: 10px;
      height: 10px;
      margin: auto;
      border-top: 2px solid #fff;
      border-right: 2px solid #fff;
      transform: rotate(45deg);
      right: 10px;
      top: 0;
      bottom: 0;
    }

    button[type="submit"].submit_back::after {
        right: auto;
        left: 10px;
        border-top:none;
        border-right:none;
        border-left: 2px solid #fff;
        border-bottom: 2px solid #fff;
        transform: rotate(45deg);        
    }

    .innerLR10 {
      margin: 0;
    }
/*--------profile------------*/
    #profile01 th {
      width: 20%;
      display: block;
      border-bottom: none;
    }       

    #profile01 td {
      width: auto;
      min-width: 140px;
    }
    .phAlt {
      text-align: center;
    }
/*--------business------------*/
    #business01 .photoWrap {
      width: auto;
    }


    #business01 .twoColumnPhotoL,
    #business01 .twoColumnPhotoR {
      text-align: center;
      max-width: 300px;
      margin:0 auto 10px;
      overflow: hidden;
      float: none;
    }

    #business01 .comment {
      width: auto;
      margin-bottom: 30px;
    }

    #business01 .comment table {
      width: 100%;
    }


    #business01 .comment th{
        width: 100% !important;
        border-right:none;
        border-bottom:4px solid #999;
        display: block;
    }

    #business01 .comment td{
        width: auto;
        display: block;
        margin-bottom: 20px;
    }

    #business01 .oneColumnPhotoR {
      width: auto;
    }

}

