@charset "utf-8";

@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700,900|Noto+Serif+JP:200,300,400,500,600,700,900&display=swap&subset=japanese");
@import url("https://fonts.googleapis.com/css2?family=Zen+Old+Mincho:wght@400;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Bellefair&display=swap");

/*	レイアウト
---------------------------------*/
html {
  font-size: 62.5%;
}
body {
  padding: 90px 0 0;
  width: 100%;
  color: #333;
  line-height: 1.6;
  background: #faf9ff;
  font-family: "Noto Sans JP", sans-serif;
}
#wrapper {
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  body {
    padding: 84px 0 0;
  }
}

/*	ヘッダー
---------------------------------*/
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background:#faf9ff;
  line-height: 1;
  z-index: 1010;
}
.hd-inr {
  position: relative;
  margin: 0 auto;
  padding: 0 15px;
  width: 100%;
  max-width: 1710px;
}
.hd-logo {
  margin: 0;
  padding: 0;
}
.hd-info {
  padding: 0;
}
.hd-tel {
  display: block;
  margin: 0 0 10px;
  text-align: center;
  line-height: 1;
}
.hd-tel a span {
  display: inline-block;
  position: relative;
  padding: 0 0 0 20px;
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  white-space: nowrap;
  font-family: "Arial", sans-serif;
}
.hd-tel a span::before {
  content: "";
  position: absolute;
  top: calc(50% - 7px);
  left: 0;
  width: 15px;
  height: 15px;
  background: url(../img/cmn/icon_tel.png) no-repeat center center;
}
.hd-mail {
  display: block;
  margin: 0 0 0 auto;
  width: 140px;
  text-align: center;
}
.hd-mail a {
  display: block;
  width: 100%;
  background: #e20d0d;
  text-align: center;
}
.hd-mail a span {
  display: inline-block;
  padding: 0;
  font-size: 14px;
  color: #fff;
  line-height: 30px;
}
@media screen and (max-width: 1279px) {
  .hd-inr {
    padding: 0 15px;
  }
  .hd-logo {
    margin: 0;
    padding: 20px 0;
  }
  .hd-info {
    padding: 0;
  }
  .hd-contact {
    display: flex;
    margin: 0 10px 0 0;
  }
  .hd-tel {
    display: block;
    margin: 0 10px;
    width: auto;
  }
  .hd-tel a {
    display: block;
    position: relative;
    padding: 0;
    width: 40px;
    height: 40px;
    border: 1px solid #333;
  }
  .hd-tel a:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    margin: 0;
    width: 20px;
    height: 20px;
    background: url(../img/cmn/icon_tel.png) no-repeat center center;
    background-size: contain;
  }
  .hd-tel a span {
    display: none;
  }
  .hd-mail {
    display: block;
    margin: 0;
    width: auto;
  }
  .hd-mail a {
    display: block;
    position: relative;
    padding: 0;
    width: 40px;
    height: 40px;
  }
  .hd-mail a:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    margin: 0;
    width: 20px;
    height: 20px;
    background: url(../img/cmn/icon_mail.png) no-repeat center center;
    background-size: contain;
  }
  .hd-mail a span {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .hd-logo {
    margin: 0;
    max-width: 180px;
  }
  .hd-info {
    padding: 0;
    width: calc(100% - 180px);
  }
  .hd-contact {
    padding: 0;
  }
}

/*	フッター
---------------------------------*/
footer {
  position: relative;
  padding: 0;
}

.ft-inr {
  padding-top: 50px;
  padding-bottom: 100px;
}
.ft-logo h2 {
  margin: 0 0 25px;
}
.ft-logo p {
  font-size: 1.4rem;
}
.ft-nav > ul {
}
.ft-nav > ul > li {
  position: relative;
  margin: 0 0 0 80px;
  font-size: 1.6rem;
  line-height: 1;
}
.ft-nav > ul > li:first-of-type {
  margin-left: 0;
}
.ft-nav > ul > li li {
  position: relative;
  margin: 15px 0 0;
  width: 1px;
  font-size: 1.4rem;
  line-height: 1;
  white-space: nowrap;
}
.ft-nav > ul > li li:first-of-type {
  margin-top: 20px;
}
.ft-copyright {
  padding: 50px 0 0;
  width: 100%;
  text-align: center;
  font-size: 1.2rem;
}

footer.top-page {
  background:#faf9ff;
}
.ft-logo h2 {
  color: #333;
}
footer.top-page .ft-logo p {
  color: #333;
}
footer.top-page .ft-nav > ul > li {
  color: #333;
}
footer.top-page {
}
footer.top-page .ft-copyright {
  color: #333;
}

@media screen and (max-width: 1440px) {
  .ft-nav > ul > li {
    margin: 0 0 0 75px;
  }
}
@media screen and (max-width: 1279px) {
  .ft-logo {
    margin: 0 0 40px;
    width: 100%;
    text-align: center;
  }
  .ft-nav {
    display: inline-block;
    margin: auto;
  }
}
@media screen and (max-width: 767px) {
  footer {
    position: relative;
    padding: 0;
  }
  .btn-pagetop {
    width: 40px;
  }
  .ft-inr {
    padding-top: 30px;
    padding-bottom: 20px;
    text-align: center;
  }
  .ft-logo {
    width: 100%;
  }
  .ft-logo h2 {
    margin: 0 auto 20px;
    width: 150px;
  }
  .ft-logo p {
    font-size: 1.4rem;
  }
  .ft-nav {
    display: none;
  }
  .ft-copyright {
    padding: 0;
    width: 100%;
    text-align: center;
    font-size: 1.2rem;
  }
}

/*	グローバナビ（PC用）
---------------------------------*/
.pc-nav {
  line-height: 1;
}
.pc-nav > ul {
  margin: 0 70px 0 0;
}
.pc-nav > ul > li {
  position: relative;
  margin: 0 0 0 50px;
  padding: 0;
  height: 90px;
}
.pc-nav > ul > li > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  position: relative;
  padding: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  font-weight: 400;
}
.pc-nav > ul > li > a span {
  position: relative;
  font-size: 16px;
}
.pc-nav > ul > li.parent div {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  padding: 20px;
  max-height: 0;
  background: rgba(0, 0, 0, 0.7);
  text-align: center;
  color: #fff;
  z-index: 100;
  opacity: 0;
  overflow: hidden;
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.pc-nav > ul > li.parent div ul {
  display: inline-block;
}
.pc-nav > ul > li.parent div li {
}
.pc-nav > ul > li.parent div li a {
  display: block;
  padding: 10px 0;
  text-align: left;
  font-size: 14px;
  white-space: nowrap;
}
.pc-nav > ul > li.parent:hover div {
  max-height: 300px;
  opacity: 1;
}
@media screen and (max-width: 1440px) {
  .pc-nav > ul {
    margin: 0 30px 0 0;
  }
  .pc-nav > ul > li {
    margin: 0 0 0 40px;
  }
}
@media screen and (max-width: 1279px) {
  .pc-nav {
    display: none;
  }
}

/*	グローバナビ（スマホ用）
---------------------------------*/
header .navToggle,
header nav.sp-nav {
  display: none;
}
@media screen and (max-width: 1279px) {
  header nav.sp-nav {
    display: block;
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    padding: 10% 15%;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
    font-size: 1.6rem;
    font-weight: 400;
    z-index: 1000;
    visibility: hidden;
    opacity: 0;
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    -webkit-transition: -webkit-transform 0.2s, opacity 0.2s, visibility 0s 0.2s;
    transition: transform 0.2s, opacity 0.2s, visibility 0s 0.2s;
  }
  /* ナビゲーション アニメーション */
  header.open nav.sp-nav {
    visibility: visible;
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transition: -webkit-transform 0.4s, opacity 0.4s;
    transition: transform 0.4s, opacity 0.4s;
  }
  header nav.sp-nav a {
    color: #fff;
  }
  header nav.sp-nav a * {
    transition: 0s;
  }
  header nav.sp-nav > ul {
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 100%;
  }
  header nav.sp-nav > ul > li {
    margin: 20px 0;
    overflow: hidden;
    text-align: center;
    line-height: 1;
    text-transform: uppercase;
  }
  header nav.sp-nav > ul > li > a {
    display: inline-block;
  }
  header nav.sp-nav > ul > li.parent {
    margin: 25px 0;
  }
  header nav.sp-nav > ul > li.parent > a {
    text-decoration: none;
    border: none;
  }
  header nav.sp-nav > ul > li.parent div ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding: 5px 0 0;
  }
  header nav.sp-nav > ul > li.parent div li {
    margin: 10px 0 0;
    font-size: 0.875em;
  }
  header nav.sp-nav > ul > li.parent div li a {
    display: inline-block;
    color: #ccc;
  }
  header nav.sp-nav > ul > li.parent div li a:hover {
    display: inline-block;
    border-bottom: none;
  }
  header nav.sp-nav > ul > li.parent div li:last-of-type {
    margin: 10px 0 0;
  }
  header nav.sp-nav > ul > li.parent div li::after {
    content: "/";
    display: inline;
    margin: 0 5px;
    color: #999;
  }
  header nav.sp-nav > ul > li.parent div li:last-of-type::after {
    content: "";
  }
  header nav.sp-nav ul li small,
  header nav.sp-nav ul li br {
    display: none;
  }
  /*ハンバーガーボタン*/
  header .navToggle {
    display: block;
    position: relative;
    margin: 0;
    width: 40px;
    height: 40px;
    border: 1px solid #333;
    cursor: pointer;
    z-index: 1002;
  }
  header .navToggle div {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    width: 25px;
    height: 16px;
  }
  header .navToggle span {
    display: block;
    position: absolute;
    height: 2px;
    width: 100%;
    background: #333;
    left: 0;
    -webkit-transition: 0.35s ease-in-out;
    -moz-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
  }
  header .navToggle span:nth-child(1) {
    top: 0;
  }
  header .navToggle span:nth-child(2) {
    top: 7px;
  }
  header .navToggle span:nth-child(3) {
    top: 14px;
  }
  /* ハンバーガーボタン 切り替えアニメーション */
  header.open .navToggle span {
  }
  header.open .navToggle span:nth-child(1) {
    top: 7px;
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg);
    background: #faf9ff;;
  }
  header.open .navToggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  header.open .navToggle span:nth-child(3) {
    top: 7px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg);
    background: #faf9ff;;
  }
}
@media screen and (max-width: 767px) {
  header nav.sp-nav {
    font-size: 14px;
  }
}

/*	基本レイアウト
---------------------------------*/
.contents-inr {
  position: relative;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
  max-width: 1230px;
}
.contents-inr.small {
  max-width: 1110px;
}
.contents-inr.large {
  max-width: 1470px;
}
.contents-inr.exlarge {
  max-width: 1710px;
}
.contents-inr.full {
  position: relative;
  margin: 0 auto;
  padding-left: 0;
  padding-right: 0;
  max-width: 100%;
}

/*	汎用タイトル
---------------------------------*/
.ttl-cmn01 {
  margin: 0 0 40px;
}
.ttl-cmn01.center {
  text-align: center;
}
.ttl-cmn01 > strong {
  display: inline-block;
  position: relative;
  font-size: 8rem;
  font-weight: 400;
  font-family: "Zen Old Mincho", serif;
  line-height: 1.2;
}
.ttl-cmn01.large > strong {
  font-size: 9rem;
}
.ttl-cmn01.bold > strong {
  font-weight: 900;
}
.ttl-cmn01 > strong span {
  display: block;
  font-size: 11rem;
  font-weight: 900;
}
.ttl-cmn01 > strong img:first-of-type {
  display: inline-block;
  position: absolute;
  left: -70px;
  top: -40px;
  z-index: 1;
}
.ttl-cmn01 > strong img:last-of-type {
  display: inline-block;
  position: absolute;
  right: -45px;
  bottom: -70px;
  z-index: 1;
}
.ttl-cmn01.large > strong img:last-of-type {
  right: -15px;
}
.ttl-cmn01 > span {
  display: block;
  position: relative;
  margin: 20px 0 0;
  font-size: 1.6rem;
  z-index: 2;
}
.ttl-cmn01.large > span {
  margin: 50px 0 0;
}
.ttl-cmn01.bold > span {
  margin: 60px 0 0;
}
@media screen and (max-width: 767px) {
  .ttl-cmn01 {
    margin: 0 0 20px;
  }
  .ttl-cmn01 > strong {
    font-size: 4rem;
  }
  .ttl-cmn01.large > strong {
    font-size: 4rem;
  }
  .ttl-cmn01.bold > strong {
    font-size: 3rem;
    letter-spacing: -0.08em;
  }
  .ttl-cmn01.bold > strong {
    font-weight: 900;
  }
  .ttl-cmn01 > strong span {
    font-size: 5rem;
  }
  .ttl-cmn01.large > strong img:last-of-type {
    right: -15px;
  }
  .ttl-cmn01 > span {
    margin: 10px 0 0;
    font-size: 1.6rem;
  }
  .ttl-cmn01.large > span {
    margin: 20px 0 0;
  }
  .ttl-cmn01.bold > span {
    margin: 30px 0 0;
  }
  .ttl-cmn01 > strong img:first-of-type {
    width: 62px;
    left: -18px;
    top: -20px;
  }
  .ttl-cmn01 > strong img:last-of-type {
    width: 62px;
    right: -18px;
    bottom: -50px;
  }
}

/*	汎用ボタン
---------------------------------*/
.btn-cmn01 {
  margin: 0;
  width: 100%;
  max-width: 230px;
  text-align: center;
}
.btn-cmn01.center {
  margin: auto;
}
.btn-cmn01.cen {
    margin: 60px auto 0;
    max-width: 300px;
}
.btn-cmn01 p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  position: relative;
  padding: 0;
  width: 100%;
  height: 60px;
  border-top: 1px solid #df1f41;
  border-bottom: 1px solid #df1f41;
  text-align: center;
}
.btn-cmn01 p span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  position: relative;
  padding: 0;
  width: 100%;
  height: 50px;
  border-left: 1px solid #df1f41;
  border-right: 1px solid #df1f41;
  font-size: 16px;
  color: #df1f41;
}
.btn-cmn01.col01 p {
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}
.btn-cmn01.col01 p span {
  border-left: 1px solid #fff;
  border-right: 1px solid #fff;
  color: #fff;
}
.btn-cmn02 {
  margin: 0;
  width: 100%;
  max-width: 360px;
  text-align: center;
}
.btn-cmn02.center {
  margin: auto;
}
.btn-cmn02 span {
  display: inline-block;
  position: relative;
  padding: 0 50px;
  width: 100%;
  background: url(../img/cmn/icon_arw01.png) no-repeat right 25px center;
  border: 1px solid #df1f41;
  text-align: center;
  font-size: 24px;
  color: #df1f41;
  line-height: 78px;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 767px) {
  .btn-cmn01 p {
    height: 50px;
  }
  .btn-cmn01 p span {
    height: 40px;
    font-size: 16px;
  }
  .btn-cmn02 span {
    padding: 0 50px;
    background: url(../img/cmn/icon_arw01.png) no-repeat right 25px center;
    font-size: 16px;
    line-height: 58px;
  }
}

/*	メインイメージ
---------------------------------*/
.main-img-otr {
  position: relative;
}
.main-img-inr {
  margin: 0 auto;
  padding: 0;
  max-width: 100%;
  background: #00b0f2;
  z-index: 1001;
}
.main-img {
  position: relative;
  width: 100%;
  height: 1110px;
  background: no-repeat right center;
}
.main-img.img01 {
  background-image: url(../img/top/img_main.jpg);
}
.main-img.img02 {
  background-image: url(../img/top/img_main02.jpg);
}
.main-img.img03 {
  background-image: url(../img/top/img_main03.jpg);
}
.main-img-cap {
  position: absolute;
  top: 70.6%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  padding: 0 75px;
  width: 100%;
  max-width: 1680px;
  text-align: left;
  z-index: 1001;
}
@media screen and (max-width: 1279px) {
  .main-img {
    height: 80vw;
    background: no-repeat right -5vw top / cover;
  }
  .main-img-cap {
    position: absolute;
    top: 70.6%;
    padding: 0 15px;
  }
}
@media screen and (max-width: 767px) {
}

/*	トップページ
---------------------------------*/
/*MESSAGE*/
.top-message {
  background: #ececec;
}
.top-message-about {
  position: relative;
  width: 840px;
}
.top-message-cap {
  width: 180px;
}
.top-message-cap h3 {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  line-height: 1;
}
.top-message-cap h3 span {
  display: block;
  margin: 0 35px 0 0;
  font-size: 8rem;
  text-transform: uppercase;
  font-family: "Bellefair", serif;
  letter-spacing: 0.1em;
}
.top-message-cap h3 strong {
  display: block;
  font-size: 1.8rem;
  font-family: "Zen Old Mincho", serif;
}
.top-message-txt {
  padding: 90px;
  width: calc(100% - 180px);
  background:#faf9ff;
}
.top-message-txt h4 {
  margin: 0 0 20px;
}
.top-message-txt h4 strong {
  font-size: 3.6rem;
  font-family: "Zen Old Mincho", serif;
}
.top-message-txt > p {
  margin: 0 0 40px;
  font-size: 1.6rem;
  line-height: 2.5;
}
.top-message figure {
  position: relative;
  width: calc(100% - 840px);
  height: 890px;
}
.top-message figure img {
  position: absolute;
  top: 0;
  left: -360px;
  max-width: none;
  max-width: initial;
}
@media screen and (max-width: 1279px) {
  .top-message-about {
    position: relative;
    width: 100%;
  }
  .top-message-cap {
    width: 100%;
  }
  .top-message-cap h3 {
    margin: 0 0 25px;
    -ms-writing-mode: initial;
    writing-mode: initial;
  }
  .top-message-cap h3 strong {
    margin: 0 0 25px;
  }
  .top-message-txt {
    width: 100%;
  }
  .top-message figure {
    margin: 0 0 25px;
    width: 100%;
    height: auto;
  }
  .top-message figure img {
    position: relative;
    top: 0;
    left: -15px;
    max-width: 100vw;
  }
}
@media screen and (max-width: 767px) {
  .top-message-cap h3 span {
    font-size: 4rem;
  }
  .top-message-cap h3 strong {
    font-size: 1.6rem;
  }
  .top-message-txt {
    padding: 30px 20px;
  }
  .top-message-txt h4 {
    margin: 0 0 10px;
  }
  .top-message-txt h4 strong {
    font-size: 2.2rem;
  }
  .top-message-txt > p {
    margin: 0 0 20px;
    font-size: 1.6rem;
  }
}

/*	ABOUT	*/
.top-about {
  position: relative;
  padding: 100px 0 150px;
  color: #fff;
}
.top-about::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 480px;
  background: #df1f41;
  pointer-events: none;
  z-index: -1;
}
.top-about-list {
  margin: 140px 0 0;
}
.top-about figure {
  position: relative;
  width: calc(100% - 780px);
  height: 600px;
}
.top-about figure img {
  position: absolute;
  top: 0;
  right: -60px;
  max-width: none;
  max-width: initial;
}
.top-about .row-reverse figure img {
  right: auto;
  left: -60px;
}
.top-about-txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  position: relative;
  top: 60px;
  width: 780px;
  height: 600px;
  background:#faf9ff;
  text-align: center;
  color: #333;
  z-index: 10;
}
.top-about-txt h4 {
  margin: 0 0 30px;
}
.top-about-txt h4 strong {
  display: block;
  margin: 0 0 15px;
  font-size: 1.8rem;
  font-family: "Zen Old Mincho", serif;
}
.top-about-txt h4 span {
  display: block;
  font-size: 6rem;
  line-height: 1;
  text-transform: uppercase;
  font-family: "Bellefair", serif;
  letter-spacing: 0.1em;
}
.top-about-btn {
  margin: 0 0 40px;
}
.top-about-btn li {
  position: relative;
  margin: 0 5px 10px;
  width: 160px;
  background: linear-gradient(-35deg, #00aef0, #00aef0 50%, #00a5ee 50%, #00a5ee);
  background: linear-gradient(-35deg, #00aef0, #00aef0 50%, #00a5ee 50%, #00a5ee);
  background: linear-gradient(125deg, #00aef0, #00aef0 50%, #00a5ee 50%, #00a5ee);
}
.top-about-btn li span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  width: 100%;
  height: 120px;
  font-size: 1.6rem;
  line-height: 2;
  color: #fff;
}
@media screen and (max-width: 1279px) {
  .top-about {
    padding: 100px 0 50px;
  }
  .top-about figure {
    position: relative;
    width: 100%;
    height: auto;
  }
  .top-about figure img {
    position: relative;
    top: 0;
    right: 0;
    max-width: 100%;
  }
  .top-about .row-reverse figure img {
    right: auto;
    left: 0;
  }
  .top-about-txt {
    top: 0;
    padding: 40px;
    width: 100%;
    height: auto;
  }
}
@media screen and (max-width: 767px) {
  .top-about {
    padding: 50px 0;
  }
  .top-about::before {
    height: 340px;
  }
  .top-about-list {
    margin: 40px 0 0;
  }
  .top-about-txt h4 {
    margin: 0 0 20px;
  }
  .top-about-txt h4 strong {
    margin: 0 0 15px;
    font-size: 1.6rem;
  }
  .top-about-txt h4 span {
    font-size: 3rem;
  }
  .top-about-btn {
    margin: 0 0 20px;
    width: 100%;
  }
  .top-about-btn li {
    margin: 0 0 10px;
    width: 100%;
  }
}

/*	SERVICE	*/
.top-service {
  padding: 120px 0 0;
  background: #00b0f2;
  color: #fff;
}
.top-service-list {
  position: relative;
  width: 100%;
  z-index: 2;
}
.top-service li {
  position: relative;
  margin: 0;
  width: 50%;
  height: 540px;
  overflow: hidden;
}
.top-service li:last-of-type {
  position: relative;
  margin: 0;
  width: 100%;
  height: 420px;
}
.top-service li::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background: #e20d0d;
  z-index: 5;
  opacity: 0;
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.top-service li:hover::before {
  opacity: 1;
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.top-service-about {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  position: relative;
  padding: 15px;
  width: 100%;
  height: 100%;
}
.top-service-about::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  pointer-events: none;
}
.top-service-about img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
}
.top-service-about h3 {
  position: relative;
  margin: 0 0 40px;
  text-align: center;
  color: #fff;
  line-height: 1;
}
.top-service-about h3 strong {
  display: block;
  margin: 0;
  font-size: 3.6rem;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 1279px) {
  .top-service li {
    width: 100%;
    height: 420px;
  }
  .top-service li:last-of-type {
    width: 100%;
    height: 420px;
  }
}
@media screen and (max-width: 767px) {
  .top-service {
    padding: 50px 0 0;
  }
  .top-service li {
    position: relative;
    height: 240px;
  }
  .top-service li:last-of-type {
    height: 240px;
  }
  .top-service-about h3 {
    margin: 0 0 20px;
  }
  .top-service-about h3 strong {
    font-size: 1.8rem;
  }
}

/*	STAFF	*/
.link-list .top-staff-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.link-list .top-staff-item + .top-staff-item {
  margin-top: 0px;
}

.link-list .top-staff-item {
  width: 24%;
}
.link-list .top-staff-item figure {
  width: 100%;
}

.link-list .top-staff-about {
  width: 100%;
  height: 220px;
  background: #fafafa;
}

.link-list .top-staff-box {
  flex-direction: column;
  justify-content: flex-start;
}

.top-staff {
  position: relative;
  padding: 120px 0 150px;
  background: #00b0f2;
  color: #fff;
}
.top-staff-item {
  background:#faf9ff;
}
.top-staff-item + .top-staff-item {
  margin-top: 50px;
}
.top-staff-item figure {
  position: relative;
  width: calc(100% - 360px);
  height: 320px;
}
.top-staff-item figure img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.top-staff-about {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  position: relative;
  padding: 15px;
  width: 360px;
  height: 320px;
  color: #0b0b0b;
}
.top-staff-date {
  margin: 0;
  font-size: 1.8rem;
  font-family: "Zen Old Mincho", serif;
}
.top-staff-ttl {
  margin: 0 0 20px;
  font-size: 4rem;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 767px) {
  .link-list .top-staff-item {
    width: 48%;
    margin-bottom: 4%;
  }
}
@media screen and (max-width: 767px) {
  .top-staff {
    padding: 50px 0;
  }
  .top-staff-item figure {
    position: relative;
    width: 100%;
    height: 210px;
  }
  .top-staff-about {
    padding: 25px 15px;
    width: 100%;
    height: auto;
  }
  .top-staff-date {
    font-size: 1.6rem;
  }
  .top-staff-ttl {
    margin: 0 0 20px;
    font-size: 2rem;
  }
}

/*	DATA	*/
.top-data {
  position: relative;
  padding: 120px 0 145px;
  background: url(../img/top/bg_data.png) no-repeat center center / cover;
}
@media screen and (max-width: 767px) {
  .top-data {
    padding: 60px 0 65px;
  }
}

/*	CONTACT	*/
.top-contact {
  position: relative;
  padding: 125px 0;
}
.top-contact.top-page {
  background: #000;
}
.top-contact.top-page .ttl-cmn01.bold > strong {
  color: #fff;
}
.top-contact.top-page .ttl-cmn01.bold > span {
  color: #fff;
}
@media screen and (max-width: 767px) {
  .top-contact {
    padding: 65px 0;
  }
}

/*=============================
Sub(Lower)Page setting
===============================*/

/* visual
------------------------------*/
.top-contact.sub {
  background: #df1f41;
  padding: 80px;
}
.top-contact.sub .btn-cmn02 span {
  background: url(../img/cmn/icon_arw01.png) no-repeat right 25px center;
  border: 1px solid #fff;
  color: #fff;
}

/* visual
------------------------------*/
#sub_visual {
  height: 200px;
  background: #00b0f2;
}
#sub_visual h2 {
  text-align: center;
  padding-top: 90px;
  line-height: 140%;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  color: #fff;
}
#sub_visual h2 span {
  color: #fff;
  display: inline-block;
  font-size: 100px;
  position: absolute;
  right: 0px;
  opacity: 0.2;
  text-transform: uppercase;
  bottom: -70px;
  font-weight: 500;
  font-style: italic;
  font-family: "Bellefair", serif;
}
#sub_visual h2 small {
  font-weight: bold;
  font-family: "Zen Old Mincho", serif;
  font-size: 56px;
}

/* bread_crumb_list
------------------------------*/
#sub_contents .bread_crumb_list {
  margin: 10px 0px 60px 0px;
  text-align: left;
  font-size: 14px;
  color: #777;
}
#sub_contents .bread_crumb_list ul {
  margin: 0 auto;
  max-width: 1200px;
}
#sub_contents .bread_crumb li {
  display: inline;
  margin-left: 5px;
  text-transform: uppercase;
}
#sub_contents .bread_crumb li:after {
  content: "―";
  padding-left: 10px;
}
#sub_contents .bread_crumb li:last-child:after {
  content: "";
}
#sub_contents .bread_crumb li a {
  text-decoration: underline;
  margin-left: 0px;
}
#sub_contents .bread_crumb li a:hover {
  text-decoration: none;
}
#sub_contents .bread_crumb li.current {
  font-weight: bold;
}

/* sub_contents
------------------------------*/
#sub_contents {
  line-height: 180%;
  font-size: 16px;
}
#sub_contents section {
  margin: 0 auto 130px;
  max-width: 1200px;
  font-size: 16px;
}
#sub_contents h3 {
  position: relative;
  margin: 0px 0 100px;
}
#sub_contents h3 strong {
  font-size: 36px;
  padding: 0px 50px;
}
#sub_contents h3.sub {
  text-align: center;
  font-family: "Zen Old Mincho", serif;
  border-bottom: 1px solid #00b0f2;
  border-top: 1px solid #00b0f2;
  color: #00b0f2;
  padding: 25px 0px;
}
#sub_contents h3.sub span {
  font-size: 29px;
  font-weight: bold;
}
#sub_contents h3.sub.experience {
  color: #df1f41;
  border-bottom: 1px solid #df1f41;
  border-top: 1px solid #df1f41;
}
#sub_contents h4::before {
  background: #ebd800;
  height: 3px;
  width: 35px;
  position: absolute;
  top: 50%;
  left: 0px;
  content: "";
}
#sub_contents h5 {
  font-size: 20px;
  font-weight: bold;
  color: #ff7906;
  margin-bottom: 10px;
}
#sub_contents p {
  margin-bottom: 10px;
  font-size: 16px;
}
#sub_contents hr {
  margin: 30px auto 70px;
  border-color: #ddd;
  border-width: 0.5px;
}
#sub_contents ul.ulbox li {
  list-style-position: inside;
  list-style-type: disc;
  margin-bottom: 10px;
}
#sub_contents .sp {
  display: none;
}
#sub_contents .mb30 {
  margin-bottom: 30px;
}
#sub_contents .mb50 {
  margin-bottom: 50px;
}
#sub_contents .mb100 {
  margin-bottom: 100px;
}
#sub_contents .txt_cen {
  text-align: center;
  font-size: 22px;
  font-family: "Zen Old Mincho", serif;
  line-height: 180%;
}
#sub_contents .txt_cen b {
  font-weight: bold;
  color: #00b0f2;
  display: block;
  margin: 10px 0px;
}

/* staff
-------------------------*/
#sub_contents .staff_list li {
  width: 32%;
  background:#faf9ff;
  margin-bottom: 30px;
  padding: 35px 20px;
}
#sub_contents .staff_list li span {
  text-align: center;
  font-size: 22px;
  font-family: "Zen Old Mincho", serif;
  display: block;
  position: relative;
  margin-bottom: 30px;
  font-weight: bold;
}
#sub_contents .staff_list li span::after {
  position: absolute;
  left: 0;
  right: 0;
  width: 100px;
  height: 2px;
  margin: 0 auto;
  content: "";
  background: #00b0f2;
  bottom: -10px;
}
#sub_contents .staff_list li figure {
  text-align: center;
  margin: 10px auto 30px;
  display: block;
}
#sub_contents .staff_list li figure img {
  width: 140px;
}
#sub_contents .staff_list li i {
  font-style: normal;
  display: block;
  text-align: center;
  margin-bottom: 20px;
}
#sub_contents .staff_list li b {
  font-size: 60px;
  font-family: "Bellefair", serif;
  font-weight: 500;
  left: 0.5em;
  margin: 0px 10px;
}
#sub_contents .staff_list li small {
  font-weight: bold;
}
#sub_contents .staff_list li dl {
  width: 41%;
  margin-bottom: 8px;
  padding-bottom: 2px;
  border-bottom: 1px solid #fff;
}
#sub_contents .staff_list li .txtbox {
  background: #eaf9ff;
  padding: 30px;
}
#sub_contents .staff_list li .txtbox p {
  text-align: center;
  margin-bottom: 13px;
}
#sub_contents .fuki_ttl {
  background: #00b0f2;
  padding: 20px 35px;
  margin-bottom: 20px;
  font-family: "Zen Old Mincho", serif;
  color: #fff;
}
#sub_contents .fuki_ttl span {
  font-weight: bold;
  font-size: 24px;
  border-left: 5px solid #faeb00;
  padding-left: 15px;
}
#sub_contents .fuki_area {
  padding: 20px;
}
#sub_contents .fuki_area .txt_area {
  position: relative;
  display: inline-block;
  margin: 0px 0 1.5em 15px;
  padding: 30px 35px;
  width: 72%;
  background:#faf9ff;
  border: solid 1px #00b0f2;
  box-sizing: border-box;
}
#sub_contents .fuki_area figure {
  width: 25%;
  text-align: center;
}
#sub_contents .fuki_area figure img {
  text-align: center;
  margin: 0 auto;
  display: block;
  width: 100%;
}
#sub_contents .fuki_area figure figcaption {
  text-align: center;
  font-weight: bold;
}
#sub_contents .fuki_area .txt_area p {
  margin-bottom: 0px;
  font-size: 16px;
}

/* experience
-------------------------*/
#sub_contents .car_list.experience li {
  background: #df1f41;
}
#sub_contents .car_list.experience li:nth-child(2) {
  background: #ac4557;
}
#sub_contents .car_list.experience li:nth-child(3) {
  background: #df1f41;
}
#sub_contents .car_list.experience li:nth-child(4) {
  background: #ac4557;
}
#sub_contents .car_list.experience li:nth-child(5) {
  background: #df1f41;
}
#sub_contents .car_list.experience li:nth-child(6) {
  background: #ac4557;
}
#sub_contents .car_list.experience li:nth-child(7) {
  background: #df1f41;
}

/* inexperienced
-------------------------*/
#sub_contents .img_list li {
  width: 50%;
}
#sub_contents .car_list li {
  height: 300px;
  width: 16.5%;
  background: #00b0f2;
  padding: 30px 12px;
  position: relative;
}
#sub_contents .car_list li:nth-child(2) {
  height: 350px;
  background: #0097d0;
}
#sub_contents .car_list li:nth-child(3) {
  height: 400px;
  background: #00b0f2;
}
#sub_contents .car_list li:nth-child(4) {
  height: 450px;
  background: #0097d0;
}
#sub_contents .car_list li:nth-child(5) {
  height: 500px;
  background: #00b0f2;
}
#sub_contents .car_list li:nth-child(6) {
  height: 550px;
  background: #0097d0;
}
#sub_contents .car_list li:nth-child(7) {
  height: 600px;
  background: #00b0f2;
}
#sub_contents .car_list li span {
  font-size: 19px;
  font-weight: bold;
  text-align: center;
  display: block;
  color: #fff;
  border: 1px solid #fff;
  margin-bottom: 10px;
  font-family: "Zen Old Mincho", serif;
}
#sub_contents .car_list li b {
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  color: #fff;
  margin-bottom: 10px;
  font-family: "Zen Old Mincho", serif;
  position: absolute;
  top: -15px;
  margin: 0 auto;
  left: 0;
  right: 0;
  font-weight: bold;
  background: #111;
  width: 50%;
}
#sub_contents .car_list li p {
  color: #fff;
  font-size: 14px;
}

/* feature
-------------------------*/
#sub_contents .m_list li {
  margin-bottom: 30px;
}
#sub_contents .m_list li b {
  text-align: center;
  font-size: 40px;
  font-family: "Bellefair", serif;
  color: #00b0f2;
  display: block;
  margin-bottom: 10px;
}

/* message
-------------------------*/
#sub_contents .box_greeting {
  background: #f6f6f6;
  padding: 60px 75px;
}
#sub_contents .txt_gr {
  line-height: 300%;
  font-size: 17px;
}
#sub_contents .txt_gr small {
  text-align: right;
  display: block;
  font-weight: bold;
  font-family: "Zen Old Mincho", serif;
}
#sub_contents .txt_gr span {
  display: block;
  font-weight: bold;
  font-size: 26px;
  background: #111;
  color: #fff;
  padding: 5px 40px;
  margin-bottom: 20px;
  text-align: center;
  font-family: "Zen Old Mincho", serif;
}
#sub_contents .bg_rinen {
  background: #00b0f2;
  padding: 150px 0px 10px;
}
#sub_contents .bg_rinen h3 {
  margin-bottom: 120px;
  color: #fff;
}
#sub_contents .case_list {
  margin-top: 40px;
}
#sub_contents .case_list li {
  width: 32%;
  background: url(../img/greeting/icon_cnt01.png) no-repeat left 15px top 15px / 10px auto, url(../img/greeting/icon_cnt01.png) no-repeat left 15px bottom 15px / 10px auto,
    url(../img/greeting/icon_cnt01.png) no-repeat right 15px top 15px / 10px auto, url(../img/greeting/icon_cnt01.png) no-repeat right 15px bottom 15px / 10px auto;
  background-color: #faf9ff;
  padding: 45px 35px 35px;
  position: relative;
  margin-bottom: 55px;
}
#sub_contents .case_list li .top-cnt-no {
  display: block;
  font-size: 40px;
  font-weight: 500;
  font-family: "Bellefair", serif;
  position: absolute;
  top: -15px;
  right: 30px;
}
#sub_contents .case_list li .top-cnt-no::first-letter {
  color: #df1f41;
}
#sub_contents .case_list li p {
  font-size: 19px;
  font-family: "Zen Old Mincho", serif;
}
#sub_contents .case_list li p.top-cnt-info {
  font-family: "Bellefair", serif;
  font-size: 15px;
  color: #999;
  line-height: 120%;
}
#sub_contents .m_list li {
  width: 48%;
}
#sub_contents .m_list li span {
  font-size: 22px;
  font-family: "Zen Old Mincho", serif;
  text-align: center;
  display: block;
  margin-bottom: 15px;
  border-bottom: 2px solid #00b0f2;
  padding-bottom: 10px;
  font-weight: bold;
}
#sub_contents .m_list li figure {
  margin-bottom: 10px;
}

/* company
-------------------------*/
#sub_contents .c_box {
  background:#faf9ff;
  padding: 70px 50px;
}
#sub_contents .c_box small {
  font-size: 29px;
  font-weight: bold;
  font-family: "Zen Old Mincho", serif;
  text-align: center;
  margin-bottom: 25px;
  display: block;
  color: #00b0f2;
}
#sub_contents .c_box p {
  font-size: 17px;
  font-weight: bold;
  font-family: "Zen Old Mincho", serif;
  text-align: center;
  margin-bottom: 25px;
}
#sub_contents .c_box span {
  font-family: "Zen Old Mincho", serif;
  margin-bottom: 20px;
  display: block;
  font-size: 23px;
}
#sub_contents .c_box span::before {
  content: "■";
  margin-right: 10px;
  color: #00b0f2;
  font-size: 16px;
}
#sub_contents .c_box b {
  margin: 10px auto 20px;
}
#sub_contents .c_box b figure {
  width: 49%;
}
#sub_contents .sub_bg {
  background: #eee;
  padding: 100px 0px 1px;
}
#sub_contents table.tbl_company tr:first-child {
  border-top: 1px solid #00b0f2;
}
#sub_contents table.tbl_company tr {
  display: block;
  border-bottom: 1px solid #00b0f2;
  padding: 12px 0px;
}
#sub_contents table.tbl_company th {
  width: 400px;
  font-weight: bold;
  vertical-align: middle;
  background: #00b0f2;
  color: #fff;
}
#sub_contents table.tbl_company td {
  padding: 10px 10px 10px 35px;
  width: 880px;
}
#sub_contents table.tbl_company td a {
  color: #d10f0f;
  text-decoration: underline;
}
#sub_contents table.tbl_company td a.tel {
  color: inherit;
  text-decoration: inherit;
}

/* works
----------------------------------- */
#sub_contents .works_list li {
  width: 33.33%;
  padding: 0px 10px;
}
#sub_contents .works_list li a {
  border: 1px solid #fff;
  display: block;
  padding: 10px 15px;
  margin-bottom: 35px;
  background:#faf9ff;
}
#sub_contents .works_list li a:hover {
  transition: 1s;
}
#sub_contents .works_list li a img {
  width: 100%;
  margin-bottom: 10px;
}
#sub_contents .works_list li a .top-works-ttl {
  display: block;
  margin-bottom: 0px;
}

/* flow
-------------------------*/
#sub_contents ul.entry_list li {
  position: relative;
  background: #eee;
  padding: 40px;
  margin-bottom: 40px;
}
#sub_contents ul.entry_list dl {
  width: 56%;
}
#sub_contents ul.entry_list b {
  width: 41%;
}
#sub_contents ul.entry_list li dt span {
  font-size: 17px;
  font-weight: 500;
  background: #00b0f2;
  font-family: "Bellefair", serif;
  color: #fff;
  margin-right: 15px;
  padding: 1px 30px 0px;
}
#sub_contents ul.entry_list li dt {
  font-size: 22px;
  font-family: "Zen Old Mincho", serif;
}
#sub_contents ul.entry_list li dd {
  margin-top: 15px;
}
#sub_contents ul.entry_list li dd p {
  font-size: 17px;
  margin-bottom: 0px;
}
#sub_contents ul.entry_list li dd a {
  text-decoration: underline;
}
#sub_contents ul.entry_list li::before,
#sub_contents ul.entry_list li::after {
  position: absolute;
  bottom: -36px;
  left: 0;
  right: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}
#sub_contents ul.entry_list li::before {
  box-sizing: border-box;
  width: 18px;
  height: 18px;
  border: 18px solid transparent;
  border-top: 18px solid #eee;
}
#sub_contents ul.entry_list li:last-child::before {
  display: none;
}

/* entry
----------------------------------- */
#sub_contents p.con_cen {
  border: 1px solid #ddd;
  text-align: center;
  padding: 30px 50px 30px;
  font-size: 16px;
  line-height: 180%;
  margin: 50px 0px 60px;
  box-shadow: 6px 6px 0px #ddd;
}
#sub_contents p.con_cen a {
  display: inline-block;
  margin: 15px 0px;
  width: 330px;
}
#sub_contents p.con_cen a.cc-tel {
  margin: 10px 0 10px;
  font-size: 3.6rem;
  font-weight: 500;
  font-family: "Zen Old Mincho", serif;
}
#sub_contents p.con_cen a.cc-tel small {
  font-size: 1.9rem;
  margin-right: 5px;
}
#sub_contents p.con_cen span {
  font-size: 1rem;
  color: #888;
  display: flex;
  font-weight: normal;
  max-width: 1290px;
  justify-content: center;
}
#sub_contents table.defTable01 {
  margin: 0px auto 80px;
  border-collapse: collapse;
  box-sizing: border-box;
}
#sub_contents table.defTable01 tr {
  display: block;
  border-bottom: 1px solid #ddd;
  padding: 10px 0px;
}
#sub_contents table.defTable01 tr:first-child {
  border-top: 1px solid #ddd;
}
#sub_contents table.defTable01 th {
  padding: 15px 40px 15px 30px;
  width: 36%;
  display: inline-block;
  box-sizing: border-box;
  font-weight: bold;
  vertical-align: top;
}
#sub_contents table.defTable01 th small {
  font-size: 13px;
  display: block;
  font-weight: bold;
}
#sub_contents table.defTable01 td {
  padding: 15px 0px 15px 0px;
  display: inline-block;
  box-sizing: border-box;
  width: 63.5%;
  text-align: left;
}
#sub_contents table.defTable01 td a {
  font-weight: bold;
  color: #76c73a;
}
#sub_contents table.defTable01 th em.clrred {
  font-size: 22px;
  color: #d30000;
  font-style: normal;
  text-align: center;
  display: inline-block;
}
#sub_contents table.defTable01 td.cen {
  text-align: center;
  margin: 0 auto;
  display: block;
}
#sub_contents table.defTable01 td.cen input {
  padding: 10px;
  color: #fff;
  font-size: 16px;
  width: 33%;
  background: #111;
  cursor: pointer;
  border: 0px solid #ccc;
  display: block;
  text-align: center;
  margin: 0 auto;
}
#sub_contents table.defTable01 td.cen input:hover {
  background: #000;
  opacity: 0.8;
  filter: alpha(opacity=80);
  -moz-opacity: 1;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  color: #fff;
}
#sub_contents table.defTable01 input {
  padding: 8px 10px;
  background: #eee;
  font-size: 13px;
  border: none;
  box-sizing: border-box;
  width: 100%;
}
#sub_contents table.defTable01 textarea {
  padding: 8px 10px;
  background: #eee;
  font-size: 13px;
  border: none;
  width: 100%;
  box-sizing: border-box;
}
#sub_contents table.defTable01 select {
  padding: 8px 10px;
  background: #eee;
  font-size: 13px;
  border: none;
  width: 100%;
  box-sizing: border-box;
}
#sub_contents table.defTable01 .bbn {
  border-bottom: none !important;
}
#sub_contents table.defTable01 td.tel_area input {
  width: 23%;
}
#sub_contents table.defTable01 input[type="checkbox"] {
  width: 3%;
}
#sub_contents table.defTable01 input[type="radio"] {
  width: 3%;
}
#sub_contents table.defTable01 .privacyBox {
  padding: 10px 25px 30px;
  width: calc(100% - 0px);
  height: 300px;
  overflow-y: scroll;
  margin-bottom: 20px;
  background:#faf9ff;
  font-size: 90%;
  border: 1px solid #ddd;
  box-sizing: border-box;
}
#sub_contents table.defTable01 .privacyBox .sub_ttl {
  margin: 20px 0px 15px 0px;
  font-size: 140%;
  line-height: 120%;
  padding: 2px 0px 2px 8px;
  border-left: 5px solid #df1f41;
  font-weight: bold;
  font-family: "Zen Old Mincho", serif;
}
#sub_contents table.defTable01 .privacyBox p {
  text-align: left;
  margin-bottom: 10px;
  font-size: 14px;
  line-height: 160%;
}
#sub_contents table.defTable01 .privacyBox ul.ulbox li {
  list-style-type: disc;
  list-style-position: inside;
  margin-left: 0px;
  font-size: 14px;
}
#sub_contents table.defTable01 .privacyBox::-webkit-scrollbar {
  height: 5px;
}
#sub_contents table.defTable01 .privacyBox::-webkit-scrollbar-track {
  background: #eee;
}
#sub_contents table.defTable01 .privacyBox::-webkit-scrollbar-thumb {
  background: #df1f41;
}

#sub_contents table.tbl_company.recruit-page {
  margin-bottom: 65px;
}
#sub_contents p.con_cen a.line {
    margin-left: 15px;
}
#sub_contents p.con_cen .btn-cmn02 a.line span {
    color: #06C755;
    border: 1px solid;
    background: no-repeat;
    background: url(https://suginogikou-recruit.com/wp-content/themes/suginogikou-re/img/cmn/line-icon.png)no-repeat left 60px center;
    padding-left: 25%;
    background-size: 30px;
}
/* news
------------------------------*/
#sub_contents .news_list li {
  position: relative;
  margin: 0 2% 5% 0;
  padding: 0;
  width: 23%;
  font-size: 1.4rem;
}
#sub_contents .news_list li:nth-of-type(4n) {
  margin-right: 0;
}
#sub_contents .news_list li figure {
  margin: 0 0 15px;
}
#sub_contents .news_list li img {
  width: 100%;
}
#sub_contents .news_list li .top-news-info {
  margin: 10px 0 0;
  font-size: 1.2rem;
}

/* wp-pagenavi
------------------------------*/
#sub_contents .wp-pagenavi {
  clear: both;
  text-align: center;
  margin-top: 40px;
}
#sub_contents .wp-pagenavi a,
.wp-pagenavi span {
  display: inline-block;
  color: #333;
  padding: 8px 12px;
  margin: 0 2px 5px;
  white-space: nowrap;
  text-align: center;
  text-decoration: none;
  background:#faf9ff;
}
#sub_contents .wp-pagenavi span.pages {
  display: none;
}
#sub_contents .wp-pagenavi a:hover {
  color: #fff;
  background-color: #111;
  opacity: 1;
  transition: 1s;
}
#sub_contents .wp-pagenavi span.current {
  color: #fff;
  background-color: #111;
  font-weight: bold;
}

@media screen and (max-width: 1200px) {
  #sub_visual h2 {
    text-align: center;
    padding-top: 90px;
    font-size: 27px;
    line-height: 140%;
    width: 94%;
  }
  #sub_contents .bread_crumb_list ul {
    margin: 0 auto;
    width: 94%;
  }
  #sub_contents section {
    margin: 50px auto 70px;
    max-width: 94%;
    font-size: 14px;
  }
}

@media screen and (max-width: 767px) {
	
#sub_contents p.con_cen a.line {
    margin-left: 0;
}
	
  /* visual
------------------------------*/
  .top-contact.sub {
    background: #df1f41;
    padding: 30px 10px;
  }
  .top-contact.sub .btn-cmn02 span {
    background: url(../img/cmn/icon_arw01.png) no-repeat right 25px center;
    border: 1px solid #fff;
    color: #fff;
  }

  /* visual
------------------------------*/
  #sub_visual {
    height: 120px;
    background: #00b0f2;
  }
  #sub_visual h2 {
    text-align: center;
    padding-top: 40px;
    line-height: 140%;
    max-width: 94%;
    margin: 0 auto;
    position: relative;
    color: #fff;
  }
  #sub_visual h2 span {
    color: #fff;
    display: inline-block;
    font-size: 50px;
    position: absolute;
    right: 0px;
    opacity: 0.2;
    text-transform: uppercase;
    bottom: -50px;
    font-weight: 500;
    font-style: italic;
    font-family: "Bellefair", serif;
  }
  #sub_visual h2 small {
    font-weight: bold;
    font-family: "Zen Old Mincho", serif;
    font-size: 26px;
  }

  /* bread_crumb_list
------------------------------*/
  #sub_contents .bread_crumb_list {
    margin: 10px 0px 10px 0px;
    text-align: left;
    font-size: 13px;
    color: #777;
  }
  #sub_contents .bread_crumb_list ul {
    margin: 0 auto;
    max-width: 94%;
  }
  #sub_contents .bread_crumb li {
    display: inline;
    margin-left: 5px;
    text-transform: uppercase;
  }
  #sub_contents .bread_crumb li:after {
    content: "―";
    padding-left: 10px;
  }
  #sub_contents .bread_crumb li:last-child:after {
    content: "";
  }
  #sub_contents .bread_crumb li a {
    text-decoration: underline;
    margin-left: 0px;
  }
  #sub_contents .bread_crumb li a:hover {
    text-decoration: none;
  }
  #sub_contents .bread_crumb li.current {
    font-weight: bold;
  }

  /* sub_contents
------------------------------*/
  #sub_contents {
    line-height: 170%;
    font-size: 15px;
  }
  #sub_contents section {
    margin: 30px auto 70px;
    max-width: 94%;
    font-size: 15px;
  }
  #sub_contents h3 {
    position: relative;
    margin: 0px 0 50px;
  }
  #sub_contents h3 strong {
    font-size: 22px;
    padding: 0px 20px;
  }
  #sub_contents h3.sub {
    text-align: center;
    font-family: "Zen Old Mincho", serif;
    border-bottom: 1px solid #00b0f2;
    border-top: 1px solid #00b0f2;
    color: #00b0f2;
    padding: 15px 0px;
  }
  #sub_contents h3.sub span {
    font-size: 20px;
    font-weight: bold;
  }
  #sub_contents h3.sub.experience {
    color: #df1f41;
    border-bottom: 1px solid #df1f41;
    border-top: 1px solid #df1f41;
  }
  #sub_contents h4::before {
    background: #ebd800;
    height: 2px;
    width: 25px;
    position: absolute;
    top: 50%;
    left: 0px;
    content: "";
  }
  #sub_contents h5 {
    font-size: 17px;
    font-weight: bold;
    color: #ff7906;
    margin-bottom: 10px;
  }
  #sub_contents p {
    margin-bottom: 10px;
    font-size: 15px;
  }
  #sub_contents hr {
    margin: 30px auto 70px;
    border-color: #ddd;
    border-width: 0.5px;
  }
  #sub_contents ul.ulbox li {
    list-style-position: inside;
    list-style-type: disc;
    margin-bottom: 10px;
  }
  #sub_contents .sp {
    display: none;
  }
  #sub_contents .mb30 {
    margin-bottom: 20px;
  }
  #sub_contents .mb50 {
    margin-bottom: 30px;
  }
  #sub_contents .mb100 {
    margin-bottom: 50px;
  }
  #sub_contents .txt_cen {
    text-align: center;
    font-size: 15px;
    font-family: "Zen Old Mincho", serif;
    line-height: 180%;
  }
  #sub_contents .txt_cen b {
    font-weight: bold;
    color: #00b0f2;
    display: block;
    margin: 10px 0px;
  }

  /* staff
-------------------------*/
  #sub_contents .staff_list li {
    width: 100%;
    background: #faf9ff;;
    margin-bottom: 20px;
    padding: 25px 15px;
  }
  #sub_contents .staff_list li span {
    text-align: center;
    font-size: 22px;
    font-family: "Zen Old Mincho", serif;
    display: block;
    position: relative;
    margin-bottom: 30px;
    font-weight: bold;
  }
  #sub_contents .staff_list li span::after {
    position: absolute;
    left: 0;
    right: 0;
    width: 100px;
    height: 2px;
    margin: 0 auto;
    content: "";
    background: #00b0f2;
    bottom: -10px;
  }
  #sub_contents .staff_list li figure {
    text-align: center;
    margin: 10px auto 30px;
    display: block;
  }
  #sub_contents .staff_list li figure img {
    width: 100px;
  }
  #sub_contents .staff_list li i {
    font-style: normal;
    display: block;
    text-align: center;
    margin-bottom: 20px;
  }
  #sub_contents .staff_list li b {
    font-size: 60px;
    font-family: "Bellefair", serif;
    font-weight: 500;
    left: 0.5em;
    margin: 0px 10px;
  }
  #sub_contents .staff_list li small {
    font-weight: bold;
  }
  #sub_contents .staff_list li .txtbox {
    background: #eaf9ff;
    padding: 30px;
  }

  #sub_contents .staff_list li dl {
    margin-bottom: 10px;
  }
  #sub_contents .fuki_ttl {
    background: #00b0f2;
    padding: 15px 10px;
    margin-bottom: 15px;
    font-family: "Zen Old Mincho", serif;
    color: #fff;
    border-left: 3px solid #faeb00;
  }
  #sub_contents .fuki_ttl span {
    font-weight: bold;
    font-size: 17px;
    border-left: 0px solid #faeb00;
    padding-left: 0px;
  }
  #sub_contents .fuki_area {
    padding: 0px;
  }
  #sub_contents .fuki_area .txt_area {
    position: relative;
    display: inline-block;
    margin: 0px 0px 1.5em 0px;
    padding: 15px 15px;
    width: 100%;
    background: #faf9ff;;
    border: solid 1px #00b0f2;
    box-sizing: border-box;
  }
  #sub_contents .fuki_area figure {
    width: 100%;
    text-align: center;
    margin-bottom: 10px;
  }
  #sub_contents .fuki_area figure img {
    text-align: center;
    margin: 0 auto;
    display: block;
    width: 100%;
  }
  #sub_contents .fuki_area figure figcaption {
    text-align: center;
    font-weight: bold;
  }
  #sub_contents .fuki_area .txt_area p {
    margin-bottom: 0px;
    font-size: 16px;
  }

  /* experience
-------------------------*/
  #sub_contents .car_list.experience li {
    background: #df1f41;
  }
  #sub_contents .car_list.experience li:nth-child(2) {
    background: #ac4557;
  }
  #sub_contents .car_list.experience li:nth-child(3) {
    background: #df1f41;
  }
  #sub_contents .car_list.experience li:nth-child(4) {
    background: #ac4557;
  }
  #sub_contents .car_list.experience li:nth-child(5) {
    background: #df1f41;
  }
  #sub_contents .car_list.experience li:nth-child(6) {
    background: #ac4557;
  }
  #sub_contents .car_list.experience li:nth-child(7) {
    background: #df1f41;
  }

  /* inexperienced
-------------------------*/
  #sub_contents .img_list li {
    width: 100%;
  }
  #sub_contents .car_list li {
    height: auto;
    width: 100%;
    background: #00b0f2;
    padding: 30px 12px;
    position: relative;
    margin-bottom: 30px;
  }
  #sub_contents .car_list li:nth-child(2) {
    height: auto;
    background: #0097d0;
  }
  #sub_contents .car_list li:nth-child(3) {
    height: auto;
    background: #00b0f2;
  }
  #sub_contents .car_list li:nth-child(4) {
    height: auto;
    background: #0097d0;
  }
  #sub_contents .car_list li:nth-child(5) {
    height: auto;
    background: #00b0f2;
  }
  #sub_contents .car_list li:nth-child(6) {
    height: auto;
    background: #0097d0;
  }
  #sub_contents .car_list li:nth-child(7) {
    height: auto;
    background: #00b0f2;
  }
  #sub_contents .car_list li span {
    font-size: 16px;
    font-weight: bold;
    text-align: center;
    display: block;
    color: #fff;
    border: 1px solid #fff;
    margin-bottom: 10px;
    font-family: "Zen Old Mincho", serif;
  }
  #sub_contents .car_list li b {
    font-size: 16px;
    font-weight: bold;
    text-align: center;
    color: #fff;
    margin-bottom: 10px;
    font-family: "Zen Old Mincho", serif;
    position: absolute;
    top: -15px;
    margin: 0 auto;
    left: 0;
    right: 0;
    font-weight: bold;
    background: #111;
    width: 100%;
  }
  #sub_contents .car_list li p {
    color: #fff;
    font-size: 14px;
  }

  /* feature
-------------------------*/
  #sub_contents .m_list li {
    margin-bottom: 30px;
  }
  #sub_contents .m_list li b {
    text-align: center;
    font-size: 40px;
    font-family: "Bellefair", serif;
    color: #00b0f2;
    display: block;
    margin-bottom: 10px;
  }

  /* message
-------------------------*/
  #sub_contents .box_greeting {
    background: #f6f6f6;
    padding: 20px 10px;
  }
  #sub_contents .txt_gr {
    line-height: 160%;
    font-size: 14px;
  }
  #sub_contents .txt_gr small {
    text-align: right;
    display: block;
    font-weight: bold;
    font-family: "Zen Old Mincho", serif;
  }
  #sub_contents .txt_gr span {
    display: block;
    font-weight: bold;
    font-size: 18px;
    background: #111;
    color: #fff;
    padding: 5px 40px;
    margin-bottom: 20px;
    text-align: center;
    font-family: "Zen Old Mincho", serif;
  }
  #sub_contents .bg_rinen {
    background: #00b0f2;
    padding: 40px 0px 10px;
  }
  #sub_contents .bg_rinen h3 {
    margin-bottom: 50px;
    color: #fff;
  }
  #sub_contents .case_list {
    margin-top: 30px;
  }
  #sub_contents .case_list li {
    width: 100%;
    background: url(../img/greeting/icon_cnt01.png) no-repeat left 15px top 15px / 10px auto, url(../img/greeting/icon_cnt01.png) no-repeat left 15px bottom 15px / 10px auto,
      url(../img/greeting/icon_cnt01.png) no-repeat right 15px top 15px / 10px auto, url(../img/greeting/icon_cnt01.png) no-repeat right 15px bottom 15px / 10px auto;
    background-color: #faf9ff;
    padding: 30px 15px 30px;
    position: relative;
    margin-bottom: 55px;
  }
  #sub_contents .case_list li .top-cnt-no {
    display: block;
    font-size: 28px;
    font-weight: 500;
    font-family: "Bellefair", serif;
    position: absolute;
    top: -10px;
    right: 20px;
  }
  #sub_contents .case_list li .top-cnt-no::first-letter {
    color: #df1f41;
  }
  #sub_contents .case_list li p {
    font-size: 18px;
    font-family: "Zen Old Mincho", serif;
  }
  #sub_contents .case_list li p.top-cnt-info {
    font-family: "Bellefair", serif;
    font-size: 15px;
    color: #999;
    line-height: 120%;
  }
  #sub_contents .m_list li {
    width: 100%;
    margin-bottom: 15px;
  }
  #sub_contents .m_list li span {
    font-size: 20px;
    font-family: "Zen Old Mincho", serif;
    text-align: center;
    display: block;
    margin-bottom: 15px;
    border-bottom: 2px solid #00b0f2;
    padding-bottom: 10px;
    font-weight: bold;
  }
  #sub_contents .m_list li figure {
    margin-bottom: 10px;
  }

  /* company
-------------------------*/
  #sub_contents .c_box {
    background: #faf9ff;;
    padding: 20px 10px;
  }
  #sub_contents .c_box small {
    font-size: 20px;
    font-weight: bold;
    font-family: "Zen Old Mincho", serif;
    text-align: center;
    margin-bottom: 15px;
    display: block;
    color: #00b0f2;
  }
  #sub_contents .c_box p {
    font-size: 15px;
    font-weight: bold;
    font-family: "Zen Old Mincho", serif;
    text-align: center;
    margin-bottom: 15px;
  }
  #sub_contents .c_box span {
    font-family: "Zen Old Mincho", serif;
    margin-bottom: 20px;
    display: block;
    font-size: 19px;
  }
  #sub_contents .c_box span::before {
    content: "■";
    margin-right: 5px;
    color: #00b0f2;
    font-size: 16px;
  }
  #sub_contents .c_box b {
    margin: 10px auto 20px;
  }
  #sub_contents .c_box b figure {
    width: 100%;
    margin-bottom: 10px;
  }
  #sub_contents .sub_bg {
    background: #eee;
    padding: 60px 0px 1px;
  }
  #sub_contents table.tbl_company tr:first-child {
    border-top: 0px solid #00b0f2;
  }
  #sub_contents table.tbl_company tr {
    display: block;
    border-bottom: 0px solid #00b0f2;
    padding: 0px 0px;
  }
  #sub_contents table.tbl_company th {
    width: 100%;
    padding: 10px;
    display: block;
    font-weight: bold;
    vertical-align: middle;
    background: #00b0f2;
    color: #fff;
  }
  #sub_contents table.tbl_company td {
    padding: 10px;
    width: 100%;
    display: block;
  }
  #sub_contents table.tbl_company td a {
    color: #d10f0f;
    text-decoration: underline;
  }
  #sub_contents table.tbl_company td a.tel {
    color: inherit;
    text-decoration: inherit;
  }
  #sub_contents iframe {
    height: 300px;
  }

  /* works
----------------------------------- */
  #sub_contents .works_list li {
    width: 100%;
    padding: 0px 0px;
  }
  #sub_contents .works_list li a {
    border: 1px solid #fff;
    display: block;
    padding: 10px 15px;
    margin-bottom: 35px;
    background: #faf9ff;;
  }
  #sub_contents .works_list li a:hover {
    transition: 1s;
  }
  #sub_contents .works_list li a img {
    width: 100%;
    margin-bottom: 10px;
  }
  #sub_contents .works_list li a .top-works-ttl {
    display: block;
    margin-bottom: 0px;
  }

  /* flow
-------------------------*/
  #sub_contents ul.entry_list li {
    position: relative;
    background: #eee;
    padding: 20px;
    margin-bottom: 40px;
  }
  #sub_contents ul.entry_list dl {
    width: 100%;
  }
  #sub_contents ul.entry_list b {
    width: 100%;
    margin-bottom: 20px;
  }
  #sub_contents ul.entry_list li dt span {
    font-size: 15px;
    font-weight: 500;
    background: #00b0f2;
    font-family: "Bellefair", serif;
    color: #fff;
    margin-right: 15px;
    padding: 1px 30px 0px;
  }
  #sub_contents ul.entry_list li dt {
    font-size: 17px;
    font-family: "Zen Old Mincho", serif;
  }
  #sub_contents ul.entry_list li dd {
    margin-top: 10px;
  }
  #sub_contents ul.entry_list li dd p {
    font-size: 14px;
    margin-bottom: 0px;
  }
  #sub_contents ul.entry_list li dd a {
    text-decoration: underline;
  }
  #sub_contents ul.entry_list li::before,
  #sub_contents ul.entry_list li::after {
    position: absolute;
    bottom: -36px;
    left: 0;
    right: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
  }
  #sub_contents ul.entry_list li::before {
    box-sizing: border-box;
    width: 18px;
    height: 18px;
    border: 18px solid transparent;
    border-top: 18px solid #eee;
  }
  #sub_contents ul.entry_list li:last-child::before {
    display: none;
  }

  /* entry
----------------------------------- */
  #sub_contents p.con_cen {
    border: 1px solid #ddd;
    text-align: center;
    padding: 15px 20px 15px;
    font-size: 14px;
    line-height: 160%;
    margin: 30px 0px 60px;
    box-shadow: 3px 3px 0px #ddd;
  }
  #sub_contents p.con_cen a {
    display: inline-block;
    margin: 10px 0px;
  }
  #sub_contents p.con_cen a.cc-tel {
    margin: 10px 0 10px;
    font-size: 21px;
    font-weight: 500;
    font-family: "Zen Old Mincho", serif;
  }
  #sub_contents p.con_cen a.cc-tel small {
    font-size: 17px;
    margin-right: 5px;
  }
  #sub_contents p.con_cen span {
    font-size: 14px;
    color: #888;
    display: block;
    font-weight: normal;
  }
  #sub_contents table.defTable01 {
    margin: 0px auto 50px;
    border-collapse: collapse;
    box-sizing: border-box;
  }
  #sub_contents table.defTable01 tr {
    display: block;
    border-bottom: 0px solid #ddd;
    padding: 0px 0px;
  }
  #sub_contents table.defTable01 tr:first-child {
    border-top: 0px solid #ddd;
  }
  #sub_contents table.defTable01 th {
    padding: 10px 0px 10px 0px;
    width: 100%;
    display: block;
    text-align: left;
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    box-sizing: border-box;
    font-weight: bold;
    vertical-align: top;
  }
  #sub_contents table.defTable01 th small {
    font-size: 12px;
    display: block;
    font-weight: bold;
  }
  #sub_contents table.defTable01 td {
    padding: 10px 0px 10px 0px;
    display: block;
    box-sizing: border-box;
    width: 100%;
    text-align: left;
  }
  #sub_contents table.defTable01 td a {
    font-weight: bold;
    color: #76c73a;
  }
  #sub_contents table.defTable01 th em.clrred {
    font-size: 17px;
    color: #d30000;
    font-style: normal;
    text-align: center;
    display: inline-block;
  }
  #sub_contents table.defTable01 td.cen {
    text-align: center;
    margin: 0 auto;
    display: block;
  }
  #sub_contents table.defTable01 td.cen input {
    padding: 10px;
    color: #fff;
    font-size: 15px;
    width: 100%;
    background: #111;
    cursor: pointer;
    border: 0px solid #ccc;
    display: block;
    text-align: center;
    margin: 0 auto;
  }
  #sub_contents table.defTable01 td.cen input:hover {
    background: #000;
    opacity: 0.8;
    filter: alpha(opacity=80);
    -moz-opacity: 1;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
    color: #fff;
  }
  #sub_contents table.defTable01 input {
    padding: 8px 10px;
    background: #eee;
    font-size: 13px;
    border: none;
    box-sizing: border-box;
    width: 100%;
  }
  #sub_contents table.defTable01 textarea {
    padding: 8px 10px;
    background: #eee;
    font-size: 13px;
    border: none;
    width: 100%;
    box-sizing: border-box;
  }
  #sub_contents table.defTable01 select {
    padding: 8px 10px;
    background: #eee;
    font-size: 13px;
    border: none;
    width: 100%;
    box-sizing: border-box;
  }
  #sub_contents table.defTable01 .bbn {
    border-bottom: none !important;
  }
  #sub_contents table.defTable01 td.tel_area input {
    width: 23%;
  }
  #sub_contents table.defTable01 input[type="checkbox"] {
    width: 3%;
  }
  #sub_contents table.defTable01 input[type="radio"] {
    width: 3%;
  }
  #sub_contents table.defTable01 .privacyBox {
    padding: 10px 25px 30px;
    width: calc(100% - 0px);
    height: 300px;
    overflow-y: scroll;
    margin-bottom: 20px;
    background: #faf9ff;;
    font-size: 90%;
    border: 1px solid #ddd;
    box-sizing: border-box;
  }
  #sub_contents table.defTable01 .privacyBox .sub_ttl {
    margin: 20px 0px 15px 0px;
    font-size: 140%;
    line-height: 120%;
    padding: 2px 0px 2px 8px;
    border-left: 5px solid #df1f41;
    font-weight: bold;
    font-family: "Zen Old Mincho", serif;
  }
  #sub_contents table.defTable01 .privacyBox p {
    text-align: left;
    margin-bottom: 10px;
    font-size: 14px;
    line-height: 160%;
  }
  #sub_contents table.defTable01 .privacyBox ul.ulbox li {
    list-style-type: disc;
    list-style-position: inside;
    margin-left: 0px;
    font-size: 14px;
  }
  #sub_contents table.defTable01 .privacyBox::-webkit-scrollbar {
    height: 5px;
  }
  #sub_contents table.defTable01 .privacyBox::-webkit-scrollbar-track {
    background: #eee;
  }
  #sub_contents table.defTable01 .privacyBox::-webkit-scrollbar-thumb {
    background: #df1f41;
  }

  /* wp-pagenavi
------------------------------*/
  #sub_contents .wp-pagenavi {
    clear: both;
    text-align: center;
    margin-top: 30px;
  }
  #sub_contents .wp-pagenavi a,
  .wp-pagenavi span {
    display: inline-block;
    color: #333;
    padding: 5px 6px;
    margin: 0 1px 5px;
    white-space: nowrap;
    text-align: center;
    text-decoration: none;
    background: #faf9ff;;
  }
  #sub_contents .wp-pagenavi span.pages {
    display: none;
  }
  #sub_contents .wp-pagenavi a:hover {
    color: #fff;
    background-color: #111;
    opacity: 1;
    transition: 1s;
  }
  #sub_contents .wp-pagenavi span.current {
    color: #fff;
    background-color: #111;
    font-weight: bold;
  }
}

/*
Wordpress
__________________________*/

/* single-page*/
.single strong {
  font-weight: bold;
}
.single cite,
.single em,
.single i {
  font-style: italic;
}
.single big {
  font-size: 131.25%;
}
.single ins {
  background: #ffc;
  text-decoration: none;
}
.single blockquote {
  font-style: italic;
  padding: 0.3em;
}
.single blockquotecite,
.single blockquoteem,
.single blockquotei {
  font-style: normal;
}
.single pre {
  background: #f7f7f7;
  color: #222;
  line-height: 18px;
  margin-bottom: 18px;
  overflow: auto;
  padding: 1.5em;
}
.single abbr,
.single acronym {
  border-bottom: 1px dotted #666;
  cursor: help;
}
.single sup,
.single sub {
  height: 0;
  line-height: 1;
  position: relative;
  vertical-align: baseline;
}
.single sup {
  bottom: 1ex;
}
.single sub {
  top: 0.5ex;
}
.single img,
.single img.alignnone {
  display: inline-block;
  margin-bottom: 20px;
  font-size: inherit;
}
.single img.size-auto,
.single img.size-full,
.single img.size-large,
.single img.size-medium,
.single .attachment img {
  max-width: 100%;
  height: auto;
}
.single .alignleft,
.single img.alignleft {
  display: inline;
  float: left;
  margin-right: 24px;
  margin-top: 4px;
}
.single .alignright,
.single img.alignright {
  display: inline;
  float: right;
  margin-left: 24px;
  margin-top: 4px;
}
.single .aligncenter,
.single img.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.single p {
  display: block;
  margin-bottom: 1em;
}
.single table,
.single th,
.single td {
  border: 1px solid #000;
}
.single table {
  border-collapse: separate;
  border-spacing: 0;
  border-width: 1px 0 0 1px;
  margin: 0 0 28px;
  width: 100%;
}
.single table th,
.single table caption {
  border-width: 0 1px 1px 0;
  padding: 7px;
  text-align: left;
  vertical-align: baseline;
}
.single table td {
  border-width: 0 1px 1px 0;
  padding: 7px;
  vertical-align: baseline;
}
.single ol {
  list-style: decimal outside;
}
.single ul {
  list-style: disc outside;
}
.single li {
  margin-left: 1em;
}
#sub_contents .single .wp-pagenavi a,
.single .wp-pagenavi span {
  border: 1px solid #000;
}

@media screen and (max-width: 767px) {
  .single .alignleft,
  .single img.alignleft,
  .single .alignright,
  .single img.alignright,
  .single .aligncenter,
  .single img.aligncenter {
    clear: both;
    display: block;
    float: none;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0;
  }
  .single img.alignleft,
  .single img.alignright,
  .single img.aligncenter {
    margin-bottom: 12px;
  }
}

/*Contact Form 7*/
.wpcf7-mail-sent-ok {
  display: none !important;
}
.wpcf7-form input[type="checkbox"] {
  width: 1em !important;
  margin: 0 0.1em !important;
}
.wpcf7-form input[type="radio"] {
  width: 1em !important;
  margin: 0 0.1em !important;
}
.wpcf7-list-item {
  display: inline-block !important;
  margin-left: 0em !important;
  margin-right: 0em !important;
}
.wpcf7-list-item-label::after {
  content: "";
  margin-right: 1em;
}
.wpcf7-spinner {
  display: none !important;
}
.cen .wpcf7-form-control {
  margin-bottom: 10px !important;
}

/*others*/
.thankspage,
.page404 {
  text-align: center;
}
.post_none2 {
  text-align: center;
  margin: 2em auto;
}
img {
  height: auto;
}
.bread_crumb li br {
  display: none;
}

.video{
  background-color: #01B0F3;
  padding: 80px 0 40px;
}

.video-text{
  text-align: center;
  color: #fff;
}

.mil-embed-KrLQ68{
  margin-bottom: 15px;
}

.video-text strong{
  margin-bottom: 10px!important;
  display: block;
  font-size: 1.8rem;
  font-family: "Zen Old Mincho", serif;
}

.video-text span{
  display: block;
  font-size: 6rem;
    line-height: 1;
    text-transform: uppercase;
    font-family: "Bellefair", serif;
    letter-spacing: 0.1em;
    margin-bottom: 15px!important;
}


@media screen and (max-width: 767px){
.video-text span{
  font-size: 3rem;
}
}

ul.tuika001 {
    display: flex;
    justify-content: center;
    margin-bottom: 20px;
}

ul.tuika002 {
    display: flex;
    justify-content: center;
    margin-bottom: 80px;
}

.toptuika {
    display: block;
    text-align: center;
    margin-bottom: 100px;
}

.staff_thumbnail {
    width: 600px;
    display: block;
    margin: 0 auto;
}

@media screen and (max-width: 767px){
	.staff_thumbnail {
    width: 350px;
    display: block;
		margin:0 auto;
}}


.karikarikari {
    display: block;
    text-align:center !important;
}

#sub_contents .staff_thumbnail p{
  font-size: 2em;
  padding-bottom: 10px;
}
#sub_contents .staff_thumbnail p{
  font-size: 2em;
}

@media screen and (max-width: 767px){
  #sub_contents .staff_thumbnail p{
    font-size: 1.5em;
      padding-bottom: 6px;
  }
  #sub_contents .staff_thumbnail p{
    font-size: 1.5em;
  }
}
/*230124*/
.top-news {
	margin: -80px 0 0;
	padding: 0;
	background-color: #01b0f3;
}
.top-news .btn-cmn01 {
	position: absolute;
	bottom: 75px;
	left: 100px;
}
.top-news__box {
	position: relative;
	padding: 75px 0;
	z-index: 1001;
}
.top-news__box::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100%;
	background:#faf9ff;
	border: 1px solid #222;
	border-radius: 15px;
	z-index: -1;
}
.top-news__cap {
	padding: 0 0 0 100px;
	width: 400px;
}
.top-news__cap h3 {
	text-align: left;
}
.top-news__list {
	position: relative;
	width: calc(100% - 420px);
	max-width: 670px;
}
.top-news__list li + li {
	position: relative;
	margin: 35px 0 0;
}
.top-news__about {
	position: relative;
	margin: 0;
}
.top-news__date {
	margin: 0 40px 0 0;
	font-size: 1.6rem;
}
.top-news__ttl {
	margin: 0;
	font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
	.top-news {
		margin: -40px 0 0;
	}
	.top-news .btn-cmn01 {
		position: relative;
		bottom: 0;
		left: 0;
	}
	.top-news__box {
		padding: 25px 15px;
	}
	.top-news__cap {
		padding: 0;
		width: 100%;
	}
	.top-news__list {
		margin-bottom: 40px;
		width: 100%;
		max-width: 100%;
	}
	.top-news__list li + li {
		margin: 15px 0 0;
	}
	.top-news__about {
		position: relative;
		margin: 0;
	}
	.top-news__date {
		margin: 0 0 10px;
		width: 100%;
		font-size: 1.6rem;
	}
	.top-news__ttl {
		margin: 0;
		font-size: 1.6rem;
	}
}
.ttl-cmn01.blog_ttl {
    margin: 0 0 65px;
}
.ttl-cmn01.blog_ttl.col01 {
	color: #fff;
}
.ttl-cmn01.blog_ttl span {
	display: block;
	margin: 0;
	font-size: 8rem;
	font-weight: 600;
	font-family: 'Inter', sans-serif;
}
.ttl-cmn01.blog_ttl span:first-letter {
	color: #00a5ee;
	}
.ttl-cmn01.blog_ttl.col01 span:first-letter {
	color: #00a5ee;
}
.ttl-cmn01.blog_ttl strong {
	display: block;
	font-size: 2rem;
	font-weight: 500;
}
.ttl-cmn01.blog_ttl.col01 strong {
	color: #fff;
}
@media screen and (max-width:767px) {
	.ttl-cmn01.blog_ttl {
		margin: 0 auto 30px;
	}
	.ttl-cmn01.blog_ttl span {
		font-size: 4rem;
	}
	.ttl-cmn01.blog_ttl strong {
		margin: 15px 0 0;
		font-size: 1.6rem;
	}
	.ttl-cmn01.blog_ttl span:first-letter {
		font-size: 38px;
	}
}

.btn-cmn01.blog_bnr {
	margin: 0;
	text-align: center;
	font-family: 'Inter', sans-serif;
}
.btn-cmn01.blog_bnr.left {
	margin-left: 0;
}
.btn-cmn01.blog_bnr a {
	position: relative;
	padding: 0 55px 0 0;
}
.btn-cmn01.blog_bnr a::before {
	content:"";
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 40px;
	height: 40px;
	background: url(../img/cmn/btn_arw01.png);
}
.btn-cmn01.blog_bnr a:hover {
	opacity: 1;
}
.btn-cmn01.blog_bnr span {
	display: inline-block;
	position: relative;
	padding: 5px 0;
	border-bottom: 2px solid #00a5ee;
	text-align: center;
	font-size: 18px;
	font-weight: 600;
	color: #00a5ee;
	letter-spacing: 0.1em;
	font-family: 'Inter', 'Noto Sans JP', '游ゴシック体', 'Yu Gothic', 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', 'Osaka', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
.btn-cmn01.blog_bnr.col01 a::before {
	background: url(../img/cmn/btn_arw02.png);
}
.btn-cmn01.blog_bnr.col01 span {
	border-bottom: 2px solid #fff;
	color: #fff;
}
@media screen and (max-width:767px) {
	.btn-list.flex-end .btn-cmn01.blog_bnr {
		margin: 0 0 0 30px;
	}
	.btn-list.flex-nml .btn-cmn01.blog_bnr {
		margin: 0 30px 0 0;
	}
	.btn-cmn01.blog_bnr {
		margin: 0;
		text-align: center;
		font-family: 'Inter', sans-serif;
	}
	.btn-cmn01.blog_bnr a {
		position: relative;
		padding: 0 35px 0 0;
	}
	.btn-cmn01.blog_bnr a::before {
		width: 20px;
		height: 20px;
		background-size: contain!important;
	}
	.btn-cmn01.blog_bnr a:hover {
		opacity: 1;
	}
	.btn-cmn01.blog_bnr span {
		font-size: 14px;
	}
}


p.firsttxt:first-letter{
  color:#00b0f2;

}
.flex-btw {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#sub_contents .staff_list li dl {
    width: 41%;
    margin-bottom: 8px;
    padding-bottom: 2px;
    border-bottom: 1px solid #fff;
}

#sub_contents p.con_cen .btn-cmn02 a span {
    font-size: 20px;
    color: #df1f41;
    background: url(/wp-content/themes/suginogikou-re/img/cmn/icon_arw02.png) no-repeat right 25px center;
    padding: 0px 75px 0 60px;
}

@media screen and (max-width: 767px)
#sub_contents .staff_list li .txtbox {
    background: #eaf9ff;
    padding: 30px;
}

@media screen and (max-width: 767px)
#sub_contents .staff_list li dl {
    margin-bottom: 10px;
}

/*ここから*/
.companyQualification-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	justify-content: center;
}
.companyQualification-box-data {
    width: calc(100% / 3);
    border: 1px solid #e2e2e2;
}
tbody {
    display: table-row-group;
    vertical-align: middle;
    border-color: inherit;
}
.companyQualification-box-data tr {
    border-bottom: 1px solid #e2e2e2;
}
.companyQualification-box-data th {
    padding: 13px 10px 13px 30px;
    border-right: 1px solid #e2e2e2;
    background: #eaf9ff;
    width: 400px;
}
.companyQualification-box-data td {
    width: 100px;
    text-align: center;
	    background: white;
}
.pc_none {
    display: none;
}
@media screen and (max-width: 767px){
.companyQualification-box {
    display: block;
}
.companyQualification-box-data {
    width: 100%;
}
.companyQualification-box-data th, .companyQualification-box-data td {
    padding: 10px;
}
.companyQualification-box-data td {
    width: 70px;
}
.pc_none {
    display: block;
}
}
@media screen and (max-width: 767px){
img.aligncenterrrr {
    display: none;
}
}
/*ここ*/

@media screen and (max-width: 767px){
section.tuikacontent {
    display: none;
}}
@media screen and (min-width: 768px){
section.tuikacontentsp {
    display: none;
}}
#sub_contents .staff_list li.kari {
  width: 100%;
  background:#faf9ff;
  margin-bottom: 30px;
  padding: 35px 20px;
}
.recruit_bnr li {
    width: 33%;
    text-align: center;
}

.recruit_bnr ul.tuika001 {
    justify-content: center;
}

.recruit_bnr p {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    position: relative;
    padding: 0;
    width: 90%;
    margin: 0 auto;
    height: 60px;
    border-top: 1px solid #df1f41;
    border-bottom: 1px solid #df1f41;
    text-align: center;
}

.recruit_bnr p span {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    position: relative;
    padding: 0;
    width: 100%;
    height: 50px;
    border-left: 1px solid #df1f41;
    border-right: 1px solid #df1f41;
    font-size: 16px;
    color: #df1f41;
}
#sub_contents .recruit_table h3 {
    display: block;
    line-height: 200%;
    font-weight: bold;
    margin: 2.5rem 0;
    font-size: 24px;
    background: #111;
    color: #fff;
    padding: 5px 40px;
    margin-bottom: 20px;
    text-align: center;
    font-family: "Zen Old Mincho", serif;
}


/*240919add*/
.symbol-logo {
    display: flex;
    height: 90px;
    justify-content: center;
}
@media screen and (max-width: 1279px) {
	.symbol-logo {
		margin-top: 2rem;
	}
}
@media screen and (max-width: 767px){
.symbol-logo {
	margin-top: 0;
}
}


/*250115add*/
.comic_area {
    width: 50%;
    align-content: center;
}
.comic_area img {
    max-height: 500px;
}
@media screen and (max-width: 767px) {
    #sub_contents .comic_area {
		width: 100%;
	}
}

/* 250512add
recapcha非表示の文言を中央揃え
-------------------------------------------------------------- */
.recapcha-text {
    text-align: center;