@charset "UTF-8";
/* Scss Document */
/*!
Theme Name: code-og-plan
Author: code
Description: originaltheme.
Version: 1.0
*/
/* Scss Document */
.c1 {
  color: #fff; }

.c2 {
  color: #37B500; }

.c3 {
  color: #00A24B; }

.c4 {
  color: #4BC6FF; }

.bg-a {
  background: rgba(0, 0, 0, 0.1); }

.bc0 {
  background-color: #ffffff; }

.bc1 {
  background-color: #EDEDED; }

.bc2 {
  background-color: #37B500; }

.bc3 {
  background-color: #00A24B; }

.bc4 {
  background-color: #4BC6FF; }

.gray1 {
  background: #E7EDF1; }

.red {
  color: #E80003; }

/* Scss Document */
a {
  text-decoration: none !important; }

.divlink {
  position: relative;
  z-index: 1;
  /* 必要であればリンク要素の重なりのベース順序指定 */ }

.divlink a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent: -999px;
  z-index: 2;
  /* 必要であればリンク要素の重なりのベース順序指定 */ }

.divlink a:hover {
  opacity: 0.5; }

a {
  text-decoration: none; }

ul {
  margin-left: 0;
  padding-left: 0;
  list-style: none; }

.pdg-0 {
  padding: 0 !important; }

.pdg-1 {
  padding: 1rem; }

.pdg-2 {
  padding: 2rem; }

.pdg-3 {
  padding: 3rem; }

.pdg-4 {
  padding: 4rem; }

.pdg-5 {
  padding: 5rem; }

.pdg-6 {
  padding: 6rem; }

.pdg-7 {
  padding: 7rem; }

.pdg-t1 {
  padding-top: 1rem; }

.pdg-t2 {
  padding-top: 2rem; }

.pdg-t3 {
  padding-top: 3rem; }

.pdg-t4 {
  padding-top: 4rem; }

.pdg-t5 {
  padding-top: 5rem; }

.pdg-b1 {
  padding-bottom: 1rem; }

.pdg-b2 {
  padding-bottom: 2rem; }

.pdg-b3 {
  padding-bottom: 3rem; }

.pdg-b4 {
  padding-bottom: 4rem; }

.pdg-b5 {
  padding-bottom: 5rem; }

.pdg-tb1 {
  padding-top: 1rem;
  padding-bottom: 1rem; }

.pdg-tb2 {
  padding-top: 2rem;
  padding-bottom: 2rem; }

.pdg-tb3 {
  padding-top: 3rem;
  padding-bottom: 3rem; }

.pdg-tb4 {
  padding-top: 4rem;
  padding-bottom: 4rem; }

.pdg-tb5 {
  padding-top: 5rem;
  padding-bottom: 5rem; }

.pdg-tb6 {
  padding-top: 6rem;
  padding-bottom: 6rem; }

.pdg-tb7 {
  padding-top: 7rem;
  padding-bottom: 7rem; }

.pdg-lr1 {
  padding-left: 1rem;
  padding-right: 1rem; }

.pdg-lr2 {
  padding-left: 2rem;
  padding-right: 2rem; }

.pdg-lr3 {
  padding-left: 3rem;
  padding-right: 3rem; }

.pdg-lr4 {
  padding-left: 4rem;
  padding-right: 4rem; }

.pdg-lr5 {
  padding-left: 5rem;
  padding-right: 5rem; }

.pdg-l1 {
  padding-left: 1rem;
  padding-right: 1rem; }

.pdg-l2 {
  padding-left: 2rem;
  padding-right: 2rem; }

.pdg-l3 {
  padding-left: 3rem;
  padding-right: 3rem; }

.pdg-l4 {
  padding-left: 4rem;
  padding-right: 4rem; }

.pdg-l5 {
  padding-left: 5rem;
  padding-right: 5rem; }

.mg1 {
  margin: 1rem; }

.mg2 {
  margin: 2rem; }

.mg3 {
  margin: 3rem; }

.mg4 {
  margin: 4rem; }

.mg5 {
  margin: 5rem; }

.mg-t0 {
  margin-top: 0; }

.mg-t1 {
  margin-top: 1rem; }

.mg-t2 {
  margin-top: 2rem; }

.mg-t3 {
  margin-top: 3rem; }

.mg-t4 {
  margin-top: 4rem; }

.mg-t5 {
  margin-top: 5rem; }

.mg-b0 {
  margin-bottom: 0; }

.mg-b1 {
  margin-bottom: 1rem; }

.mg-b2 {
  margin-bottom: 2rem; }

.mg-b3 {
  margin-bottom: 3rem; }

.mg-b4 {
  margin-bottom: 4rem; }

.mg-b5 {
  margin-bottom: 5rem; }

.mg-tb1 {
  margin-top: 1rem;
  margin-bottom: 1rem; }

.mg-tb2 {
  margin-top: 2rem;
  margin-bottom: 2rem; }

.mg-tb3 {
  margin-top: 3rem;
  margin-bottom: 3rem; }

.mg-tb4 {
  margin-top: 4rem;
  margin-bottom: 4rem; }

.mg-tb5 {
  margin-top: 5rem;
  margin-bottom: 5rem; }

.mg-lr1 {
  margin-right: 1rem;
  margin-left: 1rem; }

.mg-lr2 {
  margin-right: 2rem;
  margin-left: 2rem; }

.mg-lr3 {
  margin-right: 3rem;
  margin-left: 3rem; }

.mg-lr4 {
  margin-right: 4rem;
  margin-left: 4rem; }

.mg-lr5 {
  margin-right: 5rem;
  margin-left: 5rem; }

.mg-r1 {
  margin-right: 1rem; }

.mg-r2 {
  margin-right: 2rem; }

.mg-r3 {
  margin-right: 3rem; }

.mg-r4 {
  margin-right: 4rem; }

.mg-r5 {
  margin-right: 5rem; }

.mg-l1 {
  margin-left: 1rem; }

.mg-l2 {
  margin-left: 2rem; }

.mg-l3 {
  margin-left: 3rem; }

.mg-l4 {
  margin-left: 4rem; }

.mg-l5 {
  margin-left: 5rem; }

/*==================================================
ふわっ
===================================*/
/* その場で */
.fadeIn {
  animation-name: fadeInAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes fadeInAnime {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
/* 下から */
.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px); }
  to {
    opacity: 1;
    transform: translateY(0); } }
/* 上から */
.fadeDown {
  animation-name: fadeDownAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes fadeDownAnime {
  from {
    opacity: 0;
    transform: translateY(-100px); }
  to {
    opacity: 1;
    transform: translateY(0); } }
/* 左から */
.fadeLeft {
  animation-name: fadeLeftAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes fadeLeftAnime {
  from {
    opacity: 0;
    transform: translateX(-100px); }
  to {
    opacity: 1;
    transform: translateX(0); } }
/* 右から */
.fadeRight {
  animation-name: fadeRightAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes fadeRightAnime {
  from {
    opacity: 0;
    transform: translateX(100px); }
  to {
    opacity: 1;
    transform: translateX(0); } }
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.fadeInTrigger,
.fadeUpTrigger,
.fadeDownTrigger,
.fadeLeftTrigger,
.fadeRightTrigger {
  opacity: 0; }

/*==================================================
パタッ
===================================*/
/* 下へ */
.flipDown {
  animation-name: flipDownAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes flipDownAnime {
  from {
    transform: perspective(2500px) rotateX(100deg);
    opacity: 0; }
  to {
    transform: perspective(2500px) rotateX(0);
    opacity: 1; } }
/* 左へ */
.flipLeft {
  animation-name: flipLeftAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  perspective-origin: left center;
  opacity: 0; }

@keyframes flipLeftAnime {
  from {
    transform: perspective(600px) translate3d(0, 0, 0) rotateY(30deg);
    opacity: 0; }
  to {
    transform: perspective(600px) translate3d(0, 0, 0) rotateY(0deg);
    opacity: 1; } }
/* 左上へ */
.flipLeftTop {
  animation-name: flipLeftTopAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes flipLeftTopAnime {
  from {
    transform: translate(-20px, 80px) rotate(-15deg);
    opacity: 0; }
  to {
    transform: translate(0, 0) rotate(0deg);
    opacity: 1; } }
/* 右へ */
.flipRight {
  animation-name: flipRightAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  perspective-origin: right center;
  opacity: 0; }

@keyframes flipRightAnime {
  from {
    transform: perspective(600px) translate3d(0, 0, 0) rotateY(-30deg);
    opacity: 0; }
  to {
    transform: perspective(600px) translate3d(0, 0, 0) rotateY(0deg);
    opacity: 1; } }
/* 右上へ */
.flipRightTop {
  animation-name: flipRightTopAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes flipRightTopAnime {
  from {
    transform: translate(-20px, 80px) rotate(25deg);
    opacity: 0; }
  to {
    transform: translate(0, 1) rotate(0deg);
    opacity: 1; } }
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.flipDownTrigger,
.flipLeftTrigger,
.flipLeftTopTrigger,
.flipRightTrigger,
.flipRightTopTrigger {
  opacity: 0; }

/*==================================================
くるっ
===================================*/
/* X 軸（縦へ） */
.rotateX {
  animation-name: rotateXAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards; }

@keyframes rotateXAnime {
  from {
    transform: rotateX(0);
    opacity: 0; }
  to {
    transform: rotateX(-360deg);
    opacity: 1; } }
/*　Y軸（横へ） */
.rotateY {
  animation-name: rotateYAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards; }

@keyframes rotateYAnime {
  from {
    transform: rotateY(0);
    opacity: 0; }
  to {
    transform: rotateY(-360deg);
    opacity: 1; } }
/* Z 軸（左へ） */
.rotateLeftZ {
  animation-name: rotateLeftZAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards; }

@keyframes rotateLeftZAnime {
  from {
    transform: rotateZ(0);
    opacity: 0; }
  to {
    transform: rotateZ(-360deg);
    opacity: 1; } }
/*　Z 軸（右へ） */
.rotateRightZ {
  animation-name: rotateRightZAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards; }

@keyframes rotateRightZAnime {
  from {
    transform: rotateZ(0);
    opacity: 0; }
  to {
    transform: rotateZ(360deg);
    opacity: 1; } }
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.rotateXTrigger,
.rotateYTrigger,
.rotateLeftZTrigger,
.rotateRightZTrigger {
  opacity: 0; }

/*==================================================
ボンッ、ヒュッ
===================================*/
/* 拡大 */
.zoomIn {
  animation-name: zoomInAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards; }

@keyframes zoomInAnime {
  from {
    transform: scale(0.6);
    opacity: 0; }
  to {
    transform: scale(1);
    opacity: 1; } }
/* 縮小 */
.zoomOut {
  animation-name: zoomOutAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards; }

@keyframes zoomOutAnime {
  from {
    transform: scale(1.2);
    opacity: 0; }
  to {
    transform: scale(1);
    opacity: 1; } }
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.zoomInTrigger,
.zoomOutTrigger {
  opacity: 0; }

/*==================================================
じわっ
===================================*/
/* ぼかしから出現 */
.blur {
  animation-name: blurAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards; }

@keyframes blurAnime {
  from {
    filter: blur(10px);
    transform: scale(1.02);
    opacity: 0; }
  to {
    filter: blur(0);
    transform: scale(1);
    opacity: 1; } }
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.blurTrigger {
  opacity: 0; }

/*==================================================
にゅーん
===================================*/
/* 滑らかに変形して出現 */
.smooth {
  animation-name: smoothAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  　transform-origin: left;
  opacity: 0; }

@keyframes smoothAnime {
  from {
    transform: translate3d(0, 100%, 0) skewY(12deg);
    opacity: 0; }
  to {
    transform: translate3d(0, 0, 0) skewY(0);
    opacity: 1; } }
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.smoothTrigger {
  opacity: 0; }

/*==================================================
スーッ（枠線が伸びて出現）
===================================*/
/*枠線が伸びて出現*/
.lineTrigger {
  position: relative;
  /* 枠線が書かれる基点*/
  opacity: 0; }

.lineTrigger.lineanime {
  animation-name: lineAnimeBase;
  animation-duration: 1s;
  animation-fill-mode: forwards; }

@keyframes lineAnimeBase {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
/*上下線*/
.lineTrigger::before,
.lineTrigger::after {
  position: absolute;
  content: "";
  width: 0;
  height: 1px;
  background: #333;
  /* 枠線の色*/ }

/*左右線*/
.line2::before,
.line2::after {
  position: absolute;
  content: "";
  width: 1px;
  height: 0;
  background: #333;
  /* 枠線の色*/ }

/*上線*/
.lineTrigger::before {
  top: 0;
  left: 0; }

.lineTrigger.lineanime::before {
  animation: lineAnime .5s linear 0s forwards;
  /*表示されて0秒後に上線が0.5秒かけて表示*/ }

/*右線*/
.line2::before {
  top: 0;
  right: 0; }

.lineTrigger.lineanime .line2::before {
  animation: lineAnime2 .5s linear .5s forwards;
  /*表示されて0.5秒後に右線が0.5秒かけて表示*/ }

/*下線*/
.lineTrigger::after {
  bottom: 0;
  right: 0; }

.lineTrigger.lineanime::after {
  animation: lineAnime .5s linear 1s forwards;
  /*表示されて1秒後に下線が0.5秒かけて表示*/ }

/*左線*/
.line2::after {
  bottom: 0;
  left: 0; }

.lineTrigger.lineanime .line2::after {
  animation: lineAnime2 .5s linear 1.5s forwards;
  /*表示されて1.5秒後に左線が0.5秒かけて表示*/ }

@keyframes lineAnime {
  0% {
    width: 0%; }
  100% {
    width: 100%; } }
@keyframes lineAnime2 {
  0% {
    height: 0%; }
  100% {
    height: 100%; } }
/*枠線内側の要素*/
.lineTrigger.lineanime .lineinappear {
  animation: lineInnerAnime .5s linear 1.5s forwards;
  /*1.5秒後に中央のエリアが0.5秒かけて表示*/
  opacity: 0;
  /*初期値を透過0にする*/ }

@keyframes lineInnerAnime {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
/*==================================================
シャッ（背景色が伸びて出現）
===================================*/
/*背景色が伸びて出現（共通）*/
.bgextend {
  animation-name: bgextendAnimeBase;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  /*　はみ出た色要素を隠す　*/
  opacity: 0; }

@keyframes bgextendAnimeBase {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
/*中の要素*/
.bgappear {
  animation-name: bgextendAnimeSecond;
  animation-duration: 1s;
  animation-delay: 0.6s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
/*左から*/
.bgLRextend::before {
  animation-name: bgLRextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666;
  /*伸びる背景色の設定*/ }

@keyframes bgLRextendAnime {
  0% {
    transform-origin: left;
    transform: scaleX(0); }
  50% {
    transform-origin: left;
    transform: scaleX(1); }
  50.001% {
    transform-origin: right; }
  100% {
    transform-origin: right;
    transform: scaleX(0); } }
/*右から*/
.bgRLextend::before {
  animation-name: bgRLextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666;
  /*伸びる背景色の設定*/ }

@keyframes bgRLextendAnime {
  0% {
    transform-origin: right;
    transform: scaleX(0); }
  50% {
    transform-origin: right;
    transform: scaleX(1); }
  50.001% {
    transform-origin: left; }
  100% {
    transform-origin: left;
    transform: scaleX(0); } }
/*下から*/
.bgDUextend::before {
  animation-name: bgDUextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666;
  /*伸びる背景色の設定*/ }

@keyframes bgDUextendAnime {
  0% {
    transform-origin: bottom;
    transform: scaleY(0); }
  50% {
    transform-origin: bottom;
    transform: scaleY(1); }
  50.001% {
    transform-origin: top; }
  100% {
    transform-origin: top;
    transform: scaleY(0); } }
/*上から*/
.bgUDextend::before {
  animation-name: bgUDextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666;
  /*伸びる背景色の設定*/ }

@keyframes bgUDextendAnime {
  0% {
    transform-origin: top;
    transform: scaleY(0); }
  50% {
    transform-origin: top;
    transform: scaleY(1); }
  50.001% {
    transform-origin: bottom; }
  100% {
    transform-origin: bottom;
    transform: scaleY(0); } }
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.bgappearTrigger,
.bgUDextendTrigger,
.bgDUextendTrigger,
.bgRLextendTrigger,
.bgLRextendTrigger {
  opacity: 0; }

/*==================================================
アニメーション設定
===================================*/
/* アニメーションの回数を決めるCSS*/
.count2 {
  animation-iteration-count: 2;
  /*この数字を必要回数分に変更*/ }

.countinfinite {
  animation-iteration-count: infinite;
  /*無限ループ*/ }

/* アニメーションスタートの遅延時間を決めるCSS*/
.delay-time05 {
  animation-delay: 0.5s; }

.delay-time1 {
  animation-delay: 1s; }

.delay-time15 {
  animation-delay: 1.5s; }

.delay-time2 {
  animation-delay: 2s; }

.delay-time25 {
  animation-delay: 2.5s; }

.delay-time-a {
  animation-delay: 0.1s; }

.delay-time-b {
  animation-delay: 0.2s; }

.delay-time-c {
  animation-delay: 0.3s; }

.delay-time-top1 {
  animation-delay: 2s; }

.delay-time-top2 {
  animation-delay: 2.3s; }

.delay-time-top3 {
  animation-delay: 2.8s; }

/* アニメーション自体が変化する時間を決めるCSS*/
.change-time05 {
  animation-duration: 0.5s; }

.change-time1 {
  animation-duration: 1s; }

.change-time15 {
  animation-duration: 1.5s; }

.change-time2 {
  animation-duration: 2s; }

.change-time25 {
  animation-duration: 2.5s; }

.change-time-a {
  animation-duration: 0.3s; }

.change-time-b {
  animation-duration: 0.6s; }

.no-sc {
  overflow: hidden; }

/* Scss Document */
.kugiri {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 300px; }

.kugiri__Inner {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  clip: rect(0, auto, auto, 0); }

.kugiri-Image {
  position: fixed;
  z-index: -1;
  display: block;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-size: cover;
  background-position: center center; }

.viewpoint01, .viewpoint02, .viewpoint03, .viewpoint04 {
  padding: 0;
  margin: 0 auto;
  width: 100%;
  height: 400px;
  box-sizing: border-box;
  position: relative;
  overflow: hidden; }

.bg01, .bg02, .bg03, .bg04, .bg05, .bg06, .bg07, .bg08, .bg09, .bg10 {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  /* ← ここを修正！ */
  z-index: -1;
  opacity: 0;
  /* 初期は透明 */
  background-size: cover;
  /* 画像を全面カバー */
  background-position: center;
  /* 上下左右の中央に */
  background-repeat: no-repeat;
  /* 念のため繰り返し防止 */ }

.bg01 {
  background-image: url("images/DSC04033.jpg");
  z-index: -4;
  /**HTMLに記載の順番で下げていく**/ }

.bg02 {
  background-image: url("images/DSC03987.jpg");
  z-index: -2; }

.bg03 {
  background-image: url("images/DSC03987.jpg");
  z-index: -1; }

.bg04 {
  background-image: url("images/DSC04008.jpg");
  z-index: -3; }

.pp-box {
  margin: 1rem auto;
  background: #E6E6E6; }
  .pp-box p {
    margin: 0;
    padding: 0.5rem; }

.pp-btn {
  text-align: center;
  background: #A0DA94;
  display: block;
  margin: 0;
  padding: 1rem; }

.cntct table.contact {
  border: none; }
  .cntct table.contact th, .cntct table.contact td {
    border: none;
    border-bottom: 1px solid #ccc; }
  .cntct table.contact th {
    font-weight: bold;
    color: #37B500;
    border-bottom: 1px solid #ccc;
    padding-top: 2rem;
    text-align: right;
    padding-right: 2rem; }
  @media (max-width: 768px) {
    .cntct table.contact th, .cntct table.contact td {
      display: block;
      padding: 1rem;
      text-align: left; }
      .cntct table.contact th p, .cntct table.contact td p {
        margin: 0; } }
  .cntct table.contact input, .cntct table.contact textarea {
    border: 1px solid #BDBDBD;
    line-height: 2rem;
    width: 100%; }

table.recinfo {
  font-size: 14px;
  margin-bottom: 5rem; }
  @media (max-width: 768px) {
    table.recinfo th, table.recinfo td {
      display: block; }
    table.recinfo th {
      background: #ECECEC; } }

/*会社概要*/
#about table th {
  white-space: nowrap;
  width: 11rem; }

.divlink {
  position: relative;
  z-index: 1;
  /* 必要であればリンク要素の重なりのベース順序指定 */ }

.divlink a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent: -999px;
  z-index: 2;
  /* 必要であればリンク要素の重なりのベース順序指定 */ }

.divlink img {
  transition: 1s; }

.divlink:hover img {
  opacity: 0.5; }

.divlink:hover {
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3); }

.nav_sdw {
  box-shadow: 0px 1px 5px black; }

.nav_border {
  box-shadow: 0px 1px 0px #9E9E9E; }

#page_top {
  width: 50px;
  height: 50px;
  position: fixed;
  right: 20px;
  bottom: 50px;
  background: #00A24B;
  opacity: 0.6;
  border-radius: 50%; }

#page_top a {
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
  text-align: center;
  line-height: 50px;
  color: #fff; }

.pic-center {
  display: block;
  margin: 0 auto 1rem; }

table {
  background: #fff;
  width: 100%;
  border: 1px solid #ececec; }
  table th, table td {
    border: 1px solid #ececec;
    padding: 1rem; }
  table th {
    font-weight: normal; }

th.tt {
  width: 20%; }

.data {
  width: 40%; }

table.list-style {
  font-size: 14px;
  background: #ffffff; }
  table.list-style th {
    text-align: center;
    font-size: 11px;
    white-space: nowrap; }
    table.list-style th i {
      font-size: 14px;
      display: flex;
      justify-content: center;
      align-items: center;
      width: 30px;
      height: 30px;
      font-size: 1rem;
      color: #37B500;
      background: #f3f3f3;
      padding: .25rem;
      margin: 0 auto .25rem;
      border-radius: 50%; }
  @media (max-width: 768px) {
    table.list-style th, table.list-style td {
      display: block; }
    table.list-style th {
      text-align: left;
      font-size: 14px;
      font-weight: bold;
      color: #37B500; }
      table.list-style th i {
        font-size: 14px;
        display: inline; } }

table.contact th, table.contact td {
  padding: 0.8rem; }
  @media (max-width: 768px) {
    table.contact th, table.contact td {
      display: block; } }
  table.contact th p, table.contact td p {
    margin: 0; }
  table.contact th span, table.contact td span {
    font-size: 12px;
    color: #E20003; }
  table.contact th input, table.contact th textarea, table.contact td input, table.contact td textarea {
    font-size: 1rem;
    padding: 0.4rem;
    border: 1px solid #D5D5D5; }

span.wpcf7-spinner {
  display: none; }

/*ボタン*/
.btn1 {
  display: inline-block;
  width: 70%;
  text-align: center;
  background-color: #00A24B;
  font-size: 16px;
  color: #FFF;
  text-decoration: none;
  font-weight: bold;
  padding: 10px 24px;
  border-radius: 4px;
  border-bottom: 4px solid #37B500; }

.btn1:hover {
  color: #fff; }

.btn1:active {
  transform: translateY(4px);
  border-bottom: none; }

/*----------------------*/
.btn2 {
  display: inline-block;
  width: 180px;
  height: 50px;
  text-align: center;
  background-color: #9ec34b;
  font-size: 16px;
  line-height: 48px;
  color: #FFF;
  text-decoration: none;
  font-weight: bold;
  border: 2px solid #9ec34b;
  position: relative;
  overflow: hidden;
  z-index: 1; }

.btn2:after {
  width: 100%;
  height: 0;
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  background: #FFF;
  opacity: 0;
  transform: translateX(-50%) translateY(-50%) rotate(45deg);
  transition: .2s;
  z-index: -1; }

.btn2:hover {
  color: #9ec34b; }

.btn2:hover:after {
  height: 240%;
  opacity: 1; }

.btn2:active:after {
  height: 340%;
  opacity: 1; }

.insta_btn2 {
  /*ボタンの下地*/
  color: #FFF;
  /*文字・アイコン色*/
  border-radius: 7px;
  /*角丸に*/
  position: relative;
  display: block;
  height: 50px;
  /*高さ*/
  width: 200px;
  padding: 0px 1.5rem;
  text-align: center;
  /*中身を中央寄せ*/
  font-size: 25px;
  /*文字のサイズ*/
  line-height: 50px;
  /*高さと合わせる*/
  background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  /*グラデーション①*/
  overflow: hidden;
  /*はみ出た部分を隠す*/
  text-decoration: none;
  /*下線は消す*/
  margin: auto; }

.insta_btn2:before {
  /*グラデーション②*/
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  /*全体を覆う*/
  height: 100%;
  /*全体を覆う*/
  background: -webkit-linear-gradient(15deg, #ffdb2c, #f9764c 25%, rgba(255, 77, 64, 0) 50%) no-repeat;
  background: linear-gradient(15deg, #ffdb2c, #f9764c 25%, rgba(255, 77, 64, 0) 50%) no-repeat; }

.insta_btn2 .fa-instagram {
  /*アイコン*/
  font-size: 35px;
  /*アイコンサイズ*/
  position: relative;
  top: 4px;
  /*アイコン位置の微調整*/ }

.insta_btn2 span {
  /*テキスト*/
  display: inline-block;
  position: relative;
  transition: .5s;
  margin-left: 0.8rem;
  font-size: 20px; }

.insta_btn2:hover span {
  /*ホバーで一周回転*/
  -webkit-transform: rotateX(360deg);
  -ms-transform: rotateX(360deg);
  transform: rotateX(360deg);
  color: #fff; }

.insta_btn2:hover {
  color: #fff; }

/*Contact Form 7カスタマイズ*/
/*見出し欄*/
.inquiry {
  width: 100%; }

.inquiry th {
  text-align: left;
  font-size: 14px;
  color: #444;
  padding-right: 5px;
  width: 30%;
  background: #f7f7f7;
  border: solid 1px #d7d7d7; }

/*通常欄*/
.inquiry td {
  font-size: 13px;
  border: solid 1px #d7d7d7; }

/*横の行とテーブル全体*/
.entry-content .inquiry tr, .entry-content table {
  border: solid 1px #d7d7d7; }

/*必須の調整*/
.haveto {
  font-size: 7px;
  padding: 5px;
  background: #C30000;
  color: #fff;
  border-radius: 2px;
  margin-right: 5px;
  position: relative;
  bottom: 1px; }

/*任意の調整*/
.any {
  font-size: 7px;
  padding: 5px;
  background: #93c9ff;
  color: #fff;
  border-radius: 2px;
  margin-right: 5px;
  position: relative;
  bottom: 1px; }

/*ラジオボタンを縦並び指定*/
.verticallist .wpcf7-list-item {
  display: block; }

/*送信ボタンのデザイン変更*/
#formbtn {
  padding: 15px;
  max-width: 350px;
  background: #005DB6;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  border: none;
  margin: 25px auto;
  display: block; }

/*送信ボタンマウスホバー時*/
#formbtn:hover {
  background: #fff;
  color: #005DB6;
  border: 2px solid #005DB6; }

.wpcf7c-btn-confirm {
  padding: 15px;
  max-width: 350px;
  background: #5FA93F;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  border: none;
  margin: 25px auto;
  display: block; }

/*送信ボタンマウスホバー時*/
.wpcf7c-btn-confirm:hover {
  background: #fff;
  color: #5FA93F;
  border: 2px solid #5FA93F; }

.wpcf7c-btn-back {
  padding: 15px;
  max-width: 350px;
  background: #1D89D0;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  border: none;
  margin: 25px auto;
  display: block; }

/*送信ボタンマウスホバー時*/
.wpcf7c-btn-confirm:back {
  background: #fff;
  color: #1D89D0;
  border: 2px solid #1D89D0; }

.spam-c {
  text-align: center; }

/*スマホContact Form 7カスタマイズ*/
@media only screen and (max-width: 500px) {
  .inquiry th, .inquiry td {
    display: block;
    width: 100%;
    border-top: none;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box; }
    .inquiry th .textsp, .inquiry th .mailsp, .inquiry th .content, .inquiry td .textsp, .inquiry td .mailsp, .inquiry td .content {
      width: 100%; }

  .inquiry tr:first-child th {
    border-top: 1px solid #d7d7d7; }

  /* 必須・任意のサイズ調整 */
  .inquiry .haveto, .inquiry .any {
    font-size: 10px; } }
.iziModal {
  background: #000 !important; }

.close {
  background: rgba(0, 0, 0, 0.4);
  display: inline-block;
  padding: 0.5rem; }
  .close a {
    color: #fff;
    font-size: 1rem;
    text-align: right; }

table.s-form th {
  width: 30%; }
table.s-form th span.must {
  color: #CD0003; }

.pic_hover1 img {
  transition: 1s; }

.pic_hover1:hover img {
  opacity: 0.5; }

.pic_hover2, .pic_hover3, .pic_hover4, .pic_hover5, .pic_hover6 {
  overflow: hidden;
  display: block; }

.pic_hover2 img {
  -webkit-transform: scale(1);
  transform: scale(1);
  -webkit-transition: .3s ease-in-out;
  transition: .3s ease-in-out; }

.pic_hover2:hover img {
  -webkit-transform: scale(1.3);
  transform: scale(1.3); }

.pic_hover3 img {
  -webkit-filter: blur(3px);
  filter: blur(3px);
  -webkit-transition: .2s ease-in-out;
  transition: .2s ease-in-out;
  transform: scale(1.1); }

.pic_hover3:hover img {
  -webkit-filter: blur(0);
  filter: blur(0); }

.pic_hover4 img {
  -webkit-filter: grayscale(100%);
  filter: grayscale(100%);
  -webkit-transition: .3s ease-in-out;
  transition: .3s ease-in-out; }

.pic_hover4:hover img {
  -webkit-filter: grayscale(0);
  filter: grayscale(0); }

.pic_hover5 img {
  -webkit-filter: grayscale(0) blur(0);
  filter: grayscale(0) blur(0);
  -webkit-transition: .3s ease-in-out;
  transition: .3s ease-in-out; }

.pic_hover5:hover img {
  -webkit-filter: grayscale(100%) blur(3px);
  filter: grayscale(100%) blur(3px); }

.pic_hover6 {
  background: #002C73; }

.pic_hover6 img {
  transition: 1s; }

.pic_hover6:hover img {
  opacity: 0.5; }

img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover; }

img.size-maru {
  border-radius: 50%;
  width: 80%;
  height: 80%;
  display: block;
  margin: 2rem auto; }

.h-100 {
  height: 100%; }

.left-rad, .left-rad2 {
  border-top-left-radius: 18px;
  border-bottom-left-radius: 18px; }
  @media (max-width: 768px) {
    .left-rad, .left-rad2 {
      border-top-right-radius: 18px;
      border-bottom-left-radius: 0px; } }

@media (max-width: 768px) {
  .left-rad2 {
    border-top-right-radius: 0px;
    border-top-left-radius: 0px;
    border-bottom-left-radius: 18px;
    border-bottom-right-radius: 18px; } }

.right-rad, .right-rad2 {
  border-top-right-radius: 18px;
  border-bottom-right-radius: 18px; }
  @media (max-width: 768px) {
    .right-rad, .right-rad2 {
      border-top-right-radius: 0px;
      border-bottom-right-radius: 18px;
      border-bottom-left-radius: 18px; } }

@media (max-width: 768px) {
  .right-rad2 {
    border-top-right-radius: 18px;
    border-top-left-radius: 18px;
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px; } }

.sdw {
  box-shadow: 0 0px 8px 0 rgba(0, 0, 0, 0.4); }

.border1 {
  border: 1px solid #333; }

.border2 {
  border-top: 6px double #333;
  border-bottom: 6px double #333;
  padding: 1rem; }

.marker {
  background: linear-gradient(transparent 50%, #ffcc00 50%);
  display: inline;
  /* 背景の繰り返しを停止 */
  background-repeat: no-repeat;
  /* マーカーの横方向を0にして縮める */
  background-size: 0% 100%;
  /* マーカーが引かれる速度を指定 */
  transition: background-size 1.5s; }

/* マーカーが引かれる際に付与するクラス */
.marker.on {
  /* 横方向を100%にして、マーカーを引く */
  background-size: 100% 100%; }

.gmap {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
  border: 8px solid #fff; }

.gmap iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%; }

.review-box {
  display: none !important; }

/*========= LoadingのためのCSS ===============*/
/* Loading背景画面設定　*/
#splash {
  /*fixedで全面に固定*/
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 999;
  background: #fff;
  text-align: center;
  color: #fff;
  height: 100vh;
  height: 100dvh;
  overflow-y: auto; }

/* Loading画像中央配置　*/
#splash_logo {
  height: 80vh;
  position: relative; }
  #splash_logo img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); }

/* Loading アイコンの大きさ設定　*/
#splash_logo img {
  width: 320px; }

/* fadeUpをするアイコンの動き */
.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px); }
  to {
    opacity: 1;
    transform: translateY(0); } }
.sidebar .view-all {
  display: block;
  text-align: center;
  background: #37B500;
  color: #fff;
  padding: 1rem;
  border-radius: 8px; }
.sidebar .title {
  font-weight: bold;
  font-size: 18px; }
.sidebar .cate {
  list-style: none; }
  .sidebar .cate li {
    display: inline-block;
    margin: 0 1rem 1rem 0;
    border: 1px solid #37B500; }
    .sidebar .cate li a {
      color: #37B500;
      padding: 0 0.4rem; }

.policybox {
  border: 2px solid #DCDCDC;
  padding: 0.8rem;
  height: 300px;
  overflow: auto;
  font-size: 0.9rem; }
  .policybox p {
    margin: 0.5rem auto; }

.header {
  width: 100%;
  background-image: linear-gradient(rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0));
  z-index: 999; }

.site-header .header {
  position: fixed;
  top: 0;
  transition: .5s; }

.site-header.hide .header {
  transform: translateY(-100%); }

.header_inner {
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between; }

h1 {
  margin: 0 0 0 1rem; }

.logo img {
  width: 100%;
  height: auto;
  max-height: 50px;
  margin-left: 16px; }
  @media (max-width: 768px) {
    .logo img {
      width: auto;
      height: 40px;
      margin-left: 0px; } }

.title {
  font-size: 2rem;
  font-weight: 600; }

@media only screen and (max-width: 990px) {
  .header_inner {
    height: 70px; }

  .nav {
    position: fixed;
    right: -130%;
    /* 右から出てくる */
    top: 0;
    width: 100vw;
    /* スマホに収まるサイズ */
    height: 100vh;
    padding-top: 70px;
    background-color: #fff;
    transition: all .6s;
    z-index: 200;
    overflow-y: auto;
    /* メニューが多くなったらスクロールできるように */ }

  .hamburger {
    background: rgba(0, 0, 0, 0.5);
    position: fixed;
    right: 10px;
    top: 16px;
    width: 40px;
    /* クリックしやすい幅 */
    height: 40px;
    /* クリックしやすい高さ */
    cursor: pointer;
    z-index: 300; }

  .nav_list {
    margin: 0;
    padding: 0;
    list-style: none;
    width: 100%; }

  .nav_item {
    padding: 0 14px; }

  .nav_item a {
    display: block;
    padding: 1rem;
    border-bottom: 1px solid #eee;
    text-decoration: none;
    color: #333;
    font-weight: bold;
    font-size: 16px; }
    .nav_item a span {
      display: block;
      font-size: 10px;
      font-weight: normal; }

  .nav_item a:hover {
    background-color: #eee; }

  .nav_list li.nav-contact {
    text-align: center !important; }
    .nav_list li.nav-contact a {
      color: #fff;
      background: #0076C5; }
      .nav_list li.nav-contact a span {
        display: inline;
        margin-left: 1rem;
        font-weight: bold;
        font-size: 16px; }

  .hamburger_border {
    position: absolute;
    left: 11px;
    width: 18px;
    height: 2px;
    background-color: #fff;
    transition: all .6s; }

  .hamburger_border_top {
    top: 14px; }

  .hamburger_border_center {
    top: 20px; }

  .hamburger_border_bottom {
    top: 26px; }

  .black_bg {
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    z-index: 100;
    background-color: #333;
    opacity: 0;
    visibility: hidden;
    transition: all .6s;
    cursor: pointer; }

  /* 表示された時用のCSS */
  .nav-open .nav {
    right: 0; }

  .nav-open .black_bg {
    opacity: .8;
    visibility: visible; }

  .nav-open .hamburger_border_top {
    transform: rotate(45deg);
    top: 20px; }

  .nav-open .hamburger_border_center {
    width: 0;
    left: 50%; }

  .nav-open .hamburger_border_bottom {
    transform: rotate(-45deg);
    top: 20px; } }
/* sp */
@media only screen and (min-width: 991px) {
  .header_inner {
    width: 100%;
    margin-left: auto;
    margin-right: auto; }

  nav {
    height: 70px; }

  .nav_list {
    display: flex;
    text-align: right;
    margin: 0;
    height: 70px; }

  .nav_list li {
    text-align: right; }

  .nav_list li a {
    color: #fff;
    font-weight: 600;
    display: block;
    padding: 15px 24px 0 24px;
    height: 70px;
    transition: 0.5s;
    font-size: 24px;
    letter-spacing: 0.1rem;
    line-height: 1.4rem; }
    .nav_list li a span {
      display: block;
      font-size: 12px;
      font-weight: normal; }

  .nav_list li a:hover {
    background: #009A5F;
    color: #fff; }

  .nav_list li.nav-contact {
    text-align: center !important; }
    .nav_list li.nav-contact a {
      color: #fff;
      padding: 10px 16px 0 16px !important; }
    .nav_list li.nav-contact i {
      font-size: 30px; } }
/* pc */
/* Scss Document */
.text-c {
  text-align: center; }

.text-r {
  text-align: right; }

.font-xs {
  font-size: 0.7rem; }

.font-s {
  font-size: 0.8rem; }

.font-l {
  font-size: 1.2rem; }

.font-xl {
  font-size: 1.6rem; }

.font-xxl {
  font-size: 3.5rem; }

.bold {
  font-weight: bold; }

h1, h2, h3, h4, h5 {
  font-weight: bold; }

h1, h2 {
  font-size: 32px; }

h3 {
  font-size: 26px; }

h4, h5 {
  font-size: 20px; }

h2 {
  margin: 2rem auto; }

.bold {
  font-weight: bold; }

.title1 {
  position: relative;
  display: inline-block;
  padding: 0 55px;
  margin-bottom: 1.5rem;
  font-weight: bold;
  font-size: 1.2rem; }

.title1:before, .title1:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 45px;
  height: 1px;
  background-color: black; }

.title1:before {
  left: 0; }

.title1:after {
  right: 0; }

/* Scss Document */
.top-head {
  position: relative;
  height: 100vh;
  background: url(images/hero1.jpg) no-repeat 0 0/cover; }
  .top-head .h-text {
    text-align: center;
    width: 90%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    font-weight: bold;
    font-size: 50px;
    z-index: 10;
    line-height: 3.5rem; }
    @media (max-width: 768px) {
      .top-head .h-text {
        font-size: 40px; } }
    .top-head .h-text span {
      font-size: 10px;
      border: 1px solid #fff;
      padding: 4px 8px;
      font-weight: normal;
      letter-spacing: .2rem; }

.zoom-fade {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  margin: 0 auto; }

.zoom-fade__item {
  height: 100vh;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover; }

.zoom-fade__item:first-child {
  background-image: url(images/s1.jpg); }

.zoom-fade__item:nth-child(2) {
  background-image: url(images/s2.jpg); }

.zoom-fade__item:nth-child(3) {
  background-image: url(images/s3.jpg); }

.zoom-fade__item:nth-child(4) {
  background-image: url(images/s4.jpg); }

.add-animation {
  /* アニメーション名 アニメーションにかかる時間 アニメーションの実行前後の状態 */
  /* zoom-fade 10秒 [実行前]最初のキーフレーム（0%） → [実行後]最後のキーフレーム（100%） */
  animation: zoom-fade 10s both; }

@keyframes zoom-fade {
  0% {
    /*transform: scale(1.05);*/
    transform: scale(1); }
  100% {
    /*transform: scale(1);*/
    transform: scale(1.1); } }
/* Scss Document */
.home-logo {
  max-width: 300px;
  height: auto;
  margin: auto; }
  @media (max-width: 768px) {
    .home-logo {
      margin-bottom: 20px; } }

p.name {
  text-align: right;
  margin-bottom: 0; }

.ceoname {
  display: inline !important;
  width: 250px !important; }

p.p-index {
  font-size: 1.3rem;
  border-bottom: 1px solid #ccc;
  padding-bottom: 8px;
  font-weight: bold;
  margin-top: 2rem; }

.box1 {
  background: #fff; }
  .box1 p {
    margin-bottom: 0;
    padding: 2rem; }
  .box1 .box1-title {
    font-weight: bold;
    font-size: 1.2rem;
    border-bottom: 1px solid #ececec;
    display: flex;
    align-items: center;
    padding: 1rem 0; }
    .box1 .box1-title p {
      padding: 0rem; }
    .box1 .box1-title .motto {
      padding: 0 2rem 0 1rem; }
    .box1 .box1-title .num {
      padding: 0;
      width: 50px;
      height: 50px;
      line-height: 50px;
      text-align: center;
      margin-left: 2rem; }

.mgrade {
  border: 1px solid #ccc;
  padding: 1.2rem; }
  .mgrade .mg-title {
    border-bottom: 1px solid #319C00;
    margin-bottom: 0.4rem; }
  .mgrade span {
    display: inline-block;
    background: #319C00;
    color: #fff;
    font-size: .9rem;
    padding: .3rem 1rem; }

.sikaku {
  width: 90%;
  margin: 0 auto;
  border-top: 1px #ececec dashed; }
  .sikaku li {
    text-align: center;
    padding: .7rem;
    border-bottom: 1px #ececec dashed; }

.timeline-item {
  padding: 2rem 1rem 1rem 2rem;
  position: relative;
  color: rgba(0, 0, 0, 0.7);
  border-left: 2px solid #ccc; }
  .timeline-item p {
    margin-bottom: 1rem; }
  .timeline-item::before {
    content: attr(date-is);
    position: absolute;
    left: 2em;
    font-weight: bold;
    top: 1em;
    display: block;
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: .785rem; }
  .timeline-item::after {
    width: 10px;
    height: 10px;
    display: block;
    top: 1em;
    position: absolute;
    left: -6px;
    border-radius: 10px;
    content: '';
    border: 2px solid #71BF00;
    background: #71BF00; }
  .timeline-item:last-child {
    border-image: linear-gradient(to bottom, #ccc 60%, rgba(204, 204, 204, 0)) 1 100%; }

.point {
  list-style: disc;
  padding-left: 1rem; }
  .point li {
    margin-bottom: 6px; }

.recruit {
  border: none; }
  .recruit th {
    white-space: nowrap; }
  .recruit th, .recruit td {
    border: none;
    border-bottom: 1px solid #ececec; }

footer {
  background-color: #242828;
  text-align: center;
  color: #fff;
  padding: 10px; }

.title-box h2 {
  letter-spacing: 0.1rem;
  font-size: 40px;
  line-height: 2rem; }
  .title-box h2 span {
    display: inline-block;
    font-size: 14px;
    font-weight: normal;
    background: #00A24B;
    color: #fff;
    padding: 0px 8px;
    line-height: 1.4rem; }

.form-table {
  font-size: 14px;
  border: none; }
  .form-table th, .form-table td {
    border: none; }
  .form-table input[type="text"], .form-table textarea {
    width: 100%; }
  .form-table .must {
    background: #EC0003;
    color: #fff;
    font-size: 11px;
    padding: 2px 4px;
    margin-left: 8px;
    border-radius: 3px;
    letter-spacing: 0.1rem; }

#map_clip {
  overflow: hidden;
  position: relative;
  max-width: 600px;
  height: 500px; }

#map_clip iframe {
  position: absolute;
  inset: -150px;
  width: calc(100% + 300px);
  height: calc(100% + 300px); }

/*フォームボタン*/
.s_button {
  border: none;
  background: #ccc;
  color: #fff;
  width: 240px;
  text-align: center;
  padding: 10px;
  font-size: 18px;
  cursor: not-allowed; }

.s_button:enabled {
  background-color: #37B500;
  /* 有効時の背景色 */
  cursor: pointer; }

.s-check label {
  cursor: pointer; }

/* Scss Document */
#footer {
  font-size: 90%; }

.fnavi {
  list-style: none; }
  .fnavi li {
    float: left; }
    .fnavi li a {
      color: #333;
      display: block;
      padding: 4px 10px;
      -webkit-transition: 0.4s;
      -moz-transition: 0.4s;
      -o-transition: 0.4s;
      -ms-transition: 0.4s;
      transition: 0.4s; }
    .fnavi li a:hover {
      background: rgba(0, 0, 0, 0.1); }

.footer-logo {
  text-align: center; }
  .footer-logo a {
    display: block;
    text-align: center;
    margin: auto; }
    .footer-logo a img {
      margin: auto;
      max-width: 200px; }

.phone {
  font-size: 30px;
  line-height: 30px; }
  .phone span {
    color: #333;
    font-size: 14px; }

.foot-map {
  margin-bottom: 3rem; }
  .foot-map a {
    color: #333;
    padding: 0 1.2rem; }

/*========= ページトップのためのCSS ===============*/
/*リンクの形状*/
#page-top a {
  display: block;
  background: #fff;
  border-radius: 5px;
  border: 1px solid #37B500;
  width: 60px;
  height: 60px;
  color: #37B500;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none;
  font-size: 0.6rem;
  line-height: 0.8rem;
  transition: all 0.3s; }
  #page-top a i {
    font-size: 1rem;
    margin-top: 8px; }

#page-top a:hover {
  background: #37B500;
  color: #fff; }

/*リンクを右下に固定*/
#page-top {
  position: fixed;
  right: 10px;
  bottom: 10px;
  z-index: 2;
  /*はじめは非表示*/
  opacity: 0;
  transform: translateY(100px); }

/*　上に上がる動き　*/
#page-top.UpMove {
  animation: UpAnime 0.5s forwards; }

@keyframes UpAnime {
  from {
    opacity: 0;
    transform: translateY(100px); }
  to {
    opacity: 1;
    transform: translateY(0); } }
/*　下に下がる動き　*/
#page-top.DownMove {
  animation: DownAnime 0.5s forwards; }

@keyframes DownAnime {
  from {
    opacity: 1;
    transform: translateY(0); }
  to {
    opacity: 1;
    transform: translateY(100px); } }
