@media (min-width: 768px) {
  .sp {
    display: none; } }
@media (max-width: 767.98px) {
  .pc {
    display: none; } }
.c1 {
  color: #8CB808; }

.c2 {
  color: #F9F8F6; }

.c3 {
  color: #237F81; }

.c4 {
  color: #FF6010; }

.c5 {
  color: #898989; }

.bs1 {
  box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.2); }

.ts1 {
  text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.1); }

@media (min-width: 768px) {
  #base {
    min-width: 1300px;
    display: flex; } }
.container {
  position: relative;
  text-align: left; }
  @media (max-width: 1199px) and (min-width: 768px) {
    .container {
      max-width: 100%;
      width: 100%;
      padding-left: 30px;
      padding-right: 30px; } }
  @media (max-width: 767.98px) {
    .container {
      max-width: 100%;
      width: 100%; } }
.row {
  position: relative;
  text-align: left; }
  @media (min-width: 768px) {
    .row.row-40 {
      margin-left: -20px;
      margin-right: -20px; }
      .row.row-40 > div[class*="col"] {
        padding-left: 20px;
        padding-right: 20px; }
    .row.row-50 {
      margin-left: -25px;
      margin-right: -25px; }
      .row.row-50 > div[class*="col"] {
        padding-left: 25px;
        padding-right: 25px; }
    .row.row-60 {
      margin-left: -30px;
      margin-right: -30px; }
      .row.row-60 > div[class*="col"] {
        padding-left: 30px;
        padding-right: 30px; }
    .row.row-70 {
      margin-left: -35px;
      margin-right: -35px; }
      .row.row-70 > div[class*="col"] {
        padding-left: 35px;
        padding-right: 35px; }
    .row.row-80 {
      margin-left: -40px;
      margin-right: -40px; }
      .row.row-80 > div[class*="col"] {
        padding-left: 40px;
        padding-right: 40px; }
    .row.row-90 {
      margin-left: -45px;
      margin-right: -45px; }
      .row.row-90 > div[class*="col"] {
        padding-left: 45px;
        padding-right: 45px; }
    .row.row-100 {
      margin-left: -50px;
      margin-right: -50px; }
      .row.row-100 > div[class*="col"] {
        padding-left: 50px;
        padding-right: 50px; } }
@media (min-width: 768px) {
  header {
    width: 315px;
    background: #8CB808; } }
@media (min-width: 768px) {
  .layout--head {
    position: fixed;
    left: 0;
    top: 0;
    width: 315px;
    border-top: 5px solid #8CB808; } }
@media (max-width: 1300px) and (min-width: 768px) {
  .layout--head {
    position: absolute; } }
@media (max-height: 850px) {
  .layout--head {
    position: absolute; } }
@media (max-width: 767.98px) {
  .layout--head {
    position: relative;
    height: 50px; } }
.layout--site_logo {
  text-indent: -9999px; }
  @media (min-width: 768px) {
    .layout--site_logo {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 315px;
      height: 245px;
      background: #FFF;
      box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2); } }
  .layout--site_logo a {
    display: block; }
    @media (min-width: 768px) {
      .layout--site_logo a {
        width: 210px;
        height: 178px;
        background: url(../image/layout/site_logo.png) no-repeat left top;
        background-size: contain; } }
    @media (max-width: 767.98px) {
      .layout--site_logo a {
        position: absolute;
        left: 10px;
        top: 5px;
        width: 157px;
        height: 39px;
        background: url(../image/layout/site_logo-sp.png) no-repeat left top;
        background-size: contain; } }
@media (max-width: 767.98px) {
  .layout-- {
    position: relative;
    z-index: 100;
    height: 50px;
    background: #FFF; }
    .layout--head_menu-sp {
      position: absolute;
      right: 0;
      top: 0; }
      .layout--head_menu-sp a {
        display: block;
        width: 45px;
        height: 50px;
        background: url(../image/head/head_menu-sp.png) no-repeat left top;
        background-size: 45px auto; }
    #base.open .layout--head_menu-sp a {
      background: url(../image/head/head_menu-sp.png) no-repeat left bottom;
      background-size: 45px auto; }
    #base.open .layout--menu_back-sp {
      position: fixed;
      left: 0;
      top: 0;
      z-index: 10;
      height: 100%;
      width: 100%;
      background: rgba(0, 0, 0, 0.6); } }
@media (min-width: 768px) {
  .layout--main_navi > ul {
    padding: 60px 35px; }
    .layout--main_navi > ul > li {
      text-align: left; }
      .layout--main_navi > ul > li:not(:last-child) {
        margin-bottom: 60px; }
      .layout--main_navi > ul > li > a {
        display: block;
        position: relative;
        padding-left: 75px;
        font-size: 1.9rem;
        font-weight: bold;
        color: #FFF;
        text-decoration: none; }
        .layout--main_navi > ul > li > a:before {
          content: "";
          display: block;
          position: absolute;
          left: 0px;
          top: 50%;
          width: 50px;
          height: 54px;
          vertical-align: middle;
          transform: translateY(-50%); }
      .layout--main_navi > ul > li.navi_0 a:before {
        background: url("../image/layout/icon_navi_0.png") center center no-repeat;
        background-size: contain; }
      .layout--main_navi > ul > li.navi_1 a:before {
        background: url("../image/layout/icon_navi_1.png") center center no-repeat;
        background-size: contain; }
      .layout--main_navi > ul > li.navi_2 a:before {
        background: url("../image/layout/icon_navi_2.png") center center no-repeat;
        background-size: contain; }
      .layout--main_navi > ul > li.navi_3 a:before {
        background: url("../image/layout/icon_navi_3.png") center center no-repeat;
        background-size: contain; }
      .layout--main_navi > ul > li.navi_4 a:before {
        background: url("../image/layout/icon_navi_4.png") center center no-repeat;
        background-size: contain; }
      .layout--main_navi > ul > li.navi_5 a:before {
        background: url("../image/layout/icon_navi_5.png") center center no-repeat;
        background-size: contain; }
      .layout--main_navi > ul > li.navi_contact {
        display: none; } }
@media (max-width: 767.98px) {
  .layout--main_navi {
    display: none;
    position: absolute;
    top: 50px;
    left: 0;
    z-index: 100;
    width: 100%;
    background: #282828; }
    .layout--main_navi > ul {
      width: 100%; }
      .layout--main_navi > ul > li {
        position: relative;
        width: 100%;
        text-align: left;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
        .layout--main_navi > ul > li dl dt {
          font-weight: normal; }
        .layout--main_navi > ul > li dl dt a, .layout--main_navi > ul > li > a {
          display: block;
          padding: 12px 15px;
          color: #FFF; }
        .layout--main_navi > ul > li dl dd a {
          color: #999999; }
        .layout--main_navi > ul > li dl dd ul li {
          margin: 0 0 15px 28px; }
        .layout--main_navi > ul > li.navi_contact {
          background: #237F81; }
    .layout--main_navi a {
      text-decoration: none; }
    .layout--main_navi .toggle_icon {
      display: block;
      position: absolute;
      right: 0;
      top: 0;
      width: 44px;
      height: 44px;
      background: url(../image/head/head_toggle-sp.png) no-repeat center top;
      background-size: 22px; }
    .layout--main_navi .toggle_icon.-active {
      background: url(../image/head/head_toggle-sp.png) no-repeat center bottom;
      background-size: 22px; } }
@media (min-width: 768px) {
  main {
    width: calc(100% - 315px);
    background: #F7F7F7; } }
.layout--body_head {
  display: flex;
  justify-content: flex-end;
  background: #FFF; }
  @media (max-width: 767.98px) {
    .layout--body_head {
      display: none; } }
  .layout--body_head .comment {
    margin-right: auto;
    padding: 30px;
    text-align: left;
    font-size: 1.3rem; }
    @media (max-width: 1400px) {
      .layout--body_head .comment {
        display: none; } }
  .layout--body_head .tel {
    padding-right: 30px; }
    .layout--body_head .tel table {
      margin-top: 16px;
      margin-bottom: 7px; }
      .layout--body_head .tel table .th {
        padding-right: 5px;
        line-height: 1;
        vertical-align: bottom;
        font-size: 2rem;
        font-weight: bold;
        color: #8CB808; }
      .layout--body_head .tel table .num {
        line-height: 1;
        vertical-align: bottom;
        font-size: 3.6rem;
        font-weight: bold;
        color: #8CB808; }
      .layout--body_head .tel table .time {
        padding-left: 15px;
        line-height: 1;
        vertical-align: bottom;
        font-weight: bold; }
      .layout--body_head .tel table + p {
        font-size: 1.3rem; }
  .layout--body_head .contact {
    display: block;
    padding: 20px;
    height: 100%;
    background: #237F81;
    color: #FFF;
    font-weight: bold;
    text-decoration: none;
    transition: all ease 0.2s; }
    .layout--body_head .contact:before {
      content: "";
      display: block;
      width: 70px;
      height: 30px;
      margin: 0 auto 5px;
      background: url("../image/layout/icon_navi_6.png") no-repeat center center;
      background-size: contain; }
    .layout--body_head .contact:hover {
      background: #8CB808; }
@media (min-width: 1600px) {
  .layout--body_flex {
    display: flex;
    justify-content: space-between; } }
@media (min-width: 768px) {
  .layout--body_flex {
    padding: 35px 35px 100px; } }
@media (min-width: 1600px) {
  .layout--body_primary {
    width: calc(100% - 310px); } }
@media (min-width: 1600px) {
  .layout--body_secondary {
    width: 295px; } }
@media (max-width: 1599.98px) {
  .layout--body_secondary {
    padding: 30px 15px; } }
.layout--body_foot {
  padding: 100px 0;
  background: #DCEAB2; }
  @media (max-width: 767.98px) {
    .layout--body_foot {
      padding: 50px 0; } }
  .layout--body_foot .nav {
    margin: 40px 0; }
    @media (min-width: 768px) {
      .layout--body_foot .nav {
        display: flex;
        justify-content: center; } }
    .layout--body_foot .nav li {
      position: relative;
      padding: 0 20px; }
      @media (max-width: 767.98px) {
        .layout--body_foot .nav li:not(:last-child) {
          margin-bottom: 10px; } }
      @media (min-width: 768px) {
        .layout--body_foot .nav li:not(:last-child):after {
          content: "";
          position: absolute;
          right: 0;
          top: 0;
          width: 1px;
          height: 100%;
          background: rgba(0, 0, 0, 0.5); } }
      .layout--body_foot .nav li a {
        color: #222;
        text-decoration: none; }
        .layout--body_foot .nav li a:hover {
          text-decoration: underline; }
.layout--foot_pagetop a {
  display: block;
  position: fixed;
  right: 0px;
  bottom: 0px;
  z-index: 30;
  width: 90px;
  height: 90px;
  background: #8CB808 url(../image/layout/pagetop.png) no-repeat center center;
  background-size: contain;
  box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.2); }
  @media (max-width: 575.98px) {
    .layout--foot_pagetop a {
      display: none; } }
