@charset "UTF-8";
/*  ▼ cmn-logo
------------------------------------- */
.cmn-logo {
  transition: all 0.5s; }
  .cmn-logo:hover {
    opacity: 0.6; }

/*  ▼ cmn-title
------------------------------------- */
.cmn-title {
  width: 100%;
  margin: 0 0 70px;
  font-size: 3.6rem;
  font-weight: 700;
  text-align: center; }
  .cmn-title_dot {
    display: inline-block;
    position: relative;
    z-index: 0; }
    .cmn-title_dot::before {
      content: '';
      width: 7px;
      height: 7px;
      margin: auto;
      border-radius: 50%;
      background-color: #33955e;
      position: absolute;
      top: -5px;
      right: 0;
      left: 0;
      z-index: -1; }
  .cmn-title_marker {
    display: inline-block;
    padding: 0 5px;
    background: linear-gradient(0deg, #c4e9d5 40%, rgba(196, 233, 213, 0) 40%); }
  .cmn-title__font-large {
    font-size: 127.77778%; }
  .cmn-title__font-green {
    color: #33955e; }

/*  ▼ cmn-button
------------------------------------- */
.cmn-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 340px;
  height: 55px;
  margin: 0 auto;
  color: #fff;
  background-color: #171717;
  position: relative;
  z-index: 0; }
  .cmn-button::before {
    content: '';
    width: 13px;
    height: 16px;
    background: url(../images/common/cmn-button_shape.png) no-repeat center/contain;
    position: absolute;
    left: 45px;
    z-index: -1; }
  .cmn-button::after {
    content: '';
    width: 0;
    height: 100%;
    background-color: #33955e;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -2;
    transition: all 0.5s ease-in-out; }
  .cmn-button:hover::after {
    width: 100%;
    right: auto;
    left: 0; }

/*  ▼ cmn-info-button
------------------------------------- */
.cmn-info-button {
  line-height: 1; }
  .cmn-info-button_item {
    align-items: center;
    justify-content: center;
    width: 180px;
    height: 50px;
    color: #fff;
    font-size: 1.5rem;
    background: linear-gradient(-30deg, #65dd9b 0%, #1f7645 100%); }
    .cmn-info-button_item:hover {
      opacity: 0.6; }
    .cmn-info-button_item img {
      margin-right: 10px; }
    .cmn-info-button_item__size-large {
      width: 100%;
      font-size: 1.6rem;
      background: #171717; }
  .cmn-info-button__font-large {
    font-size: 1.8rem; }

/*  ▼ side-button
------------------------------------- */
.side-button {
  position: fixed;
  right: 0;
  bottom: 195px;
  z-index: 500; }
  .side-button:hover {
    opacity: 0.6; }

/*  ▼ page-top
------------------------------------- */
.page-top {
  position: fixed;
  right: 20px;
  bottom: 50px;
  z-index: 500; }
  .page-top:hover {
    opacity: 0.7;
    bottom: 60px; }

/*  ▼ post
------------------------------------- */
.post {
  overflow: visible; }
  .post_navigation {
    width: 190px;
    line-height: 1.5;
    font-size: 1.8rem;
    text-align: center;
    border-top: 1px solid #bbb; }
    .post_navigation_item {
      border-bottom: 1px solid #bbb; }
    .post_navigation_link {
      padding: 9px 5px; }
      .post_navigation_link:hover {
        color: #33955e; }
  .post_content {
    align-items: stretch;
    width: 830px; }
    .post_content_item {
      width: 380px;
      padding: 0 0 30px;
      margin: 0 0 30px;
      position: relative;
      z-index: 0; }
      .post_content_item:nth-child(odd):not(:nth-last-child(-n+2))::after {
        content: '';
        width: calc(200% + 70px);
        height: 1px;
        background-color: #bbb;
        position: absolute;
        bottom: 0;
        left: 0;
        z-index: -1; }
    .post_content_link {
      width: 100%;
      height: 100%; }
    .post_content_figure {
      width: 100%;
      height: 380px;
      margin: 0 0 20px;
      position: relative;
      z-index: 0;
      overflow: hidden; }
      .post_content_figure::after {
        opacity: 0;
        content: '';
        width: 100%;
        height: 100%;
        border: 5px solid #33955e;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 10;
        pointer-events: none;
        transition: all 0.5s ease-in-out; }
    .post_content_image {
      width: 100%;
      height: 100%; }
    .post_content_text-box {
      align-items: center;
      justify-content: flex-start; }
    .post_content_time {
      margin: 0 10px 10px 0;
      color: #bbb;
      font-size: 1.7rem; }
    .post_content_tag {
      align-items: center;
      justify-content: flex-start; }
      .post_content_tag_item {
        min-width: 110px;
        padding: 0 10px;
        margin: 0 10px 10px 0;
        color: #fff;
        text-align: center;
        background-color: #33955e; }
    .post_content_title {
      width: 100%;
      margin: -5px 0 0;
      font-size: 2rem;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap; }
    .post_content_link:hover .post_content_figure::after {
      opacity: 1; }

/*  ▼ banner
------------------------------------- */
.banner {
  align-items: center;
  align-content: center;
  justify-content: center;
  height: 270px;
  outline: 1px solid #fff;
  outline-offset: -10px;
  background: url(../images/common/banner_bg.png) no-repeat center/cover; }
  .banner_title {
    width: 100%;
    margin: 0 0 20px;
    color: #fff;
    font-size: 3rem;
    font-weight: 700;
    text-align: center; }
    .banner_title__font-large {
      color: #00b04e;
      font-size: 146.66667%; }
  .banner_logo {
    height: auto; }
  .banner_tel {
    display: flex;
    align-items: center;
    height: auto;
    margin: 0 40px;
    line-height: 1;
    color: #fff;
    font-weight: 700;
    font-size: 4.5rem; }
    .banner_tel::before {
      content: '';
      width: 22px;
      height: 30px;
      margin-right: 15px;
      background: url(../images/common/icon_tel__green.png) no-repeat center/contain;
      transform: translateY(4px); }
  .banner_button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 300px;
    height: 55px;
    color: #fff;
    font-size: 2rem;
    font-weight: 700;
    background-color: #33955e; }
    .banner_button::before {
      content: '';
      width: 21px;
      height: 15px;
      margin-right: 20px;
      background: url(../images/common/icon_mail.png) no-repeat center/contain;
      transform: translateY(2px); }
    .banner_button:hover {
      background-color: #1f7645; }
    .banner_button__font-large {
      font-size: 122.72727%; }

/*  ▼ cmn-table
------------------------------------- */
.cmn-table_row {
  background-color: #f5f5f5; }
  .cmn-table_row:not(:last-child) {
    border-bottom: 2px solid #fff; }

.cmn-table_title {
  width: 190px;
  color: #fff;
  vertical-align: middle;
  background-color: #128c47; }

.cmn-table_text {
  padding: 12px 30px; }

/*  ▼ news
------------------------------------- */
.news-list {
  width: 100%; }
  .news-list_item {
    border-bottom: 1px solid #bbb; }
  .news-list_link {
    align-items: center;
    justify-content: flex-start;
    padding: 20px 0; }
    .news-list_link:hover {
      color: #33955e; }
  .news-list_tag {
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    margin: 0 0 2px; }
    .news-list_tag_item {
      min-width: 80px;
      padding: 0 10px;
      margin-right: 10px;
      color: #fff;
      font-size: 1.3rem;
      text-align: center;
      background-color: #33955e; }
  .news-list_time {
    margin-right: 35px;
    color: #82bb9b;
    font-weight: 700; }
  .news-list_title {
    flex: 1;
    font: inherit;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap; }

.news-under_title {
  margin: 0 0 50px; }

.news-under_list {
  margin: -20px 0 0; }

.news-detail {
  padding: 100px 0; }
  .news-detail_content {
    align-items: center;
    align-content: flex-start;
    justify-content: flex-start; }
  .news-detail_time {
    margin-right: 15px;
    font-size: 2rem; }
  .news-detail_title {
    width: 100%;
    margin: -5px 0 25px;
    font-weight: 700; }
  .news-detail_text {
    width: 100%; }
  .news-detail_box {
    align-items: center;
    width: 100%;
    margin: 33px 0 0; }
    .news-detail_box_item {
      width: 530px;
      height: 350px;
      margin: 0 0 20px; }
    .news-detail_box_image {
      width: 100%;
      height: 100%; }

/*  ▼ postView
------------------------------------- */
.post-view {
  width: 100%;
  margin-top: 30px;
  line-height: 2;
  position: relative; }
  .post-view_prev {
    margin-right: auto; }
  .post-view_next {
    margin-left: auto; }
  .post-view_home {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); }

/*  ▼ pagenation
------------------------------------- */
.pagenation {
  display: flex;
  justify-content: center;
  width: 100%;
  margin: 50px 0 0;
  line-height: 1.5; }
  .pagenation li {
    background-color: #ccc; }
    .pagenation li:not(:last-child) {
      margin-right: 10px; }
    .pagenation li:not(.current):hover {
      opacity: 0.7; }
    .pagenation li.current {
      color: #fff;
      background-color: #33955e; }
  .pagenation a {
    padding: 5px 10px;
    text-decoration: underline; }
  .pagenation span {
    display: block;
    padding: 5px 10px; }

/*  ▼ breadcrumbs
------------------------------------- */
.breadcrumbs {
  padding: 7px 0;
  font-size: 1.4rem; }
  .breadcrumbs_wrap {
    justify-content: flex-start; }
  .breadcrumbs_item {
    list-style: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    position: relative;
    transition: all 0.5s; }
    .breadcrumbs_item:last-child {
      flex: 1 1 0%;
      color: #33955e; }
    .breadcrumbs_item:not(:last-child) {
      padding-right: 30px; }
      .breadcrumbs_item:not(:last-child)::before {
        content: ' ';
        display: block;
        width: 8px;
        height: 8px;
        margin: auto;
        border-top: 2px solid;
        border-right: 2px solid;
        transform: rotate(45deg);
        position: absolute;
        top: 0;
        bottom: 0;
        right: 13px; }
    .breadcrumbs_item a {
      text-decoration: underline; }
      .breadcrumbs_item a:hover {
        opacity: 0.6; }

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