@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600&display=swap");
@font-face {
  font-family: 'NotoSansCJKjp';
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/NotoSansCJKjp-Regular.woff2") format("woff2"), url("../fonts/NotoSansCJKjp-Regular.woff") format("woff"), url("../fonts/NotoSansCJKjp-Regular.ttf") format("truetype");
  font-display: swap;
}

@font-face {
  font-family: 'NotoSansCJKjp';
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/NotoSansCJKjp-Medium.woff2") format("woff2"), url("../fonts/NotoSansCJKjp-Medium.woff") format("woff"), url("../fonts/NotoSansCJKjp-Medium.ttf") format("truetype");
  font-display: swap;
  font-display: swap;
}

@font-face {
  font-family: 'NotoSansCJKjp';
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/NotoSansCJKjp-Bold.woff2") format("woff2"), url("../fonts/NotoSansCJKjp-Bold.woff") format("woff"), url("../fonts/sNotoSansCJKjp-Bold.ttf") format("truetype");
  font-display: swap;
}

/*--------------------------
 ブレークポイント設定
----------------------------*/
:focus {
  outline: none;
}

/* 変数 -----*/
/*--------------------------
 共通設定
----------------------------*/
body {
  font-family: "NotoSansCJKjp", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Helvetica Neue", Arial, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #333;
  font-style: normal;
  font-weight: 300;
  letter-spacing: 1px;
  position: relative;
}

@media (max-width: 959px) {
  body {
    margin-bottom: 70px;
  }
}

@media (max-width: 767px) {
  body {
    margin-bottom: 0px;
  }
}

body img {
  width: 100%;
}

body .wrap {
  position: relative;
}

body .uk-container {
  max-width: 1400px;
  width: 90%;
  margin: 0 auto;
  padding: 0px 25px;
}

@media (min-width: 1400px) {
  body .uk-container {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
}

@media (max-width: 767px) {
  body .uk-container {
    width: 100%;
    padding-left: 15px !important;
    padding-right: 15px !important;
    box-sizing: border-box;
  }
}

body h1, body h2, body h3, body h4, body h5, body h6 {
  font-family: "NotoSansCJKjp", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Helvetica Neue", Arial, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.5;
  color: #333;
}

/*--------------------------
    フォントサイズ
----------------------------*/
html {
  font-size: 58%;
}

@media (min-width: 1400px) {
  html {
    font-size: 62.5%;
  }
}

@media (max-width: 767px) {
  html {
    font-size: 62.5%;
  }
}

body {
  font-size: 16px !important;
  font-size: 1.6rem !important;
  text-align: left !important;
  position: relative;
  font-weight: 500;
}

@media (max-width: 640px) {
  body {
    font-size: 14px !important;
    font-size: 1.4rem !important;
  }
}

/* リンク img ------*/
a img {
  transition: all 0.5s ease 0s;
}

a:hover {
  text-decoration: none;
}

a:hover img {
  transition: all 0.5s ease 0s;
}

/* PC時tel無効 ------*/
@media (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}

@media (min-width: 1400px) {
  .uk-hidden-xlarge {
    display: none !important;
  }
}

.uk-visible-xlarge {
  display: none;
}

@media (min-width: 1400px) {
  .uk-visible-xlarge {
    display: block !important;
  }
}

/* --- スマホ縦　非表示　--- */
@media (max-width: 640px) {
  .uk-hidden-xs {
    display: none !important;
  }
}

/* --- スマホ縦のみ表示　--- */
@media (min-width: 480px) {
  .uk-visible-xs {
    display: none !important;
  }
}

@media (max-width: 640px) {
  .uk-visible-xs {
    display: block !important;
  }
}

/*--------------------------
    中央配置
----------------------------*/
/* 上下左右中央配置 */
/* 上下のみ中央配置 */
/* 左右のみ中央配置 */
/* 中央配置解除 */
/* margin auto */
/* 縦書き */
.svg-wrap {
  height: 0;
  position: relative;
}

.svg-wrap img {
  height: 100%;
  display: block;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

a {
  transition: all 0.5s ease 0s;
  color: #56a546;
}

a:hover {
  transition: all 0.5s ease 0s;
}

/*--------------------------
 共通事項
----------------------------*/
a:hover {
  color: #06692a;
}

a:hover .uk-overlay-scale {
  /* transform: scale(1.1);*/
  filter: opacity(70%);
  transition: all 0.5s ease 0s;
}

.uk-section {
  margin-left: auto;
  margin-right: auto;
}

p {
  line-height: 1.8;
}

/* ※注意書き ----*/
.att {
  text-indent: -0.5em;
  padding-left: 1em;
}

.att::before {
  content: '※';
  display: inline-block;
}

/* アニメーション----*/
.uk-animation-slide-bottom-title {
  animation-name: uk-fade-bottom-title;
  animation-duration: 1.2s;
}

.uk-animation-slide-bottom-small {
  animation-duration: 0.8s;
}

.uk-animation-fade-mv {
  animation-duration: 1.2s;
}

@keyframes uk-fade-bottom-title {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes uk-fade-bottom-small {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

#ToolBar #UserMenu img {
  width: auto;
}

/*--------------------------
 loader
----------------------------*/
#loader-bg {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  background: #56a546;
  z-index: 999999;
}

#loader-bg #loader {
  display: none;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  width: 200px;
  height: 100px !important;
  text-align: center;
}

#loader-bg #loader .loader_img {
  position: absolute;
  z-index: 99999;
}

#loader-bg #loader .loader_img img {
  width: 50px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  position: fixed;
}

#loader-bg #loader .loader_text {
  color: #fff;
  z-index: 999999;
  font-weight: bold;
  position: relative;
  text-align: center;
  padding-top: 80px;
  font-family: "Montserrat", sans-serif;
  font-size: 12px;
}

/*--------------------------
 ヘッダー
----------------------------*/
header {
  width: calc(20% - 50px);
  position: absolute;
  left: 0;
  top: 0;
  z-index: 99;
  margin: 40px 0 0 50px;
  text-align: center;
  /* sticky */
}

@media (min-width: 1400px) {
  header {
    margin: 60px 0 0 100px;
    width: calc(20% - 100px);
  }
}

@media (max-width: 959px) {
  header {
    margin: 0;
    width: 100%;
  }
}

header h1 {
  max-width: 200px;
  margin: 0 auto 100px;
  background: #f4f6e6;
}

header h1 img {
  mix-blend-mode: multiply;
}

header h1 img.sp {
  display: none;
}

@media (max-width: 959px) {
  header h1 img.pc {
    display: none;
  }
  header h1 img.sp {
    display: block;
  }
}

@media (max-width: 959px) {
  header h1 {
    max-width: 100%;
    margin: 15px;
    background: none;
  }
  header h1 img.sp {
    width: auto;
    height: 40px;
    max-width: auto;
  }
}

@media (max-width: 640px) {
  header h1 {
    width: calc(100% - 90px);
    margin-right: 5px;
  }
  header h1 img.sp {
    width: 100%;
    height: auto;
  }
}

header ul.gnavi {
  display: inline-block;
  text-align: left;
}

@media (max-width: 959px) {
  header ul.gnavi {
    display: none;
  }
}

header ul.gnavi li {
  margin: 30px 0;
}

header ul.gnavi li button {
  background: none;
  border: none;
  text-align: left;
  letter-spacing: 1px;
  padding: 0;
  transition: all 0.5s ease 0s;
  padding-right: 30px;
  line-height: 1.5;
}

header ul.gnavi li a, header ul.gnavi li button {
  font-weight: bold;
  display: block;
  color: #333;
  font-size: 16px;
  position: relative;
}

header ul.gnavi li a span, header ul.gnavi li button span {
  font-size: 11px;
  display: block;
  color: #56a546;
  font-weight: 500;
  font-family: "Montserrat", sans-serif;
}

header ul.gnavi li a:hover, header ul.gnavi li button:hover {
  transform: translateX(-10px);
}

header ul.gnavi li.yasuragi {
  display: none;
}

header ul.gnavi li .uk-dropdown {
  width: auto;
  padding: 0;
  margin-left: 20px;
  background: none;
}

header ul.gnavi li .uk-dropdown p {
  margin: 0;
}

header ul.gnavi li .uk-dropdown p a {
  padding: 10px 15px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  font-size: 15px;
  white-space: nowrap;
  display: block;
  color: #fff;
  background: #56a546;
  font-weight: 500;
}

header ul.gnavi li .uk-dropdown p a:hover {
  transform: none;
  background: #58cd40;
}

header ul.gnavi li .uk-dropdown p:last-child a {
  border-bottom: none;
}

@media (max-width: 959px) {
  header .uk-sticky.uk-active {
    display: none;
  }
}

header .uk-sticky.uk-active ul.gnavi {
  position: fixed;
  background: rgba(255, 255, 255, 0.9);
  padding: 10px;
  top: 10px;
  left: 0px;
  display: flex;
}

header .uk-sticky.uk-active ul.gnavi li {
  margin: 0 20px;
  text-align: center;
  position: relative;
}

header .uk-sticky.uk-active ul.gnavi li button {
  text-align: center;
  padding-right: 0;
  line-height: 1.5;
}

header .uk-sticky.uk-active ul.gnavi li a:hover, header .uk-sticky.uk-active ul.gnavi li button:hover {
  transform: translateY(-5px);
}

header .uk-sticky.uk-active ul.gnavi li a[class*="cr"]::before, header .uk-sticky.uk-active ul.gnavi li button[class*="cr"]::before {
  content: none !important;
}

header .uk-sticky.uk-active ul.gnavi li a span, header .uk-sticky.uk-active ul.gnavi li button span {
  font-size: 10px;
}

header .uk-sticky.uk-active ul.gnavi li .uk-dropdown {
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  left: 50% !important;
  bottom: -105px;
  top: auto !important;
  margin-left: 0;
}

header .uk-sticky.uk-active ul.gnavi li .uk-dropdown a:hover {
  transform: none;
}

/*--------------------------
 スマホヘッダー
----------------------------*/
.spn__toggle {
  position: fixed;
  top: 0px;
  right: 10px;
  background: #06692a;
  width: 60px;
  height: 60px;
  padding: 0;
  z-index: 999;
  text-align: center;
  border-radius: 0 0 5px 5px;
}

/* メニュー開 */
#modal_menu {
  background: #fff;
  padding: 30px;
  z-index: 9999;
}

@media (max-width: 767px) {
  #modal_menu {
    padding: 20px;
  }
}

#modal_menu .uk-modal-dialog {
  background: none;
  padding: 50px 0px;
}

#modal_menu .uk-modal-dialog .uk-close {
  opacity: 1;
  width: 50px;
  height: 50px;
  right: 0;
  position: absolute;
  top: 0;
  background: none;
  border: none;
}

#modal_menu .uk-modal-dialog .uk-close::after {
  content: '';
  background: url(../img/common/ico_close.svg) no-repeat center/contain;
  width: 50px;
  height: 50px;
  display: block;
}

#modal_menu .uk-modal-dialog .nav__gnav ul li {
  text-align: left;
  border-bottom: 1px solid #ccc;
  margin-top: 0 !important;
}

#modal_menu .uk-modal-dialog .nav__gnav ul li button {
  background: none;
  border: none;
  text-align: left;
  letter-spacing: 1px;
  padding: 0;
  transition: all 0.5s ease 0s;
  padding-right: 30px;
  line-height: 1.5;
  pointer-events: none;
}

#modal_menu .uk-modal-dialog .nav__gnav ul li a, #modal_menu .uk-modal-dialog .nav__gnav ul li button {
  color: #333;
  font-size: 18px;
  padding: 15px;
  display: block;
  position: relative;
  font-weight: bold;
}

#modal_menu .uk-modal-dialog .nav__gnav ul li a span, #modal_menu .uk-modal-dialog .nav__gnav ul li button span {
  font-size: 12px;
  display: block;
  font-family: "Montserrat", sans-serif;
  color: #56a546;
}

#modal_menu .uk-modal-dialog .nav__gnav ul li .uk-dropdown {
  display: block;
  position: relative;
  background: none;
  box-shadow: none;
  padding: 0 0 10px;
  left: auto;
  top: auto;
}

#modal_menu .uk-modal-dialog .nav__gnav ul li .uk-dropdown p {
  margin: 0;
}

#modal_menu .uk-modal-dialog .nav__gnav ul li .uk-dropdown p a {
  font-size: 16px;
  padding: 0 15px 5px 30px;
  position: relative;
}

#modal_menu .uk-modal-dialog .nav__gnav ul li .uk-dropdown p a::before {
  content: '';
  width: 10px;
  height: 1px;
  background: #56a546;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  left: 15px;
}

/*--------------------------
 電話
----------------------------*/
.telbox {
  position: absolute;
  top: 16px;
  right: 180px;
}

@media (max-width: 959px) {
  .telbox {
    top: 10px;
    right: 80px;
  }
}

@media (max-width: 767px) {
  .telbox {
    display: none;
  }
}

.telbox a {
  font-family: "Montserrat", sans-serif;
  font-size: 35px;
  font-weight: 600;
  color: #56a546;
  position: relative;
  padding-left: 40px;
}

.telbox a::before {
  content: '';
  width: 35px;
  height: 35px;
  background: url(../img/common/ico_tel.svg) no-repeat center/contain;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  left: 0;
}

/*--------------------------
 固定ボタン
----------------------------*/
.uk-container {
  position: relative;
}

.uk-sticky-placeholder {
  height: 0 !important;
}

.fixed {
  position: absolute !important;
  right: 40px;
  z-index: 9999;
  top: 0px;
  width: auto !important;
  display: inline-block;
}

@media (max-width: 959px) {
  .fixed {
    position: fixed !important;
    width: 100% !important;
    left: 0;
    right: 0;
    bottom: 0;
    top: auto !important;
  }
}

@media (max-width: 767px) {
  .fixed__inner {
    display: flex;
  }
}

@media (max-width: 767px) {
  .fixed__btn {
    width: 50%;
  }
}

.fixed__btn a {
  background: #06692a;
  padding: 20px 15px;
  border-radius: 0 0 10px 10px;
  display: block;
  color: #fff;
  font-weight: bold;
  text-align: center;
}

@media (max-width: 959px) {
  .fixed__btn a {
    border-radius: 0;
    padding: 12px 10px 0;
    vertical-align: middle;
    height: 70px;
    box-sizing: border-box;
    position: relative;
  }
}

.fixed__btn a:hover {
  background: #56a546;
}

@media (max-width: 959px) {
  .fixed__btn a:hover {
    background: #3f8e2f;
  }
}

.fixed__btn a img {
  width: 40px;
  height: 40px;
  margin: 0 auto 8px;
}

@media (max-width: 959px) {
  .fixed__btn a img {
    display: none;
  }
}

.fixed__btn a span {
  font-size: 13px;
  display: block;
}

@media (max-width: 959px) {
  .fixed__btn a span {
    display: inline-block;
    font-size: 16px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    text-align: center;
    width: 100%;
  }
  .fixed__btn a span::before {
    content: url(../img/common/ico_contact.svg);
    width: 30px;
    height: 30px;
    display: inline-block;
    margin-right: 10px;
    vertical-align: middle;
  }
}

.fixed .telbox__sp {
  display: none;
}

@media (max-width: 767px) {
  .fixed .telbox__sp {
    display: block;
  }
}

@media (max-width: 767px) and (max-width: 767px) {
  .fixed .telbox__sp {
    width: 50%;
  }
  .fixed .telbox__sp a {
    display: block;
    background: #56a546;
    height: 100%;
    position: relative;
    padding: 0 !important;
    color: #fff;
  }
  .fixed .telbox__sp a span {
    font-size: 16px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    text-align: center;
    font-weight: bold;
    width: 100%;
  }
  .fixed .telbox__sp a span::before {
    content: url(../img/common/ico_tel_white.svg);
    width: 30px;
    height: 30px;
    display: inline-block;
    margin-right: 10px;
    vertical-align: middle;
  }
}

.uk-sticky.uk-active .fixed {
  position: fixed !important;
  right: 0;
  top: 10px !important;
}

@media (max-width: 959px) {
  .uk-sticky.uk-active .fixed {
    bottom: 0;
    top: auto !important;
  }
}

.uk-sticky.uk-active .fixed a {
  padding: 15px 20px 10px;
  border-radius: 10px 0 0 10px;
}

.uk-sticky.uk-active .fixed a img {
  width: 30px;
  height: 30px;
}

.uk-sticky.uk-active .fixed a span {
  display: none;
}

@media (max-width: 959px) {
  .uk-sticky.uk-active .fixed a {
    border-radius: 0;
  }
  .uk-sticky.uk-active .fixed a span {
    display: block;
  }
}

.uk-sticky.uk-active .telbox {
  display: none;
}

.txt-btn {
  display: inline-block;
}

.txt-btn a {
  color: #06692a;
  font-size: 18px;
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
  display: inline-block;
  line-height: 1.0;
}

.txt-btn a::after {
  content: url(../img/common/ico_arrow.svg);
  width: 24px;
  height: 12px;
  display: inline-block;
  margin-left: 10px;
  transition: all 0.5s ease 0s;
}

.txt-btn a:hover {
  color: #56a546;
}

.txt-btn a:hover::after {
  margin-left: 15px;
  transition: all 0.5s ease 0s;
}

/* h3 ----*/
h3 {
  font-size: 18px;
  font-weight: 600;
  color: #333;
}

h3 span {
  font-size: 50px;
  font-weight: 600;
  font-family: "Montserrat", sans-serif;
  color: #56a546;
  display: block;
}

@media (max-width: 640px) {
  h3 {
    font-size: 15px;
    font-weight: bold;
  }
  h3 span {
    font-size: 36px;
  }
}

/* .bg-left ----*/
.bg-left {
  position: relative;
}

.bg-left::after {
  content: '';
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 30%;
  height: 100%;
  background: #f4f6e6;
}

@media (max-width: 959px) {
  .bg-left::after {
    width: 20%;
  }
}

@media (max-width: 640px) {
  .bg-left::after {
    height: 25%;
    width: 30%;
  }
}

/*--------------------------
 アクセス
----------------------------*/
.access {
  text-align: center;
}

.access div[uk-grid] {
  margin-left: -30px;
}

.access div[uk-grid] > div {
  padding-left: 30px;
}

@media (min-width: 1400px) {
  .access div[uk-grid] {
    margin-left: -60px;
  }
  .access div[uk-grid] > div {
    padding-left: 60px;
  }
}

@media (max-width: 959px) {
  .access div[uk-grid] {
    margin-left: -20px;
  }
  .access div[uk-grid] > div {
    padding-left: 20px;
  }
}

.access h3 {
  margin-bottom: 60px;
}

@media (max-width: 640px) {
  .access h3 {
    margin-bottom: 0;
  }
}

@media (max-width: 640px) {
  .access__box {
    margin-top: 60px !important;
  }
  .access__box:first-child {
    margin-top: 40px;
  }
  .access__box:first-child .img::after {
    content: none !important;
  }
}

@media (max-width: 640px) {
  .access .img {
    position: relative;
  }
  .access .img img {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
  .access .img::after {
    content: '';
    width: 100%;
    height: 1px;
    background: #ccc;
    position: absolute;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    top: -30px;
  }
}

.access .text {
  padding: 30px 10px;
}

@media (max-width: 959px) {
  .access .text {
    text-align: left;
  }
}

@media (max-width: 640px) {
  .access .text {
    padding: 20px 0 10px;
    text-align: center;
  }
}

.access .text h4 {
  font-weight: bold;
  font-size: 18px;
}

@media (max-width: 767px) {
  .access .text h4 {
    margin-bottom: 15px;
  }
}

.access .text p {
  margin: 5px 0;
  font-size: 1.4rem;
}

@media (max-width: 640px) {
  .access .text p {
    font-size: 12px;
    letter-spacing: 0;
    margin: 3px 0;
  }
}

.access .text p span {
  display: inline-block;
  margin: 0 8px;
}

@media (max-width: 959px) {
  .access .text p span {
    display: none;
  }
}

@media (max-width: 640px) {
  .access .text p span {
    display: inline-block;
    margin: 0 8px;
  }
}

.access .text p br.sp {
  display: none;
}

@media (max-width: 959px) {
  .access .text p br.sp {
    display: block;
  }
}

@media (max-width: 640px) {
  .access .text p br.sp {
    display: none;
  }
}

@media (max-width: 640px) {
  .access .sq-btn {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
}

.access .sq-btn a {
  display: block;
  border: 1px solid #06692a;
  color: #06692a;
  font-weight: 600;
  font-family: "Montserrat", sans-serif;
  padding: 15px;
}

@media (max-width: 959px) {
  .access .sq-btn a {
    font-size: 14px;
  }
}

.access .sq-btn a:hover {
  background: #f4f6e6;
}

.access .sq-btn a::after {
  display: inline-block;
  content: url(../img/common/ico_window.svg);
  width: 16px;
  height: 16px;
}

/*--------------------------
 トップページ
----------------------------*/
#home {
  /* グロナビ カレント ----*/
  /*--------------------------
     メインビジュアル
    ----------------------------*/
  /*--------------------------
     news
    ----------------------------*/
  /*--------------------------
     会社概要
    ----------------------------*/
  /*--------------------------
     会社概要
    ----------------------------*/
}

#home header ul li a.cr-home::before {
  content: '';
  width: 20px;
  height: 1px;
  background: #56a546;
  position: absolute;
  top: 12px;
  left: -30px;
}

#home .mv {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 80px 0 0;
  position: relative;
  box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
}

#home .mv .uk-container {
  position: relative;
}

#home .mv__img {
  width: 75%;
  margin-left: 25%;
  position: relative;
  border-radius: 30px;
  overflow: hidden;
}

@media (max-width: 959px) {
  #home .mv__img {
    border-radius: 15px;
    width: 95%;
    margin-left: 5%;
    margin-right: 0px;
  }
}

@media (max-width: 640px) {
  #home .mv__img {
    width: calc(100% - 20px);
    margin-left: 20px;
  }
}

#home .mv__img h2 {
  font-size: 0;
  margin: 0;
}

#home .mv__img div[uk-slideshow] {
  position: relative;
}

#home .mv__img .uk-slideshow-nav {
  position: absolute;
  bottom: 20px;
  right: 30px;
  z-index: 1;
  margin-left: -8px;
  margin: 0;
}

#home .mv__img .uk-slideshow-nav li {
  padding-left: 8px;
}

#home .mv__img .uk-slideshow-nav li a {
  background: rgba(255, 255, 255, 0.5);
  border: none;
}

#home .mv__img .uk-slideshow-nav li.uk-active a {
  background: white;
}

#home .mv__scroll {
  position: absolute;
  left: 20px;
  bottom: 80px;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  -o-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
}

@media (min-width: 1400px) {
  #home .mv__scroll {
    left: 50px;
  }
}

@media (min-width: 1200px) {
  #home .mv__scroll {
    left: 15px;
  }
}

@media (max-width: 767px) {
  #home .mv__scroll {
    bottom: 0px;
    left: 15px;
  }
}

@media (max-width: 640px) {
  #home .mv__scroll {
    left: 8px;
  }
}

#home .mv__scroll p {
  margin: 0;
  color: #56a546;
  font-size: 12px;
  letter-spacing: 1px;
  position: relative;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
}

#home .mv__scroll p::after {
  content: "";
  position: absolute;
  width: 1px;
  bottom: -70px;
  height: 60px;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  background: #56a546;
  -webkit-animation: scroll 3.5s infinite cubic-bezier(0.075, 0.82, 0.165, 1);
  animation: scroll 3.5s infinite cubic-bezier(0.075, 0.82, 0.165, 1);
}

@media (max-width: 767px) {
  #home .mv__scroll p::after {
    height: 40px;
    bottom: -50px;
  }
}

@-webkit-keyframes scroll {
  0% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: bottom;
    transform-origin: bottom;
  }
  30% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: bottom;
    transform-origin: bottom;
  }
  31% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: top;
    transform-origin: top;
  }
  45% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: top;
    transform-origin: top;
  }
  100% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: top;
    transform-origin: top;
  }
}

#home .news {
  margin-left: 35%;
  width: 60%;
  margin-right: 5%;
}

@media (max-width: 959px) {
  #home .news {
    margin-left: 25%;
    width: 70%;
  }
}

@media (max-width: 640px) {
  #home .news {
    margin-left: 5%;
    width: 90%;
    z-index: 1;
    position: relative;
    padding-top: 100px;
  }
}

#home .news__inner {
  max-width: 950px;
}

#home .news h3 {
  font-size: 24px;
  margin-bottom: 0px;
}

#home .news h3 span {
  font-size: 13px;
}

@media (max-width: 640px) {
  #home .news h3 {
    margin-bottom: 0;
    font-size: 20px;
  }
  #home .news h3 span {
    font-size: 12px;
  }
}

#home .news .txt-btn {
  margin-left: 30px;
  margin-top: 10px;
}

#home .news .txt-btn a {
  font-size: 16px;
}

#home .news__list li {
  margin-bottom: 15px;
  border-bottom: 1px solid #ccc;
  padding: 15px 10px;
}

@media (max-width: 640px) {
  #home .news__list li {
    display: block;
    padding: 10px;
    padding-top: 0;
  }
  #home .news__list li::before {
    height: 0;
  }
}

#home .news__list li .date {
  display: inline-block;
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
  margin-right: 15px;
}

@media (max-width: 640px) {
  #home .news__list li .date {
    display: block;
  }
}

#home .news__list li .txt {
  display: inline-block;
}

#home .news__list li .txt a {
  color: #333;
}

#home .news__list li .txt a:hover {
  color: #56a546;
}

@media (max-width: 640px) {
  #home .news__list li .txt {
    display: block;
  }
}

#home .news .bnrarea .bnr__sdgs {
  margin: 0 auto;
  margin-top: 50px;
  margin-bottom: 25px;
  max-width: 630px;
}

#home .news .bnrarea ul {
  display: block;
  justify-content: center;
}

#home .news .bnrarea ul li {
  margin: 30px 15px;
  text-align: center;
}

#home .news .bnrarea ul li p {
  font-size: 13px;
  margin-bottom: 5px;
}

#home .news .bnrarea ul li img {
  max-width: 300px;
}

@media (max-width: 640px) {
  #home .news .bnrarea ul {
    display: block;
    margin-top: 50px;
    margin-bottom: 0;
  }
  #home .news .bnrarea ul li {
    margin: 30px 0;
    text-align: center;
  }
}

#home .aboutus {
  z-index: 1;
  position: relative;
}

#home .aboutus::before {
  content: '';
  background: #fff;
  left: 0;
  right: 0;
  bottom: 0;
  height: 50%;
  z-index: 1;
  position: absolute;
}

@media (max-width: 959px) {
  #home .aboutus::before {
    height: 100%;
  }
}

#home .aboutus div[uk-grid] {
  margin-left: -60px;
  position: relative;
  z-index: 2;
}

#home .aboutus div[uk-grid] > div {
  padding-left: 60px;
}

#home .aboutus .img__inner {
  background: url(../img/top/aboutus_img.jpg) no-repeat center/cover;
  border-radius: 15px;
  overflow: hidden;
  height: 100%;
}

@media (max-width: 959px) {
  #home .aboutus .img__inner {
    padding-top: 50%;
    height: auto;
  }
}

@media (max-width: 959px) {
  #home .aboutus .img {
    order: 2;
    margin-top: 40px;
  }
}

#home .aboutus .text h3 {
  margin: 20px 0 40px;
}

#home .aboutus .text p {
  line-height: 2.0;
}

@media (max-width: 767px) {
  #home .aboutus .text p {
    font-size: 14px;
  }
}

#home .aboutus .text .btn {
  margin: 40px 0 20px;
}

@media (max-width: 959px) {
  #home .aboutus .text {
    text-align: center;
    order: 1;
  }
}

@media (max-width: 640px) {
  #home .aboutus .text {
    text-align: left;
  }
  #home .aboutus .text h3 {
    text-align: center;
  }
}

#home .business {
  position: relative;
  padding-bottom: 100px;
  padding-top: 100px;
}

#home .business::after {
  content: '';
  width: 100%;
  position: absolute;
  bottom: 0;
  background: #f4f6e6;
  height: 60%;
}

@media (max-width: 959px) {
  #home .business::after {
    height: 40%;
  }
}

@media (max-width: 640px) {
  #home .business::after {
    height: 60%;
  }
}

#home .business .uk-container {
  position: relative;
  z-index: 1;
}

#home .business .text {
  position: relative;
  height: 100%;
}

@media (max-width: 959px) {
  #home .business .text {
    text-align: center;
  }
}

#home .business .text .ld {
  font-weight: 600;
  font-size: 2.0rem;
  color: #06692a;
  margin-top: 50px;
}

@media (max-width: 1230px) and (min-width: 960px) {
  #home .business .text .ld {
    font-size: 1.8rem;
  }
  #home .business .text .ld br {
    display: none;
  }
}

@media (max-width: 640px) {
  #home .business .text .ld {
    font-size: 4.5vw;
  }
}

#home .business .text__inner {
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  left: 0;
}

@media (max-width: 959px) {
  #home .business .text__inner {
    position: absolute;
    left: auto;
    top: auto;
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
    position: relative;
    left: auto;
    bottom: auto;
  }
}

#home .business .cnts .business__box {
  max-width: 380px;
  margin-left: auto;
  margin-right: auto;
}

#home .business .cnts .img {
  border-radius: 10px 10px 0 0;
  overflow: hidden;
}

#home .business .cnts .text {
  position: relative;
  padding: 40px 25px 80px;
  background: #fff;
  border-radius: 0 0 10px 10px;
}

@media (max-width: 959px) {
  #home .business .cnts .text {
    text-align: left;
  }
}

#home .business .cnts .text .num {
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  top: -28px;
  width: 56px;
  height: 56px;
  background: #06692a;
  margin: 0;
  border-radius: 28px;
}

#home .business .cnts .text .num span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  font-size: 20px;
}

#home .business .cnts .text h4 {
  margin-top: 0;
  font-weight: bold;
  color: #333;
  font-size: 18px;
  text-align: center;
}

#home .business .cnts .text p {
  margin-bottom: 0;
}

#home .business .cnts .text .txt-btn {
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  bottom: 30px;
  white-space: nowrap;
}

/*--------------------------
 下層共通
----------------------------*/
.page {
  /*-- header ---*/
  /*--メインビジュアル ---*/
  /*--パンくず ---*/
  /*--h3 ---*/
  /*-- 表組 ---*/
}

.page header {
  margin-top: 30px;
}

.page header h1 {
  margin-bottom: 20px;
}

.page header h1 img {
  width: 80%;
}

.page header ul li {
  margin: 20px 0;
}

@media (max-width: 959px) {
  .page header {
    margin-top: 0;
  }
  .page header h1 img {
    width: 100%;
  }
}

.page .mv {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 80px 0 0;
  position: relative;
  box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
}

.page .mv .uk-container {
  position: relative;
}

.page .mv__img {
  width: 75%;
  margin-left: 25%;
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  height: 380px;
}

@media (max-width: 959px) {
  .page .mv__img {
    border-radius: 15px;
    width: 100%;
    margin-left: 0;
    margin-right: 0px;
  }
}

@media (max-width: 640px) {
  .page .mv__img {
    height: 250px;
  }
}

.page .mv__img__inner {
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  left: 0;
  background-color: rgba(86, 165, 70, 0.8);
  padding: 10px 50px;
  border-radius: 0 10px 10px 0;
}

@media (max-width: 640px) {
  .page .mv__img__inner {
    padding: 10px 30px;
  }
}

.page .mv__img__inner h2 {
  font-size: 4.0rem;
  color: #fff;
  font-weight: bold;
  margin: 0;
  text-align: left;
  line-height: 1.0;
  letter-spacing: 5px;
}

.page .mv__img__inner h2 span {
  font-family: "Montserrat", sans-serif;
  font-size: 14px;
  display: block;
  margin-top: 15px;
  margin-left: 4px;
}

@media (max-width: 640px) {
  .page .mv__img__inner h2 {
    font-size: 28px;
  }
  .page .mv__img__inner h2 span {
    font-size: 13px;
  }
}

.page #Crumbs {
  margin: 20px;
  padding-bottom: 20px;
  margin-left: calc(30% + 20px);
  font-size: 13px;
  position: relative;
  z-index: 1;
  font-family: "Montserrat", sans-serif, "NotoSansCJKjp", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Helvetica Neue", Arial, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

@media (max-width: 959px) {
  .page #Crumbs {
    margin-left: calc(20% + 20px);
  }
}

@media (max-width: 640px) {
  .page #Crumbs {
    margin-top: 10px;
    margin-left: 20px;
  }
}

.page #Crumbs a {
  position: relative;
  margin-right: 20px;
}

.page #Crumbs a::after {
  content: '>';
  display: inline-block;
  pointer-events: none;
  color: #333;
  position: relative;
  z-index: 1;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  right: -15px;
}

.page #Crumbs strong {
  font-weight: normal;
}

.page h3.ttl01 {
  font-size: 3.6rem;
  color: #06692a;
  font-weight: bold;
}

.page h3.ttl01 span {
  font-size: 1.4rem;
  font-weight: 600;
  font-family: "Montserrat", sans-serif;
  color: #333;
  display: block;
  margin-top: 5px;
}

@media (max-width: 640px) {
  .page h3.ttl01 {
    font-size: 28px;
  }
}

.page .access {
  padding: 80px 0;
  background: #f5f5f5;
  /*--h3 ---*/
}

.page .access h3 {
  font-size: 3.6rem;
  color: #06692a;
  font-weight: bold;
}

.page .access h3 span {
  font-size: 1.4rem;
  font-weight: 600;
  font-family: "Montserrat", sans-serif;
  color: #333;
  display: block;
  margin-top: 5px;
}

@media (max-width: 640px) {
  .page .access h3 {
    font-size: 28px;
  }
}

.page table.tbl01 {
  max-width: 800px;
  margin: 60px auto;
}

.page table.tbl01 th, .page table.tbl01 td {
  padding: 30px;
  text-align: left;
  font-size: 16px;
}

@media (max-width: 767px) {
  .page table.tbl01 th, .page table.tbl01 td {
    display: block;
  }
}

.page table.tbl01 th {
  font-size: 16px;
  font-weight: bold;
  color: #333;
  white-space: nowrap;
  vertical-align: top;
  border-bottom: 2px solid #56a546;
  text-align: center;
  padding: 30px 50px;
}

@media (max-width: 767px) {
  .page table.tbl01 th {
    border-bottom: none;
    padding: 20px 30px 0;
    text-align: left;
    position: relative;
  }
  .page table.tbl01 th::before {
    content: '';
    width: 6px;
    height: 25px;
    position: absolute;
    bottom: 0;
    left: 15px;
    background: #56a546;
  }
}

.page table.tbl01 td {
  border-bottom: 2px solid #dbddcb;
}

@media (max-width: 767px) {
  .page table.tbl01 td {
    padding: 10px 30px 20px;
  }
}

.page table.tbl01 td ul.link li a {
  color: #333;
}

.page table.tbl01 td ul.link li a::after {
  content: url(../img/common/ico_window.svg);
  display: inline-block;
  width: 15px;
  margin-left: 10px;
}

.page table.tbl01 td ul.link li a:hover {
  color: #06692a;
}

.page table.tbl01 td.sanpai img {
  max-width: 300px;
  border: 1px solid #ccc;
}

.page table.tbl01 td.sanpai a {
  color: #333;
}

.page table.tbl01 td.sanpai a:hover {
  color: #06692a;
}

.page table.tbl01 td.sanpai a:hover img {
  opacity: .8;
  border: 1px solid #56a546;
}

.page table.tbl01 td.sanpai p {
  margin-top: 5px;
  margin-bottom: 0;
}

.page table.tbl01 td.sanpai p::after {
  content: url(../img/common/ico_window.svg);
  display: inline-block;
  width: 15px;
  margin-left: 10px;
}

/*--------------------------
 会社概要
----------------------------*/
#about {
  /* グロナビ カレント ----*/
  /* 経営方針 ----*/
  /* 会社概要 ----*/
  /* 許認可 ----*/
}

#about header ul li a.cr-about::before {
  content: '';
  width: 20px;
  height: 1px;
  background: #56a546;
  position: absolute;
  top: 12px;
  left: -30px;
}

#about .mv__img {
  background: url(../img/about/mv.jpg) no-repeat center/cover;
}

#about .policy .uk-container {
  max-width: 1000px;
}

#about .policy h3 {
  text-align: center;
  margin-bottom: 60px;
}

#about .policy .img {
  text-align: center;
  position: relative;
}

#about .policy .img__inner {
  max-width: 200px;
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
}

#about .policy .img__inner img {
  border-radius: 10px;
}

@media (max-width: 959px) {
  #about .policy .img__inner {
    position: absolute;
    left: auto;
    top: auto;
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
    position: relative;
    margin: 0 auto;
  }
}

#about .policy .img .name {
  line-height: 1.4;
}

#about .policy .img .name span {
  display: block;
  font-size: 90%;
  margin-bottom: 10px;
}

#about .policy__list li {
  position: relative;
  padding-left: 60px;
  font-size: 16px;
  margin: 30px 0;
  line-height: 1.8;
}

@media (max-width: 640px) {
  #about .policy__list li {
    margin-top: 0;
  }
}

#about .policy__list li .num {
  position: absolute;
  left: 0;
  top: 0;
  font-size: 2.0rem;
  font-weight: 600;
  color: #fff;
  font-family: "Montserrat", sans-serif;
  background: #56a546;
  width: 45px;
  text-align: center;
}

#about .profile {
  text-align: center;
  background: #f4f6e6;
}

#about .permit {
  text-align: center;
}

#about .permit h3 {
  margin-bottom: 60px;
}

#about .permit__box {
  text-align: left;
  max-width: 1000px;
  margin: 40px auto;
}

#about .permit__box h4 {
  font-weight: bold;
  font-size: 20px;
  color: #06692a;
}

#about .permit__box p {
  max-width: 850px;
  font-size: 1.8rem;
}

@media (max-width: 767px) {
  #about .permit__box p {
    font-size: 16px;
  }
}

#about .permit__list {
  display: flex;
  flex-wrap: wrap;
}

#about .permit__list li {
  width: 50%;
  margin-top: 0;
  margin-bottom: 10px;
  padding-left: 20px;
  position: relative;
  box-sizing: border-box;
  letter-spacing: 0;
  font-size: 1.8rem;
}

@media (max-width: 767px) {
  #about .permit__list li {
    font-size: 16px;
    width: 100%;
  }
}

#about .permit__list li::before {
  content: '';
  width: 10px;
  height: 2px;
  background: #56a546;
  position: absolute;
  left: 0;
  top: 12px;
}

/*--------------------------
 事業内容
----------------------------*/
body[id*=business] {
  /* グロナビ カレント ----*/
}

body[id*=business] header ul li button.cr-business::before {
  content: '';
  width: 20px;
  height: 1px;
  background: #56a546;
  position: absolute;
  top: 12px;
  left: -30px;
}

body[id*=business] #Crumbs a:nth-child(2) {
  pointer-events: none;
  color: #333;
  margin-right: 14px;
}

body[id*=business] #Crumbs a:nth-child(2)::after {
  content: '/';
  color: #999;
  right: -9px;
  font-family: "Montserrat", sans-serif;
  font-weight: normal;
}

@media (max-width: 640px) {
  body[id*=business] h3 {
    font-size: 7vw !important;
    margin-bottom: 0px;
  }
}

@media (max-width: 959px) {
  body[id*=business] .flex-wrap {
    display: block;
  }
}

body[id*=business] .business__cnts {
  max-width: 1400px;
}

body[id*=business] .business__cnts .ld {
  margin: 60px 0 0;
  font-size: 1.8rem;
}

@media (max-width: 767px) {
  body[id*=business] .business__cnts .ld {
    font-size: 16px;
  }
}

@media (max-width: 640px) {
  body[id*=business] .business__cnts .ld {
    text-align: left;
    margin: 30px 0 0;
  }
}

body[id*=business] .business__cnts__menu {
  width: 290px;
  order: 2;
}

@media (max-width: 959px) {
  body[id*=business] .business__cnts__menu {
    display: none;
  }
}

body[id*=business] .business__cnts__menu__inner ul li {
  border-bottom: 1px solid #d8dcbc;
  margin-top: 0;
}

body[id*=business] .business__cnts__menu__inner ul li:last-child {
  border-bottom: none;
}

body[id*=business] .business__cnts__menu__inner ul li a {
  color: #333;
  padding: 15px 20px 15px 40px;
  display: block;
  font-weight: bold;
  background: #f4f6e6;
  position: relative;
}

body[id*=business] .business__cnts__menu__inner ul li a:hover {
  background: #e3e8c1;
}

body[id*=business] .business__cnts__menu__inner ul li a::before {
  content: '';
  width: 10px;
  height: 3px;
  border-radius: 1.5px;
  background: #56a546;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  left: 20px;
}

body[id*=business] .business__cnts__menu .uk-sticky.uk-active {
  z-index: 10;
}

body[id*=business] .business__cnts__main {
  width: calc(100% - 330px);
  margin-right: 50px;
  order: 1;
}

@media (max-width: 959px) {
  body[id*=business] .business__cnts__main {
    width: 100%;
    margin-left: 0;
  }
}

body[id*=business] .business__cnts__box {
  margin: 200px 0 0;
  position: relative;
}

body[id*=business] .business__cnts__box::after {
  content: '';
  width: 100%;
  height: 1px;
  border-top: 1px dotted #ccc;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  top: -100px;
}

body[id*=business] .business__cnts__box.bd-none {
  margin: 100px 0 0;
}

body[id*=business] .business__cnts__box.bd-none::after {
  content: none;
}

@media (max-width: 640px) {
  body[id*=business] .business__cnts__box {
    margin: 120px 0 0;
  }
  body[id*=business] .business__cnts__box::after {
    top: -60px;
  }
}

body[id*=business] .business__cnts__box h4 {
  font-size: 2.8rem;
  font-weight: bold;
  color: #333;
  position: relative;
  border-left: 5px solid #06692a;
  padding-left: 10px;
  margin-bottom: 60px;
  line-height: 1.2;
}

@media (max-width: 640px) {
  body[id*=business] .business__cnts__box h4 {
    font-size: 6vw;
    margin-bottom: 40px;
  }
}

body[id*=business] .business__cnts__box .ld02 {
  font-size: 2.0rem;
  font-weight: bold;
  padding-left: 10px;
  border-bottom: 3px solid #dbddcb;
  padding-bottom: 10px;
  margin-bottom: 0;
}

body[id*=business] .business__cnts__box .ld02 span {
  font-size: 1.6rem;
  display: inline-block;
  font-weight: normal;
}

body[id*=business] .business__cnts__box .number {
  display: inline-block;
  background: #eaeaea;
  padding: 5px 20px !important;
  border-radius: 5px;
  margin: 0;
}

@media (max-width: 640px) {
  body[id*=business] .business__cnts__box .number {
    font-size: 13px;
    padding: 5px 10px !important;
  }
}

body[id*=business] .business__cnts__box .tbl01 {
  max-width: 100%;
  margin-top: 0px;
}

body[id*=business] .business__cnts__box .tbl01 th {
  text-align: left;
}

@media (min-width: 768px) {
  body[id*=business] .business__cnts__box .tbl01 th {
    padding: 30px 30px 30px 10px;
  }
}

body[id*=business] .business__cnts__box .tbl01 td div {
  margin: 0;
}

body[id*=business] .business__cnts__box .tbl01 td div.hinmoku {
  padding: 10px;
  margin-top: 10px;
  display: inline-block;
}

@media (max-width: 640px) {
  body[id*=business] .business__cnts__box .tbl01 td div.hinmoku {
    font-size: 14px;
  }
}

body[id*=business] .business__cnts__box .tbl01 td div.hinmoku span {
  display: inline-block;
  border-radius: 30px;
  margin-left: -5px;
  font-weight: bold;
  text-align: center;
  margin-left: -10px;
  margin-bottom: 10px;
  font-size: 16px;
}

body[id*=business] .business__cnts__box .tbl01 td div.hinmoku span::before {
  content: '【';
  display: inline-block;
}

body[id*=business] .business__cnts__box .tbl01 td div.hinmoku span::after {
  content: '】';
  display: inline-block;
}

body[id*=business] .business__cnts__box .tbl01 td div.hinmoku strong {
  display: inline-block;
  margin-left: -10px;
}

body[id*=business] .business__cnts__box .business__list {
  margin-left: 10px;
}

body[id*=business] .business__cnts__box .business__list li {
  position: relative;
  padding-left: 1.2em;
}

body[id*=business] .business__cnts__box .business__list li::after {
  content: '●';
  color: #56a546;
  position: absolute;
  left: 0;
  top: 0;
  font-size: 14px;
}

body[id*=business] #yasuragi {
  background: url(../img/business/yasuragi_bg.jpg) no-repeat center/cover;
  position: relative;
}

body[id*=business] #yasuragi .uk-container {
  max-width: 1100px;
  position: relative;
  z-index: 2;
}

body[id*=business] #yasuragi .yasuragi__inner {
  text-align: center;
  background: rgba(255, 255, 255, 0.8);
  padding: 50px;
  box-sizing: border-box;
  border-radius: 10px;
}

@media (max-width: 767px) {
  body[id*=business] #yasuragi .yasuragi__inner {
    padding: 30px;
  }
}

@media (max-width: 640px) {
  body[id*=business] #yasuragi .yasuragi__inner {
    padding: 30px 20px;
  }
}

body[id*=business] #yasuragi .yasuragi__inner h3 {
  color: #06692a;
  font-size: 2.8rem !important;
  font-weight: bold;
}

@media (max-width: 767px) {
  body[id*=business] #yasuragi .yasuragi__inner h3 {
    font-size: 20px !important;
  }
}

@media (max-width: 640px) {
  body[id*=business] #yasuragi .yasuragi__inner h3 {
    font-size: 6vw !important;
  }
}

body[id*=business] #yasuragi .yasuragi__inner .attention {
  margin: 40px 0 60px;
  border-radius: 10px;
}

@media (max-width: 640px) {
  body[id*=business] #yasuragi .yasuragi__inner .attention {
    margin: 30px 0;
  }
}

body[id*=business] #yasuragi .yasuragi__inner .attention p {
  color: #ab0909;
  font-size: 1.8rem;
  margin-bottom: 0;
  font-weight: bold;
}

body[id*=business] #yasuragi .yasuragi__inner .attention p br.tab {
  display: none;
}

@media (max-width: 959px) {
  body[id*=business] #yasuragi .yasuragi__inner .attention p br.tab {
    display: block;
  }
}

@media (max-width: 767px) {
  body[id*=business] #yasuragi .yasuragi__inner .attention p {
    font-size: 16px;
    text-align: left;
  }
  body[id*=business] #yasuragi .yasuragi__inner .attention p br.tab {
    display: none;
  }
}

@media (max-width: 640px) {
  body[id*=business] #yasuragi .yasuragi__inner .attention p {
    font-size: 15px;
    line-height: 1.4;
  }
}

body[id*=business] #yasuragi .yasuragi__inner .img {
  text-align: center;
}

body[id*=business] #yasuragi .yasuragi__inner .img img {
  max-width: 400px;
}

body[id*=business] #yasuragi .yasuragi__inner .text {
  text-align: left;
  line-height: 1.8;
}

body[id*=business] #yasuragi .yasuragi__inner ul {
  text-align: left;
  margin: 30px 0 0;
  display: flex;
  flex-wrap: wrap;
}

body[id*=business] #yasuragi .yasuragi__inner ul li {
  width: 100%;
  margin: 5px 0;
}

body[id*=business] #yasuragi .yasuragi__inner ul li span {
  background: #56a546;
  padding: 3px 10px;
  color: #fff;
  display: inline-block;
  margin-right: 15px;
  text-align: center;
  width: 6em;
  font-weight: bold;
  border-radius: 5px;
}

@media (max-width: 767px) {
  body[id*=business] #yasuragi .yasuragi__inner ul li {
    width: 100%;
  }
}

@media (max-width: 640px) {
  body[id*=business] #yasuragi .yasuragi__inner ul li {
    text-align: center;
  }
  body[id*=business] #yasuragi .yasuragi__inner ul li:nth-child(n+2) {
    margin-top: 15px;
  }
  body[id*=business] #yasuragi .yasuragi__inner ul li span {
    display: block;
    margin: 0 auto 5px;
  }
}

#business_business01 .mv__img {
  background: url(../img/business/mv01.jpg) no-repeat center/cover;
}

@media (max-width: 640px) {
  #business_business01 .caseimg {
    margin-left: 0;
  }
  #business_business01 .caseimg > div {
    padding-left: 0;
  }
}

#business_business01 .visible-pc {
  width: 100%;
  background: #efefef;
  margin-top: 100px;
}

@media (max-width: 767px) {
  #business_business01 .visible-pc {
    display: none;
  }
}

#business_business01 .visible-pc .ld02 {
  position: absolute;
  left: 0px;
  top: -50px;
  border-bottom: none;
}

#business_business01 .visible-pc .map_link {
  width: 45%;
}

#business_business01 .visible-pc .number {
  display: block;
}

@media (max-width: 1100px) and (min-width: 960px) {
  #business_business01 .visible-pc {
    padding-bottom: 5px;
    text-align: center;
  }
  #business_business01 .visible-pc .map_link {
    width: 35%;
    margin: 10px auto;
  }
}

#business_business01 .himeji {
  margin-top: 50px;
}

@media (max-width: 767px) {
  #business_business01 .himeji {
    display: none;
  }
}

#business_business01 .visible-spn {
  display: none;
}

@media (max-width: 767px) {
  #business_business01 .visible-spn {
    display: block;
  }
  #business_business01 .visible-spn .maps {
    padding-top: calc(900 / 1500 * 100%);
    background: url(../img/business/map.jpg) no-repeat center/contain;
  }
}

@media (max-width: 767px) and (max-width: 767px) {
  #business_business01 .visible-spn .maps {
    padding-top: 60%;
    background: url(../img/business/map.jpg) no-repeat center/100% auto;
  }
}

@media (max-width: 767px) and (max-width: 640px) {
  #business_business01 .visible-spn .maps {
    padding-top: 80%;
    background: url(../img/business/map.jpg) no-repeat center/120% auto;
  }
}

#business_business01 .rightbox {
  width: calc(55% - 10px);
  left: 45%;
  position: absolute;
  right: 5px !important;
  top: 8px;
  bottom: 8px !important;
  background: #fff;
  padding: 20px;
  box-sizing: border-box;
  border-radius: 5px;
}

#business_business01 .rightbox h5 {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 10px;
}

#business_business01 .rightbox p {
  font-size: 13px;
  margin-top: 0;
}

@media (max-width: 1100px) and (min-width: 960px) {
  #business_business01 .rightbox {
    position: relative;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: calc(100% - 10px);
    margin-left: 5px;
    padding-bottom: 0;
    background: none;
    padding-top: 0;
  }
}

#business_business01 #p_gifu01, #business_business01 #p_gifu02,
#business_business01 #p_aichi01, #business_business01 #p_aichi02,
#business_business01 #p_mie01, #business_business01 #p_mie02,
#business_business01 #p_shiga01, #business_business01 #p_shiga02 {
  display: none;
}

#business_business01 .p_box {
  width: calc(55% - 28px);
  position: absolute;
  right: 18px !important;
  top: 110px;
  left: calc(45% + 10px);
  bottom: 15px !important;
  padding: 0;
  background: #f4f6e6;
}

@media (max-width: 1200px) and (min-width: 960px) {
  #business_business01 .p_box {
    top: 60px;
  }
}

@media (max-width: 1100px) and (min-width: 960px) {
  #business_business01 .p_box {
    position: relative;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: calc(100% - 10px);
    margin-left: 5px;
  }
}

#business_business01 .p_box .p_title {
  border-top: 2px solid #56a546;
  margin: 0;
  font-weight: bold;
  font-size: 18px;
  padding: 10px 0 0;
  padding-left: 15px;
}

@media (max-width: 1200px) and (min-width: 960px) {
  #business_business01 .p_box .p_title {
    font-size: 16px;
  }
}

#business_business01 .p_box .p_txt {
  padding: 15px 15px 0;
}

#business_business01 .p_box .p_txt .number {
  background: #fff;
  font-size: 15px !important;
  padding: 5px 10px !important;
}

@media (max-width: 1200px) and (min-width: 960px) {
  #business_business01 .p_box .p_txt .number {
    font-size: 13px !important;
  }
}

@media (max-width: 1100px) and (min-width: 960px) {
  #business_business01 .p_box .p_txt .number br {
    display: none;
  }
}

#business_business01 .p_box .p_txt .hinmoku {
  padding: 10px;
  margin-top: 10px;
  display: inline-block;
  font-size: 15px;
}

#business_business01 .p_box .p_txt .hinmoku span {
  display: inline-block;
  border-radius: 30px;
  margin-left: -5px;
  font-weight: bold;
  text-align: center;
  margin-left: -10px;
  font-size: 16px;
  margin-bottom: 10px;
}

#business_business01 .p_box .p_txt .hinmoku span::before {
  content: '【';
  display: inline-block;
}

#business_business01 .p_box .p_txt .hinmoku span::after {
  content: '】';
  display: inline-block;
}

#business_business01 .p_box .p_txt .hinmoku strong {
  display: inline-block;
  margin-left: -10px;
}

@media (max-width: 1200px) and (min-width: 960px) {
  #business_business01 .p_box .p_txt .hinmoku {
    font-size: 13px;
  }
  #business_business01 .p_box .p_txt .hinmoku span {
    font-size: 14px;
  }
}

#business_business01 #anc03 img {
  max-width: 600px;
}

#business_business01 #anc03 .sq-btn {
  display: inline-block;
  margin: 50px 0 0;
}

@media (max-width: 640px) {
  #business_business01 #anc03 .sq-btn {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    display: block;
    text-align: center;
  }
}

#business_business01 #anc03 .sq-btn a {
  display: block;
  border: 1px solid #06692a;
  color: #06692a;
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
  padding: 15px;
}

@media (max-width: 959px) {
  #business_business01 #anc03 .sq-btn a {
    font-size: 14px;
  }
}

#business_business01 #anc03 .sq-btn a span {
  display: inline-block;
  margin-left: 10px;
}

@media (max-width: 640px) {
  #business_business01 #anc03 .sq-btn a span {
    margin-left: 0;
  }
}

#business_business01 #anc03 .sq-btn a:hover {
  background: #f4f6e6;
}

#business_business01 #anc03 .sq-btn a::after {
  display: inline-block;
  content: url(../img/common/ico_window.svg);
  width: 16px;
  height: 16px;
}

#business_business01 #anc05 h4 {
  margin-bottom: 40px;
}

#business_business02 .mv__img {
  background: url(../img/business/mv02.jpg) no-repeat center/cover;
}

#business_business02 #anc01 p {
  padding-left: 10px;
}

#business_business02 #anc01 .business__list li {
  box-sizing: border-box;
  margin: 5px 0;
}

#business_business02 #anc01 .business__list li::after {
  top: 3px;
}

#business_business02 #anc01 .adult {
  margin-bottom: 50px;
}

#business_business02 #anc01 .adult .business__list {
  display: flex;
  flex-wrap: wrap;
}

#business_business02 #anc01 .adult .business__list li {
  width: 50%;
}

@media (max-width: 767px) {
  #business_business02 #anc01 .adult .business__list li {
    width: 100%;
  }
}

#business_business02 #anc02 h4 {
  margin-bottom: 40px;
}

#business_business02 #anc02 .number {
  margin: 5px;
}

#business_business02 #anc02 .business__list {
  display: flex;
  flex-wrap: wrap;
}

#business_business02 #anc02 .business__list li {
  width: 50%;
  box-sizing: border-box;
  margin: 5px 0;
}

@media (max-width: 767px) {
  #business_business02 #anc02 .business__list li {
    width: 100%;
  }
}

#business_business02 #anc03 h4 {
  margin-bottom: 40px;
}

#business_business02 #anc03 p {
  padding-left: 10px;
}

#business_business02 .access {
  background: #fff;
}

/*--------------------------
 お問い合わせ
----------------------------*/
body[id*=contact] .mv__img {
  background: url(../img/common/mv.jpg) no-repeat center/cover;
}

body[id*=contact] h3 {
  text-align: center;
}

body[id*=contact] .mail-description {
  text-align: center;
}

@media (max-width: 640px) {
  body[id*=contact] .mail-description {
    text-align: left;
  }
}

body[id*=contact] .mail-description .form-message {
  border: #eec8c7 5px solid;
  margin: 30px 0;
  padding: 30px 50px;
  text-align: center;
}

@media (max-width: 640px) {
  body[id*=contact] .mail-description .form-message {
    padding: 30px 20px;
  }
}

body[id*=contact] .mail-description .form-message p {
  font-size: 18px;
  margin-bottom: 0;
  color: #56a546;
  font-weight: 500;
}

body[id*=contact] .mail-description .form-message p a.tel {
  font-size: 30px;
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
  color: #111;
  line-height: 35px;
  margin-top: 10px;
  text-align: center;
}

body[id*=contact] .mail-description .form-message p a.tel::before {
  content: '';
  margin-right: 5px;
  display: inline-block;
  vertical-align: top;
  height: 35px;
  width: 60px;
  background: url(../img/common/ico_tel_brown.svg) no-repeat center;
}

body[id*=contact] .cnts {
  max-width: 900px;
  padding: 0 0 50px;
}

body[id*=contact] .cnts .mail-description {
  margin-bottom: 30px;
}

body[id*=contact] .cnts .alert-message {
  color: #c71212;
}

body[id*=contact] .cnts form table {
  width: 100%;
}

body[id*=contact] .cnts form table tr th, body[id*=contact] .cnts form table tr td {
  padding: 15px;
  border-bottom: 1px dotted #ccc;
  font-size: 16px;
  color: #111;
  box-sizing: border-box;
}

@media (max-width: 640px) {
  body[id*=contact] .cnts form table tr th, body[id*=contact] .cnts form table tr td {
    display: block;
    width: 100% !important;
    box-sizing: border-box;
  }
}

body[id*=contact] .cnts form table tr th {
  color: #111;
  width: 40%;
}

@media (max-width: 640px) {
  body[id*=contact] .cnts form table tr th {
    border-bottom: none;
    padding-bottom: 0;
  }
}

body[id*=contact] .cnts form table tr th span {
  padding: 0px 10px;
  border-radius: 5px;
  margin-left: 10px;
  display: inline-block;
  font-size: 13px;
  font-weight: normal;
}

body[id*=contact] .cnts form table tr th span.required {
  background: #56a546;
  color: #fff;
}

body[id*=contact] .cnts form table tr th span.normal {
  background: #ccc;
  color: #7d7d7d;
}

body[id*=contact] .cnts form table tr input[type="text"], body[id*=contact] .cnts form table tr input[type="email"], body[id*=contact] .cnts form table tr textarea, body[id*=contact] .cnts form table tr select, body[id*=contact] .cnts form table tr input[type="password"] {
  margin: 3px 8px;
  padding: 10px;
  border: 1px solid #d5d5d5;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px;
  background-color: #fff;
  box-sizing: border-box;
  font-size: 16px;
  color: #111;
}

body[id*=contact] .cnts form table tr input:focus, body[id*=contact] .cnts form table tr textarea:focus {
  border: 1px solid #56a546;
  outline: 0;
}

body[id*=contact] .cnts form table tr input, body[id*=contact] .cnts form table tr textarea {
  box-sizing: border-box;
}

body[id*=contact] .cnts form table tr input.form-error, body[id*=contact] .cnts form table tr textarea.form-error {
  border: 1px solid #56a546;
  outline: 0;
}

@media (max-width: 640px) {
  body[id*=contact] .cnts form table tr input, body[id*=contact] .cnts form table tr textarea {
    width: calc( 100% - 16px);
  }
}

@media (max-width: 640px) {
  body[id*=contact] .cnts form table tr input[size="5"], body[id*=contact] .cnts form table tr input[size="3"] {
    width: auto !important;
  }
}

body[id*=contact] .cnts form table tr textarea {
  width: calc( 100% - 16px);
}

body[id*=contact] .cnts form table tr .error-message {
  color: red;
  margin: 5px 0 10px;
}

body[id*=contact] .cnts form table tr span.mail-description {
  text-align: left;
}

body[id*=contact] .cnts form .submit {
  margin: 40px 0;
  text-align: center;
}

body[id*=contact] .cnts form .submit input {
  font-size: 18px;
  font-weight: bold;
  padding: 10px 20px;
  border: none;
  display: inline-block;
  margin: 0 5px;
  transition: all 0.5s ease 0s;
}

@media (max-width: 640px) {
  body[id*=contact] .cnts form .submit input {
    display: block;
    margin: 10px 0;
    max-width: 400px;
    width: 100%;
  }
}

body[id*=contact] .cnts form .submit input:hover {
  filter: brightness(110%);
  transition: all 0.5s ease 0s;
}

body[id*=contact] .cnts form .submit input.btn-gray {
  background: #ccc;
  color: #7d7d7d;
}

body[id*=contact] .cnts form .submit input.btn-orange {
  background: #56a546;
  color: #fff;
}

body[id*=contact] .cnts form .submit input#BtnMessageBack {
  background: #06692a;
  color: #fff;
}

body[id*=contact] .cnts form .submit input#BtnMessageSubmit {
  background: #56a546;
  color: #fff;
}

body[id*="confirm"] #flashMessage {
  text-align: center;
  margin-bottom: 60px;
}

body[id*="confirm"] table th, body[id*="confirm"] table td {
  padding: 25px 15px !important;
}

@media (max-width: 640px) {
  body[id*="confirm"] table th {
    padding-bottom: 0px !important;
  }
  body[id*="confirm"] table td {
    padding-top: 10px !important;
  }
}

@media (max-width: 640px) {
  body[id*="confirm"] .uk-text-center {
    text-align: left !important;
  }
}

/*--------------------------
新着情報
----------------------------*/
body[id*="news"] {
  /* グロナビ カレント ----*/
}

body[id*="news"] header ul li a.cr-news::before {
  content: '';
  width: 20px;
  height: 1px;
  background: #56a546;
  position: absolute;
  top: 12px;
  left: -30px;
}

body[id*="news"] .mv__img {
  background: url(../img/common/mv.jpg) no-repeat center/cover;
}

body[id*="news"] h3.ttl01 {
  text-align: center;
}

body[id*="news"] .uk-container.post-container {
  max-width: 1000px;
}

body[id*="news"] .bc-contents .cnts {
  padding-top: 60px;
  padding-bottom: 60px;
}

@media (max-width: 640px) {
  body[id*="news"] .bc-contents .cnts {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

body[id*="news"] .bc-contents table.tbl01 th, body[id*="news"] .bc-contents table.tbl01 td {
  border-bottom: 1px dotted #ccc;
  padding: 15px;
}

@media (max-width: 640px) {
  body[id*="news"] .bc-contents table.tbl01 th, body[id*="news"] .bc-contents table.tbl01 td {
    display: block;
  }
}

body[id*="news"] .bc-contents table.tbl01 th {
  vertical-align: top;
  white-space: nowrap;
}

@media (max-width: 640px) {
  body[id*="news"] .bc-contents table.tbl01 th {
    border: none !important;
    padding-bottom: 0 !important;
    font-size: 15px;
  }
}

@media (max-width: 640px) {
  body[id*="news"] .bc-contents table.tbl01 td {
    padding-top: 5px !important;
  }
}

body[id*="news"] .blog h2.blog__title {
  text-align: left;
}

body[id*="news"] .blog .main-cnts {
  width: calc(100% - 360px);
  float: left;
  padding: 60px 0;
  margin-right: 60px;
  box-sizing: border-box;
}

@media (max-width: 959px) {
  body[id*="news"] .blog .main-cnts {
    width: 100%;
    float: none;
    margin-right: 0;
  }
}

body[id*="news"] .blog .main-cnts .post__title {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 15px;
  border-bottom: 1px dotted #ccc;
  padding-bottom: 15px;
  position: relative;
  margin-top: 10px !important;
  text-align: left;
}

body[id*="news"] .blog .main-cnts .post__title a {
  color: #111;
}

body[id*="news"] .blog .main-cnts .post__title::after {
  content: none;
}

@media (max-width: 640px) {
  body[id*="news"] .blog .main-cnts .post__title {
    font-size: 18px;
  }
}

body[id*="news"] .blog .main-cnts .box {
  border-bottom: 1px solid #ccc;
  padding-bottom: 50px;
  margin-bottom: 50px;
  padding-top: 50px;
}

body[id*="news"] .blog .main-cnts .post-body {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 60px;
}

body[id*="news"] .blog .main-cnts .post-body a[rel="colorbox"] {
  margin: 10px;
}

body[id*="news"] .blog .main-cnts .post-body a[rel="colorbox"] img {
  max-width: 300px;
}

body[id*="news"] .blog .main-cnts .img-eye-catch {
  width: 35%;
  float: left;
  margin-right: 20px;
}

body[id*="news"] .blog .main-cnts .post-date {
  text-align: left;
  font-size: 14px;
  font-family: "Montserrat", sans-serif;
  letter-spacing: 2px;
  color: #06692a;
}

body[id*="news"] .blog .main-cnts .contents-navi {
  margin: 30px 0;
}

body[id*="news"] .blog .main-cnts .contents-navi a {
  color: #999;
  font-size: 14px;
}

body[id*="news"] .blog .main-cnts .contents-navi a:hover {
  color: #56a546;
}

body[id*="news"] .blog .main-cnts .contents-navi .text_btn {
  display: block;
  margin-bottom: 30px;
}

body[id*="news"] .blog .main-cnts .contents-navi .text_btn a {
  color: #56a546;
}

body[id*="news"] .blog .main-cnts .contents-navi .txt-btn {
  display: block;
  margin-bottom: 60px;
}

body[id*="news"] .blog .main-cnts .contents-navi .txt-btn a {
  font-size: 18px;
  color: #06692a;
}

body[id*="news"] .blog .main-cnts .contents-navi .txt-btn a:hover {
  color: #56a546;
}

body[id*="news"] .blog .main-cnts .contents-navi .list {
  display: block;
  margin-bottom: 30px;
}

body[id*="news"] .blog .main-cnts .contents-navi .list a {
  border: #56a546 1px solid;
  padding: 5px 20px;
  color: #fff;
  text-align: center;
  border-radius: 15px;
  font-size: 16px;
  color: #56a546;
}

body[id*="news"] .blog .main-cnts .contents-navi .list a:hover {
  filter: brightness(110%);
  background: #56a546;
  color: #fff;
}

body[id*="news"] .blog .main-cnts .pagination span span {
  display: inline-block;
  box-sizing: border-box;
  margin: 0 5px;
  border-radius: 5px;
}

body[id*="news"] .blog .main-cnts .pagination span span a {
  background: #efefef;
  color: #56a546;
  display: block;
  padding: 8px;
  border-radius: 5px;
}

body[id*="news"] .blog .main-cnts .pagination span span a:hover {
  color: #fff;
  background: #56a546;
}

body[id*="news"] .blog .main-cnts .pagination span span.number {
  color: #fff;
  text-align: center;
}

body[id*="news"] .blog .main-cnts .pagination span span.number.current {
  background: #56a546;
  padding: 8px;
}

body[id*="news"] .blog .main-cnts .pagination span.next, body[id*="news"] .blog .main-cnts .pagination span.prev {
  display: inline-block;
}

body[id*="news"] .blog .main-cnts .pagination span.next a, body[id*="news"] .blog .main-cnts .pagination span.prev a {
  background: #efefef;
  color: #56a546;
  display: block;
  padding: 8px;
  border-radius: 5px;
}

body[id*="news"] .blog .main-cnts .pagination span.next a:hover, body[id*="news"] .blog .main-cnts .pagination span.prev a:hover {
  color: #fff;
  background: #56a546;
}

body[id*="news"] .blog .main-cnts .pagination span.disabled {
  color: #fff;
  background: #d5d5d5;
  box-sizing: border-box;
  margin: 0 5px;
  border-radius: 5px;
  padding: 8px;
}

body[id*="news"] .blog.archives h2.blog__title .cate {
  font-size: 16px;
}

body[id*="news"] .blog.archives h2.blog__title .cate::before {
  content: '#';
}

@media (max-width: 767px) {
  body[id*="news"] .blog.archives h2.blog__title .cate {
    font-size: 13px;
  }
}

body[id*="news"] .blog.archives h2.blog__title .blog-description {
  font-size: 16px;
  margin-top: 20px;
}

@media (max-width: 767px) {
  body[id*="news"] .blog.archives h2.blog__title .blog-description {
    font-size: 13px;
    margin-top: 10px;
  }
}

body[id*="news"] .blog.archives .main-cnts h3.post__title {
  border-bottom: none;
  margin-bottom: 0;
}

body[id*="news"] .blog.archives .main-cnts h3.post__title a {
  color: #111;
}

body[id*="news"] .blog.archives .main-cnts h3.post__title .cate a {
  color: #fff;
}

body[id*="news"] .blog.archives .main-cnts .box {
  padding-top: 0;
}

body[id*="news"] .blog.archives .main-cnts .honbun {
  font-size: 14px;
  color: #999;
}

body[id*="news"] .blog.archives .main-cnts .honbun a.detail {
  display: block;
  margin-top: 10px;
}

body[id*="news"] .blog.archives .main-cnts .honbun a.detail::after {
  content: '…';
}

body[id*="news"] .blog .menu {
  width: 300px;
  float: left;
  padding: 60px 0;
}

@media (max-width: 959px) {
  body[id*="news"] .blog .menu {
    width: 100%;
    float: none;
    padding-top: 0;
  }
}

body[id*="news"] .blog .menu .widget-area h2 {
  background: #56a546;
  color: #fff;
  padding: 5px 20px;
  font-weight: bold;
  font-size: 16px;
  text-align: center;
  margin: 30px 0 15px;
}

body[id*="news"] .blog .menu .widget-area ul {
  list-style: none;
  padding: 0;
}

body[id*="news"] .blog .menu .widget-area ul li {
  margin-bottom: 10px;
  padding: 0 10px;
  position: relative;
}

body[id*="news"] .blog .menu .widget-area ul li a {
  color: #333;
  font-size: 14px;
  padding-left: 1em;
  display: block;
}

body[id*="news"] .blog .menu .widget-area ul li a:hover {
  color: #56a546;
}

body[id*="news"] .blog .menu .widget-area ul li::before {
  content: '▶︎';
  color: #06692a;
  display: inline-block;
  margin-right: 5px;
  font-size: 80%;
  position: absolute;
  left: 5px;
  top: 0;
}

body[id*="news"] .blog .menu .widget-area .widget-blog-calendar {
  margin-bottom: 40px;
  background: #efefef;
  padding: 30px 15px;
  border-radius: 10px;
}

body[id*="news"] .blog .menu .widget-area .widget-blog-calendar table {
  width: 100%;
}

body[id*="news"] .blog .menu .widget-area .widget-blog-calendar table th, body[id*="news"] .blog .menu .widget-area .widget-blog-calendar table td {
  text-align: center;
}

/*--------------------------
 ページのトップへ
----------------------------*/
#pageTop {
  position: fixed;
  right: 20px;
  z-index: 999;
  margin: 0;
  /* &::before {
        content: '';
        width: 1px;
        height: 15px;
        top: -77px;
        right: 8;
        transform: rotate(45deg);
        background: #000;
        display: block;
        position: absolute;
    }
    */
}

#pageTop.normal {
  bottom: 10px !important;
}

@media (max-width: 959px) {
  #pageTop.normal {
    bottom: 80px !important;
    right: 15px;
  }
}

#pageTop a {
  display: block;
}

#pageTop a img {
  width: 10px;
  height: 75px;
}

#pageTop::after {
  content: "";
  position: absolute;
  width: 1px;
  bottom: 80px;
  height: 70px;
  right: 3px;
  background: #06692a;
  -webkit-animation: totop 3.5s infinite cubic-bezier(0.075, 0.82, 0.165, 1);
  animation: totop 3.5s infinite cubic-bezier(0.075, 0.82, 0.165, 1);
}

@-webkit-keyframes totop {
  0% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: bottom;
    transform-origin: bottom;
  }
  30% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: bottom;
    transform-origin: bottom;
  }
  31% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: top;
    transform-origin: top;
  }
  45% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: top;
    transform-origin: top;
  }
  100% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: top;
    transform-origin: top;
  }
}

/*--------------------------
 footer
----------------------------*/
footer {
  background: #56a546;
  padding: 0px 0 30px;
  text-align: center;
  position: relative;
}

@media (max-width: 767px) {
  footer {
    z-index: 9998;
    padding: 0 0 130px;
  }
}

footer .uk-container {
  position: relative;
}

@media (max-width: 767px) {
  footer .uk-container {
    position: initial;
  }
}

footer .ft__info {
  width: 50%;
  text-align: left;
  position: absolute;
  top: 70px;
  left: 0;
}

@media (max-width: 767px) {
  footer .ft__info {
    bottom: 0;
    top: auto;
    text-align: center;
    padding: 0 15px 15px;
    width: 100%;
    box-sizing: border-box;
  }
}

footer .ft__info h3 {
  text-align: left;
}

footer .ft__info h3 img {
  max-width: 300px;
}

@media (max-width: 767px) {
  footer .ft__info h3 img {
    max-width: 100%;
    width: auto;
    height: 40px;
  }
}

@media (max-width: 767px) {
  footer .ft__info h3 {
    text-align: center;
  }
}

footer .ft__info ul {
  margin: 40px 10px;
}

@media (max-width: 767px) {
  footer .ft__info ul {
    display: none;
  }
}

footer .ft__info ul li {
  margin: 20px 0;
}

footer .ft__info ul li a {
  color: #fff;
  position: relative;
}

footer .ft__info ul li a:hover {
  color: rgba(255, 255, 255, 0.5);
}

footer .ft__info ul li a.child {
  font-size: 90%;
  display: inline-block;
  margin-right: 15px;
}

footer .ft__info ul li a.child::after {
  content: '|';
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  right: -12px;
}

footer .ft__info ul li a.child.last::after {
  content: none;
}

footer .ft__info ul li span {
  color: #fff;
  display: block;
  margin-bottom: 5px;
}

footer .ft__info .copy {
  color: #fff;
  font-size: 12px;
  letter-spacing: 1px;
  font-family: "Montserrat", sans-serif;
  margin-bottom: 0;
}

footer .ft__contact {
  background: #76b566;
  padding: 60px;
  box-sizing: border-box;
  margin-left: 45%;
  width: 55%;
  text-align: left;
  border-radius: 0 0 0 30px;
  color: #fff;
}

@media (max-width: 767px) {
  footer .ft__contact {
    width: 100%;
    margin-left: 0;
    border-radius: 0;
    text-align: center;
    padding: 30px;
  }
}

footer .ft__contact h3 {
  color: #fff !important;
  font-size: 24px !important;
  text-align: left;
}

footer .ft__contact h3 span {
  font-size: 12px !important;
  color: #fff !important;
  margin-top: 15px;
}

@media (max-width: 767px) {
  footer .ft__contact h3 span {
    margin-top: 5px;
  }
}

@media (max-width: 767px) {
  footer .ft__contact h3 {
    text-align: center;
  }
}

footer .ft__contact .ld {
  margin: 30px 0 20px;
}

@media (max-width: 640px) {
  footer .ft__contact .ld {
    margin: 15px 0 10px;
  }
}

footer .ft__contact .tel {
  font-family: "Montserrat", sans-serif;
  font-size: 35px;
  font-weight: 600;
  color: #fff;
  position: relative;
  padding-left: 40px;
  letter-spacing: 2px;
}

footer .ft__contact .tel::before {
  content: '';
  width: 35px;
  height: 35px;
  background: url(../img/common/ico_tel_white.svg) no-repeat center/contain;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  left: 0;
}

@media (max-width: 640px) {
  footer .ft__contact .tel {
    font-size: 30px;
  }
}

footer .ft__contact .time {
  margin-top: 5px;
  padding-left: 40px;
  font-size: 14px;
}

footer .ft__contact .btn {
  max-width: 350px;
  margin-top: 30px;
}

@media (max-width: 767px) {
  footer .ft__contact .btn {
    margin-left: auto;
    margin-right: auto;
  }
}

footer .ft__contact .btn a {
  display: block;
  padding: 12px;
  box-sizing: border-box;
  text-align: center;
  color: #fff;
  border: 1px solid #fff;
}

footer .ft__contact .btn a::before {
  content: url(../img/common/ico_contact.svg);
  width: 20px;
  height: 20px;
  display: inline-block;
  margin-right: 5px;
  vertical-align: middle;
}

footer .ft__contact .btn a:hover {
  background: #06692a;
  border-color: #06692a;
}
