/* CSS Document */
@charset "utf-8";


/* TOP */
/* ---------------------------------------------------------------------------- */

/* about */
/* ---------------------------------------------------------------------------- */
div[class^="sec"] {
  text-align: left;
}

.txt-small{
  font-size: .7em;
}

.flexbox {
  display: flex;
  justify-content: space-between;
}
.flexbox::before, .flexbox::after {
  content: none;
}

/* sec1 */
.sec1 {
  padding: 80px 0 148px;
}
.be-like-sports {
  align-items: center;
  gap: 80px;
}
.be-like-sports .flex-txt {
  max-width: 440px;
}
.be-like-sports .flex-txt h2 {
  font-size: 40px;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 40px;
}
.be-like-sports .flex-txt h2 .underline {
  background-repeat: repeat-y;
  background-size: 100% 1.5em;
  display: inline;
}
.be-like-sports .flex-txt h2 .underline.underline-orange {
  /*background-image: linear-gradient(transparent 80%, #ed6c00 80%);*/
  text-decoration-line: underline;
  text-decoration-color: #ed6c00;
  text-decoration-thickness: 4px;
  text-underline-offset: 8px;
  text-decoration-skip-ink: none;
}
.be-like-sports .flex-txt p {
  font-weight: 700;
  letter-spacing: .043em;
}
.sec1 .logo-aadp {
  margin-top: 5px;
  max-height: 15px;
  width: auto;
}

@media screen and (max-width: 767px) {
  .sec1 {
    padding-bottom: 120px;
  }
  .be-like-sports {
    flex-direction: column;
    gap: 30px;
  }
  .be-like-sports .flex-txt h2 {
    font-size: 28px;
    line-height: 45.81px;
    margin-bottom: 30px;
  }
  .be-like-sports .flex-txt p {
    line-height: 23px;
    letter-spacing: .02em;
  }
  .be-like-sports .flex-img {
    margin: 0 -15px;
  }
}

/* sec2 */
.sec2 {
  
}
.catch{font-size: 35px; line-height: 1.4; letter-spacing: .02em; margin-bottom: 98px; text-align: center; font-weight: 700; position: relative; z-index: 1;}
.catch .orange{color:#ed6c00;}

.concept-wrap{background:#fdf4e3 url(../img/bg-sec2_01.jpg) no-repeat 0 0 / cover; padding-bottom: 120px;}
.concept-wrap h2.hukidashi{font-size: 34px; letter-spacing: .05em; line-height: 1.466; position: relative; background: #ed6c00; color:#FFF; width: 530px; text-align: center; margin: auto; transform: translateY(-30px); padding: 5px 30px; font-weight: 700;}
.concept-wrap h2.hukidashi::before{content:""; display: inline-block; position: absolute; border-top: 16px solid #ed6c00; border-left: 10px solid transparent; border-right: 10px solid transparent; left: 50%; bottom: 0; transform: translate(-50%,100%);}
.concept-wrap .content{width: 758px; margin: auto;}
.concept-wrap h2.hukidashi + p{font-size: 16px; line-height: 1.6; letter-spacing: .053em; margin: 10px 0 50px; font-weight: 500;}
.concept-wrap .feature h3{background: #ed6c00; color:#FFF; border-radius: 100px; text-align: center; padding: 3px 0; font-size: 18px; font-weight: 700; letter-spacing: .02em; ;}
.concept-wrap .feature:nth-of-type(1) p{font-size: 27px; letter-spacing: .02em; padding: 20px 0 45px; text-align: center; font-weight: 700; line-height: 1.5;}
.concept-wrap .feature ul{padding: 28px 0;}
.concept-wrap .feature ul li{display: flex; align-items: center; justify-content: flex-start; font-size: 23px; letter-spacing: .03em; line-height: 1.565; font-weight: 700;}
.concept-wrap .feature ul li::before{ content: ""; display: inline-block; width: 12px; height: 12px; border-radius: 100px; background: #ed6c00; margin-right: 4px;}
.concept-wrap .feature:nth-of-type(3) h4{font-size: 23px; letter-spacing: .02em; line-height: 1.565; text-align: center; margin: 20px auto; font-weight: 700;}
.concept-wrap .feature:nth-of-type(3) h4 + p{font-size: 16px; letter-spacing: .053em; line-height: 1.6; font-weight: 500;}

.concept-detail {
}
.concept-detail .flexbox {
  background: #FFF;
  margin-bottom: 20px;
  border-radius: 10px;
}
.concept-detail .flexbox:nth-of-type(even) {
  flex-direction: row-reverse;
}
.concept-detail .flexbox:last-of-type {
  margin-bottom: 0;
}
.concept-detail .flexbox .flex-img {
  min-width: 298.4902px;
  max-width: 100%;
}
.concept-detail .flexbox .flex-img img {
  border-radius: 10px 0 0 10px;
}
.concept-detail .flexbox:nth-of-type(even) .flex-img img {
  border-radius: 0 10px 10px 0;
}
.concept-detail .flexbox .flex-txt {
  padding: 30px 50px 30px 54px;
}
.concept-detail .flexbox .flex-txt h3 {
  font-size: 24px;
  font-weight: 700;
  /*line-height: 2.75;*/
  line-height: 1;
  margin-bottom: 20px;
  color: #ed6c00;
  display: flex;
  align-items: center;
  gap: 10px;
}
.concept-detail .flexbox .flex-txt h3 .numbering {
  font-size: 36px;
  font-family: "Bahnschrift", YuGothic, "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "Yu Gothic", "游ゴシック", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Arial, Helvetica, Verdana, sans-serif;
}
.concept-detail .flexbox .flex-txt h3 img {
  margin: 0 2px 0px 0;
}
.concept-detail .flexbox .flex-txt p {
  font-weight: 500;
  line-height: 26px;
  letter-spacing: .06em;
}

@media screen and (max-width:767px){
  .catch{font-size: 25px;}
  .concept-wrap{padding-bottom: 80px; background:#FDF4E3;}
  .concept-wrap .content{width:100%;}
  .concept-wrap h2.hukidashi{max-width: 320px; box-sizing:border-box; font-size: 28px; line-height: 32px; padding: 10px;}
  .concept-wrap h2.hukidashi + p{padding: 0; margin-top: 0; margin-bottom: 35px; font-size: 15px; line-height: 23px; letter-spacing: 0.02em;}
  .concept-wrap .feature h3{padding: 5px 0; margin: 0 auto; font-size: 16.92px; border-radius: 11.2px;}
  .concept-wrap .feature:nth-of-type(1) p{font-size: 24px; line-height: 32px; padding-bottom: 40px;}
  .concept-wrap .feature:nth-of-type(1) p .txt-small {
    display: inline-block;
    margin-top: 10px;
    font-size: 16px;
    line-height: 24px;
  }
  .concept-wrap .feature ul{padding:28px 10px;}
  .concept-wrap .feature ul li{position: relative; padding-left: 1em;}
  .concept-wrap .feature ul li:not(:last-of-type){margin-bottom: 10px;}
  .concept-wrap .feature ul li::before{position: absolute; left: 0; top:.5em}
  .concept-wrap .feature:nth-of-type(3) h4{padding: 0 10px;}
  .concept-wrap .feature:nth-of-type(3) h4 + p{padding: 0 10px;}
  
  .sec2 .concept-wrap .content {
    padding: 0 15px;
    box-sizing: border-box;
  }
  .concept-detail .flexbox:nth-of-type(odd), .concept-detail .flexbox:nth-of-type(even) {
    flex-direction: column;
  }
  .concept-detail .flexbox:nth-of-type(odd) .flex-img img, .concept-detail .flexbox:nth-of-type(even) .flex-img img {
    width: 100%;
    border-radius: 10px 10px 0 0px;
  }
  .concept-detail .flexbox .flex-txt {
    padding: 25px;
  }
  .concept-detail .flexbox .flex-txt h3 {
    font-size: 20px;
    gap: 8px;
    margin-bottom: 15px;
  }
  .concept-detail .flexbox .flex-txt h3 .numbering {
    font-size: 30px;
  }
  .concept-detail .flexbox .flex-txt h3 img {
    width: 12px;
  }
  .concept-detail .flexbox .flex-txt p {
    font-size: 14px;
    line-height: 22px;
    letter-spacing: 0;
  }
}

/* sec3 */
.sec3 {
  
}
.p-top__need { background: url(../img/need_bg1.png) center top; padding-top: 48px; position: relative; color: #fff; }
.p-top__need:before { display: block; content: ""; position: absolute; width: 100%; height: 404px; left: 0; top: -60px; background: url(../img/need_img1.png) no-repeat center top; z-index: 1; }
.p-top__need-wrap { padding-bottom: 102px; background: url(../img/need_img2.png) no-repeat calc(50% + 22px) bottom; position: relative; z-index: 2; }
.p-top__need .heading { text-align: center; margin-bottom: 22px; }
.p-top__need .heading h2 { font-size: 25px; font-size: 2.5rem; line-height: 140%; font-weight: 700; }
.p-top__need .content dl { margin-top: 0; margin-bottom: 6px; }
.p-top__need .content dl:last-child { margin-bottom: 0; }
.p-top__need .content dt { font-size: 18px; font-size: 1.8rem; background: #ed6c00; cursor: pointer; font-weight: 600; padding:5px 42px 5px 30px; position: relative;}
/* 260216 */
.p-top__need .content dt::before, .p-top__need .content dt::after {
  content: "";
	position: absolute;
  width: 16px;
  height: 1px;
  background: #fff;
  right: 30px;
  transition: all .4s ease-in-out;
}
.p-top__need .content dt::before {
  transform: rotate(90deg);
  top: 50%;
}
.p-top__need .content dt::after {
  top: 50%;
}
.p-top__need .content dt.is-open::before {
  transform: rotate(180deg);
}
.p-top__need .content dt.is-open::after {
  opacity: 0;
}
/* /260216 */
/* .p-top__need .content dt h3 { background: url(../img/arrow_2-down.svg) no-repeat right center; background-size: auto 15px; padding-top: 5px; padding-bottom: 5px; padding-right: 30px; } */
.p-top__need .content dt.is-open h3 { background-image: url(../img/arrow_2-up.svg); }
.p-top__need .content dd { display: none; background: #fff; padding: 20px 26px; color: #231815; }
.p-top__need .content dd p{font-weight: 500;}
.p-top__need .content dd a.orange { color: #ed6c00; }
.p-top__need .content dd em { color: #ed6c00; }
.p-top__need .content .seven-abilities { margin-top: 15px; }
.p-top__need .content .seven-abilities li { float: left; width: 23.875%; margin-left: 1.5%; margin-bottom: 1.5%; border-radius: 8px; -webkit-box-sizing: border-box; box-sizing: border-box; background: #ed6c00; color: #fff; padding: 12px 15px; }
.p-top__need .content .seven-abilities li:nth-child(4n+1) { clear: both; margin-left: 0; }
.p-top__need .content .seven-abilities li h4 { font-size: 16px; font-size: 1.6rem; margin-bottom: 5px; }
.p-top__need .content .seven-abilities li h4 span { display: inline-block; *display: inline; *zoom: 1; vertical-align: 1px; background: #fff; color: #ed6c00; border-radius: 100%; width: 20px; height: 20px; line-height: 20px; margin-right: 2px; font-size: 14px; font-size: 1.4rem; text-align: center; }
.p-top__need .content .seven-abilities li p { font-size: 13px; font-size: 1.3rem; line-height: 1.6; }

@media screen and (max-width:767px){
  .p-top__need { padding-top: 30px; }
  .p-top__need:before { top: -30px; background-size: contain; }
  .p-top__need-wrap { padding-bottom: 30vw; background-size: 95%; background-position: calc(50% + 16px) bottom; }
  .p-top__need .heading { margin-bottom: 20px; }
  .p-top__need .heading h2 { font-size: 18px; font-size: 1.8rem; }
  .p-top__need .content dt { font-size: 16px; font-size: 1.6rem; padding: 4px 40px 4px 15px; }
  .p-top__need .content dt h3 { background-size: auto 12px; padding-right: 20px; }
  .p-top__need .content dd { padding: 15px; }
  .p-top__need .content .seven-abilities { margin-top: 8px; }
  .p-top__need .content .seven-abilities li { float: none; width: auto; margin-left: 0; margin-bottom: 0; margin-top: 10px; }
  
  /* 260216 */
  .p-top__need .content dt::before, .p-top__need .content dt::after {
    right: 15px;
  }
  /* /260216 */
}

/* sec4 */
.sec4 {
  
}
.p-top__recommend { background: url(../img/recommend_bg1.png) no-repeat center top; padding-top: 55px; }
.p-top__recommend-professor { margin-bottom: 55px; }
.p-top__recommend-professor .heading { text-align: center; margin-bottom: 42px; }
.p-top__recommend-professor .heading h2 { display: inline-block; *display: inline; *zoom: 1; width: 100%; border: 3px solid #ed6c00; padding-top: 4px; padding-bottom: 4px; position: relative; color: #ed6c00; max-width: 220px; letter-spacing: 0.1em; font-weight: 700; }
.p-top__recommend-professor .heading h2:before, .p-top__recommend-professor .heading h2:after { display: block; content: ""; position: absolute; left: 50%; }
.p-top__recommend-professor .heading h2:before { border-top: 15px solid #ed6c00; border-left: 11px solid transparent; border-right: 11px solid transparent; bottom: -15px; margin-left: -11px; z-index: 1; }
.p-top__recommend-professor .heading h2:after { border-top: 10px solid #fff; border-left: 7px solid transparent; border-right: 7px solid transparent; bottom: -10px; margin-left: -7px; z-index: 2; }
.p-top__recommend-professor .block1 { margin-bottom: 20px; background: #fef2de; }
.p-top__recommend-professor .block1:first-child .profile-logo { /*padding-bottom: 4px;*/ }
.p-top__recommend-professor .block1:nth-last-of-type(1),
.p-top__recommend-professor .block1:nth-last-of-type(2) { /*margin-bottom: 0;*/ }
.p-top__recommend-professor .block1:before, .p-top__recommend-professor .block1:after { display: none; }
.p-top__recommend-professor .img1 { width: 32%; }
.p-top__recommend-professor .box1 { width: 63%; padding: 0; -webkit-box-sizing: border-box; box-sizing: border-box;/* display: flex;*/ justify-content: space-between; flex-direction: column; }
.p-top__recommend-professor .box1:before, .p-top__recommend-professor .box1:after { display: none; }
.p-top__recommend-professor .txt1 { font-size: 14px; font-size: 1.4rem; line-height: 150%; }
.p-top__recommend-professor .profile { display: flex; justify-content: space-between; align-items: flex-end; margin-top: 12px; }
.p-top__recommend-professor .profile:before, .p-top__recommend-professor .profile:after { display: none; }
/*.p-top__recommend-professor .profile-txt { width: 70%; }*/
.p-top__recommend-professor .profile .name { font-size: 16px; font-size: 1.6rem; font-weight: bold; line-height: 140%; letter-spacing: 0.1em; margin-bottom: 5px; }
.p-top__recommend-professor .profile .name span { font-size: 13px; font-size: 1.3rem; }
.p-top__recommend-professor .profile .biography { font-size: 12px; font-size: 1.2rem; line-height: 155%; }
.p-top__recommend-btn,.p-top__contact-btn { display: flex; justify-content: center; margin-bottom: 120px; }
.p-top__recommend-btn-content + .p-top__recommend-btn-content { margin-left: 30px; }

.p-top__recommend-btn::before,.p-top__recommend-btn::after{content:none;}
.p-top__recommend-btn-content::before,.p-top__recommend-btn-content::after{content:none;}
.p-top__recommend-btn .p-top__recommend-btn-content a { background: #ed6d00; color: #FFF; font-size: 22px; font-weight: 700; display: block; width: 274px; text-align: center; padding: 9px 0px; border-radius: 30px;}
.p-top__recommend-btn .p-top__recommend-btn-content a:hover{text-decoration: none;}
.p-top__recommend-btn .p-top__recommend-btn-content.btn-c-blue a {background: #004098;}

.each-field-recommendation.flexbox { display: flex; flex-wrap: wrap; justify-content: space-between; }
.each-field-recommendation.flexbox::before,
.each-field-recommendation.flexbox::after { content: none; }
.each-field-recommendation.flexbox .block1 { width: calc((100% - 20px) / 2); padding: 30px; box-sizing: border-box; }
.img1-and-box1.flexbox { display: flex; flex-wrap: wrap; justify-content: space-between; margin-bottom: 15px; }
.img1-and-box1.flexbox .box1 .profile-logo { height: 30px; }
.img1-and-box1.flexbox::before,
.img1-and-box1.flexbox::after { content: none; }

.see-details {
  margin-top: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  font-size: 13px;
  line-height: 24px;
}


@media screen and (max-width: 767px) {
  .p-top__recommend { padding-top: 30px; padding-bottom: 50px; }
  .p-top__recommend-professor { margin-bottom: 80px; }
  .p-top__recommend-professor .heading { margin-bottom: 20px; }
  .p-top__recommend-professor .block1 { display: block; }
  .p-top__recommend-professor .block1:first-child .profile-logo { padding-bottom: 0; }
  .p-top__recommend-professor .box1 { /*width: auto; display: block;*/ }
  .p-top__recommend-professor .img1 { /*float: left; width: 24%;*/ }
  .p-top__recommend-professor .txt1 { margin-bottom: 15px; display: none; }
  .p-top__recommend-professor .profile { display: block; }
  .p-top__recommend-professor .profile-txt { float: right; margin-bottom: 6px; }
  .p-top__recommend-professor .profile-logo { /*margin-left: 30%;*/ }
  .p-top__recommend-btn,.p-top__contact-btn { display: flex; justify-content: center; margin-bottom: 40px; }
  .p-top__recommend-btn { display: block; text-align: center; margin-bottom: 20px; }
  .p-top__recommend-btn .p-top__recommend-btn-content + .p-top__recommend-btn-content { margin-left: 0; margin-top: 20px; }
  
  .p-top__recommend-btn{margin-bottom: 18px;}
  
  .p-top__recommend-btn .p-top__recommend-btn-content a{margin: auto;}
  
  .each-field-recommendation.flexbox { justify-content: center;}
  .each-field-recommendation.flexbox .block1 { width: 100%; padding: 20px; margin-bottom: 0; }
  .each-field-recommendation.flexbox .block1 + .block1 { margin-top: 20px; }
}

@media screen and (max-width: 844px) and (orientation:landscape) {
  .p-top__recommend-btn{display: flex;}
  .p-top__recommend-btn .p-top__recommend-btn-content{margin: 0 10px;}
  .p-top__recommend-btn .p-top__recommend-btn-content a{width:auto; padding:9px 20px;}
  .p-top__recommend-btn .p-top__recommend-btn-content + .p-top__recommend-btn-content{margin-top: 0;}
}
