@import 'https://fonts.googleapis.com/css?family=Chivo';
/***************************************************************
File name 						: 			common.css
Description 					: 			共通スタイル定義
Date 								: 			2014/08
Table of contents:
・body
・header
・footer
**************************************************************/
/*-------------------------------------------------------------
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,
input,
select,
textarea,
label {
    font-size: 100%; /*vertical-align:top;*/
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    background: transparent;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
    font: inherit; /*vertical-align:top;*/
    font-size: 100%;
    display: block;
    margin: 0;
    padding: 0;
    border: 0;
}
body {
    /*overflow-x:hidden;*/
    font-family: Arial, '游ゴシック', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, sans-serif;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: .1em;
    color: #333;
    -webkit-text-size-adjust: 100%;
}
h1,
h2,
h3,
h4,
h5,
h6,
address {
    font-weight: normal;
    font-style: normal;
    letter-spacing: .05em;
}
p,
table,
th,
td,
ul,
ol,
li,
dl,
dt,
dd {
    line-height: 1.734;
}
p {
    max-height: 99999px;
}
table {
    border-spacing: 0;
    border-collapse: separate;
}
th {
    font-weight: normal;
    text-align: left;
}
img {
    vertical-align: top;
    border: 0;
}
ul,
ol,
li,
dl,
dt,
dd {
    list-style-type: none;
}
input,
select,
textarea {
    font-family: Arial, '游ゴシック', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, sans-serif;
    font-size: 15px;
    font-weight: 500;
    vertical-align: middle;
    letter-spacing: .1em;
    color: #333;
}
label {
    cursor: pointer;
}
table tr:first-of-type th:first-child,
table tr:first-of-type td:first-child {
    border-radius: 10px 0 0 0;
}
table tr:first-of-type th:last-child,
table tr:first-of-type td:last-child {
    border-radius: 0 10px 0 0;
}
table tr:last-of-type th:first-child,
table tr:last-of-type td:first-child {
    border-radius: 0 0 0 10px;
}
table tr:last-of-type th:last-child,
table tr:last-of-type td:last-child {
    border-radius: 0 0 10px 0;
}
table.noradius tr:first-of-type th:first-child,
table.noradius tr:first-of-type td:first-child {
    border-radius: 0;
}
table.noradius tr:first-of-type th:last-child,
table.noradius tr:first-of-type td:last-child {
    border-radius: 0;
}
table.noradius tr:last-of-type th:first-child,
table.noradius tr:last-of-type td:first-child {
    border-radius: 0;
}
table.noradius tr:last-of-type th:last-child,
table.noradius tr:last-of-type td:last-child {
    border-radius: 0;
}
a[href^='tel:'] {
    cursor: default !important;
    opacity: 1 !important;
}
/*-------------------------------------------------------------
header
-------------------------------------------------------------*/
header {
    position: relative;
}
header h1 {
    height: 97px;
    padding: 53px 0 0;
    text-align: center;
    border-bottom: 1px solid #e2e2e2;
}
header #hContact {
    font-size: 16px;
    line-height: 50px;
    position: absolute;
    z-index: 10;
    top: 0;
    right: 0;
    box-sizing: border-box;
    width: 200px;
    height: 50px;
    -webkit-transition: all .6s ease;
            transition: all .6s ease;
    text-align: center;
    color: #fff;
    background: #1871bc;
}
header #hContact a {
    display: block;
    width: 100%;
    height: 100%;
    color: #fff;
    padding-left: 16px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
header #hContact a span {
    padding: 0 0 0 32px;
    background: url('../img/common/email_icon.png') left no-repeat;
    background-size: 22px auto;
}
header #hTel {
    font-size: 21px;
    line-height: 50px;
    position: absolute;
    z-index: 10;
    top: 0;
    right: 200px;
    width: 220px;
    height: 50px;
    -webkit-transition: all .6s ease;
            transition: all .6s ease;
    text-align: center;
    color: #fff;
    background: #7ab337;
}
header #hTel a {
    display: block;
    width: 100%;
    height: 100%;
    color: #fff;
}
header #hTel span {
    padding: 0 0 0 26px;
    background: url('../img/common/tel_icon.png') left no-repeat;
    background-size: auto 18px;
}
header #menuSp {
    display: none;
}
header .spMenu {
    position: absolute;
    z-index: 1000000000;
    top: 60px;
    left: 0;
    overflow: hidden;
    box-sizing: border-box;
    width: 100%;
    height: 0;
    opacity: 0;
    background: #e3e3e3;
}
header .spMenu .menuBody {
    padding: 30px 0;
    background: #e3e3e3;
}
header .spMenu .menuBody > ul {
    padding: 0 15px 15px;
}
header .spMenu .menuBody > ul > li {
    margin-bottom: 14px;
    border-radius: 5px;
    background: #fff;
}
header .spMenu .menuBody > ul > li .spMenu01 {
    background: url('../img/common/home_icon.png') no-repeat 15px center;
    background-size: 17px 16px;
}
header .spMenu .menuBody > ul > li .spMenu02 {
    background: url('../img/common/service_icon.png') no-repeat 15px center, url('../img/common/spMenu_open.png') no-repeat right 20px center;
    background-size: 16px,10px 10px;
}
header .spMenu .menuBody > ul > li .spMenu03 {
    background: url('../img/common/price_icon.png') no-repeat 15px center;
    background-size: 15px 19px;
}
header .spMenu .menuBody > ul > li .spMenu04 {
    background: url('../img/common/about_icon.png') no-repeat 15px center, url('../img/common/spMenu_open.png') no-repeat right 20px center;
    background-size: 15px 16px,10px 10px;
}
header .spMenu .menuBody > ul > li .spMenu05 {
    background: url('../img/common/faq_icon.png') no-repeat 15px center;
    background-size: 16px;
}
header .spMenu .menuBody > ul > li .spMenu06 {
    background: url('../img/common/info_icon.png') no-repeat 15px center, url('../img/common/spMenu_open.png') no-repeat right 20px center;
    background-size: 16px,10px 10px;
}
header .spMenu .menuBody > ul > li > a,
header .spMenu .menuBody > ul > li > p {
    font-size: 15px;
    line-height: 50px;
    display: block;
    box-sizing: border-box;
    width: 100%;
    height: 50px;
    padding-left: 40px;
    color: #333;
}
header .spMenu .menuBody > ul > li ul {
    font-size: 0;
    overflow: hidden;
    height: 0;
    -webkit-transition: all .6s ease;
            transition: all .6s ease;
    opacity: 0;
}
header .spMenu .menuBody > ul > li ul li {
    font-size: 12px;
    line-height: 40px;
    float: left;
    box-sizing: border-box;
    width: 50%;
    height: 40px;
    border-bottom: 1px solid #ececec;
}
header .spMenu .menuBody > ul > li ul li:nth-of-type(odd) {
    border-right: 1px solid #ececec;
}
header .spMenu .menuBody > ul > li ul li a {
    display: block;
    padding: 0 0 0 15px;
}
header .spMenu .menuBody > ul > li.active > p {
    height: 52px;
    border-bottom: 2px solid #1871bc;
}
header .spMenu .menuBody > ul > li.active .spMenu02 {
    background: url('../img/common/service_icon.png') no-repeat 15px center, url('../img/common/spMenu_close.png') no-repeat right 16px center;
    background-size: 16px,14px 3px;
}
header .spMenu .menuBody > ul > li.active .spMenu02 ul {
    height: 240px;
}
header .spMenu .menuBody > ul > li.active .spMenu04 {
    background: url('../img/common/about_icon.png') no-repeat 15px center, url('../img/common/spMenu_close.png') no-repeat right 16px center;
    background-size: 15px 16px,14px 3px;
}
header .spMenu .menuBody > ul > li.active .spMenu04 ul {
    height: 120px;
}
header .spMenu .menuBody > ul > li.active .spMenu06 {
    background: url('../img/common/info_icon.png') no-repeat 15px center, url('../img/common/spMenu_close.png') no-repeat right 16px center;
    background-size: 16px,14px 3px;
}
header .spMenu .menuBody > ul > li.active .spMenu06 ul {
    height: 80px;
}
header .spMenu .menuBody > ul > li:nth-of-type(2).active ul {
    height: 240px;
    opacity: 1;
}
header .spMenu .menuBody > ul > li:nth-of-type(2).active ul li:last-of-type {
    display: block;
    width: 100%;
    border-bottom: none;
}
header .spMenu .menuBody > ul > li:nth-of-type(4).active ul {
    height: 120px;
    opacity: 1;
}
header .spMenu .menuBody > ul > li:nth-of-type(4).active ul li:last-of-type {
    display: block;
    width: 100%;
    border-bottom: none;
}
header .spMenu .menuBody > ul > li:nth-of-type(6).active ul {
    height: 80px;
    opacity: 1;
}
header .spMenu .menuBody ul.spContact {
    display: table;
    width: 100%;
    padding: 0;
}
header .spMenu .menuBody ul.spContact li {
    display: table-cell;
    width: 50%;
    padding: 0;
    vertical-align: top;
    color: #fff;
    border-radius: 0;
}
header .spMenu .menuBody ul.spContact li a {
    font-weight: bold;
    line-height: 1.2;
    display: table-cell;
    height: 75px;
    margin: 0;
    padding: 0;
    vertical-align: middle;
    color: #fff;
    width: 400px;
}
header .spMenu .menuBody ul.spContact li.tel {
    background: #7ab337;
}
header .spMenu .menuBody ul.spContact li.tel span {
    display: block;
    padding: 0 0 0 46px;
    background: url('../img/common/tel_icon.png') 15px center no-repeat;
    background-size: 23px auto;
}
header .spMenu .menuBody ul.spContact li.email {
    background: #1871bc;
}
header .spMenu .menuBody ul.spContact li.email span {
    display: block;
    padding: 0 0 0 46px;
    background: url('../img/common/email_icon.png') 15px center no-repeat;
    background-size: 19px auto;
}
header nav {
    width: 960px;
    height: 64px;
    margin: 0 auto;
}
header nav ul li {
    font-size: 16px;
    font-weight: bold;
    line-height: 64px;
    float: left;
    text-align: center;
}
header nav ul li a {
    font-weight: bold;
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    -webkit-transition: .3s;
            transition: .3s;
    color: #333;
}
header nav ul li a span {
    position: relative;
    display: inline-block;
}
header nav ul li a span:after {
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0;
    height: 4px;
    content: '';
    -webkit-transition: .3s;
            transition: .3s;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    background-color: #325d81;
}
header nav ul li a:hover {
    zoom: 1;
    cursor: pointer;
    -webkit-transition-property: none;
            transition-property: none;
           opacity: 1;
    color: #325d81;
        filter: alpha(opacity=100);
    -ms-filter: 'alpha(opacity=100)';
      -moz-opacity: 1.0;
    -khtml-opacity: 1.0;
}
header nav ul li a:hover span:after {
    width: 110%;
}
header nav ul .navActive a {
    color: #325d81;
}
header nav ul .navActive a span:after {
    width: 110%;
}
header nav ul li:nth-child(1) {
    width: 160px;
}
header nav ul li:nth-child(2) {
    width: 130px;
}
header nav ul li:nth-child(3) {
    width: 190px;
}
header nav ul li:nth-child(4) {
    width: 200px;
}
header nav ul li:nth-child(5) {
    width: 280px;
}
header #menuWrap {
    position: absolute;
    z-index: 100000;
    top: 60px;
    left: 0;
    width: 100%;
    background: #e3e3e3;
}
/*-------------------------------------------------------------
mv
-------------------------------------------------------------*/
main #mv {
    display: table;
    width: 100%;
    height: 300px;
    margin: 0 0 60px;
    text-align: center;
    background: url(../img/common/mv03.jpg) center no-repeat;
    background-size: cover;
}
main #mv h2 {
    display: table-cell;
    vertical-align: middle;
}
main #mv h2 img {
    max-width: 100%;
    height: auto;
}
#service main #mv,
#tax main #mv,
#inheritance main #mv,
#finance main #mv,
#promotion main #mv,
#management main #mv,
#individual main #mv,
#ta-change main #mv,
#one-stop main #mv,
#simulation main #mv,
#labor main #mv,
#sp-corporation main #mv {
    background: url(../img/common/mv01.jpg) center no-repeat;
    background-size: cover;
}
#price main #mv,
#faq main #mv,
#recruit main #mv,
#contact main #mv,
#about main #mv,
#message main #mv,
#privacy-policy main #mv {
    background: url(../img/common/mv02.jpg) center no-repeat;
    background-size: cover;
}
/*-------------------------------------------------------------
contents
-------------------------------------------------------------*/
.workPanel {
    width: 960px;
    margin: 0 auto;
    -webkit-transition-duration: .5s;
            transition-duration: .5s;
    -webkit-transition-property: width;
            transition-property: width;
}
.workPanel ul {
    margin: 0 0 0 -30px;
}
.workPanel ul li {
    position: relative;
    z-index: 10;
    float: left;
    width: 300px;
    height: 315px;
    margin: 0 0 30px 30px;
    background: #fff;
}
.workPanel ul li a {
    display: block;
    width: 100%;
    height: 100%;
}
.workPanel ul li a > div {
    position: relative;
    display: table-cell;
    width: 300px;
    height: 200px;
    text-align: center;
    vertical-align: middle;
    background: url(../img/common/service/bg.gif) top left repeat;
}
.workPanel ul li a > div div {
    line-height: 32px;
    position: absolute;
    bottom: 0;
    left: 0;
    box-sizing: border-box;
    width: 130px;
    height: 32px;
    text-align: left;
    color: #fff;
    background: #1871bc;
}
.workPanel ul li a > div div span {
    display: block;
    padding: 0 0 0 25px;
}
.workPanel ul li a > div div:after {
    position: absolute;
    top: 13px;
    right: 9px;
    width: 9px;
    height: 6px;
    content: '';
    background: url(../img/common/btn_arrow.png) no-repeat right;
    background-size: 9px 6px;
}
.workPanel ul li a p {
    line-height: 1.73;
    padding: 20px 0 0;
    color: #000;
}
.workPanel ul li:nth-of-type(2) div div {
    width: 240px;
}
.workPanel ul li:last-child div div {
    width: 150px;
}
.cateListV,
.cateList {
    margin-bottom: 80px;
}
.cateListV ul,
.cateList ul {
    overflow: hidden;
}
.cateListV ul li,
.cateList ul li {
    float: left;
    width: 460px;
    height: 70px;
    border-bottom: 1px solid #dadada;
}
.cateListV ul li:nth-of-type(even),
.cateList ul li:nth-of-type(even) {
    float: right;
}
.cateListV ul li:first-of-type,
.cateListV ul li:nth-of-type(2),
.cateList ul li:first-of-type,
.cateList ul li:nth-of-type(2) {
    border-top: 1px solid #dadada;
}
.cateListV ul li.current-cat a,
.cateList ul li.current-cat a {
    background: #ecf4fa;
}
.cateListV ul li a,
.cateList ul li a {
    font-size: 16px;
    font-weight: bold;
    line-height: 70px;
    display: block;
    overflow: hidden;
    padding: 0 20px;
    color: #325d81;
}
.cateListV ul li a:after,
.cateList ul li a:after {
    display: block;
    float: right;
    width: 9px;
    height: 70px;
    content: '';
    vertical-align: middle;
    background: url('../img/common/btn_arrow2.png') no-repeat left center;
    background-size: 9px 6px;
}
.cateListV ul li a:hover,
.cateList ul li a:hover {
    -webkit-transition: all .6s ease;
            transition: all .6s ease;
    opacity: 1;
    background: #ecf4fa;
}
.cateListV ul li a:after {
    width: 6px;
    background: url('../img/common/btn_arrow2v.png') no-repeat left center;
    background-size: 6px 9px;
}
#individual .cateListV {
    margin-bottom: 0;
}
#labor .cateList {
    margin-bottom: 0;
}
#contents .secBox {
    overflow: hidden;
    margin-bottom: 90px;
}
#contents .secBox p,
#contents .secBox ul {
    margin-bottom: 30px;
}
#contents .secBox p:last-child,
#contents .secBox ul:last-child {
    margin-bottom: 0;
}
#contents .secBox .cateList:last-child {
    margin-bottom: 0;
}
#contents .secBox .box3:last-child .box {
    margin-bottom: 8px;
}
#contents .secBox .bgg:last-child {
    margin-bottom: 8px;
}
#price #contents .secBox:last-of-type {
    overflow: hidden;
    margin-bottom: 110px;
}
#contents h3 {
    font-size: 22px;
    font-weight: bold;
    line-height: 30px;
    clear: both;
    margin-bottom: 40px;
    padding: 10px;
    text-align: center;
    color: #1871bc;
    border-bottom: 2px solid #1871bc;
    background: #ecf4fa;
}
#contents h4 {
    font-size: 18px;
    font-weight: bold;
    clear: both;
    margin-bottom: 16px;
    padding-bottom: 5px;
    color: #7ab337;
    border-bottom: 1px solid #ececec;
}
#contents .table {
    display: table;
}
#contents .table .t-tr {
    display: table-row;
}
#contents .table .t-th,
#contents .table .t-td {
    display: table-cell;
}
#contents .textGreenB {
    font-weight: bold;
    margin-left: 15px;
    color: #7ab337;
}
#contents .secBox .catchCopy {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 48px;
}
#contents .secBox .catchCopy strong {
    padding-bottom: 2px;
    color: #7ab337;
    border-bottom: 4px solid #7ab337;
}
#contents .secBox .catchCopy2 {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.9;
    margin-bottom: 48px;
}
#contents .secBox .catchCopy2 strong {
    padding-bottom: 2px;
    color: #7ab337;
    border-bottom: 4px solid #7ab337;
}
#contents .list01 li {
    position: relative;
    padding-left: 23px;
}
#contents .list01 li:before {
    position: absolute;
    top: 10px;
    left: 0;
    display: inline-block;
    width: 12px;
    height: 4px;
    margin-right: 12px;
    content: '';
    background: #325d81;
}
#contents .list01.bold li {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 15px;
}
#contents .list01.boldBlue li {
    font-weight: bold;
    color: #325d81;
}
#contents .list01.col2 {
    display: inline-block;
    width: 48%;
    vertical-align: top;
}
#contents .list01Txt {
    margin-bottom: 34px;
}
#contents .list01Txt li {
    font-weight: bold;
    position: relative;
    margin-bottom: 10px;
    padding-left: 19px;
    color: #325d81;
}
#contents .list01Txt li:before {
    position: absolute;
    top: 10px;
    left: 0;
    display: inline-block;
    width: 12px;
    height: 4px;
    margin-right: 12px;
    content: '';
    background: #325d81;
}
#contents .list01Txt li p {
    font-weight: normal;
    color: #000;
}
#contents ol.dcml {
    margin-left: 50px;
    list-style-type: decimal;
}
#contents ol.dcml li {
    line-height: 1.87;
    list-style-type: decimal;
}
#contents .ttlg,
#contents .ttlg2 {
    line-height: 160%;
    margin-bottom: 20px;
    color: #66a121;
}
#contents .ttlg span,
#contents .ttlg2 span {
    font-size: 16px;
    display: inline-block;
    margin-right: 3px;
    padding: 6px 14px 2px 19px;
    color: #fff;
    background: #7ab337;
}
#contents .bgg {
    margin-bottom: 40px;
    padding: 28px 28px 20px;
    background: #ecf5e2;
}
#contents .bgg p {
    font-size: 16px;
    margin-bottom: 0;
}
#contents .bgg p span {
    display: block;
}
#contents .link_btn {
    text-align: center;
}
#contents .link_btn a {
    font-size: 16px;
    display: inline-block;
    margin: 32px 0 10px;
    padding: 3px 10px 2px 31px;
    color: #fff;
    background: #1871bc;
}
#contents .link_btn a:after {
    display: inline-block;
    width: 9px;
    height: 6px;
    margin-left: 12px;
    content: '';
    vertical-align: middle;
    background: url('../img/common/btn_arrow.png') no-repeat left center;
    background-size: 9px 6px;
}
#contents .q {
    margin-bottom: 10px;
}
#contents .q li {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 25px;
    padding: 0 0 0 45px;
    background: url('../img/service/q_icon.png') no-repeat left top;
    background-size: 35px;
}
#contents .q li:last-of-type {
    margin-bottom: 0;
}
#contents .q li.active {
    margin-bottom: 25px;
}
#contents .q li span {
    cursor: pointer;
    display: inline-block;
    padding-top: 4px;
}
#contents .q li p {
    font-size: 15px;
    font-weight: normal;
    display: none;
    margin-left: -45px;
    padding: 9px 0 28px;
    border-bottom: 1px solid #e2e2e2;
}
#contents .secBox .serviceFlow .flowBox {
    overflow: hidden;
    margin-bottom: 40px;
    text-align: left;
}
#contents .secBox .serviceFlow .flowBox:last-child {
    margin-bottom: 8px;
}
#contents .secBox .serviceFlow .flowBox .cntL,
#contents .secBox .serviceFlow .flowBox .cntLR,
#contents .secBox .serviceFlow .flowBox .cntR {
    border: 1px solid #1871bc;
    border-radius: 10px;
}
#contents .secBox .serviceFlow .flowBox .cntL p,
#contents .secBox .serviceFlow .flowBox .cntLR p,
#contents .secBox .serviceFlow .flowBox .cntR p {
    margin-bottom: 0;
}
#contents .secBox .serviceFlow .flowBox .cntL .ttl,
#contents .secBox .serviceFlow .flowBox .cntLR .ttl,
#contents .secBox .serviceFlow .flowBox .cntR .ttl {
    font-size: 16px;
    font-weight: bold;
    line-height: 48px;
    margin-bottom: 0;
    text-align: center;
    border-bottom: 1px solid #1871bc;
    border-radius: 10px 10px 0 0;
}
#contents .secBox .serviceFlow .flowBox .cntL .cnt,
#contents .secBox .serviceFlow .flowBox .cntLR .cnt,
#contents .secBox .serviceFlow .flowBox .cntR .cnt {
    margin-bottom: 0;
    padding: 14px 23px 18px;
}
#contents .secBox .serviceFlow .flowBox .cntL .cnt .link,
#contents .secBox .serviceFlow .flowBox .cntLR .cnt .link,
#contents .secBox .serviceFlow .flowBox .cntR .cnt .link {
    text-align: center;
}
#contents .secBox .serviceFlow .flowBox .cntL .cnt .link a,
#contents .secBox .serviceFlow .flowBox .cntLR .cnt .link a,
#contents .secBox .serviceFlow .flowBox .cntR .cnt .link a {
    display: inline-block;
    margin: 20px 0 10px;
    padding: 4px 10px 2px 33px;
    letter-spacing: .15em;
    color: #fff;
    background: #1871bc;
}
#contents .secBox .serviceFlow .flowBox .cntL .cnt .link a:after,
#contents .secBox .serviceFlow .flowBox .cntLR .cnt .link a:after,
#contents .secBox .serviceFlow .flowBox .cntR .cnt .link a:after {
    display: inline-block;
    width: 9px;
    height: 6px;
    margin-left: 12px;
    content: '';
    vertical-align: middle;
    background: url('../img/common/btn_arrow.png') no-repeat left center;
    background-size: 9px 6px;
}
#contents .secBox .serviceFlow .flowBox .cntL {
    position: relative;
    float: left;
    clear: both;
    box-sizing: border-box;
    width: 380px;
}
#contents .secBox .serviceFlow .flowBox .cntL:after {
    position: absolute;
    top: 60px;
    right: -40px;
    display: block;
    width: 18px;
    height: 22px;
    content: '';
    background: url('../img/common/arrow01.png') no-repeat right center;
    background-size: 18px 22px;
}
#contents .secBox .serviceFlow .flowBox .cntL .ttl {
    background: #f5f5f5;
}
#contents .secBox .serviceFlow .flowBox .cntR {
    float: right;
    box-sizing: border-box;
    width: 520px;
}
#contents .secBox .serviceFlow .flowBox .cntR .ttl {
    color: #7ab337;
    background: #ecf5e2;
}
#contents .secBox .serviceFlow .flowBox .cntLR {
    box-sizing: border-box;
    width: 100%;
}
#contents .secBox .serviceFlow .flowBox .cntLR .ttl {
    color: #7ab337;
    background: #ecf5e2;
}
#contents .secBox .serviceFlow .flowBox.bg .cntL {
    width: 380px;
    margin-right: 58px;
}
#contents .secBox .serviceFlow .flowBox.bg .cntL .cnt {
    padding: 19px 23px 20px;
}
#contents .secBox .serviceFlow .flowBox.bg .cntL:after {
    top: 50%;
    margin-top: -12px;
}
#contents .secBox .serviceFlow .flowBox.bg .cntR {
    float: left;
    width: 450px;
    padding-top: 18px;
    border-color: #7ab337;
}
#contents .secBox .serviceFlow .flowBox.bg .cntR .telttl {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 18px;
    text-align: center;
}
#contents .secBox .serviceFlow .flowBox.bg .cntR .teltxt {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.9;
    margin-bottom: 15px;
    margin-left: 18px;
    padding-left: 115px;
    color: #7ab337;
    background: url('../img/service/contact_icon.png') no-repeat left center;
    background-size: 90px 95px;
}
#contents .secBox .serviceFlow .flowBox.bg .cntR .teltxt span {
    display: inline-block;
    border-bottom: 3px solid #7ab337;
}
.copyGU {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 30px;
}
.copyGU strong {
    padding-bottom: 2px;
    color: #7ab337;
    border-bottom: 4px solid #7ab337;
}
.wrapTable {
    width: 100%;
}
#inheritance #contents .link_btn a {
    margin-top: 0;
}
#contents .bgg .wrapCnt {
    overflow: hidden;
}
#contents .bgg .wrapCnt .cntL {
    float: left;
    width: 444px;
    margin-right: 45px;
}
#contents .bgg .wrapCnt .cntL .ttl {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 20px;
    text-align: center;
    border-bottom: 4px solid #7ab337;
}
#contents .bgg .wrapCnt .cntL .img {
    text-align: center;
}
#contents .bgg .wrapCnt .cntR {
    float: left;
    width: 350px;
}
#contents .bgg .wrapCnt .cntR .borderBoxB {
    box-sizing: border-box;
    width: 100%;
    min-height: 150px;
    padding: 20px 30px;
    border: 1px solid #1871bc;
    border-radius: 10px;
    background: #fff;
}
#contents .bgg .wrapCnt .cntR .borderBoxB .ttl {
    font-size: 16px;
    margin-bottom: 5px;
}
#contents .bgg .wrapCnt .cntR .borderBoxB .cnt {
    font-size: 16px;
    line-height: 1.2;
    color: #1871bc;
}
#contents .bgg .wrapCnt .cntR .borderBoxB .cnt strong span {
    font-size: 30px;
    display: inline;
}
.center {
    text-align: center;
}
.bold {
    font-weight: bold;
}
.vText {
        -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
            writing-mode: vertical-rl;
}
.marker {
    font-weight: normal;
    padding: 1px 3px;
    background: #cceaa9;
}
#contents .secBox .mbs {
    margin-bottom: 16px;
}
#contents .secBox .col2Box {
    overflow: hidden;
    margin-bottom: 30px;
}
#contents .secBox .col2Box:last-child {
    margin-bottom: 0;
}
#contents .secBox .col2Box .cntL,
#contents .secBox .col2Box .cntR {
    border: 1px solid #1871bc;
    border-radius: 10px;
}
#contents .secBox .col2Box .cntL p,
#contents .secBox .col2Box .cntR p {
    margin-bottom: 0;
}
#contents .secBox .col2Box .cntL .ttl,
#contents .secBox .col2Box .cntR .ttl {
    font-size: 16px;
    font-weight: bold;
    line-height: 48px;
    margin-bottom: 0;
    text-align: center;
    border-bottom: 1px solid #1871bc;
    border-radius: 10px 10px 0 0;
}
#contents .secBox .col2Box .cntL .ttl.textL,
#contents .secBox .col2Box .cntR .ttl.textL {
    padding-right: 19px;
    padding-left: 19px;
    text-align: left;
}
#contents .secBox .col2Box .cntL .ttl .ttlg,
#contents .secBox .col2Box .cntR .ttl .ttlg {
    font-size: 14px;
    display: inline-block;
    margin-right: 12px;
}
#contents .secBox .col2Box .cntL .ttl .ttlg span,
#contents .secBox .col2Box .cntR .ttl .ttlg span {
    font-size: 14px;
    padding: 3px 6px 2px 9px;
}
#contents .secBox .col2Box .cntL .cnt,
#contents .secBox .col2Box .cntR .cnt {
    margin-bottom: 0;
    padding: 14px 23px 18px;
}
#contents .secBox .col2Box .cntL {
    float: left;
    width: 460px;
}
#contents .secBox .col2Box .cntL .ttl {
    background: #f5f5f5;
}
#contents .secBox .col2Box .cntL .ttl.ttlg {
    color: #7ab337;
    background: #ecf5e2;
}
#contents .secBox .col2Box .cntR {
    float: right;
    width: 460px;
}
#contents .secBox .col2Box .cntR .ttl {
    color: #7ab337;
    background: #ecf5e2;
}
#contents .secBox .col2Box .cntR .ttl.ttlb {
    color: #333;
    background: #f5f5f5;
}
table.col4 {
    overflow: hidden;
    width: 100%;
    border-spacing: 0;
    border-collapse: separate;
    border: 1px solid #5294cc;
    border-radius: 10px;
}
table.col4 th,
table.col4 th,
table.col4 td {
    line-height: 1.4;
    box-sizing: border-box;
    width: 25%;
    height: 50px;
    padding: 10px 20px;
    letter-spacing: .05em;
    border-bottom: 1px solid #5294cc;
}
table.col4 th {
    font-weight: bold;
    width: 385px;
}
table.col4 th:first-of-type {
    width: 190px;
}
table.col4 td.nobd {
    border-bottom: none;
}
table.col4 td:first-of-type {
    width: 190px;
    border-left: none;
}
table.col4 tr:first-of-type th {
    font-size: 16px;
    text-align: center;
    background-color: #f5f5f5;
}
table.col4 th + th,
table.col4 td {
    border-left: 1px solid #5294cc;
}
table.col4 tr:last-child th,
table.col4 tr:last-child td {
    border-bottom: none;
}
#path {
    clear: both;
    width: 1240px;
    margin: 0 auto;
}
#path ol {
    line-height: 1.4;
    margin: 0 200px 8px 0;
}
#path ol li {
    font-size: 14px;
    line-height: 1;
    position: relative;
    display: inline;
    margin: 0 34px 0 0;
}
#path ol li a {
    display: inline-block;
    padding: 10px 0;
}
#path ol li:first-child a {
    padding: 10px 0 10px 20px;
    background: url(../img/common/ico_home.png) left 8px no-repeat;
}
#path ol li:after {
    position: absolute;
    top: 0;
    right: -16px;
    width: 0;
    height: 0;
    content: '-';
    color: #333;
}
#path ol li:first-child:after {
    right: -10px;
}
#path ol li:last-child:after {
    content: '';
}
/*-------------------------------------------------------------
footer
-------------------------------------------------------------*/
footer {
    position: relative;
}
footer #pageTop {
    line-height: 1;
    position: absolute;
    top: -40px;
    right: 0;
    width: 160px;
    height: 26px;
}
footer #pageTop a {
    font-weight: bold;
    line-height: 1;
    display: block;
    height: 100%;
    color: #000;
    border-bottom: 4px solid #325d81;
    padding-top: 10px;
}
footer #fContact {
    height: 200px;
    background: #f5f5f5;
}
footer #fContact > ul {
    width: 960px;
    margin: 0 auto;
}
footer #fContact > ul > li {
    float: left;
    height: 200px;
}
footer #fContact > ul > li:last-child {
    width: 640px;
    padding: 50px 0 0;
}
footer #fContact > ul > li:last-child ul li {
    float: left;
    width: 320px;
    height: 70px;
}
footer #fContact > ul > li:last-child ul li:first-child {
    font-size: 28px;
    line-height: 70px;
    text-align: center;
    letter-spacing: .03em;
    color: #fff;
    background: #7ab337;
}
footer #fContact > ul > li:last-child ul li:first-child a {
    display: block;
    color: #fff;
}
footer #fContact > ul > li:last-child ul li:first-child span {
    padding: 0 0 0 38px;
    background: url('../img/common/tel_icon.png') left center no-repeat;
    background-size: 30px auto;
}
footer #fContact > ul > li:last-child ul li:last-child {
    font-size: 18px;
    line-height: 70px;
    text-align: center;
    color: #fff;
    background: #1871bc;
}
footer #fContact > ul > li:last-child ul li:last-child a {
    display: block;
    display: block;
    width: 100%;
    height: 100%;
    color: #fff;
}
footer #fContact > ul > li:last-child ul li:last-child a span {
    padding: 0 0 0 38px;
    background: url('../img/common/email_icon.png') left no-repeat;
    background-size: 26px auto;
}
footer #fContact > ul > li:last-child p {
    font-size: 13px;
    line-height: 1;
    padding: 20px 0 0 35px;
    letter-spacing: .05em;
}
footer #fContact > ul > li:first-child {
    position: relative;
    width: 320px;
}
footer #fContact > ul > li:first-child:after {
    position: absolute;
    top: 80px;
    right: 35px;
    display: block;
    width: 13px;
    height: 10px;
    content: '';
    background: url('../img/common/Ico_arrow.png') no-repeat right center;
}
footer #fContact > ul > li:first-child h2 {
    padding: 73px 0 0;
}
footer nav {
    width: 830px;
    margin: 0 auto;
    padding: 52px 0 53px;
}
footer nav ul li {
    line-height: 1;
    float: left;
    padding: 0 0 6px;
}
footer nav ul li a {
    font-size: 15px;
    font-weight: bold;
    color: #333;
    padding: 8px 0 10px;
    display: inline-block;
}
footer nav ul li:nth-child(4n + 1) {
    width: 170px;
}
footer nav ul li:nth-child(4n + 2) {
    width: 250px;
}
footer nav ul li:nth-child(4n + 3) {
    width: 237px;
}
footer nav ul li:nth-child(4n + 4) {
    width: 163px;
}
footer #fAddr {
    border-top: 1px solid #e2e2e2;
}
footer #fAddr ul {
    width: 650px;
    margin: 0 auto;
    padding: 59px 0 65px;
}
footer #fAddr ul li {
    font-size: 14px;
    float: left;
    width: 343px;
}
footer #fAddr ul li p {
    line-height: 1;
}
footer #fAddr ul li p:last-child {
    padding: 3px 0 0;
    color: #1871bc;
}
footer #fAddr ul li p:last-child a {
    display: inline-block;
    padding: 10px 0;
}
footer #fAddr ul > li:first-child {
    width: 250px;
    padding: 0 57px 0 0;
}
footer #copy {
    line-height: 50px;
    height: 50px;
    text-align: center;
    background: #325d81;
}
footer #copy span {
    font-size: 12px;
    color: #fff;
}
/*-------------------------------------------------------------
form
-------------------------------------------------------------*/
/*-------------------------------------------------------------
sns
-------------------------------------------------------------*/
/* twitter */
iframe.twitter-share-button {
    width: 101px !important;
}
/*-------------------------------------------------------------
a hover
-------------------------------------------------------------*/
img {
    box-shadow: #000 0 0 0;
}
a {
    text-decoration: none;
    color: #1871bc;
}
a:hover {
    cursor: pointer;
    -webkit-transition-duration: .3s;
            transition-duration: .3s;
    -webkit-transition-property: opacity;
            transition-property: opacity;
           opacity: .7;
        filter: alpha(opacity=70);
    -ms-filter: 'alpha(opacity=70)';
      -moz-opacity: .7;
    -khtml-opacity: .7;
}
a img {
    box-shadow: #000 0 0 0;
}
/*-------------------------------------------------------------
other
-------------------------------------------------------------*/
#contents .not404 {
    margin-bottom: 50px;
}
#contents .wrapPage.mb80 {
    margin-bottom: 80px;
}
#dummy {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 0;
    height: 0;
}
.webFontChivo {
    font-family: 'Chivo', sans-serif;
}
/* clear */
.clear {
    clear: both;
}
/* clearfix */
.clearfix:after {
    font-size: 0;
    line-height: 0;
    display: block;
    visibility: hidden;
    clear: both;
    height: 0;
    content: '.';
}
input {
    position: relative;
    top: -1px;
    vertical-align: middle;
}
/*-------------------------------
selection
--------------------------------*/
::-moz-selection {
    color: #1e7881;
    background: #d4f9fd;
}
::selection {
    color: #1e7881;
    background: #d4f9fd;
}
::-moz-selection {
    color: #1e7881;
    background: #d4f9fd;
}
/*-------------------------------------------------------------
top
-------------------------------------------------------------*/
#home .workPanel {
    margin-top: -30px;
    margin-bottom: 80px;
}
#home #message {
    padding: 20px;
    background: #325d81;
}
#home #message ul li {
    position: relative;
    display: table;
    overflow: hidden;
}
#home #message ul li > img {
    position: absolute;
    top: 50%;
    left: 0;
    margin: -30px 0 0;
}
#home #message ul li > div {
    font-size: 25px;
    font-weight: bold;
    line-height: 1.6;
    display: table-cell;
    height: 300px;
    padding: 0  20%;
    vertical-align: middle;
}
#home #message ul li > div div span {
    position: relative;
    display: inline-block;
    color: #7ab337;
}
#home #message ul li > div div span:after {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 4px;
    content: '';
    background: #7ab337;
}
#home #message .messageOdd {
    overflow: hidden;
}
#home #message .messageOdd li {
    float: right;
    width: 50%;
    height: 300px;
}
#home #message .messageOdd li:nth-child(odd) {
    background: #f8f8f8;
}
#home #message .messageEven {
    overflow: hidden;
}
#home #message .messageEven li {
    float: left;
    width: 50%;
    height: 300px;
}
#home #message .messageEven li:nth-child(odd) {
    background: #f8f8f8;
}
#home #message #message01 li:nth-child(even) {
    width: 50%;
    background: url(../img/home/message/photo1.jpg) no-repeat center;
    background-size: cover;
}
#home #message #message01 li div div {
    box-sizing: border-box;
    min-height: 78px;
    margin: 0 0 0 -68px;
    padding: 0 0 0 74px;
    background: url(../img/home/message/ico_no1.gif) left no-repeat;
}
#home #message #message02 li:nth-child(even) {
    width: 50%;
    background: url(../img/home/message/photo2.jpg) no-repeat center;
    background-size: cover;
}
#home #message #message02 li div div {
    min-height: 78px;
    margin: 0 0 0 -50px;
    padding: 0 0 0 94px;
    background: url(../img/home/message/ico_no2.gif) left no-repeat;
}
#home #message #message03 li:nth-child(even) {
    width: 50%;
    background: url(../img/home/message/photo3.jpg) no-repeat center;
    background-size: cover;
}
#home #message #message03 li div div {
    min-height: 84px;
    margin: 0 0 0 -92px;
    padding: 0 0 0 86px;
    background: url(../img/home/message/ico_no3.gif) left no-repeat;
}
#home #message #message04 li:nth-child(even) {
    width: 50%;
    background: url(../img/home/message/photo4.jpg) no-repeat center;
    background-size: cover;
}
#home #message #message04 li div div {
    min-height: 86px;
    margin: 0 0 0 -54px;
    padding: 0 0 0 98px;
    background: url(../img/home/message/ico_no4.gif) left no-repeat;
}
#home #topInfo {
    padding: 0 0 180px;
}
#home #topInfo > ul {
    width: 1240px;
    margin: 0 auto;
    padding: 90px 0 0;
}
#home #topInfo > ul > li {
    float: left;
}
#home #topInfo > ul > li h2 {
    position: relative;
    height: 70px;
}
#home #topInfo > ul > li h2 a {
    display: block;
    width: 100%;
    height: 100%;
}
#home #topInfo > ul > li h2 a:after {
    position: absolute;
    top: 30px;
    right: 15px;
    width: 13px;
    height: 10px;
    content: '';
    background: url(../img/common/Ico_arrow.png) no-repeat;
    background-size: 13px 10px;
}
#home #topInfo > ul > li:first-child {
    position: relative;
    z-index: 1;
    width: 470px;
    margin: 0 50px 0 0;
}
#home #topInfo > ul > li:first-child h2 {
    text-align: center;
}
#home #topInfo > ul > li:first-child h2 img {
    padding: 24px 0 0;
}
#home #topInfo > ul > li:first-child ul li {
    float: left;
    width: 290px;
    height: 180px;
}
#home #topInfo > ul > li:first-child ul li:first-child {
    width: 180px;
}
#home #topInfo > ul > li:first-child ul li:last-child {
    box-sizing: border-box;
    border-top: 1px solid #e2e2e2;
    border-bottom: 4px solid #325d81;
}
#home #topInfo > ul > li:first-child ul li:last-child dl {
    padding: 0 20px 0 25px;
}
#home #topInfo > ul > li:first-child ul li:last-child dl a {
    display: block;
    padding-bottom: 10px;
}
#home #topInfo > ul > li:first-child ul li:last-child dl dt {
    line-height: 1;
    padding: 25px 0 11px;
    color: #333;
}
#home #topInfo > ul > li:first-child ul li:last-child dl dd {
    line-height: 1.73;
    color: #1871bc;
}
#home #topInfo > ul > li:last-child {
    width: 100%;
    margin-left: -520px;
}
#home #topInfo > ul > li:last-child h2 {
    text-align: center;
}
#home #topInfo > ul > li:last-child h2 img {
    padding: 26px 0 0;
}
#home #topInfo > ul > li:last-child > div {
    margin-left: 520px;
}
#home #topInfo > ul > li:last-child > div div {
    overflow: auto;
    height: 181px;
}
#home #topInfo > ul > li:last-child > div div table {
    width: 100%;
    height: 179px;
    border-top: 1px solid #e2e2e2;
}
#home #topInfo > ul > li:last-child > div div table th {
    line-height: 1.3;
    width: 110px; /*height:59px;*/
    padding: 21px 0 18px 20px;
    vertical-align: top;
    border-bottom: 1px solid #e2e2e2;
}
#home #topInfo > ul > li:last-child > div div table td {
    line-height: 1.3;
    width: auto;
    padding: 11px 20px 8px 0;
    vertical-align: top;
    color: #1871bc; /*height:59px;*/
    border-bottom: 1px solid #e2e2e2;
}
#home #topInfo > ul > li:last-child > div div table td a {
    display: block;
    padding: 10px 0;
}
/*-------------------------------------------------------------
lower
-------------------------------------------------------------*/
#contentsWrap {
    width: 1240px;
    margin: 0 auto;
}
#contentsWrap #contents {
    float: left;
    width: 100%;
    margin-left: -220px;
}
#contentsWrap #contents > div {
    padding-left: 280px;
}
#contentsWrap #side {
    position: relative;
    z-index: 1;
    float: left;
    width: 220px;
    margin: 0 0 100px;
}
#contentsWrap #side ul {
    border-bottom: 4px solid #325d81;
}
#contentsWrap #side ul li {
    line-height: 1;
    padding: 20px 0;
    border-top: 1px solid #e2e2e2;
}
#contentsWrap #side ul li div {
    padding: 0 0 10px;
}
#contentsWrap #side ul li div a {
    display: inline-block;
    padding: 5px 0;
}
#contentsWrap #side ul li div:first-child {
    font-size: 16px;
    font-weight: bold;
    padding: 0 0 15px;
}
#contentsWrap #side ul li div:first-child a {
    color: #333;
}
#contentsWrap #side ul li div:last-child {
    padding: 0;
}
#contentsWrap #side ul li:first-of-type div:first-child {
    padding-top: 2px;
}
#contentsWrap #side ul li:first-of-type div:first-child a {
    padding-left: 25px;
    background: url('../img/common/about_icon.png') no-repeat left center;
    background-size: 15px 16px;
}
#contentsWrap #side ul li:nth-of-type(2) div:first-child a {
    padding-left: 25px;
    background: url('../img/common/service_icon.png') no-repeat left center;
    background-size: 16px;
}
#contentsWrap #side ul li:nth-of-type(3) div:first-child a {
    padding-left: 25px;
    background: url('../img/common/info_icon.png') no-repeat left center;
    background-size: 16px;
}
@media all and (-ms-high-contrast: none) {
    header #hContact a {
        padding-top: 3px;
    }
    .workPanel ul li a > div div {
        padding-top: 3px;
    }
    #contents .secBox {
        margin-top: -3px;
        padding-top: 3px;
    }
    #contents h3 {
        padding: 14px 10px 6px;
    }
    #contents .link_btn a {
        padding: 7px 10px 0 31px;
    }
    #contents .secBox .serviceFlow .flowBox .cntL .cnt .link a,
    #contents .secBox .serviceFlow .flowBox .cntLR .cnt .link a,
    #contents .secBox .serviceFlow .flowBox .cntR .cnt .link a {
        padding: 7px 10px 0 31px;
    }
    #contents .secBox .col2Box .cntL .ttl .ttlg span,
    #contents .secBox .col2Box .cntR .ttl .ttlg span {
        padding-top: 6px;
        padding-bottom: 0;
    }
    footer #fContact > ul > li:last-child ul li:last-child a {
        padding-top: 3px;
    }
}
@media screen and (max-width: 1255px) {
    .cateListV ul,
    .cateList ul {
        padding: 0;
    }
    .cateListV ul li,
    .cateList ul li {
        width: 48%;
    }
    #contents .secBox .serviceFlow .flowBox .cntL {
        width: 38%;
    }
    #contents .secBox .serviceFlow .flowBox .cntL:after {
        right: -15%;
    }
    #contents .secBox .serviceFlow .flowBox .cntR {
        width: 52%;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntL {
        width: 43%;
        margin-right: 0;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntL:after {
        right: -12%;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntR {
        float: right;
        width: 50%;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntR .teltxt span {
        display: inline;
    }
    #contents .bgg .wrapCnt .cntL {
        width: 50%;
        margin-right: 0;
    }
    #contents .bgg .wrapCnt .cntL .ttl {
        text-align: left;
    }
    #contents .bgg .wrapCnt .cntR {
        float: right;
        width: 45%;
    }
    #contents .bgg .wrapCnt .cntR .borderBoxB {
        padding: 20px;
    }
    #contents .bgg .wrapCnt .cntR .borderBoxB .cnt {
        font-size: 15px;
    }
    #contents .secBox .col2Box .cntL {
        width: 48%;
    }
    #contents .secBox .col2Box .cntR {
        width: 48%;
    }
    #contentsWrap {
        box-sizing: border-box;
        width: 100%;
        padding: 0 20px;
    }
    /*-------------------------------------------------------------
	common
	-------------------------------------------------------------*/
    header {
        position: relative;
    }
    header h1 {
        height: 97px;
        padding: 33px 0 0;
        text-align: center;
        border-bottom: 1px solid #e2e2e2;
    }
    header #hContact {
        line-height: 40px;
        top: 40px;
        width: 220px;
        height: 40px;
    }
    header #hTel {
        line-height: 40px;
        right: 0;
        height: 40px;
    }
    #path {
        width: 100%;
    }
    /*-------------------------------------------------------------
	top
	-------------------------------------------------------------*/
    #home #topInfo > ul {
        width: auto;
        margin: 0 auto;
        padding: 90px 0 0;
    }
    #home #topInfo > ul > li {
        float: left;
    }
    #home #topInfo > ul > li h2 {
        height: 70px;
    }
    #home #topInfo > ul > li:first-child {
        width: 470px;
        margin: 0 50px 0 0;
    }
    #home #topInfo > ul > li:first-child h2 {
        text-align: center;
    }
    #home #topInfo > ul > li:first-child ul li {
        float: left;
        width: 290px;
        height: 180px;
    }
    #home #topInfo > ul > li:first-child ul li:first-child {
        width: 180px;
    }
    #home #topInfo > ul > li:first-child ul li:last-child {
        box-sizing: border-box;
        border-top: 1px solid #e2e2e2;
        border-bottom: 4px solid #325d81;
    }
    #home #topInfo > ul > li:first-child ul li:last-child dl {
        padding: 0 20px 0 25px;
    }
    #home #topInfo > ul > li:first-child ul li:last-child dl dt {
        line-height: 1;
        padding: 25px 0 15px;
    }
    #home #topInfo > ul > li:first-child ul li:last-child dl dd {
        line-height: 1.73;
        color: #1871bc;
    }
    #home #topInfo > ul > li:last-child {
        width: 100%;
        margin-left: -520px;
    }
    #home #topInfo > ul > li:last-child > div {
        margin-left: 520px;
    }
    #home #message ul li > div {
        padding: 0  10% 0 20%;
    }
    #home #message #message01 li div div {
        margin: 0 0 0 -64px;
        padding: 0 0 0 74px;
    }
    #home #message #message02 li div div {
        margin: 0 0 0 -64px;
    }
    #home #message #message03 li div div {
        margin: 0 0 0 -64px;
    }
    #home #message #message04 li div div {
        margin: 0 0 0 -64px;
    }
    /*-------------------------------------------------------------
	service
	-------------------------------------------------------------*/
    #service .workPanel {
        width: 630px;
    }
}
@media screen and (max-width: 975px) {
    #home #topInfo > ul > li h2 a:after {
        display: none;
    }
    #contentsWrap #contents {
        float: left;
        width: 100%;
        margin-left: 0;
    }
    #contentsWrap #contents > div {
        padding-left: 0;
    }
    #contentsWrap #side {
        display: none;
    }
    /*-------------------------------------------------------------
	common
	-------------------------------------------------------------*/
    header nav {
        width: 100%;
    }
    header nav ul li:nth-child(1) {
        width: 16.6%;
    }
    header nav ul li:nth-child(2) {
        width: 13.5%;
    }
    header nav ul li:nth-child(3) {
        width: 19.8%;
    }
    header nav ul li:nth-child(4) {
        width: 20.8%;
    }
    header nav ul li:nth-child(5) {
        width: 29%;
    }
    footer #fContact {
        height: auto;
        padding: 0 0 50px;
    }
    footer #fContact > ul {
        width: 100%;
        margin: 0 auto;
    }
    footer #fContact > ul > li {
        float: none;
        height: auto;
    }
    footer #fContact > ul > li:last-child {
        width: 100%;
        padding: 50px 0 0;
    }
    footer #fContact > ul > li:last-child ul {
        width: 640px;
        margin: 0 auto;
    }
    footer #fContact > ul > li:last-child ul li {
        float: left;
        width: 320px;
        height: 70px;
    }
    footer #fContact > ul > li:last-child ul li:first-child {
        font-size: 28px;
        line-height: 70px;
        text-align: center;
        color: #fff;
        background: #7ab337;
    }
    footer #fContact > ul > li:last-child ul li:first-child span {
        padding: 0 0 0 38px;
        background: url(../img/common/tel_icon.png) left no-repeat;
        background-size: 30px auto;
    }
    footer #fContact > ul > li:last-child ul li:last-child {
        font-size: 18px;
        line-height: 70px;
        text-align: center;
        color: #fff;
        background: #1871bc;
    }
    footer #fContact > ul > li:last-child ul li:last-child a {
        display: block;
        width: 100%;
        height: 100%;
        color: #fff;
    }
    footer #fContact > ul > li:last-child ul li:last-child a span {
        padding: 0 0 0 38px;
        background: url(../img/common/email_icon.png) left no-repeat;
        background-size: 26px auto;
    }
    footer #fContact > ul > li:last-child p {
        font-size: 13px;
        line-height: 1;
        padding: 20px 0 0;
        text-align: center;
        letter-spacing: .05em;
    }
    footer #fContact > ul > li:first-child {
        position: relative;
        width: 100%;
        text-align: center;
    }
    footer #fContact > ul > li:first-child:after {
        display: none;
    }
    footer #fContact > ul > li:first-child h2 {
        padding: 73px 0 0;
    }
    footer nav {
        width: 100%;
    }
    footer nav ul {
        padding-right: 20px;
        padding-left: 20px;
    }
    footer nav ul li {
        line-height: 1;
        float: left;
        padding: 0 0 24px;
    }
    footer nav ul li a {
        font-size: 15px;
        font-weight: bold;
        color: #333;
    }
    footer nav ul li:nth-child(4n + 1) {
        width: 20%;
    }
    footer nav ul li:nth-child(4n + 2) {
        width: 30%;
    }
    footer nav ul li:nth-child(4n + 3) {
        width: 30%;
    }
    footer nav ul li:nth-child(4n + 4) {
        width: 20%;
    }
    footer #fAddr {
        text-align: center;
    }
    footer #fAddr ul {
        width: 100%;
        margin: 0 auto;
        padding: 50px 0;
    }
    footer #fAddr ul li {
        font-size: 14px;
        float: none;
        width: 100%;
    }
    footer #fAddr ul li p {
        font-size: 12px;
    }
    footer #fAddr ul > li:first-child {
        width: 100%;
        padding: 0 0 20px;
    }
    /*-------------------------------------------------------------
	top
	-------------------------------------------------------------*/
    #home .workPanel {
        width: 630px;
    }
    #home #message ul li div {
        font-size: 20px;
    }
    #home #topInfo > ul {
        width: auto;
        margin: 0 auto;
        padding: 90px 0 0;
    }
    #home #topInfo > ul > li {
        float: none;
    }
    #home #topInfo > ul > li h2 {
        height: 70px;
    }
    #home #topInfo > ul > li:first-child {
        width: 100%;
        margin: 0 auto 50px;
    }
    #home #topInfo > ul > li:first-child h2 {
        text-align: center;
    }
    #home #topInfo > ul > li:first-child ul li {
        float: none;
        width: 100%;
        height: 150px;
    }
    #home #topInfo > ul > li:first-child ul li:first-child {
        display: none;
        width: 180px;
    }
    #home #topInfo > ul > li:first-child ul li:last-child {
        box-sizing: border-box;
        border-top: 1px solid #e2e2e2;
        border-bottom: 4px solid #325d81;
    }
    #home #topInfo > ul > li:first-child ul li:last-child dl {
        padding: 0 20px 0 25px;
    }
    #home #topInfo > ul > li:first-child ul li:last-child dl dt {
        line-height: 1;
        padding: 25px 0 15px;
    }
    #home #topInfo > ul > li:first-child ul li:last-child dl dd {
        line-height: 1.73;
        color: #1871bc;
    }
    #home #topInfo > ul > li:last-child {
        width: 100%;
        margin: 0 auto;
    }
    #home #topInfo > ul > li:last-child > div {
        margin-left: 0;
    }
}
@media screen and (max-width: 780px) {
    #contents .secBox .serviceFlow .flowBox.bg .cntR .cnt {
        padding-right: 2px;
        padding-left: 4px;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntR .teltxt {
        padding-left: 85px;
        background: url('../img/service/contact_icon.png') no-repeat left center;
        background-size: 60px auto;
    }
    .wrapTable {
        overflow-x: scroll;
        margin-bottom: 30px;
        -webkit-overflow-scrolling: touch;
    }
    .wrapTable table {
        width: 760px;
    }
    #contents .bgg .wrapCnt .cntL {
        float: none;
        width: 100%;
        margin-bottom: 40px;
    }
    #contents .bgg .wrapCnt .cntL .img img {
        max-width: 100%;
        height: auto;
    }
    #contents .bgg .wrapCnt .cntR {
        float: none;
        width: 100%;
    }
    #path {
        padding-bottom: 40px;
    }
    #path ol {
        margin-right: 0;
    }
    footer nav {
        display: none;
    }
    /*-------------------------------------------------------------
	top
	-------------------------------------------------------------*/
    header {
        padding: 18px 10px 18px 15px;
    }
    header h1 {
        height: auto;
        padding: 0;
        text-align: left;
        border: none;
    }
    header h1 img {
        width: 155px;
        height: auto;
    }
    header #hTel {
        top: 12px;
        right: 98px;
        width: 35px;
        height: 35px;
        border-radius: 4px;
        background: #7ab337 url('../img/common/tel_icon.png') no-repeat center;
        background-size: auto 15px;
    }
    header #hTel span {
        display: none;
    }
    header #hContact {
        top: 12px;
        right: 55px;
        width: 35px;
        height: 35px;
        padding-left: 0;
        border-radius: 4px;
        background: #1871bc url('../img/common/email_icon.png') no-repeat center;
        background-size: auto 11px;
    }
    header #hContact span {
        display: none;
    }
    header #menuSp {
        position: absolute;
        top: 12px;
        right: 10px;
        display: block;
        width: 35px;
        height: 35px;
        border: 1px solid #d5d5d5;
        border-radius: 4px;
        background: url('../img/common/menu_open.png') no-repeat center;
        background-size: 20px 13px;
    }
    header #menuSp.active {
        background: url('../img/common/menu_close.png') no-repeat center;
        background-size: 20px 13px;
    }
    header nav {
        display: none;
    }
    #home #message {
        padding: 12px;
    }
    #home #message ul li div {
        font-size: 16px;
    }
    #home #message #message01 li div div {
        margin: 0 0 0 -34px;
        padding: 0 0 0 64px;
    }
    #home #message #message02 li div div {
        margin: 0 0 0 -50px;
        padding: 0 0 0 80px;
    }
    #home #message #message03 li div div {
        margin: 0 0 0 -50px;
        padding: 0 0 0 80px;
    }
    #home #message #message04 li div div {
        margin: 0 0 0 -50px;
        padding: 0 0 0 80px;
    }
}
@media screen and (max-width: 655px) {
    br.spdn {
        display: none;
    }
    header #hContact {
        font-weight: bold;
    }
    main #mv {
        box-sizing: border-box;
        height: 200px;
        padding: 0 30px;
    }
    .workPanel ul li a > div div span {
        font-weight: bold;
    }
    .cateListV ul li:nth-of-type(even),
    .cateList ul li:nth-of-type(even) {
        float: none;
    }
    .cateListV ul li:nth-of-type(2),
    .cateList ul li:nth-of-type(2) {
        border-top: none;
    }
    .cateListV ul li,
    .cateList ul li {
        float: none;
        width: 100%;
    }
    #contents .table {
        display: block;
    }
    #contents .table .t-tr {
        display: block;
    }
    #contents .table .t-th,
    #contents .table .t-td {
        display: block;
    }
    #contents .link_btn a {
        display: block;
        padding: 2px 0;
    }
    #contents .secBox .serviceFlow .flowBox .cntL .cnt .link a,
    #contents .secBox .serviceFlow .flowBox .cntLR .cnt .link a,
    #contents .secBox .serviceFlow .flowBox .cntR .cnt .link a {
        display: block;
        padding: 2px 0;
    }
    #contents .secBox .serviceFlow .flowBox .cntL {
        float: none;
        box-sizing: border-box;
        width: 100%;
        margin-bottom: 50px;
    }
    #contents .secBox .serviceFlow .flowBox .cntL:after {
        top: auto;
        right: auto;
        bottom: -35px;
        width: 100%;
        background: url('../img/common/arrow01v.png') no-repeat center;
        background-size: 22px 18px;
    }
    #contents .secBox .serviceFlow .flowBox .cntR {
        box-sizing: border-box;
        width: 100%;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntL {
        width: 100%;
        margin-right: 0;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntL:after {
        top: auto;
        left: 0;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntR {
        float: none;
        width: 100%;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntR .cnt {
        padding-right: 23px;
        padding-left: 23px;
    }
    #contents .secBox .serviceFlow .flowBox.bg .cntR .teltxt {
        min-height: 95px;
        padding-left: 115px;
        background: url('../img/service/contact_icon.png') no-repeat left center;
        background-size: 90px 95px;
    }
    #contents .secBox .col2Box .cntL {
        float: none;
        box-sizing: border-box;
        width: 100%;
        margin-bottom: 50px;
    }
    #contents .secBox .col2Box .cntR {
        box-sizing: border-box;
        width: 100%;
    }
    footer #fContact > ul > li:last-child ul li:last-child {
        font-weight: bold;
    }
    #home #topInfo > ul > li:last-child > div div {
        overflow: hidden;
        height: auto;
    }
    /*-------------------------------------------------------------
	common
	-------------------------------------------------------------*/
    footer #fContact > ul > li:first-child > img {
        right: 10px;
    }
    footer #fContact > ul > li:last-child {
        width: 300px;
        margin: 0 auto;
        padding: 50px 0 0;
    }
    footer #fContact > ul > li:last-child ul {
        width: 100%;
        margin: 0 auto;
    }
    footer #fContact > ul > li:last-child ul li {
        float: left;
        width: 300px;
        margin: 0 auto;
    }
    footer #fContact > ul > li:last-child ul li:first-child {
        font-size: 25px;
        width: 300px;
        margin: 0 0 30px;
    }
    footer #fContact > ul > li:last-child ul li:last-child {
        font-size: 15px;
    }
    footer #fContact > ul > li:last-child p {
        font-size: 13px;
        line-height: 1.6;
        padding: 25px 0 0;
        letter-spacing: .05em;
    }
    /*-------------------------------------------------------------
	top
	-------------------------------------------------------------*/
    #home .workPanel {
        width: 300px;
        margin-top: 30px;
    }
    #home #message ul li > div {
        height: 150px;
        padding: 0  2% 0 20%;
    }
    #home #message ul li div {
        font-size: 20px;
    }
    #home #message .messageOdd li {
        float: none;
        height: 150px;
    }
    #home #message .messageOdd li:nth-child(odd) {
        width: 100%;
    }
    #home #message .messageOdd li:nth-child(even) {
        width: 100%;
    }
    #home #message .messageEven li {
        float: none;
        height: 150px;
    }
    #home #message .messageEven li:nth-child(odd) {
        width: 100%;
    }
    #home #message .messageEven li:nth-child(even) {
        width: 100%;
    }
    #home #message #message01 li:nth-child(even) {
        width: 100%;
        background: url(../img/home/message/photo1.jpg) no-repeat center;
        background-size: cover;
    }
    #home #message #message02 li:nth-child(even) {
        width: 100%;
        background: url(../img/home/message/photo2.jpg) no-repeat center;
        background-size: cover;
    }
    #home #message #message03 li:nth-child(even) {
        width: 100%;
        background: url(../img/home/message/photo3.jpg) no-repeat center;
        background-size: cover;
    }
    #home #message #message04 li:nth-child(even) {
        width: 100%;
        background: url(../img/home/message/photo4.jpg) no-repeat center;
        background-size: cover;
    }
    #home #topInfo > ul > li:first-child ul li {
        height: auto;
        padding-bottom: 20px;
    }
    /*-------------------------------------------------------------
	service
	-------------------------------------------------------------*/
    #service .workPanel {
        width: 300px;
    }
}
@media screen and (max-width: 655px) and (-ms-high-contrast: none) {
    #contents .link_btn a {
        display: block;
        padding: 5px 0 2px;
    }
}
@media screen and (max-width: 655px) and (max-width: 655px) {
    #contents .secBox .serviceFlow .flowBox .cntL .cnt .link a,
    #contents .secBox .serviceFlow .flowBox .cntLR .cnt .link a,
    #contents .secBox .serviceFlow .flowBox .cntR .cnt .link a {
        display: block;
        padding: 5px 0 2px;
    }
}
@media screen and (max-width: 480px) {
    #contents .secBox .serviceFlow .flowBox.bg .cntR .teltxt {
        margin-left: 0;
        padding-left: 0;
        background: none;
    }
    table.col4 {
        display: block;
        box-sizing: border-box;
    }
    table.col4 tbody {
        display: block;
        width: 100%;
    }
    table.col4 tr {
        display: block;
        width: 100%;
    }
    table.col4 tr:last-child td:nth-of-type(-n+2) {
        border-bottom: 1px solid #5294cc;
        border-radius: 0;
    }
    table.col4 th,
    table.col4 th,
    table.col4 td {
        display: block;
        float: left;
        width: 50%;
        height: auto;
        min-height: 50px;
        padding: 15px 5px;
    }
    table.col4 th:nth-of-type(even),
    table.col4 th:nth-of-type(even),
    table.col4 td:nth-of-type(even) {
        border-left: 1px solid #5294cc;
    }
    table.col4 th:first-of-type {
        width: 50%;
    }
    table.col4 td:first-of-type {
        width: 50%;
    }
    table.col4 th + th,
    table.col4 td {
        border-left: none;
    }
    /*-------------------------------------------------------------
	top
	-------------------------------------------------------------*/
    #home #message ul li div {
        font-size: 16px;
    }
}
@media screen and (max-width: 360px) {
    #contents .link_btn a:after {
        margin-left: 6px;
    }
    #contents .secBox .serviceFlow .flowBox .cntL .cnt .link a,
    #contents .secBox .serviceFlow .flowBox .cntLR .cnt .link a,
    #contents .secBox .serviceFlow .flowBox .cntR .cnt .link a {
        font-size: 14px;
        letter-spacing: 0;
    }
    #contents .secBox .serviceFlow .flowBox .cntL .cnt .link a:after,
    #contents .secBox .serviceFlow .flowBox .cntLR .cnt .link a:after,
    #contents .secBox .serviceFlow .flowBox .cntR .cnt .link a:after {
        margin-left: 6px;
    }
    /*-------------------------------------------------------------
	common
	-------------------------------------------------------------*/
    header .spMenu {
        margin-top: 1px;
    }
    header .spMenu .menuBody > ul > li ul li.row2 {
        line-height: 17px;
        padding-top: 5px;
    }
    header .spMenu .menuBody > ul > li ul li.row2 span {
        display: block;
    }
}