@charset "UTF-8";
@font-face {
  font-family:"Teko";
  src:url("../../font/teko-medium-webfont.woff") format("woff");
  font-weight:500;
  font-style:normal
}
@font-face {
  font-family:"Teko";
  src:url("../../font/teko-bold-webfont.woff") format("woff");
  font-weight:600;
  font-style:normal
}
@font-face {
  font-family:"NotoSansJP";
  src:url("../../font/NotoSansJP-Regular.otf") format("opentype");
  font-weight:400;
  font-style:normal
}
@font-face {
  font-family:"NotoSansJP";
  src:url("../../font/NotoSansJP-Medium.otf") format("opentype");
  font-weight:500;
  font-style:normal
}
@font-face {
  font-family:"NotoSansJP";
  src:url("../../font/NotoSansJP-Bold.otf") format("opentype");
  font-weight:600;
  font-style:normal
}
html {
	font-size: 62.5%;
}
body {
	font-family: "NotoSansJP", sans-serif;
	font-size: 1.6rem;
  line-height: 1.6;
	position: relative;
	color: #272727;
  margin: 0 auto;
}
h2{
  font-weight: bold;
}
h2.ttl{
  font-size: 18px;
  padding: 30px 0 30px 56px;
  letter-spacing: .06em;
  color: #fff;
  font-weight: bold;
  position: relative;
  z-index: 0;
  max-width: 1130px;
  margin: 0 auto 10vw;
  line-height: 1;
}
h2.ttl::before{
  content: "";
  background: #2C5EB7;
  height: 100%;
  width: calc(150% - 220px);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  border-radius: 0 110px 110px 0;
}
h2.ttl span{
  font-family: "Teko";
  font-size: 1.4rem;
  letter-spacing: .2em;
  margin-top: 10px;
  display: block;
  font-weight: 500;
}
h3{
  font-weight: bold;
}
/*モバイルファースト*/
.pc_only{
  display: none;
}
.sp_hidden {
  display: none;
}
.sp_visible {
  display:block;
}
/*header--------------------*/
header{
  position: fixed;
  top: 0;
  width: 100%;
  display: table;
  z-index: 4;
}
header .wrapper_header {
  display: flex;
  align-items: center;
  width: 100%;
  background: rgba(255,255,255,.95);
  z-index: 99;
  position: relative;
  justify-content: space-between;
}
header .logo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 15px 0 10px 20px;
}
header .e_btn a {
  display: flex;
  background: #2c5eb7;
  width: 62px;
  height: 62px;
  align-items: center;
  justify-content: center;
  font-family: "Teko";
  color: #fff;
  font-size: 2.0rem;
  letter-spacing: .06em;
  text-decoration: none;
  margin-left: 10px;
}
header nav {
  display: flex;
}
header nav ul.head_nav{
  display: none;
}
header nav ul li {
  width: auto;
  margin-left: 20px;
}
header nav ul li a{
  color: #272727;
  text-decoration: none;
}
header .toggle {
  position: relative;
  background: #333;
  width: 60px;
  height: 60px;
  margin-left: auto;
  display: table-cell;
  z-index: 10;
}
header .toggle span {
  width: 28px;
  height: 3px;
  background: #fff;
  position: absolute;
  top: 18px;
  left: calc(50% - 14px);
}
header .toggle span:nth-child(2) {
  top: 28px;
}
header .toggle span:nth-child(3) {
  top: 38px;
}
header .sp_nav.active {
  transform: translateY(0);
}
header .toggle.active span:nth-child(1) {
  opacity: 0;
}
header .toggle.active span:nth-child(2) {
  top: 28px;
  transform: rotate(45deg);
}
header .toggle.active span:nth-child(3) {
  top: 28px;
  transform: rotate(135deg);
}
header .toggle.active span {
  transition: all .3s;
}
header .sp_nav {
  display: block;
  position: absolute;
  width: 100%;
  background: #fff;
  padding: 30px;
  left: 0;
  z-index: 9;
  transition: all .6s;
  transform: translateY(calc(-100% - 60px));
  top: 60px;
  overflow: scroll;
  height: auto;
}
header .sp_nav > ul > li {
  border-bottom: 1px solid #f6f6f6;
}
header .sp_nav > ul > li > a, header .sp_nav > ul > li .parent_box a {
  display: block;
  font-size: 16px;
  font-weight: bold;
  color: #003c87;
  padding: 18px 0;
  position: relative;
  text-decoration: none;
}
/*fv_block------------------*/
.fv_block{
  margin-top: 60px;
  position: relative;
  line-height: 0;
}
.fv_block picture img{
  width: 100%;
}
.fv_block .btn_contact a{
  position: absolute;
  font-family: "Teko";
  font-size: 33px;
  color: #ffffff;
  background: #2c5eb7;
  display: inline-block;
  padding: 50px 60px;
  text-decoration: none;
  bottom: 0;
  left: 0;
  text-align: center;
  display: none;
}
picture{
  padding: 0;
  margin: 0;
}
.fv_block h1{
  position: absolute;
  width: 60%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  text-align: center;
}
.fv_block h1 img{
  width: 100%;
}
/*announce_block------------*/
.announce_block{
  background-image: linear-gradient(90deg, rgba(44, 94, 183, 1), rgba(90, 153, 216, 1) 30%, rgba(96, 194, 245, 1) 70%, rgba(124, 188, 49, 1));
  color: #ffffff;
  text-align: center;
  padding: 2vw 2vw 3vw;
  line-height: 1.4;
  margin-bottom: 6vw;
}
.announce_block h2{
  position: relative;
  display: inline-block;
  padding-left: 60px;
  padding-right: 50px;
  font-size: 2.2rem;
}
.announce_block h2::before{
  left: 0;
}
.announce_block h2::after{
  right: 0;
}
.announce_block h2::before,
.announce_block h2::after{
  position: absolute;
  content: "";
  background-image: url(../images/icn_student.svg);
  background-repeat: no-repeat;
  width: 45px;
  height: 35px;
  top: 50%;
}
.announce_block p{
  font-size:1.8rem;
  font-weight: normal;
}
/*top_block-----------------*/
.top_block{
  padding: 4vw;
}
.top_block .wrapper{
  overflow: hidden;
  margin-bottom: 20vw;
}
.top_block h2{
  font-size: 2.3rem;
  margin-bottom: 4vw;
}
.top_block p{
  margin-bottom: 6vw;
  font-size: 1.8rem;
}
.top_block img{
  width: 100%;
  border-radius: 10px;
}
.top_block a{
  cursor: pointer;
}
.top_block .movie{
  margin-bottom: 4vw;
}
.top_block .movie p{
  text-align: center;
  margin-bottom: 0;
}
/*modal*/
div.modal_bg {
  position: fixed;
  top: 0;
  width: 100%;
  height: 100vh;
  background-color: rgba(0,0,0,.9);
  z-index: 100;
  display: none;
}
div.modal_bg div.modal_video video {
  position: absolute;
  z-index: 200;
  top: 50%;
  left: 50%;
  -o-object-fit: cover;
  object-fit: cover;
  transform: translate(-50%, -50%);
  max-width: 940px;
  width: 100%;
  height: auto;
}
div.modal_bg .modal_close {
  z-index: 9999;
  width: 35px;
  height: 35px;
  position: fixed;
  right: 0;
  top: 0;
  text-decoration: none;
  text-align: center;
  padding: 0;
  color: #fff;
  font-size: 35px;
  font-style: normal;
  font-family: Arial,Baskerville,monospace;
  line-height: 35px;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
  border: 0;
  background: none;
  outline: none;
  box-shadow: none;
}
/*base_block----------------*/
.base_block{
  padding: 10vw 4vw 2vw;
  background: #E7F6FE;
  margin-bottom: 10vw;
}
.base_block h2{
  color: #003c87;
  text-align: center;
  margin-bottom: 6vw;
  font-size: 2.3rem;
}
.base_block p{
  text-align: center;
  margin-bottom: 6vw;
}
.base_block .card{
  position: relative;
  margin-bottom: 30vw;
}
.base_block .card dl{
  position: absolute;
  background: #ffffff;
  opacity: 0.9;
  top: 80%;
  left: 50%;
  transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  width: 86%;
  padding: 4vw;
}
.base_block .card dt{
  border-bottom: #333333 solid 1px;
  margin-bottom: .5em;
  padding-bottom: .5em;
}
.base_block .card dd p{
  text-align: left;
  margin-bottom: 0;
}
.base_block .card dd h3{
  font-size: 2.0rem;
}
.base_block .card dd h3 span{
  font-size: 1.3rem;
  font-weight: normal;
}
.base_block img{
  width: 100%;
}
/*personality_block---------*/
.personality_block{
  padding: 10vw 4vw;
}
.personality_block .wrapper{
  position: relative;
  display:inline-block;
  padding: 10vw 8vw 8vw;
}
.personality_block .wrapper::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 40px;
  border: 10px solid transparent;
  background: linear-gradient(135deg,rgb(44,94,183) 0%,rgb(90,153,216) 30%,rgb(96,194,245) 70%,rgb(124,188,49) 100%) border-box border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  -webkit-mask-composite: destination-out;
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  mask-composite: exclude;
}
.personality_block h2{
  font-size: 2.4rem;
  color: #2C5EB7;
  text-align: center;
  margin-bottom: 6vw;
}
.personality_block h2 span{
  font-family: "Teko";
  font-size: 1.4rem;
  color: #60C2F5;
  display: block;
}
.personality_block h3{
  text-align: center;
  font-size: 2.2rem;
  margin-bottom: 6vw;
}
.personality_block h3 span{
  display: block;
  font-size: 1.4rem;
  font-weight: 500;
}
.personality_block p{
  text-align: center;
  margin-bottom: 6vw;
  line-height: 1.8;
}
.personality_block img{
  width: 100%;
}
/*business_block------------*/
.business_block{
  position: relative;
  margin-bottom: 16vw;
}
.business_block::before {
  position: absolute;
  height: calc(100% + 50px);
    top: 110px;
    border-radius: 0;
    content: "";
    width: 100%;
    height: calc(100% + -85px);
    background: #E7F6FE;
    z-index: -1;
    right: 0;
}
.business_block h2.ttl::before{
  background: #2C5EB7;
  right: 0;
  left: inherit;
  border-radius: 110px 0 0 110px;
}
.business_block p{
  padding: 0 4vw;
  margin-bottom: 6vw;
  color: #003c87;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 10vw;
}
.business_block .wrapper{
  padding: 0 4vw;
}
.business_block .card{
  background: #ffffff;
  padding: 8vw 4vw 2vw;
  margin-bottom: 4vw;
}
.business_block .card p{
  color: #333333;
  font-size: 1.6rem;
  font-weight: normal;
  text-align: left;
}
.business_block .card p.txt_blue{
  color: #60C2F5;
  margin-bottom: 0;
  font-weight: bold;
  text-align: center;
}
.business_block .card h3{
  color: #003c87;
  font-size: 2.2rem;
  text-align: center;
  margin-bottom: 4vw;
}
.business_block .card .center_box{
  margin-bottom: 6vw;
}
.business_block .card img{
  width: 100%;
}
/*feature_block-------------*/
.slider_hidden .slide_cnt .slick-dots {
  padding-left: 0;
  text-align: center;
}
.slider_hidden .slide_cnt::before {
  top: -50px;
  padding-bottom: 6vw;
}
.slider_hidden .slide_cnt .slide_cnt_in .slick-prev,
.slider_hidden .slide_cnt .slide_cnt_in .slick-next{
  z-index: 2;
}
/*number_block--------------*/
.number_block{
  margin-bottom: 16vw;
}
#number #syudan {
  margin: 0 30px;
}
#number::after {
  top: 110px;
}
#number h2.ttl{
  padding: 30px 0 30px 56px;
}
#number h2.ttl::before {
  width: calc(150% - 220px);
  right: 0;
  left: inherit;
  border-radius: 110px 0 0 110px;
}
/*information_block---------*/
.information_block h2.ttl::before{
  background: #003c87;
  left: 0;
  border-radius: 0 110px 110px 0;
}
.information_block h3{
  text-align: center;
  font-size: 2.2rem;
  margin-bottom: 6vw;
}
.information_block table{
  border-bottom: #E8EEF9 solid 2px;
  margin-bottom: 14vw;
  width: 100%;
}
.information_block th{
  display: block;
  background: #E8EEF9;
  color: #003c87;
  font-weight: bold;
  padding: 4vw;
}
.information_block td{
  display: block;
  padding: 4vw;
}
.information_block ul.welfare{
  display: flex;
  flex-wrap :wrap;
  justify-content:space-between;
  background: #E8EEF9;
  padding: 2vw 2vw 1vw;
  margin-bottom: 14vw;
}
.information_block ul.welfare li{
  background: #ffffff;
  width: 50%;
  width: calc(50% - 1vw);
  margin-bottom: 2vw;
  padding: 10px;
  box-sizing: border-box;
  text-align: center;
}
.information_block ul.welfare li::before{
  content: "";
  display: inline-block;
  background-position: top center;
  background-repeat: no-repeat;
  width: 100%;
  height: 44px;
}
.information_block ul.welfare li:nth-child(1)::before{
  background-image: url(../images/icn_info_01.svg);
}
.information_block ul.welfare li:nth-child(2)::before{
  background-image: url(../images/icn_info_02.svg);
}
.information_block ul.welfare li:nth-child(3)::before{
  background-image: url(../images/icn_info_03.svg);
}
.information_block ul.welfare li:nth-child(4)::before{
  background-image: url(../images/icn_info_04.svg);
}
.information_block ul.welfare li:nth-child(5)::before{
  background-image: url(../images/icn_info_05.svg);
}
.information_block ul.welfare li:nth-child(6)::before{
  background-image: url(../images/icn_info_06.svg);
}
.information_block ul.welfare li:nth-child(7)::before{
  background-image: url(../images/icn_info_07.svg);
}
.information_block ul.welfare li:nth-child(8)::before{
  background-image: url(../images/icn_info_08.svg);
}
.information_block td dl {
  display: flex;
}
.information_block td dt {
  width: 8em;
}
.information_block li a {
  color: #333333;
}
/*entry_block---------------*/
.entry_block h2.ttl::before{
  right: 0;
  left: inherit;
  border-radius: 110px 0 0 110px;
}
.entry_block .wrapper{
  padding: 0 4vw;
}
.entry_block p{
  text-align: center;
  margin-bottom: 6vw;
}
.entry_block .tel_box {
  padding-top: 20px;
  padding-bottom: 20px;
  border: 5px solid rgba(105,142,213,.5);
  margin-bottom: 6vw;
}
.entry_block .tel_box p{
  margin-bottom: 2vw;
}
.entry_block .tel_box .tel_col .tel {
  display: block;
  font-family: "Teko";
  color: #003c87;
  font-size: 3.2rem;
  letter-spacing: .07em;
  line-height: 1;
  text-align: center;
}
.entry_block .tel_box .tel_col .tel a{
  text-decoration: none;
  font-size: 4.0rem;
  color: #003c87;
}
.entry_block .entry_form{
  margin-bottom: 8vw;
}
.entry_block p.thanks {
  font-size: 1.8rem;
}
/*satori form*/
.satori__custom_form_52b1752233682f05_css .satori__submit_group .satori__btn {
  padding: 40px 120px;
  border-radius: 90px;
}
.satori__custom_form_52b1752233682f05_css .satori__require {
  background: #7CBC31 !important;
  font-size: 1.3rem !important;
  padding: 5px 6px 8px !important;
  color: #ffffff !important;
  border-radius: 2px;
}
.satori__custom_form_52b1752233682f05_css a, .satori__custom_form_52b1752233682f05_css a:visited {
  color: #2C5EB7 !important;
  text-decoration: underline !important;
}
input:-internal-autofill-selected {
  appearance: menulist-button;
  background-image: none !important;
  background-color: -internal-light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 1)) !important;
  color: fieldtext !important;
}
/*pagetop-------------------*/
.pagetop::before, .pagetop::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}
.pagetop::before {
  left: 22px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  text-align: center;
}
/*pagetop--------------------*/
.pagetop{
  position: fixed;
  display: block;
  width: 52px;
  height: 52px;
  z-index: 10;
  bottom: 10px;
  right: 10px;
  background-color: rgba(0, 0, 0, 0.7);
  cursor: pointer;
}
.pagetop:hover {
  opacity: 0.7;
}
.pagetop::before {
  left: 22px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  text-align: center;
}
.pagetop::before, .pagetop::after {
  position: absolute;
  top: 50%;
  bottom: 50%;
  margin: auto;
  content: "";
}
.pagetop a{
  display: none;
}
/*footer--------------------*/
footer{
  background: #333333;
  color: #ffffff;
  padding: 30px 25px;
}
footer small{
  text-align: center;
  margin: 0 auto;
  font-size: 1.1rem;
  display: block;
}
footer a{
  color: #ffffff;
  text-decoration: none;
}
footer .logo{
  margin-bottom: 4vw;
}
footer .logo img{
  width: 202px;
}
footer ul{
  margin-bottom: 6vw;
}
footer ul li{
  font-size: 1.3rem;
}
footer ul li::after{
  font-variant: normal;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  font-family: "Font Awesome 5 Free";
  font-weight: 400;
  content: '\f24d';
  margin-left: 5px;
}
#about,
#base,
#personality,
#business,
#feature,
#number,
#info,
#entry{
  padding-top: 60px;
  margin-top: -60px;
}
@media screen and (min-width:768px) {
/* 768px以上に適用されるCSS（PC/タブレット用 */
body{
  margin: 0;
  padding: 0;
}
.sp_only{
  display: none;
}
.pc_only{
  display: block;
}
.sp_visible {
  display: none;
}
.sp_hidden {
  display:inline-block;
}
.wrapper{
  margin: 0 auto;
  max-width: 1028px;
}
h2.ttl{
  font-size: 3.2rem;
  letter-spacing: .06em;
  font-weight: bold;
  position: relative;
  z-index: 0;
  margin: 0 auto 4vw;
  padding: 70px 0 70px 50px;
  max-width: 1000px;
  line-height: 1;
}
h2.ttl::before{
  width: calc(150% - 0px);
}
/*header--------------------*/
header .logo {
  padding:0 0 0 35px;
  width: 22vw;
  min-width: 220px;
  margin-right: 20px;
}
header .sp_nav{
  display: none;
}
header .toggle {
  display: none;
}
header .e_btn a {
  display: flex;
  background: #2c5eb7;
  width: 120px;
  height: 100px;
  align-items: center;
  justify-content: center;
  font-family: "Teko";
  color: #fff;
  font-size: 3.0rem;
  letter-spacing: .06em;
  text-decoration: none;
  margin-left: 20px;
}
header nav {
  width: auto;
}
header nav ul.head_nav{
  display: inherit;
  display: flex;
  flex-wrap: wrap;
}
header nav ul {
  display: flex;
}
header nav ul li {
  display: flex;
  align-items: center;
  padding: 0 1em;
  font-size: 1.4rem;
  font-weight: 500;
}
header nav ul li.e_btn {
  padding: 0;
}
/*fv_block------------------*/
.fv_block{
  margin-top: 100px;
}
.fv_block h1{
  top: 50%;
  width: 20vw;
}
.fv_block h1 img{
  width: 100%;
}
.fv_block .btn_contact a{
  display: none;
}
/*announce_block------------*/
.announce_block{
  padding: 20px 2vw;
  line-height: 1.8;
}
.announce_block h2{
  font-size: 2.6rem;
}
/*top_block-----------------*/
.top_block .wrapper {
  margin-bottom: 6vw;
}
.top_block .left_box{
  float: left;
  margin-right: 36px;
}
.top_block .right_box{
  float: left;
}
.top_block h2{
  font-size: 3.6rem;
  margin-bottom: 2vw;
}
.top_block h2 span.txt_large{
  font-size: 6.0rem;
}
.top_block p{
  margin-bottom: 2vw;
  line-height: 1.8;
}
.top_block .movie {
  margin-bottom: 2vw;
}
.top_block .movie p {
  margin-bottom: 10vw;
}
/*base_block----------------*/
.base_block{
  clear: both;
  padding: 6vw 0 0;
  margin-bottom: 8vw;
  height: 93vh;
}
.base_block h2{
  font-size: 2.8rem;
  margin-bottom: 2vw;
}
.base_block h2.ttl::before {
  content: "";
  background: #003c87;
  height: 100%;
  width: calc(150% - 220px);
  position: absolute;
  top: 0;
  left: -400px;
  z-index: -1;
  border-radius: 0 130px 130px 0;
}
.base_block p{
  font-size: 2.0rem;
  margin-bottom: 4vw;
}
.base_block .wrapper{
  position: relative;
  padding-bottom: 30vw;
}
.base_block .wrapper .card{
  position: absolute;
  width: 45vw;
  height: 260px;
  margin-bottom: 2vw;
}
.base_block .wrapper .card:nth-child(1){
  left: 0;
}
.base_block .wrapper .card:nth-child(2){
  right: 0;
  top: 10vw;
}
.base_block .wrapper .card:nth-child(3){
  left: 0;
  top: 35vh;
}
.base_block .card dl {
  padding: 2vw;
  top: 20vh;
}
.base_block .card dd h3 {
  font-size: 2.4rem;
}
.base_block .card dd p {
  font-size: 1.6rem;
}
/*personality_block---------*/
.personality_block{
  clear: both;
  padding: 8vw 0;
}
.personality_block .wrapper{
 display: inherit;
 padding: 4vw;
}
.personality_block h2{
  font-size: 4.0rem;
  margin-bottom: 3vw;
}
.personality_block h2 span {
  font-size: 1.6rem;
}
.personality_block h3 {
  font-size: 3.6rem;
  margin-bottom: 3vw;
}
.personality_block h3 span {
  font-size: 2.0rem;
}
.personality_block p {
  font-size: 1.8rem;
  line-height: 2.0;
  margin-bottom: 3vw;
}
.personality_block img{
  max-width: 750px;
  margin: 0 auto;
  display: block;
}
/*business_block------------*/
.business_block{
  overflow: hidden;
  margin-bottom: 8vw;
}
.business_block::before{
  top:230px
}
.business_block .wrapper {
  padding: 0;
}
.business_block h2.ttl::before {
  left: auto;
  right: -487px;
  border-radius: 130px 0 0 130px;
}
.business_block h2.ttl{
  padding: 70px 0 70px 50px;
}
.business_block p {
  font-size: 2.4rem;
  margin-bottom: 4vw;
}
.business_block .card{
  overflow: hidden;
  padding: 2vw;
  margin-bottom: 1vw;
}
.business_block .card:last-child{
  margin-bottom: 7vw;
}
.business_block .card .left_box_col2{
  float: left;
  width: 50%;
}
.business_block .card .right_box_col2{
  float: right;
  width: 48%;
}
.business_block .card .left_box{
  float: left;
  width: 34%;
  margin-right: 2%;
}
.business_block .card .center_box{
  float: left;
  width: 28%;
  margin-bottom: 0;
  padding-top: 2vw;
}
.business_block .card .right_box{
  float: right;
  width: 34%;
  margin-left: 2%;
}
.business_block .card h3 {
  margin-bottom: 1vw;
  font-size: 3.0rem;
}
.business_block .card p.txt_blue {
  font-size: 1.8rem;
}
.business_block .card p{
  padding: 0;
  margin-bottom: 0;
}
/*feature_block-------------*/
.feature_block h2.ttl::before {
  background: #2c5eb7;
  width: calc(150% - 50px);
  left: -400px;
  border-radius: 0 130px 130px 0;
}
.slider_hidden .slide_cnt::before {
  padding: 0;
  border-radius: 0 0 0 50px;
  top: -110px;
}
#feature .ttl{
  padding: 70px 0 70px 50px;
}
/*number_block--------------*/
.number_block .inner {
  max-width: 1028px;
  margin: 0 auto;
}
#number{
  padding-bottom: 6vw;
  margin-bottom: 6vw;
}
#number::after {
  top: 235px;
}
#number h2.ttl {
  padding: 70px 0 70px 50px;
  max-width: 1000px;
}
#number h2.ttl::before{
  border-radius: 130px 0 0 130px;
  right: -487px;
  left: inherit;
  width: calc(150% - 0px);
}
#number #syudan {
  margin: 0;
}
#feature .ttl,
#number .ttl {
  max-width: 1000px;
}
#feature .ttl::before,
#number .ttl::before {
  width: calc(150% - 0px);
  left: -487px;
}
/*information_block---------*/
.information_block .wrapper{
  width: 1028px;
  margin: 0 auto;
}
.information_block h2.ttl::before {
  left: auto;
  left: -487px;
  border-radius: 0 130px 130px 0;
}
.information_block h3{
  font-size: 3.2rem;
  text-align: left;
  margin-bottom: 40px;
}
.information_block table{
  margin: 0 auto;
  border-bottom: #707070 solid 1px;
  margin-bottom: 6vw;
  width: 100%;
}
.information_block tr{
  border-top: #707070 solid 1px;
}
.information_block th {
  display: table-cell;
  width: 25%;
  padding: 20px;
  vertical-align: middle;
}
.information_block td {
  display: table-cell;
  padding: 20px;
}
.information_block ul.welfare{
  padding: 8px 8px 0;
  margin-bottom: 8vw;
}
.information_block ul.welfare li {
  width: calc(25% - 8px);
  margin-bottom: 8px;
}
/*entry_block---------------*/
.entry_block{
  overflow: hidden;
}
.entry_block .wrapper {
  padding: 0;
}
.entry_block p{
  margin-bottom: 2vw;
}
.entry_block p.thanks {
  font-size: 2.0rem;
  font-weight: bold;
}
.entry_block h2.ttl{
  padding: 70px 0 70px 50px;
}
.entry_block h2.ttl::before {
  left: auto;
  right: -460px;
  right: -487px;
  border-radius: 130px 0 0 130px;
}
.entry_block .tel_box {
  margin-bottom: 2vw;
  padding: 20px 0 10px;
}
.entry_block .tel_box p{
  margin-bottom: 1vw;
  font-size: 2.0rem;
}
.entry_block .tel_box .tel_col .tel a{
  font-size: 6.0rem;
}
.satori__custom_form_52b1752233682f05_css .satori__btn {
  padding: 32px 0 !important;
  width: 390px !important;
  border-radius: 45px !important;
  font-size: 2.0rem !important;
  font-weight: bold !important;
}
/*footer--------------------*/
footer .wrapper{
  display: flex;
}
footer .logo {
  margin-bottom: 2vw;
  margin-right: auto;
}
footer ul {
  margin-bottom: 2vw;
  display: flex;
  text-align: right;
}
footer ul li{
  margin-left: 1em;
}
footer ul li a:hover{
  opacity: .8;
}
#about,
#base,
#personality,
#business,
#feature,
#number,
#info,
#entry{
  padding-top: 130px;
  margin-top: -130px
}
}
@media screen and (min-width: 1280px) {
/* 1280px以上に適用されるCSS（PC用） */
/*header--------------------*/
header .logo {
  width: auto;
  margin-right: 35px;
}
header nav ul.head_nav {
  width: auto;
}
header nav {
  width: calc(100% - 410px);
  display: flex;
  justify-content: end;
}
/*fv_block------------------*/
.fv_block h1{
  top: 40%;
}
.fv_block .btn_contact a{
  display: block;
  font-size: 3.3rem;
  padding: 40px 0;
  bottom: calc(10vh - 7vh);
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  text-align: center;
  width: 20vw;
  letter-spacing: .06em;
}
.fv_block .btn_contact a:hover{
  opacity: .9;
}
/*top_block-----------------*/
.top_block p{
  font-size: 1.6rem;
}
.top_block .movie p {
  margin-bottom: 0;
}
/*base_block----------------*/
.base_block{
  height: auto;
}
.base_block .wrapper {
  padding-bottom: 60vh;
}
.base_block .wrapper .card{
  position: absolute;
  width: 480px;
  height: auto;
  margin-bottom: 2vw;
}
.base_block .wrapper .card:nth-child(3){
  left: 0;
  top: 57vh;
}
.base_block .card dl {
  padding: 2vw;
  top: 270px;
}
/*feature_block-------------*/
#feature h2.ttl{
  padding: 70px 0;
}
.information_block h2.ttl{
  padding: 70px 0;
}
/*entry_block---------------*/
.satori__custom_form_52b1752233682f05_css .satori__btn {
  margin-bottom: 0 !important;
}
}