@charset "UTF-8";
/* "body"
-------------------------------------------------- */
body {
  color: #3E3A39;
  margin: 0;
  padding: 0;
  font-size: 16px;
  line-height: 1.566666666666667;
  font-family: "Open Sans" , "Helvetica Neue" , Helvetica , Arial , Verdana , Roboto , "游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" , "メイリオ" , Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif;
  text-align: center;
  letter-spacing: 0.05em;
}

/* "a" Tag
-------------------------------------------------- */
a {
  cursor: pointer;
  -webkit-transition: all .3s;
  transition: all .3s;
}

a::before, a::after {
  -webkit-transition: all .3s;
  transition: all .3s;
}

a:link, a:visited {
  color: #036EB8;
  text-decoration: none;
}

a:active, a:hover {
  color: #EA5514;
  text-decoration: underline;
}

a:hover img {
  opacity: 0.6;
}

/* "div/p" Tag
-------------------------------------------------- */
div {
  margin: 0;
  padding: 0;
}

p {
  margin: 0 0 1em;
  padding: 0;
}

/* "dl/dt/dd/li/ol/ul" Tag
-------------------------------------------------- */
dl, dt, dd, li, ol, ul {
  margin: 0;
  padding: 0;
}

ul li {
  list-style: none;
}

/* "h1-h6" Tag
-------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
  margin: 0 0 1em;
  padding: 0;
  font-weight: bold;
  font-size: 100%;
  line-height: 1.566666666666667;
}

/* "hr" Tag
-------------------------------------------------- */
hr {
  margin-bottom: 25px;
}

/* "img" Tag
-------------------------------------------------- */
img {
  border: 0;
}

/* "em/strong" Tag
-------------------------------------------------- */
em {
  font-style: italic;
  font-weight: normal;
}

strong {
  font-style: normal;
  font-weight: bold;
}

/* form
-------------------------------------------------- */
form label {
  display: block;
  padding: 0;
  font-weight: bold;
  line-height: 2.215;
}

form label.checkbox {
  display: inline-block;
  padding: 0;
  font-weight: normal;
  margin-left: 5px;
}

form label.radio {
  display: inline-block;
  padding: 0;
  font-weight: normal;
}

fieldset {
  border: 0;
}

form fieldset legend {
  font-weight: bold;
  margin-bottom: 10px;
  padding-top: 10px;
}

form p small {
  font-size: 0.75em;
  color: #777;
}

form input,
form select,
form textarea,
form .wysiwyg {
  padding: 6px;
  font-size: 13px;
  border: 1px solid #d5d5d5;
  color: #333;
}

form input[type="file"] {
  border: 0;
}

form input[type="checkbox"] {
  float: left;
  margin-right: 5px;
}

form input[type="checkbox"] + label {
  font-weight: normal;
}

form input[type="submit"] {
  cursor: pointer;
  -webkit-transition: all .3s;
  transition: all .3s;
}

form input[type="button"] {
  cursor: pointer;
  -webkit-transition: all .3s;
  transition: all .3s;
}

form button {
  cursor: pointer;
  -webkit-transition: all .3s;
  transition: all .3s;
}

form .small-input {
  width: 25% !important;
}

form .medium-input {
  width: 50% !important;
}

form .large-input {
  width: 90% !important;
  padding: 8px !important;
}

form textarea {
  width: 90% !important;
  font-family: Arial, Helvetica, sans-serif;
}

form select {
  padding: 4px;
  background: #fff;
}

form input[type="checkbox"],
form input[type="radio"] {
  padding: 0;
  background: none;
  border: 0;
}

.need {
  color: #FF0000;
}

/* table
-------------------------------------------------- */
table, td, th {
  border: solid 1px #DDD;
  border-collapse: collapse;
  padding: 10px;
  text-align: center;
}

table {
  background-color: #fff;
  width: 100%;
  border: solid 2px #DDD;
  margin-bottom: 20px;
}

table th {
  background-color: #F7F7F7;
  font-size: 12px;
}

/* notification
-------------------------------------------------- */
.notification {
  position: relative;
  margin: 0 0 20px;
  padding: 0;
  border: 1px solid;
  font-size: 13px;
}
.notification div {
  display: block;
  font-style: normal;
  padding: 10px;
  line-height: 1.5em;
}
.notification div p {
  margin: 0;
}
.notification.attention {
  border-color: #e6db55;
  color: #666452;
}
.notification.attention div {
  background: #fffbcc;
}
.notification.attention div i {
  color: #b8af44;
}
.notification.information {
  border-color: #a2b4ee;
  color: #585b66;
}
.notification.information div {
  background: #dbe3ff;
}
.notification.information div i {
  color: #8190be;
}
.notification.success {
  border-color: #9adf8f;
  color: #556652;
}
.notification.success div {
  background: #d5ffce;
}
.notification.success div i {
  color: #7bb272;
}

.error {
  background: #ffcece;
  border-color: #df8f8f;
  color: #665252;
}

.alert {
  color: #dc143c;
  font-weight: bold;
}

/* ==================================================
以下、ブロックごとの指定
================================================== */
/* コンテナ
-------------------------------------------------- */
body {
  background: url(../images/common/bg.jpg) repeat;
}

.container {
  width: 960px;
  padding: 0;
}
@media screen and (max-width: 991px) {
  .container {
    width: 100vw;
    padding-right: 15px;
    padding-left: 15px;
  }
}

/* ヘッダー（上部）
-------------------------------------------------- */
header {
  border-bottom: 1px solid #CCC;
}

.headerTop {
  height: 105px;
}

.headerTop .row {
	display: flex;
	justify-content: space-between;;
}

.headerTop h1 {
  font-size: 12px;
  margin-bottom: 0;
  text-align: left;
  font-weight: normal;
  margin-top: 5px;
}
.headerTop h2 {
  font-size: 21px;
  margin-bottom: 0;
  text-align: left;
}
.headerTop h2 .s {
  display: inline-block;
  font-size: 18px;
  margin-right: 0.5em;
}
@media screen and (max-width: 767px) {
  .headerTop h2 .s {
    display: block;
    margin-right: 0;
  }
  .headerTop h2 {
    line-height: 1.2;
  }
}
.headerTop h2 span {
  color: #FFF;
  border-radius: 5px;
  display: inline-block;
  text-align: center;
  padding: 2px 10px;
  margin-left: 12px;
  margin-bottom: 4px;
  font-size: 13px;
  vertical-align: middle;
  background: #006837;
}
.headerTop .logoBlock {
  padding-left: 50px;
  position: relative;
}
.headerTop .logoBlock::before {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  height: 44px;
  width: 44px;
}
@media screen and (max-width: 350px) {
  .headerTop .logoBlock {
    padding-left: 10px;
  }
}
.headerTop .logoBlock::before {
  background: url(../images/common/logo.png) no-repeat;
  background-size: 100% 100%;
}
@media screen and (max-width: 350px) {
  .headerTop .logoBlock::before {
    background: none;
  }
}
.headerTop ul {
  margin-top: 10px;
}
.headerTop ul li {
  float: left;
  margin-right: 20px;
}
.headerTop ul li:last-child {
  margin-right: 0;
}
.headerTop ul li.tel {
  font-size: 25px;
  font-weight: bold;
  padding-left: 50px;
  position: relative;
}
.headerTop ul li.tel::before {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  height: 40px;
  width: 40px;
}
.headerTop ul li.tel::before {
  background: url(../images/common/tel.svg) no-repeat;
  background-size: 100% 100%;
}
.headerTop ul li.tel p {
  margin-bottom: 0;
}
.headerTop ul li.tel p.small {
  font-size: 12px;
  font-weight: normal;
}
@media screen and (max-width: 767px) {
  .headerTop ul li.tel {
    display: table;
    margin: 0 auto;
    float: none;
  }
  .headerTop ul li.tel::before {
    background: url(../images/common/tel2.svg) no-repeat;
    background-size: 100% 100%;
  }
}
@media screen and (max-width: 767px) {
  .headerTop .col-md-7 {
    position: fixed;
    bottom: 0;
    text-align: center;
    background: rgba(0, 135, 60, 0.8);
    width: 100%;
    z-index: 100;
  }
  .headerTop .col-md-7 a {
    color: #FFF;
  }
}

a.btn-dl {
  background: #F7931E;
  border: 1px solid #F7931E;
  box-shadow: 0 1px #F15A24;
  color: #FFF !important;
  border-radius: 5px;
  display: inline-block;
  color: #FFF;
  text-decoration: none;
  padding: 2px 10px;
  font-size: 14px;
  font-weight: bold;
  text-align: left;
  padding-left: 50px;
  position: relative;
}
a.btn-dl:hover {
  text-decoration: none;
  background: rgba(247, 147, 30, 0.6);
}
a.btn-dl::before {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 5px;
  -ms-transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  height: 40px;
  width: 40px;
}
a.btn-dl::before {
  background: url(../images/common/pdf.svg) no-repeat;
  background-size: 100% 100%;
}

@media screen and (max-width: 767px) {
  body.home .headerTop {
    height: 200px;
  }
}

/* ヘッダー（グローバルメニュー）
-------------------------------------------------- */
.globalMenu {
  height: 36px;
  background: #00873C;
}
@media screen and (max-width: 767px) {
  .globalMenu {
    -ms-transform: translateY(-73px);
    -webkit-transform: translateY(-73px);
    transform: translateY(-73px);
    float: right;
    width: 100%;
    height: auto;
    background: none;
    z-index: 100;
  }
}
.globalMenu ul {
  display: table;
  margin: 0 auto;
  width: 959px;
  height: 36px;
  border-left: 1px solid #FFF;
  font-weight: bold;
}
@media screen and (max-width: 991px) {
  .globalMenu ul {
    width: 719px;
  }
}
@media screen and (max-width: 767px) {
  .globalMenu ul {
    width: 100%;
    border-left: 0;
  }
}
.globalMenu ul li {
  float: left;
  margin-right: 0;
  height: 36px;
  width: 159px;
  line-height: 36px;
  border-right: 1px solid #FFF;
  font-size: 14px;
}
.globalMenu ul li:last-child {
  margin-right: 0;
}
@media screen and (max-width: 991px) {
  .globalMenu ul li {
    width: 143px;
  }
}
@media screen and (max-width: 767px) {
  .globalMenu ul li {
    float: none;
    width: 100%;
    height: 73px;
    line-height: 73px;
    border-right: 0;
  }
}
.globalMenu ul li.current a {
  background: #FFF;
  color: #00873C;
  border: 1px solid #00873C;
}
@media screen and (max-width: 767px) {
  .globalMenu ul li.current a {
    background: rgba(255, 255, 255, 0.9);
  }
}
.globalMenu ul li a {
  color: #FFF;
  text-decoration: none;
  width: 100%;
  height: 36px;
  display: block;
}
@media screen and (max-width: 767px) {
  .globalMenu ul li a {
    background: rgba(0, 135, 60, 0.9);
    height: 73px;
    border-bottom: 1px solid #FFF;
  }
  .globalMenu ul li a span::after {
    content: '>';
    margin-left: 5px;
  }
}
.globalMenu ul li a:hover {
  background: #FFF;
  color: #00873C;
  border: 1px solid #00873C;
}
@media screen and (max-width: 767px) {
  .globalMenu ul li a:hover {
    background: rgba(255, 255, 255, 0.9);
  }
}
.globalMenu .navbar-toggler {
  cursor: pointer;
  font-size: 30px;
  margin-top: 10px;
  color: #333 !important;
}
.globalMenu.navbar {
  padding: 0;
}

@media screen and (max-width: 767px) {
  body.home .globalMenu {
    -ms-transform: translateY(-83px);
    -webkit-transform: translateY(-83px);
    transform: translateY(-83px);
  }
}

/* パンくず
-------------------------------------------------- */
.pan {
  font-size: 12px;
  line-height: 50px;
}
.pan li {
  float: left;
  margin-right: 5px;
}
.pan li:last-child {
  margin-right: 0;
}
.pan li::after {
  content: ' > ';
}
.pan li:last-child::after {
  content: '';
}

/* メインカラム
-------------------------------------------------- */
h2.hanabi-muscle {
  position: relative;
}
h2.hanabi-muscle::after {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(20px, -50%);
  -webkit-transform: translate(20px, -50%);
  transform: translate(20px, -50%);
  height: 35px;
  width: 35px;
}
h2.hanabi-muscle::after {
  background: url(../images/common/muscle.svg) no-repeat;
}

h2.hanabi-car {
  position: relative;
}
h2.hanabi-car::after {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(20px, -50%);
  -webkit-transform: translate(20px, -50%);
  transform: translate(20px, -50%);
  height: 35px;
  width: 35px;
}
h2.hanabi-car::after {
  background: url(../images/common/car.svg) no-repeat;
}

h2.hanabi-camera {
  position: relative;
}
h2.hanabi-camera::after {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(20px, -50%);
  -webkit-transform: translate(20px, -50%);
  transform: translate(20px, -50%);
  height: 35px;
  width: 35px;
}
h2.hanabi-camera::after {
  background: url(../images/common/camera.svg) no-repeat;
}

h2.hanabi-one {
  position: relative;
}
h2.hanabi-one::after {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(20px, -50%);
  -webkit-transform: translate(20px, -50%);
  transform: translate(20px, -50%);
  height: 35px;
  width: 35px;
}
h2.hanabi-one::after {
  background: url(../images/common/one.svg) no-repeat;
}

h2.hanabi-two {
  position: relative;
}
h2.hanabi-two::after {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(20px, -50%);
  -webkit-transform: translate(20px, -50%);
  transform: translate(20px, -50%);
  height: 35px;
  width: 35px;
}
h2.hanabi-two::after {
  background: url(../images/common/two.svg) no-repeat;
}

h2.hanabi-three {
  position: relative;
}
h2.hanabi-three::after {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(20px, -50%);
  -webkit-transform: translate(20px, -50%);
  transform: translate(20px, -50%);
  height: 35px;
  width: 35px;
}
h2.hanabi-three::after {
  background: url(../images/common/three.svg) no-repeat;
}

main h2 {
  font-size: 22px;
  padding-left: 80px;
  background: url(../images/common/hanabi.svg) no-repeat 0 50%;
  background-size: 70px 70px;
  text-align: left;
  display: table;
  margin: 0 auto 40px;
}
main h2.hanabi-none {
  background: none;
  padding-left: 0;
}
main h2.line68 {
  line-height: 68px;
}
main p {
  text-align: left;
  line-height: 1.75;
}

.boxSec {
  background: #FFF;
  padding: 0 30px;
  margin-bottom: 118px;
  position: relative;
  position: relative;
}
.boxSec::before {
  content: ' ';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  -ms-transform: translate(0, -100%);
  -webkit-transform: translate(0, -100%);
  transform: translate(0, -100%);
  height: 30px;
  width: 100%;
}
.boxSec::after {
  content: ' ';
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  height: 58px;
  width: 100%;
}
@media screen and (max-width: 575px) {
  .boxSec {
    padding-top: 30px;
  }
}
.boxSec::before {
  background: url(../images/common/boxSec-before.svg) no-repeat 100% 100%;
  background-size: 100%;
}
.boxSec::after {
  background: url(../images/common/boxSec-after.svg) no-repeat;
  background-size: 100%;
}
body.home .boxSec {
  margin-bottom: 98px;
}

.grayBox {
  box-shadow: 0 0 0 1px #FFF, 0 0 0 11px #E5E5E5;
  background: #E5E5E5;
  padding: 20px;
}
.grayBox h3 {
  text-align: left;
}
.grayBox p:last-child {
  margin-bottom: 0;
}

.titleSec {
  background: url(../images/common/title_bg.jpg) no-repeat 50% 50%;
  background-size: cover;
  height: 82px;
  margin-bottom: 60px;
  position: relative;
}
.titleSec .inner {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  height: auto;
  width: 100%;
}
.titleSec .inner p {
  margin-bottom: 0;
  font-size: 19px;
  font-weight: bold;
  text-align: center;
}
.titleSec .inner p span {
  font-size: 16px;
  font-weight: normal;
}

/* サイドカラム
-------------------------------------------------- */
/* フッター
-------------------------------------------------- */
footer {
  background: #4D4D4D;
  color: #FFF;
  text-align: center;
  font-size: 12px;
  padding-top: 30px;
  padding-bottom: 30px;
}
@media screen and (max-width: 767px) {
  footer {
    padding-bottom: 100px;
  }
}
footer ul li {
  margin-bottom: 20px;
  float: left;
  margin-right: 15px;
  color: #FFF;
  padding-right: 15px;
}
footer ul li else {
  border-right: 1px solid #FFF;
}
footer ul li a {
  color: #FFF !important;
}
footer ul li:last-child {
  margin-right: 0;
  padding-right: 0;
  border-right: 0;
}
footer p {
  margin-bottom: 0;
}

/* ==================================================
以下、装飾の指定
================================================== */
/* 頻出
-------------------------------------------------- */
.btn-basic {
  background: #F7931E;
  border: 1px solid #F7931E;
  box-shadow: 0 1px #F15A24;
  color: #FFF !important;
  border-radius: 5px;
  display: inline-block;
  color: #FFF;
  text-decoration: none;
  padding: 2px 10px;
  padding: 5px 0;
  text-align: center;
  width: 100%;
  position: relative;
}
.btn-basic:hover {
  text-decoration: none;
  background: rgba(247, 147, 30, 0.6);
}
.btn-basic::after {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  left: 100%;
  -ms-transform: translate(-100%, -50%);
  -webkit-transform: translate(-100%, -50%);
  transform: translate(-100%, -50%);
  height: 26px;
  width: 26px;
}
.btn-basic::after {
  content: '>';
}

.btn-reverse {
  background: #FFF;
  border: 1px solid #00873C;
  box-shadow: 0 1px #006837;
  color: #00873C !important;
  border-radius: 5px;
  display: inline-block;
  color: #FFF;
  text-decoration: none;
  padding: 2px 10px;
}
.btn-reverse:hover {
  text-decoration: none;
}
.btn-reverse:hover {
  background: #006837;
  border: 1px solid #006837;
  color: #FFF;
}

ul.list li {
  float: left;
  margin-right: 10px;
}
ul.list li:last-child {
  margin-right: 0;
}

/* 文字装飾
-------------------------------------------------- */
.red {
  color: #EA5504;
}

.gray {
  color: #CCCCCC;
}

.bld {
  font-weight: bold;
}

.small {
  font-size: 11px;
}

.big {
  font-size: 21px;
}

.large {
  font-size: 26px;
}

.mega {
  font-size: 32px;
}

.orange {
  color: #EA5504;
}

/* 回りこみ
-------------------------------------------------- */
.right {
  float: right;
}

.left {
  float: left;
}

.alignright {
  text-align: right;
}

.alignleft {
  text-align: left;
}

.aligncenter {
  text-align: center;
}

/* 複数カラム
-------------------------------------------------- */
[class^="line-"] div, [class*=" line-"] div {
  margin-right: 2%;
  float: left;
}

[class^="line-"] div:last-child, [class*=" line-"] div:last-child {
  margin-right: 0;
}

.line-2 div {
  width: 48%;
}

.line-3 div {
  width: 32%;
}

.line-4 div {
  width: 23.5%;
}

/* width
-------------------------------------------------- */
.w10p {
  width: 10%;
}

.w20p {
  width: 20%;
}

.w30p {
  width: 30%;
}

.w40p {
  width: 40%;
}

.w50p {
  width: 50%;
}

.w60p {
  width: 60%;
}

.w70p {
  width: 70%;
}

.w80p {
  width: 80%;
}

.w90p {
  width: 90%;
}

.w100p {
  width: 100%;
}

/* height
-------------------------------------------------- */
.h100 {
  height: 100px;
}

.h200 {
  height: 200px;
}

/* margin
-------------------------------------------------- */
.mb0 {
  margin-bottom: 0 !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

/* display
-------------------------------------------------- */
.dispBlock {
  display: block !important;
}

.dispNone {
  display: none !important;
}

.dispTable {
  display: table !important;
  margin-left: auto;
  margin-right: auto;
}

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

.clearfix {
  display: block;
}

/*# sourceMappingURL=common.css.map */
