@charset "utf-8";

body {
  color: #000;
  letter-spacing: 0.08em;
  font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  /*font-family: shippori-mincho, "YuMincho Medium", "Yu Mincho Regular", "游明朝 Regular", "游明朝体", "Yu Mincho", YuMincho, "Noto Serif JP", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;*/
  font-style: normal;
  /*font-weight: 500;*/
  padding-top: 105px;
  background-color: #fff;
}

/* Brandon Grotesque Regular */
.e {
  font-family: brandon-grotesque, sans-serif;
  font-weight: 400;
  font-style: normal;
}
/* Brandon Grotesque Bold */
.eb {
  font-family: brandon-grotesque, sans-serif;
  font-weight: 700;
  font-style: normal;
}


p,li,td {
  font-size: 14px;
  line-height: 2.14em;
}
p {
  margin-bottom: 30px;
}
p.b {
  font-size: 22px;
}

/* common */
hr {
    color: #a5a6a6;
    background-color: #a5a6a6;
    margin: 0;
}


a {
  -webkit-transition: all 0.4s;
  -moz-transition: all 0.4s;
  -ms-transition: all 0.4s;
  -o-transition: all 0.4s;
  transition: all 0.4s;
  opacity: 1;
}
a:hover {
  opacity: 0.45;
}

br.sp {
  display: none;
}
img.sp {
	display: none;
}


header {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 30000;
  width: 100%;
  height: 105px;
  background-color: rgba(255,255,255,1);
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}
header.fix {
  height: 70px;
  background-color: rgba(255,255,255,1) !important;  
}
body.top header {
  background-color: rgba(255,255,255,0);  
}

header .inner {
  position: relative;
  width: 1200px;
  margin: auto;  
}

header .inner h1 {
  position: absolute;
  left: 0;
  top: 22px;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}
header.fix h1 {
  top: 5px;
}
header .inner h1 a {
  display: inline-block;
  font-size: 0;
}
header .inner h1 img {
  width: 156px;
  height: auto;
  -webkit-transition: all 0.4s;
  -moz-transition: all 0.4s;
  -ms-transition: all 0.4s;
  -o-transition: all 0.4s;
  transition: all 0.4s;
}
body.top header .inner h1 img {
  width: 245px;
}
body.top header.fix h1 img {
  width: 156px;
}

header .inner ul {
  display: flex;
  flex-wrap: wrap;
  position: absolute;
  right: 0;
  top: 33px;
  width: 780px;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}
header.fix .inner ul {
  top: 17px;
}
header .inner ul li {
  position: relative;
  font-size: 12px;
  line-height: 1em;
  text-align: center;
  padding: 0 28px;
}
header .inner ul li::after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 2px;
  width: 1px;
  height: 30px;
  background-color: #000;
}
header .inner ul li:first-of-type {
  padding-left: 0;
}
header .inner ul li:last-of-type {
  padding-right: 0;
}
header .inner ul li:last-of-type::after {
  display: none;
}
header .inner ul li a {
  display: block;
}
header .inner ul li a span {
  display: block;
  color: #2d3c9f;
  font-size: 16px;
  margin-bottom: 10px;
}

footer {
  position: relative;  
  width: 100%;
  background-color: #2d3c9f;
}

footer .to_contact {
  padding: 90px 0;
  background-image: linear-gradient(0deg, transparent 19px, rgba(45,60,160,0.2) 20px), linear-gradient(90deg,  transparent 19px, rgba(45,60,160,0.2) 20px);
  background-size: 20px 20px;
  background-color: #fff;
}
footer .to_contact p {
  color: #2d3c9f;
  font-size: 24px;
  line-height: 1em;
  font-weight: bold;
  text-align: center;
  margin-bottom: 35px;
}
footer .to_contact a {
  display: block;
  color: #2d3c9f;
  font-size: 18.15px;
  line-height: 1em;
  text-align: center;
  width: 206px;
  height: 54px;
  padding-top: 18px;
  margin: auto;
  background-color: #fff93c;
  border-radius: 10px;
}

footer .inner {  
  display: flex;
  flex-wrap: wrap;
  position: relative;
  color: #fff;
  width: 1200px;  
  margin: auto;
  padding: 90px 0 60px;
}
footer .inner a.pt {
  display: block;
  position: absolute;
  right: 0;
  top: -45px;
  color: #fff;
  font-size: 15px;
  line-height: 1.2em;
  text-align: center;
  width: 90px;
  height: 90px;
  padding-top: 32px;
  background-color: #001478;
  border: 2px solid #fff;
  border-radius: 50%;
}
footer .inner a.pt:hover {
  opacity: 1;
  top: -48px;
}
footer .inner a.pt::after {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 1px);
  top: 20px;
  width: 8px;
  height: 8px;
  border-left: 2px solid #fff;
  border-top: 2px solid #fff;
  transform: rotate(45deg);
  transform-origin: 0 0;
}
footer .inner .logo img {
  width: 286px;
  height: auto;
}
footer .inner .text {
  width: 350px;
  margin-left: 64px;
}
footer .inner .text p {
  line-height: 1.86em;
  margin-bottom: 1em;
}
footer .inner .text a.tel {
  display: block;
  font-size: 18px;
  line-height: 1em;
  text-align: center;
  width: 210px;
  height: 34px;
  padding-top: 7px;
  border: 1px solid #fff;
  border-radius: 5px;
  pointer-events: none;
}
footer ul {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  width: 500px;
  height: 100px;
  margin-top: 10px;
}
footer ul li {
  font-size: 10px;
  line-height: 1em;
  text-align: center;
}
footer ul li:nth-of-type(1) {
  height: 100px;
}
footer ul li:nth-of-type(2) {
  margin-bottom: 35px;
}
footer ul li:nth-of-type(3) {
}
footer ul li:nth-of-type(4) {
  margin-bottom: 35px;
}
footer ul li:nth-of-type(5) {
}
footer ul li a {
  display: block;
  padding-right: 30px;
  background: url("../img/footer_link_mark.png") no-repeat calc(100% - 10px) 3px / 24px;
}
footer ul li a span {
  display: block;
  font-size: 16px;
  line-height: 1em;
  margin-bottom: 5px;
}
footer .inner .copy {
  font-size: 12px;
  line-height: 1em;
  letter-spacing: 0.1em;
  text-align: center;
  width: 100%;
  margin-top: 50px;
}


#top_part {
  position: relative;
  padding: 750px 0 150px;
  background-color: #f1f1f1;
}
#top_part::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  width: 100%;
  height: 320px;
  background-color: #fff;
}
#top_part .illust {
  position: absolute;
  left: calc(50% - 700px);
  top: -70px;
  z-index: 1000;
  width: 1400px;  
}
#top_part .illust .text {
  position: absolute;
  top: 290px;
  left: 220px;
  z-index: 3000;
}
#top_part .illust .text p {  
  position: absolute;
  color: #fff;
  font-size: 30px;
  line-height: 1em;
  font-weight: bold;
  letter-spacing: 0.1em;  
  height: 60px;
  overflow: hidden;
  padding: 15px 0;
  margin-bottom: 0;
  background-color: #2d3c9f;
  transition: all 0.5s;
}
#top_part .illust .text p span {
  margin-left: 10px;
  transition: all 0.5s;
  opacity: 1;
}
#top_part .illust .text p span.ani {  
  opacity: 0;
}
#top_part .illust .text p:nth-of-type(1) {
  left: 0;
  top: 0;
  width: 350px;
}
#top_part .illust .text p:nth-of-type(2) {
  left: 0;
  top: 80px;
  width: 385px;
}
#top_part .illust .text.ani p:nth-of-type(1),
#top_part .illust .text.ani p:nth-of-type(2) {
  width: 0;
}
#top_part .illust .back {
  position: relative;
  top: 20px;
  transition: all 1.0s;
  opacity: 1;
}
#top_part .illust .back.ani {
  top: 50px;
  opacity: 0;
}
#top_part .illust .bicycle {
  position: absolute;  
  top: 305px;
  right: 135px;
  width: 530px;
  height: auto;
  transition: all 0.5s;
  opacity: 1;
}
#top_part .illust .bicycle.ani {  
  top: 330px;
  right: 85px;
  opacity: 0;
}

#top_part .nc_box {
  position: relative;
  z-index: 5000;
  width: 980px;
  margin: auto;
  background-color: #fff;
  border: 1px solid #2d3c9f;
}
#top_part .nc_box .inner {
  position: relative;
  width: 100%;
  padding: 30px 0 75px;
}
#top_part .nc_box::before,
#top_part .nc_box::after,
#top_part .nc_box .inner::before,
#top_part .nc_box .inner::after {
  content: "";
  display: block;
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
}
#top_part .nc_box::before {
  left: -1px;
  top: -1px;
  z-index: 10;
  border-width: 30px 30px 0 0;
  border-color: #2d3c9f transparent transparent transparent;
}
#top_part .nc_box::after {
  right: -1px;
  bottom: -1px;
  z-index: 10;
  border-width: 0 0 30px 30px;
  border-color: transparent transparent #2d3c9f transparent;
}
#top_part .nc_box .inner::before {
  left: -1px;
  top: -1px;
  z-index: 20;
  border-width: 29px 29px 0 0;
  border-color: #f1f1f1 transparent transparent transparent;
}
#top_part .nc_box .inner::after {
  right: -1px;
  bottom: -1px;
  z-index: 20;
  border-width: 0 0 29px 29px;
  border-color: transparent transparent #f1f1f1 transparent;
}

#top_part .nc_box h2.midashi::before {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 28px);
  top: -46px;
  width: 56px;
  height: 34px;
  background: url("../img/icon/nc.png") no-repeat 0 0 / 56px 34px;
}
#top_part .nc_box h2.midashi::after {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 35px);
  top: -31px;
  z-index: -1;
  width: 70px;
  height: 10px;
  background-color: #fff;
}

#top_part .nc_box ul.list {
  display: flex;
  flex-wrap: wrap;
  padding: 0 59px;
}
#top_part .nc_box ul.list li {
  width: 210px;
}
#top_part .nc_box ul.list li:nth-of-type(2) {
  position: relative;
  margin: 0 115px;
}
#top_part .nc_box ul.list li:nth-of-type(2)::before,
#top_part .nc_box ul.list li:nth-of-type(2)::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: 1px;
  height: 100%;
  background-color: #2d3c9f;
}
#top_part .nc_box ul.list li:nth-of-type(2)::before {
  left: -58px;
}
#top_part .nc_box ul.list li:nth-of-type(2)::after {
  right: -58px;
}
#top_part .nc_box ul.list li a {
  display: block;
  text-align: center;
}
#top_part .nc_box ul.list li .i {
  width: 210px;
  height: 210px;
  overflow: hidden;
  border-radius: 50%;
  margin-bottom: 20px;
}
#top_part .nc_box ul.list li .d,
#news_list_wrap ul.list li .d,
#news_single .h .d {
  display: inline-block;
  font-size: 14px;
  line-height: 1em;
  vertical-align: text-bottom;
  padding: 3px 0; 
}
#top_part .nc_box ul.list li .c,
#news_list_wrap ul.list li .c,
#news_single .h .c {
  display: inline-block;
  color: #2d3c9f;
  font-size: 10px;
  line-height: 1em;
  font-weight: bold;
  vertical-align: text-bottom;  
  padding: 4px 10px;
  border: 1px solid #2d3c9f;
}
#top_part .nc_box ul.list li .t {
  font-size: 14px;
  line-height: 1.6em;
  font-weight: bold;
  margin-top: 5px;
}

#top_part .nc_box .btn {
  position: absolute;
  left: calc(50% - 100px);
  bottom: -29px;
  text-align: center;
  width: 200px;  
}
#top_part .nc_box .btn::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
  width: 100%;
  height: 50%;
  background-color: #fff;
}

#bottom_part {
  padding: 15px 0 50px;
  overflow-x: hidden;
  background: url("../img/back01.png") no-repeat 50% -90px;
}
#bottom_part .unit {
  position: relative;
  width: 1140px;
  height: 560px;
  margin: auto;
}
#bottom_part .unit:nth-of-type(2) {
  margin-bottom: 50px;
}
#bottom_part .unit:nth-of-type(2)::before {
  content: "";
  display: block;
  position: absolute;
  left: 180px;
  top: 65px;
  z-index: 1;
  width: calc(100% - 180px);
  height: 480px;
  border-radius: 40px 0 0 40px;
  background-color: rgba(255,229,60,0.13);
}
#bottom_part .unit:nth-of-type(2)::after {
  content: "";
  display: block;
  position: absolute;
  right: -1140px;
  top: 65px;
  z-index: 1;
  width: 1140px;
  height: 480px;
  background-color: rgba(255,229,60,0.13);
}
#bottom_part .unit h2 {
  color: #2d3c9f;
  font-size: 12px;
  line-height: 1em;
  text-align: center;
  width: 176px;
  height: 176px;
  padding-top: 70px;
  background-color: #fff;
  border: 1px solid #2d3c9f;
  border-radius: 50%;
}
#bottom_part .unit:nth-of-type(2) h2 {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1000;
  padding-top: 55px;
}
#bottom_part .unit h2 span {
  display: block;
  font-size: 20px;
  line-height: 1em;
  margin-bottom: 10px;
}
#bottom_part .unit:nth-of-type(2) h2 span {
  line-height: 1.3em;
}
#bottom_part .unit div.tate {
  position: absolute;
  left: 45px;
  top: 210px;
  color: #2d3c9f;
  font-size: 22px;
  line-height: 1.7em;
  font-weight: bold;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
#bottom_part .unit:nth-of-type(2) div.tate {
  left: auto;
  right: 50px;
}
#bottom_part .unit p {
  margin-bottom: 0;    
}
#bottom_part .unit p span {
  display: block;
  font-size: 12px;
  line-height: 1.8em;
  margin-top: 10px;
}

#bottom_part .unit:nth-of-type(1) div.text {
  position: absolute;
  left: 240px;
  top: 185px;
  width: 380px;
}
#bottom_part .unit .i01 {
  position: absolute;
  left: 650px;
  top: 160px;
  width: 432px;
}

#bottom_part .unit:nth-of-type(2) div.text {
  position: absolute;
  right: 200px;
  top: 200px;
  width: 320px;
}
#bottom_part .unit .i02 {
  position: absolute;
  right: 560px;
  top: 130px;
  z-index: 100;
  width: 350px;
}

#bottom_part .unit:nth-of-type(3) div.text {
  position: absolute;
  left: 240px;
  top: 130px;
  width: 380px;
}
#bottom_part .unit .i03 {
  position: absolute;
  left: 670px;
  top: 130px;
  width: 366px;  
}

#bottom_part .unit .i01 img,
#bottom_part .unit .i02 img,
#bottom_part .unit .i03 img {
  width: 100%;
  height: auto;
}

#bottom_part .unit .btn {
  margin-top: 40px;
}
#bottom_part .unit:nth-of-type(2) .btn {
  text-align: right;
}


a.more {
  display: inline-block;
  color: #fff;
  font-size: 15px;
  line-height: 1em;
  text-align: center;
  width: 170px;
  height: 55px;
  padding-top: 20px;
  background-color: #001478;
  border-radius: 10px;
}

h2.midashi,
h3.midashi {
  position: relative;
  color: #2d3c9f;
  font-size: 12px;
  line-height: 1em;
  text-align: center;
  font-weight: normal;
  margin-bottom: 40px;
}
h2.midashi span.eb,
h3.midashi span.eb {
  display: block;
  font-size: 25px;
  line-height: 1em;
  margin-bottom: 10px;
}

.hd h2 {
  font-size: 0;
  margin-bottom: 20px;
}
.hd h2 span {
  display: block;
  color: #2d3c9f;
  font-size: 12px;
  line-height: 1em;
  margin-top: 20px;
}
.hd p {
  font-weight: bold;
  line-height: 1.85em;
}


#about .hd {
  position: relative;
  width: 836px;
  height: 250px;
  padding-top: 90px;
  margin: auto;
}
#about .hd img.illust {
  position: absolute;
  top: 68px;
  right: 0;
  z-index: 1000;
  width: 380px;
  height: auto;
  transition: all 0.8s;
  opacity: 1;
}
#about .hd img.illust.ani {
  top: 60px;
  right: -30px;
  opacity: 0;
}

#concept {
  position: relative;
  width: 100%;
  min-height: 1950px;
  padding-top: 340px;
  margin: -95px 0 140px;  
  background: url("../img/about_back.png") no-repeat center top;
}
#concept img.mi {
  position: absolute;
  right: calc(((100% - 1400px) / 2) + 100px);
  top: 300px;
}
#concept img.t01 {
  position: absolute;
  left: calc(((100% - 1400px) / 2) + 155px);
  top: 120px;
  transition: all 0.8s;
  opacity: 1;
}
#concept img.t01.ani {
  top: 130px;
  opacity: 0;
}
#concept img.t02 {
  position: absolute;
  right: calc(((100% - 1400px) / 2) + 120px);
  top: 920px;
}
#concept img.t03 {
  position: absolute;
  right: calc(((100% - 1400px) / 2) + 120px);
  bottom: 20px;
}
#concept h3::before {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 25px);
  top: -46px;
  width: 50px;
  height: 33px;
  background: url("../img/icon/concept.png") no-repeat 0 0 / 50px 33px;
}
#concept .text01 {
  width: 500px;  
  margin: 0 auto 200px;
}
#concept .text01 p {
  line-height: 2.66em;
}
#concept .text01 p:nth-of-type(1) {
  color: #2d3c9f;
  font-size: 24px;
  line-height: 1.9em;
  text-align: center;
  font-weight: bold;
  margin-bottom: 50px;
}
#concept h4 {
  position: relative;
  color: #2d3c9f;
  width: 1200px;
  height: 140px;
  margin: 0 auto 80px;
}
#concept h4 span {
  display: inline-block;
  font-size: 20px;
  line-height: 1em;
  letter-spacing: 0.12em;
  height: 55px;
  padding: 17px 20px 0;
  background-color: #fff;
}
#concept h4 span:nth-of-type(2) {
  position: absolute;
  bottom: 0;
  left: 0;
  padding-left: 70px;
}
#concept h4 span:nth-of-type(2) img {
  position: absolute;
  left: 20px;
  bottom: 5px;
  width: 45px;
  height: auto;
}
#concept ul {
  display: flex;
  flex-wrap: wrap;
  width: 1060px;
  margin: auto;
  counter-reset: no;
}
#concept ul li {
  width: 300px;
}
#concept ul li:nth-of-type(2) {
  margin: 0 80px;
}
#concept ul li .illust {
  position: relative;
  width: 270px;
  height: 270px;
  margin: 0 auto 50px;
}
#concept ul li .illust::before {
  counter-increment: no; 
  content: "0"counter(no);
  display: block;
  position: absolute;
  left: -45px;
  top: -10px;
  z-index: 10;
  color: #2d3c9f;
  font-size: 33px;
  line-height: 1em;
  text-align: center;
  width: 70px;
  height: 70px;
  padding-top: 19px;
  background-color: #fff93c;
  border-radius: 50%;
}
#concept ul li .illust::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #fff;
  border: 3px solid #fff93c;
  border-radius: 50%;
}
#concept ul li .illust img {
  position: absolute;
  max-width: none;  
  height: auto;
}
#concept ul li:nth-of-type(1) .illust img {
  left: calc(50% - 184px);
  top: 35px;
  width: 368px;
}
#concept ul li:nth-of-type(2) .illust img {
  left: calc(50% - 99px);
  top: 40px;  
  width: 198px;
}
#concept ul li:nth-of-type(3) .illust img {
  left: calc(50% - 98px);
  top: 55px;  
  width: 196px;
}
#concept ul li h5 {
  color: #2d3c9f;
  font-size: 18px;
  line-height: 1.72em;
  text-align: center;
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid #000;
}
#concept ul li p {
  letter-spacing: 0.02em;
}


#profile {
  position: relative;
  width: 100%;
  padding: 75px 0 90px;
  background-color: rgba(255,229,60,0.13);
}
#profile .box01 {
  position: relative;
  width: 980px;
  margin: auto;
}
#profile .box01 img {
  position: absolute;
  left: 0;
  top: -150px;
  width: 280px;
  height: auto;
}
#profile .box01 .text {
  width: 620px;
  margin: 0 0 0 auto;
}
#profile .box01 h3,
#profile .box02 h3 {
  font-size: 16px;
  line-height: 1em;
  text-align: center;
  width: 80px;
  padding-bottom: 10px;
  margin-bottom: 30px;
  border-bottom: 1px solid #000;
}
#profile .box02 {
  position: relative;
  width: 830px;
  padding: 60px 105px;
  margin: 80px auto 90px calc(((100% - 980px) / 2) + 150px);
  background-color: #fff;
  border-radius: 35px;
}
#profile .box02 img.mi {
  position: absolute;
  left: -150px;
  top: calc(50% - 171px);
}
#profile .box02 table {
  width: 100%;
  margin-bottom: 35px;
}
#profile .box02 table tr td:nth-of-type(1) {
  position: relative;
  width: 160px;
}
#profile .box02 table tr td:nth-of-type(1)::after {
  content: "";
  display: block;
  position: absolute;
  right: 20px;
  top: calc(50% - 2px);
  width: 70px;
  height: 1px;
  border-top: 1px dotted #000;
}
#profile .box02 table tr td:nth-of-type(2) {
  width: calc(100% - 160px);
}
#profile .box02 .syozoku {
  display: flex;
  flex-wrap: wrap;
}
#profile .box02 .syozoku h3 {
  height: 27px;
  margin: 8px 40px 0 0;
}
#profile .box02 .syozoku p {
  letter-spacing: 0.02em;
  width: calc(100% - 120px);
}
#profile .hobby {
  text-align: center;
  width: 1060px;
  margin: auto;
}
#profile .hobby h3 {
  display: inline-block;
  color: #2d3c9f;
  font-size: 20px;
  line-height: 1em;
  letter-spacing: 0.06em;
  height: 55px;
  padding: 18px 30px 0;
  margin-bottom: 60px;
  background-color: #fff;
}
#profile .hobby ul {
  display: flex;
  flex-wrap: wrap;
}
#profile .hobby ul li {
  width: 220px;
  margin-right: 60px;
}
#profile .hobby ul li:last-of-type {
  margin-right: 0;
}
#profile .hobby ul li .illust {
  position: relative;
  margin-bottom: 30px;
}
#profile .hobby ul li .illust::after {
  content: "";
  display: block;
  width: 160px;
  height: 160px;
  margin: auto;
  border-radius: 50%;
  background-color: #fffb8d;
}
#profile .hobby ul li .illust::before {
  content: "";
  display: block;
  position: absolute;
  left: 20px;
  top: 0;
  z-index: 100;
  width: 58px;
  height: 35px;
  background-position: center center;
  background-repeat: no-repeat;
}
#profile .hobby ul li:nth-of-type(1) .illust::before {
  background-image: url("../img/01.png");
  background-size: 45px 35px;
}
#profile .hobby ul li:nth-of-type(2) .illust::before {
  background-image: url("../img/02.png");
  background-size: 54px 35px;
}
#profile .hobby ul li:nth-of-type(3) .illust::before {
  background-image: url("../img/03.png");
  background-size: 58px 35px;
}
#profile .hobby ul li:nth-of-type(4) .illust::before {
  background-image: url("../img/04.png");
  background-size: 54px 35px;
}
#profile .hobby ul li .illust img {
  position: absolute;
  height: auto;
}
#profile .hobby ul li:nth-of-type(1) .illust img {
  left: calc(50% - 60px);
  top: 30px;
  width: 110px;
}
#profile .hobby ul li:nth-of-type(2) .illust img {
  left: calc(50% - 47px);
  top: 30px;
  width: 94px;
}
#profile .hobby ul li:nth-of-type(3) .illust img {
  left: calc(50% - 60px);
  top: 30px;
  width: 120px;
}
#profile .hobby ul li:nth-of-type(4) .illust img {
  left: calc(50% - 53px);
  top: 35px;
  width: 106px;
}
#profile .hobby ul li h4 {
  color: #2d3c9f;
  font-size: 18px;
  line-height: 1em;
  text-align: center;
  height: 70px;
  padding-top: 25px;  
  margin-bottom: 25px;
  border-top: 1px solid #2d3c9f;
  border-bottom: 1px solid #2d3c9f;
}
#profile .hobby ul li:nth-of-type(2) h4 {
  line-height: 1.4em;
  letter-spacing: 0.01em;
  padding-top: 11px;
}
#profile .hobby ul li p {
  text-align: left;
  letter-spacing: 0.02em;
}


#office {
  position: relative;
  padding: 155px 0 130px;
}
#office img.mi {
  position: absolute;
  top: 230px;
  right: calc(((100% - 1400px) / 2) + 100px);
}
#office table {
  width: 580px;
  margin: auto;
}
#office table td {
  padding: 15px 0;
  border-bottom: 1px solid #000;
}
#office table tr td:nth-of-type(1) {
  width: 160px;
}
#office table tr td:nth-of-type(2) {
  width: calc(100% - 160px);
}
#office h3::before {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 16px);
  top: -46px;
  width: 32px;
  height: 34px;
  background: url("../img/icon/office.png") no-repeat 0 0 / 32px 34px;
}
#office .map {
  width: 1200px;
  margin: 90px auto 0;
}
#office .map iframe {
  width: 1200px;
  height: 480px;
}



#service .hd {
  position: relative;
  width: 1400px;
  height: 475px;
  margin: auto;
}
#service .hd .t {
  position: absolute;
  left: 880px;
  top: 110px;
  z-index: 2000;
}
#service .hd img.illust {
  position: absolute;
  top: 30px;
  right: 0;
  z-index: 1000;
  width: 1400px;
  height: auto;
  transition: all 0.4s;
  opacity: 1;
}
#service .hd img.illust.ani {
  top: 60px;
  opacity: 0;
}
#service .hd .t04 {
  position: absolute;
  left: 105px;
  top: 60px;
  z-index: 2000;
  transition: all 0.4s;
  opacity: 1;  
}
#service .hd .t04.ani {
  top: 70px;
  opacity: 0;
}
#service .hd .t05 {
  position: absolute;
  right: 30px;
  bottom: 80px;
  z-index: 2000;
  transition: all 0.4s;
  opacity: 1;  
}
#service .hd .t05.ani {
  bottom: 70px;
  opacity: 0;
}

#sc_wrap {
  position: relative;
  padding: 150px 0 50px;
  margin-bottom: 200px;
  background-color: rgba(255,229,60,0.13);
}
#sc_wrap::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: -200px;
  width: 100%;
  height: 200px;
  background: url("../img/service-price_back.png") no-repeat center bottom;
}
#sc_wrap img.mi {
  position: absolute;
  right: calc(((100% - 1400px) / 2 ) + 100px);
  top: 90px;
}
#sc_wrap img.t06 {
  position: absolute;
  left: calc(((100% - 1400px) / 2 ) + 90px);
  top: 900px;
}
#sc_wrap img.t07 {
  position: absolute;
  right: calc(((100% - 1400px) / 2 ) + 110px);
  top: 1600px;
}
#sc_wrap img.t08 {
  position: absolute;
  left: calc(((100% - 1400px) / 2 ) + 75px);
  top: 2700px;
}
#sc_wrap .illust02 {
  position: absolute;
  right: calc(((100% - 1400px) / 2) + 130px);
  bottom: -190px;
  z-index: 2000;
}
#sc_wrap h3.midashi::before,
#case h3.midashi::before {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 14px);
  top: -46px;
  width: 28px;
  height: 33px;
  background: url("../img/icon/sc.png") no-repeat 0 0 / 28px 33px;
}
#sc_wrap .unit {
  position: relative;
  width: 790px;
  margin: 0 auto 140px;
}
#sc_wrap .unit h4 {
  position: absolute;
  top: -80px;
  left: -164px;
  color: #2d3c9f;
  width: 84px;
}
#sc_wrap .unit:nth-of-type(2n) h4 {
  left: auto;
  right: -164px;
}
#sc_wrap .unit h4 span.eb {
  display: block;
  font-size: 73px;
  line-height: 1em;
  text-align: center;
  margin-bottom: 8px;
}
#sc_wrap .unit h4 span.waku {
  display: block;
  font-size: 18px;
  line-height: 1em;
  font-weight: bold;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  width: 100%;
  padding: 25px 32px 25px 0;
  background-color: #fff;
  border-top: 2px solid #2d3c9f;
  border-bottom: 2px solid #2d3c9f;
}
#sc_wrap .unit:nth-of-type(2) h4 span.waku,
#sc_wrap .unit:nth-of-type(3) h4 span.waku {
  line-height: 1.7em;
  padding-right: 10px;
}
#sc_wrap .unit .hyo {
  font-size: 0;
}
#sc_wrap .unit .text {
  width: 640px;
  margin: 50px auto 0;
}
#sc_wrap .unit .text p {
  margin-bottom: 0;
}
#sc_wrap .unit .omo {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  margin-top: 50px;
}
#sc_wrap .unit .omo h5 {
  color: #fff;
  font-size: 12px;
  text-align: center;
  width: 86px;
  height: 86px;
  padding-top: 25px;
  background-color: #2d3c9f;
  border-radius: 50%;
}
#sc_wrap .unit .omo p {
  font-size: 13px;
  letter-spacing: 0;
  width: calc(100% - 110px);
  margin-left: 24px;
}

#case {
  position: relative;
  padding: 100px 0 160px;
}
#case img.mi {
  position: absolute;
  left: calc(((100% - 1400px) / 2 ) + 100px);
  top: -110px;
}
#case .case_wrap {
  position: relative;
  width: 830px;  
  margin: 80px auto 0;
}
#case .case_wrap .swiper-slide {
  background-color: #fff;
}
#case .case_wrap .swiper-button-prev,
#case .case_wrap .swiper-button-next {
  width: 20px !important;
  height: 32px !important;
  background-repeat: no-repeat;
  background-position: 0 0;
}
#case .case_wrap .swiper-button-prev::after,
#case .case_wrap .swiper-button-next::after {
  display: none;
}
#case .case_wrap .swiper-button-prev {
  left: -50px;
  background-image: url(../img/s_arrow_prev.png);
}
#case .case_wrap .swiper-button-next {  
  right: -50px;
  background-image: url(../img/s_arrow_next.png);
}
#case .case_wrap .swiper-pagination-fraction {
  bottom: -30px !important;
  font-size: 16px;
  line-height: 1em;
}


#flow .hd {
  position: relative;
  width: 848px;
  height: 250px;
  padding-top: 90px;
  margin: auto;
}
#flow .hd img.illust {
  position: absolute;
  top: 65px;
  right: 0;
  z-index: 1000;
  width: 518px;
  height: auto;
  transition: all 0.4s;
  opacity: 1;
}
#flow .hd img.illust.ani {
  right: 20px;
  opacity: 0;
}

#flow .cont {
  position: relative;
  padding-bottom: 130px;
  margin: 240px 0 0;
  background-color: rgba(255,229,60,0.13);
}
#flow .cont::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: -240px;
  width: 100%;
  height: 240px;
  background: url("../img/flow_back.png") no-repeat center top;
}
#flow .cont img.mi {
  position: absolute;
  right: calc(((100% - 1400px) / 2) + 100px);
  top: -130px;
}
#flow .cont h3.midashi::before {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 22px);
  top: -56px;
  width: 44px;
  height: 42px;
  background: url("../img/icon/flow.png") no-repeat 0 0 / 44px 42px;
}
#flow .cont .inner {
  width: 1000px;
  margin: auto;
}
#flow .cont .inner .unit {
  position: relative;
  width: 100%;
  min-height: 105px;
  padding: 25px 0;
  margin-bottom: 80px;
  background-color: #fff;
  border-radius: 10px;
}
#flow .cont .inner .unit:nth-of-type(4) {
  margin-bottom: 110px;
}
#flow .cont .inner .unit::after {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 6px);
  bottom: -50px;
  width: 12px;
  height: 17px;
  background: url("../img/flow_arrow.png") no-repeat 0 0 / 12px 17px;
}
#flow .cont .inner .unit:nth-of-type(4)::after {
  bottom: -70px;
}
#flow .cont .inner .unit:last-of-type {
  border-bottom: 0;
}
#flow .cont .inner .unit:last-of-type::after {
  display: none;
}
#flow .cont .inner .unit:nth-of-type(1),
#flow .cont .inner .unit:nth-of-type(2),
#flow .cont .inner .unit:nth-of-type(5),
#flow .cont .inner .unit:nth-of-type(6) {
  padding-left: 150px;
}
#flow .cont .inner .unit:nth-of-type(1)::before,
#flow .cont .inner .unit:nth-of-type(2)::before,
#flow .cont .inner .unit:nth-of-type(5)::before,
#flow .cont .inner .unit:nth-of-type(6)::before {
  content: "";
  display: block;
  position: absolute;
  left: 115px;
  top: 28px;
  width: 1px;
  height: 50px;
  background-color: #000;
}
#flow .cont .inner .unit:nth-of-type(3),
#flow .cont .inner .unit:nth-of-type(4) {
  display: flex;
  flex-wrap: wrap;
  padding-left: 45px;
  padding-right: 45px;
}
#flow .cont .inner .unit:nth-of-type(1) .no,
#flow .cont .inner .unit:nth-of-type(2) .no,
#flow .cont .inner .unit:nth-of-type(5) .no,
#flow .cont .inner .unit:nth-of-type(6) .no {
  position: absolute;
  left: 40px;
  top: 38px;
}
#flow .cont .inner .unit:nth-of-type(3) .no,
#flow .cont .inner .unit:nth-of-type(4) .no {
  text-align: center;
  width: 100%;
  margin-bottom: 25px;
}
#flow .cont .inner .unit .no img {
  width: auto;
  height: 28px;
}
#flow .cont .inner .unit h3 {
  color: #2d3c9f;
  font-size: 18px;
  line-height: 1em;
}
#flow .cont .inner .unit:nth-of-type(1) h3 {
  margin-top: 20px;
}
#flow .cont .inner .unit:nth-of-type(2) h3,
#flow .cont .inner .unit:nth-of-type(5) h3,
#flow .cont .inner .unit:nth-of-type(6) h3 {
  margin: 5px 0 10px;
}
#flow .cont .inner .unit p {
  line-height: 1.78em;
  letter-spacing: 0;
  margin-bottom: 0;
}
#flow .cont .inner .unit:nth-of-type(4) .kome {
  position: absolute;
  left: 0;
  bottom: -35px;
  width: 100%;
}
#flow .cont .inner .unit .box {
  position: relative;
  width: 440px;
  height: 160px;
  padding: 30px 30px 0 128px;
  border: 1px solid #000;
}
#flow .cont .inner .unit .box:nth-of-type(2) {
  margin-right: 30px;
}
#flow .cont .inner .unit .box span {
  display: block;
  position: absolute;
  left: 30px;
  top: 40px;
  font-size: 12px;
  line-height: 1em;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0;
  width: 80px;
  height: 80px;
  padding-top: 35px;
  border-radius: 50%;
}
#flow .cont .inner .unit .box:nth-of-type(2) span {
  color: #fff;
  background-color: #2d3c9f;
}
#flow .cont .inner .unit .box:nth-of-type(3) span {
  color: #2d3c9f;
  background-color: #fff93c;
}
#flow .cont .inner .unit .box:nth-of-type(2) h3 {
  margin-top: 5px;
  margin-bottom: 25px;
}
#flow .cont .inner .unit .box:nth-of-type(3) h3 {
  line-height: 1.3em;
  margin-bottom: 5px;
}


#news_list {
  padding-bottom: 130px;
}
#news_list .hd {
  position: relative;
  width: 866px;
  height: 400px;
  padding-top: 90px;
  margin: auto;
}
#news_list .hd img.illust {
  position: absolute;
  top: 155px;
  right: 0;
  z-index: 1000;
  -webkit-transition: all 0.4s;
  -moz-transition: all 0.4s;
  -ms-transition: all 0.4s;
  -o-transition: all 0.4s;
  transition: all 0.4s;
  opacity: 1;
}
#news_list .hd img.illust.ani {
  top: 130px;
  opacity: 0;
}

#news_list .sub {
  width: 820px;
  margin: auto;
}
#news_list .sub h3 {
  color: #2d3c9f;
  font-size: 25px;
  line-height: 1em;
  text-align: center;
  margin-bottom: 40px;
}
#news_list .sub ul {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 60px;
}
#news_list .sub ul li {
  width: 148px;
  margin: 0 20px 20px 0;
}
#news_list .sub ul li:nth-of-type(5n) {
  margin-right: 0;
}
#news_list .sub ul li a {
  display: block;
  color: #2d3c9f;
  font-size: 15px;
  line-height: 1em;
  text-align: center;
  font-weight: bold;
  width: 100%;
  height: 36px;
  padding-top: 11px;
  background-color: #fff;
  border-radius: 5px;
}
#news_list .sub ul li a.this {
  color: #fff;
  background-color: #2d3c9f;
}

#news_list_wrap {
  width: 1120px;
  padding: 80px 0 85px;
  margin: auto;
  background-color: rgba(255,229,60,0.13);
  border-radius: 20px;
}
#news_list_wrap ul.list {
  display: flex;
  flex-wrap: wrap;
  width: 790px;
  margin: auto;
}
#news_list_wrap ul.list li {
  width: 210px;
  margin: 0 80px 60px 0;
}
#news_list_wrap ul.list li:nth-of-type(3n) {
  margin-right: 0;
}
#news_list_wrap ul.list li a {
  display: block;
  text-align: center;
}
#news_list_wrap ul.list li a .i {
  width: 210px;
  height: 210px;
  overflow: hidden;
  border-radius: 50%;
  margin-bottom: 25px;
}
#news_list_wrap ul.list li a .c {
  background-color: #fff;
}
#news_list_wrap ul.list li a .t {
  font-size: 16px;
  line-height: 1.5em;
  font-weight: bold;
}

.pagenavi {
  text-align: center;
  width: 100%;
}
.pagenavi span,
.pagenavi a {
  display: inline-block;
  color: #2d3c9f;
  font-size: 18px;
  line-height: 1em;
  letter-spacing: 0;
  font-weight: bold;
  text-align: center;
  width: 36px;
  height: 36px;
  padding: 9px 0 !important;
  margin: 0 5px !important;
  background-color: transparent;
  border: none !important;
  box-sizing: border-box;
	border-radius: 50%;
}
.pagenavi .current {
  position: relative;
  color: #fff;
	background-color: #2d3c9f;
  border: 1px solid #2d3c9f !important;
}
.pagenavi .nextpostslink,
.pagenavi .previouspostslink {
  display: inline-block;
  width: 20px;
  height: auto;
  padding: 0 !important;
  vertical-align: -1px;
  font-family: shippori-mincho,sans-serif;
  font-weight: 500;
  font-style: normal;
}


#news_single {
  padding: 100px 0 130px;
  background-color: rgba(255,229,60,0.13);
}
#news_single .wrap {
  position: relative;
  width: 1000px;
  padding: 70px 175px 60px;
  margin: auto;
  background-color: #fff;
  border-radius: 20px;
}
#news_single .wrap::after {
  content: "";
  display: block;
  position: absolute;
  right: -20px;
  top: 60px;
  width: 40px;
  height: 497px;
  background: url("../img/midashi/t_news-column.png") no-repeat 0 0 / 40px 497px;
}
#news_single .h {
  text-align: center;
  margin-bottom: 50px;
}
#news_single h2 {
  color: #2d3c9f;
  font-size: 24px;
  line-height: 2em;
  margin-bottom: 10px;
}
#news_single .wp-block-image {
  margin-bottom: 30px;
}
#news_single .wp-block-image img {
  height: auto;
}

.pager {
  width: 540px;
  margin: 60px auto 0;
}
.pager tr td {
  vertical-align: middle;
}
.pager tr td a {
  display: inline-block;
  position: relative;
  color: #2d3c9f;
  font-size: 13px;
  line-height: 1em;
  font-weight: bold;
}
.pager tr td:nth-of-type(1) {
  width: 30%;
  text-align: left;
}
.pager tr td:nth-of-type(1) a {
  height: 30px;
  padding: 9px 0 0 45px;
  background: url("../img/prev.png") no-repeat 1px 0 / 30px 30px;
}
.pager tr td:nth-of-type(2) {
  width: 40%;
  text-align: center;
}
.pager tr td:nth-of-type(2) a {
  color: #fff;
  font-size: 15px;
  width: 174px;
  height: 54px;
  padding-top: 20px;
  background-color: #2d3c9f;
  border-radius: 10px;
}
.pager tr td:nth-of-type(3) {
  width: 30%;
  text-align: right;
}
.pager tr td:nth-of-type(3) a {
  height: 30px;
  padding: 9px 45px 0 0;
  background: url("../img/next.png") no-repeat calc(100% - 1px) 0 / 30px 30px;
}


#contact {
  position: relative;
  width: 100%;
  background-color: rgba(255,229,60,0.13);
}
#contact .hd {
  position: relative;
  width: 784px;
  height: 320px;
  padding-top: 90px;
  margin: auto;
}
#contact .hd img.illust {
  position: absolute;
  top: 100px;
  right: 0;
  z-index: 1000;
  width: 419px;
  height: auto;
  transition: all 0.4s;
  opacity: 1;
}
#contact .hd img.illust.ani {
  top: 80px;
  opacity: 0;
}

#contact .ft {
  text-align: center;
  padding: 90px 0 125px;
}
#contact .ft a {
  display: inline-block;
}
#contact .ft a img {
  width: 62px;
  height: 62px;
}
#contact .ft p.line {
  color: #2d3c9f;
  font-size: 24px;
  line-height: 1em;
  letter-spacing: 0.2em;
  font-weight: bold;
  margin: 25px 0 55px;
}
#contact .ft p.line span {
  position: relative;
  display: inline-block;
}
#contact .ft p.line span::before,
#contact .ft p.line span::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  width: 2px;
  height: 24px;
  background-color: #2d3c9f;
}
#contact .ft p.line span::before {
  left: -15px;
  transform-origin: 0 100%;
  transform: rotate(-20deg);
}
#contact .ft p.line span::after {
  right: 5px;
  transform-origin: 100% 100%;
  transform: rotate(20deg);
}
#contact .qr {
  position: relative;
  width: 620px;
  min-height: 94px;
  padding-left: 125px;
  margin: auto;
}
#contact .qr .i {
  position: absolute;
  left: 0;
  top: 0;
  width: 94px;
  height: 94px;
}
#contact .qr p {
  line-height: 1.8em;
  text-align: left;
  font-weight: bold;
  padding-top: 10px;
  margin-bottom: 0;
}
#contact .inq {
  width: 1120px;
  padding: 130px 90px 80px;
  margin: auto;
  background-color: #fff;
  border-radius: 20px;
}
#contact .inq p.last {
  font-size: 12px;
  text-align: center;
  margin-top: 30px;
}
#contact table {  
  width: 100%;
}
#contact td {
  font-weight: bold;
  vertical-align: top;
}
#contact td p {
	margin-bottom: 0;
}
#contact tr td:nth-of-type(1) {
  position: relative;
  color: #000;
  padding: 15px 0 0 0;
  width: 200px;
}
#contact tr td:nth-of-type(1) span {
  color: #ec1c24;
}
#contact tr td:nth-of-type(2) {
  width: calc(100% - 200px);
  padding-bottom: 40px;
}
#contact tr td:nth-of-type(2) div {
  min-height: 60px;
  padding: 10px;
  background-color: #f1f1f1;
  border-radius: 8px;
}
#contact tr td:nth-of-type(2) div.r {
  padding: 10px 0 10px 10px;
}
#contact tr td:nth-of-type(2) div.r .first {
  margin-right: 100px;
}
#contact tr td:nth-of-type(2) div.c {
  padding: 15px 20px;
}
#contact tr td:nth-of-type(2) div.c .wpcf7-checkbox {
  display: flex;
  flex-flow: wrap;
}
#contact tr td:nth-of-type(2) div.ac {
  line-height: 1.8em;
  padding-left: 0 !important;
  background-color: transparent !important;
}
#contact tr td:nth-of-type(2) div.ac .wpcf7-list-item {
  margin-left: 0 !important;
}
#contact tr td:nth-of-type(2) div.ac span.a {
  font-weight: normal !important;
}

input[type="text"],
input[type="email"],
textarea {
  font-size: 14px;
  width: 100%;
  height: 30px;
  padding: 0 5px;
  background-color: #f1f1f1;
  border: none;
  -webkit-appearance : none;
  margin-top: 5px;
}
input[type="date"] {
  color: #a08452;
  background-color: #f1f1f1;
  border: none;
  -webkit-appearance : none;
}
textarea {
  height: 220px;
  margin-top: 10px;
}
label {
  cursor: pointer;
}
.wpcf7-checkbox .wpcf7-list-item {
  display: block;
}
#contact .btn {
  display: block;
  position: relative;
  width: 210px;
  height: 55px;
  margin: auto;
}
.wpcf7-submit {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1em;
  letter-spacing: 0.12em;
  text-align: center;
  font-weight: bold;
  width: 210px;
  height: 55px;
  border: 1px solid #2d3c9f;
  background-color: #2d3c9f;
  border-radius: 10px;
  transition: all 1s;
  -webkit-appearance: none;
  cursor: pointer;
}
.wpcf7-submit:hover {
  opacity: 0.45;
}


.wpcf7-response-output {
  display: none;
}

.inq table tr:nth-of-type(1) td:nth-of-type(2) span.wpcf7-list-item {
  margin: 0 42px 0 0;
}
.inq table tr:nth-of-type(1) td:nth-of-type(2) span.wpcf7-list-item:last-of-type {
  margin: 0;
}
.inq div.r label,
.inq div.c label {
  position: relative;
  padding-left: 18px;
  cursor: pointer;
}
.inq div.r label::before,
.inq div.c label::before {
  content: "";
  display: inline-block;
  position: absolute;
  left: 0;
  top: 2px;
  width: 10px;
  height: 10px;
  border: 1px solid #000;
  box-sizing: border-box;
}
.inq div.r label input[type="radio"],
.inq div.c label input[type="checkbox"] {
  display: none;
}
.inq div.r label input[type="radio"]:checked + .wpcf7-list-item-label::before,
.inq div.c label input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
  content: "";
  display: inline-block;
  position: absolute;
  left: 0;
  top: 2px;
  width: 10px;
  height: 10px;
  border: 1px solid #2d3c9f;
  background-color: #2d3c9f;
  box-sizing: border-box;
}
.inq div.r .wpcf7-list-item-label,
.inq div.c .wpcf7-list-item-label {
  font-size: 14px;
}
.inq div.r label span.wpcf7-list-item-label::before,
.inq div.r label span.wpcf7-list-item-label::after,
.inq div.c label span.wpcf7-list-item-label::before,
.inq div.c label span.wpcf7-list-item-label::after {
  display: none;
}

.inq div.t {
  padding: 0 !important;
  min-height: 0 !important;
}
.inq .accept {
  position: relative;
  padding-left: 0px;
  cursor: pointer;
}

.transmission {
  display: none;
  text-align: center;
  width: 1120px;
  padding: 200px 0;
  margin: auto;
  background-color: #fff;
  border-radius: 20px;
}
.transmission p {
  display: table-cell;
  font-size: 16px !important;
  line-height: 1.8em !important;
  font-weight: bold;
  letter-spacing: 0.1em;
  text-align: center;
  vertical-align: middle;
}
.sent .transmission {
  display: table;
}
.sent .inq {
  display: none;
}


/*----- reCAPTCHA ------*/
.reCAPTCHA_text p {
  font-size: 13px;
  letter-spacing: 0.18em;
	line-height: 1em;
  text-align: center;
  margin-top: 40px;
}
.grecaptcha-badge { visibility: hidden; }


.not-found {
  position: relative;
  text-align: center;
  width: 100%;
  height: calc(100vh - 335px);
}
.not-found p {
  position: relative;
  top: calc(50% + 20px);
  line-height: 2em;
}





.sa {
  opacity: 0 !important;
  transition: all 1.0s ease;
}

.sa.show {
  opacity: 1 !important;
  transform: none;
}
.sa--left {
  transform: translate(30px,0);
}
.sa--right {
  transform: translate(-30px,0);
}
.sa--up {
  transform: translate(0,30px);
}
.sa--down {
  transform: translate(0,-30px);
}

img.sss.show {
  transform: translate(0,0) scale(0.5) !important;
}
img.sss.sa--left {
  transform: translate(50px,0) scale(0.5);
}
img.sss.sa--right {
  transform: translate(-50px,0) scale(0.5);
}
img.sss.sa--up {
  transform: translate(0,50px) scale(0.5);
}
img.sss.sa--down {
  transform: translate(0,-50px) scale(0.5);
}
img.sss {
  position: absolute;
  transform: translate(0,0) scale(0.5);
  transform-origin: 0 100%;
}

.hide {
  opacity: 0 !important;
}

.md_transition {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: transform .6s cubic-bezier(.39, .575, .565, 1) 0.6s;
    z-index: 999999;
}
.md_transition::before {
    background: -webkit-gradient(linear, left bottom, left top, from(hsla(0, 0%, 100%, 0)), color-stop(33.33333%, #fff), color-stop(66.66667%, #fff), to(hsla(0, 0%, 100%, 0)));
    background: -o-linear-gradient(bottom, hsla(0, 0%, 100%, 0) 0, #fff 33.33333%, #fff 66.66667%, hsla(0, 0%, 100%, 0) 100%);
    background: linear-gradient(0deg, hsla(0, 0%, 100%, 0), #fff 33.33333%, #fff 66.66667%, hsla(0, 0%, 100%, 0));
    content: "";
    display: block;
    width: 100%;
    height: 300%;
    position: absolute;
    left: 0;
    top: -100%;
}
body.is_remove .md_transition {
    -webkit-animation: maskCloseTransition .6s cubic-bezier(.47, 0, .745, .715) 0s 1 forwards;
    animation: maskCloseTransition .6s cubic-bezier(.47, 0, .745, .715) 0s 1 forwards;
}
body:not(.is_fade) .md_transition {
    transform: translateY(-200%);
}
@-webkit-keyframes maskCloseTransition {
    0% { transform: translateY(200%); }
    to { transform: translate(0); }
}
@keyframes maskCloseTransition {
    0% { transform: translateY(200%); }
    to { transform: translate(0); }
}
