@charset "utf-8";

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    border: 0;
    margin: 0;
    padding: 0;
    vertical-align: baseline;
    box-sizing: border-box;
    outline: none;
}

body {
    width: 100%;
    color: #777;
    font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック';
    background: url("../img/bg_body.png") repeat top left #fff;
}
h1 {
    font-size: 1.2em;
    line-height: 1em;
    margin: 0;
  }
h2{
    font-size: 1.3em;
    margin-bottom: 1em;
    color: #0fa578;
    border-bottom: 1px solid #0fa578;
    padding-bottom: .5em;
}
h2 + h3{
    margin-top: 0;
}
h3{
    font-size: 1.1em;
    margin-bottom: 1em;
    font-weight: normal;
}
ol, ul{
    list-style-type: none;
    margin: 1em 0;
}
li{margin-bottom: .5em;}
dl{margin: 0;}
dt{margin: 1em 0;}
dd{margin: 0 0 1em 0;}
table {
    border-collapse: collapse;
    border-spacing: 0;
  }
thead{border-bottom: 1px solid #ddd;}
img{
    vertical-align: bottom;
    width: 100%;
    height: auto;
}
p{
    line-height: 1.5em;
    margin-bottom: 1.5em;
}

a{color: #777;}
a:hover{
    cursor: pointer;
    color: #0fa578;
}

.button{
    display: inline-block;
    padding: .8em;
    text-decoration: none;
    color: #fff;
    line-height: 1;
}
a.button:hover{color: #fff;}
.button-large{width: 100%; text-align: center;}
.button-green{background: #0fa578;}
.button-gray{background: #aaa;}
.button-blue{background: #005695;}
.button-water{background: #5b9ecb;}

.text-right{text-align: right;}
.text-left{text-align: left;}
.text-center{text-align: center;}
.text-bold{font-weight: bold;}
.text-normal{font-weight: normal;}
.text-mincho{font-family: "游明朝",YuMincho,"ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","ＭＳ Ｐ明朝","ＭＳ 明朝",serif;}


.block-info{
    background: #e1edf6;
    color: #5b9ecb;
    padding: .5em;
}

.text-white{color: #fff;}
.text-green{color: #0fa578}
.text-blue{color: #005695;}
.text-water{color: #5b9ecb;}
.text-pink{color: #fd9d9e;}

.fs12{font-size: 1.2em;}
.fs9{font-size: .9em;}
.fs8{font-size: .8em;}
.fs7{font-size: .7em;}
.fs6{font-size: .6em;}
.fs5{font-size: .5em;}

.bg-grad{background-image: linear-gradient(to bottom, #fff 0%, #e9ecef 100%);}
.bg-gray{background: #efefef;}
.bg-catch1{background: url("../img/bg_catch.jpg")}
.bg-catch2{
    background: url("../img/bg_catch2.jpg");
    background-position: right top;
}
.bg-catch3{background: url("../img/bg_catch3.jpg")}
.bg-catch4{
    background: url("../img/bg_catch4.jpg");
    background-position: right top;
}
.bg-catch5{background: url("../img/bg_catch5.jpg");}
.bg-catch6{
    background: url("../img/bg_catch6.jpg");
    background-position: right center;
}
.bg-catch7{background: url("../img/bg_catch7.jpg")}
.bg-catch8{
    background: url("../img/bg_catch8.jpg");
    background-position: right bottom;
}

.ele-block{display: block;}
.ele-hide{display: none;}
.ele-deco{
    font-size: .6em;
    display: block;
    text-align: right;
    font-weight: normal;
    border-top: 2px solid #0fa578;
    padding-top: .5em;
    margin-top: .5em;
}

.dis{
    background: #ddd !important;
    color: #555 !important;
    pointer-events: none;
}
a.dis:hover{
    cursor: default;
}

.deco h2{
    padding: .5em;
    background: #0fa578;
    color: white;
    border: none;
}

.w100p{width: 100px;}
.round50{
      border-radius: 50%;
      border: 10px solid #ddd;
}
.decoimage{
    border: 1px solid #ddd;
    background: #fff;
}

.list-table{
    border-collapse: separate;
    border-spacing: 5px;
}
.list-table th{
    background: #005695;
    color: #fff;
    padding: .5em;
    vertical-align: middle;
    border-radius: .2em;
    width: 1em;
}
.list-table td{
    padding: .5em 0 .5em .5em;
}


.tab-button{
    display: flex;
    background: #eee;
    border-top: 1px solid #ddd;
    border-left: 1px solid #ddd;
}
.tab-button div{
    background: #eee;
    cursor: pointer;
    width: 33.3%;
    text-align: center;
    font-size: 1.1em;
    height: 48px;
    line-height: 48px;
}
.tab-button span{
    display: block;
    height: 48px;
    width: 100%;
    border-right: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
}
.tab-button span.open{
    background: #fff;
    color: #005695;
    font-weight: bold;
}
.tab-button span.content2{
    border-right: 1px solid #ddd;
    border-left: 1px solid #ddd;
}
.productinfo .tab-content table{
    margin: 0;
    border-top: none;
}