@charset "UTF-8";
@import url(reset.css);
@import url(common.css);
/*** function ***/
/* ###################### */
/* ######## 変数 ######## */
/* ###################### */
/* カラー */
/* 書式 */
/* ###################### */
/* ######## 関数 ######## */
/* ###################### */
/* ###################### */
/* ######## 共通 ######## */
/* ###################### */
/* ボタン */
.btn {
  box-sizing: content-box;
  margin: 0 auto;
}
.btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  background: #46b28b;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #fff;
  letter-spacing: 0.02em;
  line-height: 1;
  text-decoration: none !important;
  transition: all 0.3s;
  position: relative;
  z-index: 0;
}
.btn a::after {
  content: "";
  background: url(../image/common/arrow.png) no-repeat center/contain;
  width: 6px;
  height: 9px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: -1;
}
.btn a:hover {
  text-decoration: none;
  background: #91ba52;
}

/*******/
html {
  /* 1rem = 10px にする*/
  font-size: 62.5%;
  _font-size: 62.5%;
  *font-size: 62.5%;
  /*ウェブフォント用*/
  text-rendering: optimizeLegibility;
}

.face_book .fbcomments,
.face_book iframe,
.face_book .fb_iframe_widget,
.face_book .fb_iframe_widget[style],
.face_book .fb_iframe_widget iframe[style],
.face_book .fbcomments iframe[style],
.face_book .fb_iframe_widget span,
.face_book ._2p3a {
  width: 100% !important;
}

#wrapper {
  overflow: hidden;
}

/********共通********/
.cont {
  margin: 0 auto;
}

.fle {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.tel a {
  text-decoration: none;
  color: #5c4c2c;
}

.table table {
  width: 100%;
  border-collapse: separate;
}
.table table tr th {
  box-sizing: border-box;
  background: #91ba52;
  color: #fff;
}
.table table tr td {
  box-sizing: border-box;
  background: #fff;
}

.h2_1 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #5c4c2c;
  letter-spacing: 0;
  line-height: 1;
}
.h2_1 .line {
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  z-index: 0;
}
.h2_1 .line::after {
  content: "";
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, #5c4c2c 3px, transparent 3px, transparent 6px);
  background-position: bottom left;
  background-size: 6px 1px;
  background-repeat: repeat-x;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  z-index: -1;
}
.h2_1::before {
  content: "";
  display: block;
  background: url(../image/common/ttl-deco.png) no-repeat center/contain;
}

/*********info***********/
.info .contents1 {
  position: relative;
  z-index: 0;
}
.info .contents1::before {
  content: "";
  width: 100%;
  background: url(../image/info/con01-deco1.png) no-repeat right center/contain;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.info .contents1::after {
  content: "";
  width: 100%;
  background: url(../image/info/con01-deco2.png) no-repeat left center/contain;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.info .contents1 h2 {
  color: #729e2d;
}
.info .contents1 .imgs {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.info .contents1 .imgs li div {
  overflow: hidden;
}
.info .contents1 .table td span {
  display: inline-block;
}
.info .contents1 .table td span:last-of-type {
  margin-right: 0;
}
.info .contents1 .map {
  overflow: hidden;
}
.info .contents1 .map iframe {
  width: 100%;
  height: 100%;
}

/*********faq***********/
.faq .contents1 {
  background: url(../image/faq/con01-bg.png) no-repeat bottom center;
}
.faq .contents1 h2 {
  color: #729e2d;
}
.faq .contents1 .box {
  background: #fff;
  border: solid #e6f5dd;
  box-sizing: border-box;
}
.faq .contents1 .box:last-of-type {
  margin-bottom: 0;
}
.faq .contents1 .box dt {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.faq .contents1 .box dt span {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #fff;
  letter-spacing: 0;
  line-height: 1;
  background: #91ba52;
  box-sizing: border-box;
  border-radius: 50%;
}
.faq .contents1 .box dt div {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #729e2d;
}
.faq .contents1 .box dd {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  background: #faf4dd;
  box-sizing: border-box;
}
.faq .contents1 .box dd span {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #fff;
  letter-spacing: 0;
  line-height: 1;
  background: #91ba52;
  box-sizing: border-box;
  border-radius: 50%;
}

/*********menu***********/
.menu .contents1 .txt p:last-of-type {
  margin-bottom: 0;
}
.menu .contents1 ul {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
.menu .contents1 ul li {
  margin: 0;
}
.menu .contents2 {
  background: url(../image/common/con-deco1.png) no-repeat top left, url(../image/common/con-deco2.png) no-repeat bottom right, #e6f5dd;
}
.menu .contents2 .box {
  background: #fff;
  box-sizing: border-box;
}
.menu .contents2 .box:last-of-type {
  margin-bottom: 0;
}
.menu .contents2 .box figure div {
  overflow: hidden;
}
.menu .contents2 .box .text h2 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #91ba52;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: solid 1px #91ba52;
}
.menu .contents2 .box .course h3 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #fff;
  letter-spacing: 0;
  line-height: 1;
  background: #91ba52;
  box-sizing: border-box;
}
.menu .contents2 .box .course dl {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: solid 1px #91ba52;
}
.menu .contents2 .box .course dl:last-of-type {
  border-bottom-width: 2px;
  margin-bottom: 0;
}
.menu .contents3 {
  background: url(../image/menu/con03-bg-top.png) no-repeat top center, url(../image/menu/con03-bg-bottom.png) no-repeat bottom center;
}
.menu .contents3 .box .in {
  background: #fff;
  border: solid #e6f5dd;
  box-sizing: border-box;
}
.menu .contents3 .box figure div {
  overflow: hidden;
}
.menu .contents3 .box .text h3 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #91ba52;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: solid 1px #91ba52;
}
.menu .contents3 .box .text h3 span {
  font-weight: 700;
}
.menu .contents3 .box .text .list .inbox {
  background: #faf4dd;
  box-sizing: border-box;
  border-radius: 5px;
}
.menu .contents3 .box .text .list .inbox h4 {
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  color: #46b28b;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: dashed 1px #5c4c2c;
}
.menu .contents3 .box .text .list .inbox .tel {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  line-height: 1;
}
.menu .contents3 .box .text .list .inbox .tel::before {
  content: "";
  display: inline-block;
  background: url(../image/common/tel-icon.png) no-repeat center/contain;
}
.menu .contents3 .box .text .list .inbox .tel a {
  color: #5c4c2c;
  text-decoration: none;
}
.menu .contents3 .box .text .list .inbox .link a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  background: #81c7ae;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  letter-spacing: 0;
  line-height: 1;
  transition: all 0.3s;
  position: relative;
  z-index: 0;
}
.menu .contents3 .box .text .list .inbox .link a::before {
  content: "";
  display: inline-block;
  background: url(../image/common/line-icon.png) no-repeat center/contain;
}
.menu .contents3 .box .text .list .inbox .link a::after {
  content: "";
  background: url(../image/common/arrow.png) no-repeat center/contain;
  width: 6px;
  height: 9px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: -1;
}
.menu .contents3 .box .text .list .inbox .link a:hover {
  text-decoration: none;
  background: #5c4c2c;
}
.menu .contents3 .box::after {
  content: "";
  display: block;
  background: url(../image/menu/con03-arrow.png) no-repeat center/contain;
  width: 100%;
}
.menu .contents3 .box:last-of-type::after {
  display: none;
}

/*********about***********/
.about .contents1 h2 {
  color: #729e2d;
}
.about .contents1 .txt p:last-of-type {
  margin-bottom: 0;
}
.about .contents2 {
  background: url(../image/common/con-deco1.png) no-repeat top left, url(../image/common/con-deco2.png) no-repeat bottom right, #e6f5dd;
}
.about .contents2 .box h3 {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #5c4c2c;
  letter-spacing: 0;
  line-height: 1;
}
.about .contents2 .box h3 span {
  display: inline-block;
}
.about .contents2 .box h3::before {
  content: "";
  display: inline-block;
  background: url(../image/about/subttl-deco.png) no-repeat center/contain;
}
.about .contents2 .box h3::after {
  content: "";
  display: inline-block;
  background: url(../image/about/subttl-deco.png) no-repeat center/contain;
  transform: scale(-1, 1);
}
.about .contents2 .box .list .li-box {
  background: #fff;
  box-sizing: border-box;
  position: relative;
  z-index: 0;
}
.about .contents2 .box .list .li-box figure {
  text-align: center;
}
.about .contents2 .box .list .li-box dt {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  border: solid 1px #729e2d;
  box-sizing: border-box;
}
.about .contents2 .box .list .li-box dt span {
  font-weight: "Zen Maru Gothic", sans-serif;
  color: #729e2d;
}
.about .contents3 {
  background: url(../image/about/con03-bg.png) no-repeat center/cover;
}
.about .contents3 figure {
  position: relative;
  z-index: 0;
}
.about .contents3 figure::before {
  content: "";
  background: url(../image/about/con03-img-deco.png) no-repeat center/contain;
  position: absolute;
  z-index: 1;
}
.about .contents3 figure div {
  overflow: hidden;
}
.about .contents3 .text h3 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #729e2d;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: solid 1px #729e2d;
}
.about .contents3 .text p:last-of-type {
  margin-bottom: 0;
}
.about .contents3 .text .box {
  box-sizing: border-box;
  background: #faf4dd;
  position: relative;
  z-index: 0;
}
.about .contents3 .text .box::before {
  content: "";
  box-sizing: border-box;
  border: dashed 1px #729e2d;
  position: absolute;
  z-index: -2;
}
.about .contents3 .text .box h4 {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #5c4c2c;
  letter-spacing: 0;
  line-height: 1;
}
.about .contents3 .text .box h4 span {
  display: inline-block;
}
.about .contents3 .text .box h4::before {
  content: "";
  display: inline-block;
  background: url(../image/about/subttl-deco.png) no-repeat center/contain;
}
.about .contents3 .text .box h4::after {
  content: "";
  display: inline-block;
  background: url(../image/about/subttl-deco.png) no-repeat center/contain;
  transform: scale(-1, 1);
}
.about .contents3 .text .box .list {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  box-sizing: border-box;
}
.about .contents3 .text .box .list ul li {
  font-weight: 500;
}
.about .contents3 .text .box .list ul li::before {
  content: "・";
}

/*********index***********/
.index .contents1 {
  position: relative;
  z-index: 0;
}
.index .contents1::before {
  content: "";
  width: 100%;
  background: url(../image/index/con01-deco.png) no-repeat bottom right/contain;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.index .contents1 h2 {
  color: #729e2d;
}
.index .contents1 .txt p:last-of-type {
  margin-bottom: 0;
}
.index .contents2 {
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.index .contents2::before {
  content: "";
  width: 100%;
  background: url(../image/common/con-deco1.png) no-repeat top left, url(../image/common/con-deco2.png) no-repeat bottom right, #e6f5dd;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  z-index: -2;
}
.index .contents2::after {
  content: "";
  background: #e6f5dd;
  border-radius: 50%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0;
  z-index: -1;
}
.index .contents2 h2 span {
  display: block;
}
.index .contents2 h2 span::before {
  content: "";
  display: block;
  box-sizing: border-box;
  border-top: dashed 1px #729e2d;
  border-bottom: dashed 1px #729e2d;
  margin: 0 auto;
}
.index .contents2 .list-box {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  background: #fff;
  box-sizing: border-box;
  position: relative;
  z-index: 0;
}
.index .contents2 .list-box::before {
  content: "";
  background: url(../image/index/con02-box-deco1.png) no-repeat center/contain;
  position: absolute;
  z-index: -1;
}
.index .contents2 .list-box::after {
  content: "";
  background: url(../image/index/con02-box-deco2.png) no-repeat center/contain;
  position: absolute;
  z-index: -1;
}
.index .contents2 .list-box figure {
  text-align: center;
}
.index .contents2 .list-box figure figcaption {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Zen Maru Gothic", sans-serif;
  color: #729e2d;
  border: solid 1px #729e2d;
  position: relative;
  z-index: 0;
}
.index .arrow {
  text-align: center;
  background: url(../image/index/con02-arrow.png) no-repeat center bottom;
}
.index .arrow p {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
}
.index .contents3 {
  background: url(../image/index/con03-bg.png) no-repeat center/cover;
}
.index .contents4 {
  background: url(../image/index/con04-bg.png) no-repeat center bottom;
  position: relative;
  z-index: 0;
}
.index .contents4::before {
  content: "";
  width: 100%;
  background: url(../image/index/con04-deco1.png) no-repeat top left, url(../image/index/con04-deco2.png) no-repeat top right;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.index .contents4 .box {
  box-sizing: border-box;
  background: url(../image/index/con04-box-bg1.png) no-repeat top right, url(../image/index/con04-box-bg2.png) no-repeat left bottom, #faf4dd;
  position: relative;
  z-index: 0;
}
.index .contents4 .box::before {
  content: "";
  box-sizing: border-box;
  border: dashed 1px #729e2d;
  position: absolute;
  z-index: -2;
}
.index .contents4 .box .text h2 {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  color: #5c4c2c;
  letter-spacing: 0;
  line-height: 1;
}
.index .contents4 .box .text h2 span {
  display: inline-block;
  position: relative;
  z-index: 0;
}
.index .contents4 .box .text h2 span::before {
  content: "";
  background: url(../image/index/con04-balloon.png) no-repeat left center/contain;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.index .contents4 .box .text h2::before {
  content: "";
  display: inline-block;
  background: url(../image/index/con04-ttl-deco.png) no-repeat center/contain;
}
.index .contents4 .box .text h2::after {
  content: "";
  display: inline-block;
  background: url(../image/index/con04-ttl-deco.png) no-repeat center/contain;
  transform: scale(-1, 1);
}
.index .contents4 .box .text .txt {
  text-align: center;
}
.index .contents4 .box .text .list {
  background: #fff;
  box-sizing: border-box;
  margin: 0 auto;
}
.index .contents4 .box .text .list h3 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  color: #46b28b;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: dashed 1px #5c4c2c;
}
.index .contents4 .box .text .list ul {
  display: flex;
  justify-content: center;
  align-items: center;
}
.index .contents4 .box .text .list ul li {
  margin: 0;
}
.index .contents5 .list dl {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  border-bottom: dashed 1px #5c4c2c;
}
.index .contents5 .list dl:last-of-type {
  margin-bottom: 0;
}
.index .contents5 .list dl .tag {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  margin-top: -4px;
}
.index .contents5 .list dl .tag span {
  display: inline-block;
  background: #ffce68;
  box-sizing: border-box;
  text-align: center;
  letter-spacing: 0;
  margin-top: 4px;
}
.index .contents5 .list dl .tag span:last-of-type {
  margin-right: 0;
}
.index .contents5 .list dl .txt {
  width: 100%;
}
.index .contents5 .list dl .txt a {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  color: #5c4c2c;
}
.index .contents5 .list dl .txt a:hover {
  text-decoration: underline;
}

/****エラーページ*****/
.error .contents1 {
  overflow: hidden;
}
.error .contents1 a {
  color: #5c4c2c;
}
.error .contents1 a:hover {
  text-decoration: underline;
}

/*==================================================
プライバシーポリシー
================================================== */
.privacy .contents1 .h3_1 {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  color: #5c4c2c;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: solid 1px #91ba52;
}
.privacy .contents1 .item-box:last-child {
  margin-bottom: 0;
}

/*==================================================
 サイトマップ
================================================== */
.site .contents1 .site_list {
  margin: 0 auto;
}
.site .contents1 .site_list ul {
  background: #faf4dd;
  position: relative;
  z-index: 0;
}
.site .contents1 .site_list ul::before {
  content: "";
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  box-sizing: border-box;
  border: dashed 1px #91ba52;
  position: absolute;
  top: 5px;
  left: 5px;
  z-index: -1;
}
.site .contents1 .site_list ul li {
  border-bottom: solid 1px #91ba52;
}
.site .contents1 .site_list ul li:last-of-type {
  border-bottom: none;
}
.site .contents1 .site_list ul li a {
  display: block;
  color: #5c4c2c;
  text-decoration: none;
  transition: all 0.3s;
}
.site .contents1 .site_list ul li a:hover {
  text-decoration: none;
  color: #91ba52;
}

/*==================================================
 ニュース
================================================== */
.news .contents1 {
  overflow: hidden;
}
.news .contents1 img {
  max-width: 100%;
}
.news .contents1 .list-box dl {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  border-bottom: dashed 1px #5c4c2c;
}
.news .contents1 .list-box dl:last-of-type {
  margin-bottom: 0;
}
.news .contents1 .list-box dl .tag {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  margin-top: -4px;
}
.news .contents1 .list-box dl .tag span {
  display: inline-block;
  background: #ffce68;
  box-sizing: border-box;
  text-align: center;
  letter-spacing: 0;
  margin-top: 4px;
}
.news .contents1 .list-box dl .tag span:last-of-type {
  margin-right: 0;
}
.news .contents1 .list-box dl .txt {
  width: 100%;
}
.news .contents1 .list-box dl .txt a {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  color: #5c4c2c;
}
.news .contents1 .list-box dl .txt a:hover {
  text-decoration: underline;
}

/*==================================================
 news詳細
================================================== */
.news_detail .contents1 {
  overflow: hidden;
}
.news_detail .contents1 .h3_1 {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  color: #5c4c2c;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: solid 1px #91ba52;
}
.news_detail .contents1 img {
  max-width: 100%;
}
.news_detail .contents1 .post-data {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.news_detail .contents1 .post-data li::after {
  content: "|";
  display: inline-block;
  margin: 0 4px;
}
.news_detail .contents1 .post-data li:last-of-type::after {
  display: none;
}
.news_detail .contents1 .post-data li.tag {
  color: #91ba52;
}
.news_detail .contents1 .post-data li.tag span::after {
  content: "、";
}
.news_detail .contents1 .post-data li.tag span:last-of-type::after {
  display: none;
}
.news_detail .contents1 .item-box {
  min-height: 230px;
  zoom: 1;
}

/*==================================================
 お問い合わせ
================================================== */
.contact .contents1 .table td a {
  color: #5c4c2c;
}
.contact .contents1 .table td a:hover {
  text-decoration: underline;
}
.contact .contents1 .table td input[type=radio],
.contact .contents1 .table td input[type=checkbox] {
  display: none;
}
.contact .contents1 .table td input[type=radio] + label,
.contact .contents1 .table td input[type=checkbox] + label {
  display: inline-block;
  color: #5c4c2c;
  position: relative;
  z-index: 0;
}
.contact .contents1 .table td input[type=radio] + label:before,
.contact .contents1 .table td input[type=checkbox] + label:before {
  content: "";
  width: 10px;
  height: 10px;
  background: #fff;
  box-sizing: border-box;
  border: solid 1px #a0a0a0;
  border-radius: 3px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}
.contact .contents1 .table td input[type=radio] + label:after,
.contact .contents1 .table td input[type=checkbox] + label:after {
  content: "";
  border-right: solid 2px #5c4c2c;
  border-bottom: solid 2px #5c4c2c;
  position: absolute;
  left: 3px;
  transform: rotate(45deg);
  opacity: 0;
}
.contact .contents1 .table td input[type=radio] + label:last-of-type,
.contact .contents1 .table td input[type=checkbox] + label:last-of-type {
  margin-right: 0;
}
.contact .contents1 .table td input[type=radio]:checked + label:after,
.contact .contents1 .table td input[type=checkbox]:checked + label:after {
  opacity: 1;
}
.contact .contents1 .table td .select-css-box {
  display: inline-block;
  position: relative;
  z-index: 0;
  min-width: 200px;
}
.contact .contents1 .table td .select-css-box::after {
  content: "<>";
  font: 1.5rem "Consolas", monospace;
  color: #5c4c2c;
  border-bottom: 1px solid #999;
  position: absolute;
  right: 4px;
  transform: rotate(90deg);
  pointer-events: none;
}
.contact .contents1 .table td .select-css-box select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: block;
  width: 100%;
  max-width: 320px;
  padding: 4px;
  margin: 0;
  font-size: 1.5rem;
  color: #5c4c2c;
  background-color: #fff;
  background-image: none;
  border: 1px solid #cccccc;
  word-break: normal;
}

/* input設定 */
.input-mid {
  width: 60%;
  padding: 4px;
  box-sizing: border-box;
}

.input-min {
  padding: 4px;
  box-sizing: border-box;
}

.input-big {
  padding: 4px;
  box-sizing: border-box;
  width: 100%;
}

form input {
  border: none;
  background: #f5f5f5;
  font-family: "Noto Sans JP", sans-serif;
}
form textarea {
  display: block;
  width: 100%;
  padding: 4px;
  box-sizing: border-box;
  border: none;
  background: #f5f5f5;
  font-family: "Noto Sans JP", sans-serif;
}

.clrred {
  color: #c00;
}

.contact-recaptcha-wrap {
  text-align: center;
  margin: 0 auto;
  width: 304px;
}
.contact-recaptcha-wrap input {
  text-align: center;
}

.mt5 {
  margin-top: 5px;
}

/* 必須マーク
-------------------------------------------------- */
.required-mark {
  color: #fff;
  font-size: 1.2rem;
  font-weight: normal;
  background: #f00;
  float: right;
}

/* 未記入エラー文
-------------------------------------------------- */
.error-text {
  margin: 0 0 5px;
  color: #f00;
}

/* 確認、バック、送信ボタン
-------------------------------------------------- */
.contact-submits {
  text-align: center;
}
.contact-submits input,
.contact-submits button {
  display: inline-block;
  border: none;
  background: #46b28b;
  border-radius: 5px;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  transition: all 0.3s;
}
.contact-submits input:hover,
.contact-submits button:hover {
  background: #5c4c2c;
  cursor: pointer;
}

.contact-submits-wrap {
  text-align: center;
  margin: 0 auto;
}
.contact-submits-wrap input {
  display: inline-block;
  border: none;
  background: #46b28b;
  border-radius: 5px;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  transition: all 0.3s;
}
.contact-submits-wrap input:hover {
  background: #5c4c2c;
  cursor: pointer;
}
.contact-submits-wrap input:disabled {
  border-color: #aaa;
  background: #aaa;
  color: #fff;
}
.contact-submits-wrap input:disabled:hover {
  background: #aaa;
  color: #fff;
  cursor: default;
}

/* セキュリティエラー
-------------------------------------------------- */
.sec-error-text {
  line-height: 50px;
  text-align: center;
  color: #f00;
  font-size: 16px;
  border: 2px solid #f00;
}