@charset "UTF-8";
/*---------------------------------------------------------
共通
---------------------------------------------------------*/
[data-cat="ao_rec_01"] p,
[data-cat="ao_rec_03"] p,
[data-cat="ao_rec_03"] td,
[data-cat="ao_rec_03"] li {
    font-size: clamp(1.4rem, 2vw, 1.8rem);
}
[data-cat="briefing-ao_rec_01"] p, 
[data-cat="briefing-ao_rec_02"] p, 
[data-cat="briefing-ao_rec_03"] p,
[data-cat="briefing-ao_rec_04"] p,
[data-cat="briefing-ao_rec_05"] p {
    font-size: clamp(1.4rem, 2vw, 1.8rem);
}
.m-1{margin:1vh 1vw;} .m-2{margin:2vh 2vw;} .m-3{margin:3vh 3vw;} .m-4{margin:4vh 4vw;} .m-5{margin:5vh 5vw;} 
.mt-1{margin-top:1vh;} .mt-2{margin-top:2vh;} .mt-3{margin-top:3vh;} .mt-4{margin-top:4vh;} .mt-5{margin-top:5vh;}
.mb-1{margin-bottom:1vh;} .mb-2{margin-bottom:2vh;} .mb-3{margin-bottom:3vh;} .mb-4{margin-bottom:4vh;} .mb-5{margin-bottom:5vh;} 
.ml-1{margin-left:1vw;} .ml-2{margin-left:2vw;}.ml-3{margin-left:3vw;}.ml-4{margin-left:4vw;}.ml-5{margin-left:5vw;}
.mr-1{margin-right:1vw;} .mr-2{margin-right:2vw;} .mr-3{margin-right:3vw;}.mr-4{margin-right:4vw;}.mr-5{margin-right:5vw;}

.p-1{padding:1vh 1vw;} .p-2{padding:2vh 2vw;} .p-3{padding:3vh 3vw;} .p-4{padding:4vh 4vw;} .p-5{padding:5vh 5vw;}
.pt-1{padding-top:1vh} .pt-2{padding-top:2vh;} .pt-3{padding-top:3vh;} .pt-4{padding-top:4vh;} .pt-5{padding-top:5vh;} 
.pb-1{padding-bottom:1vh;} .pb-2{padding-bottom:2vh;} .pb-3{padding-bottom:3vh;} .pb-4{padding-bottom:4vh;} .pb-5{padding-bottom:5vh;} 
.pl-1{padding-left:1vw;} .pl-2{padding-left:2vw;} .pl-3{padding-left:3vw;} .pl-4{padding-left:4vw;} .pl-5{padding-left:5vw;} 
.pr-1{padding-right:1vw;} .pr-2{padding-right:2vw;}  .pr-3{padding-right:3vw;}  .pr-4{padding-right:4vw;}  .pr-5{padding-right:5vw;} 
.top-ttl {font-size: clamp(2.2rem, 4vw, 5rem) !important;}
.top-ttl02 {font-size: clamp(2rem, 4vw, 4rem) !important;}
.top-ttl03 {font-size: clamp(2rem, 3vw, 3.25rem) !important;}
.semi-ttl ,.title-main{
font-size: clamp(1.8rem, 4vw, 3rem) !important;}
.semi-ttl02 {font-size: clamp(1.6rem, 4vw, 3rem) !important;}

.third-ttl {font-size: clamp(1.6rem, 4vw, 2rem) !important;}
.fw{font-weight:700;}
.naname {
    font-style: oblique 90deg;
}
.lh-13{line-height: 1.3;}
.w-1000,.w-1200,.w-800,.w-600{margin: 0 auto;width: 90%;}
.p-relative{position: relative;}
.w-1000{max-width: 1000px;}
.w-1200{max-width: 1200px;}
.w-800{max-width: 800px;}
.w-600{max-width: 600px;}
.w70{width: 70%;}
.w60{width: 60%;}
.w50{width: 50%;}
.w40{width: 40%;}
.w30{width: 30%;}
.w30-none{width: 30%;}
.fc-yellow{color:#ffff00;}
.pt-section{
    padding-top:5vh;
}
.pb-section{
    padding-bottom:5vh;
}
.bg-highgreen,.ao_rec-ttlBg{
    background: #01A56F;
}
.bg-l-yellow{background: #ffffe4;}
.bg-l-blue{background: #f0f9ff;}
.bg-white{background: #fff;}
.bg-reason{
    background-color: rgba(0, 75, 112, 1);
}
.bg-dred{background: #7e070d;}
.bg-lattice-wamgreen{
width:100%;
background-size: 16px 16px;
background-position: 50% 50%;
background-image: repeating-linear-gradient( 90deg, rgba(239,239,239,0.9) , rgba(239,239,239,0.9) 1px, transparent 1px, transparent 16px),repeating-linear-gradient( 0deg, rgba(239,239,239,0.9) , rgba(239,239,239,0.9) 1px, #fff 1px, #fff 16px);
}

.bg-lattice-l-blue{
width:100%;
background-size: 16px 16px;
background-position: 50% 50%;
background-image: repeating-linear-gradient( 90deg, rgba(0,143,210,0.2) , rgba(0,143,210,0.2) 1px, transparent 1px, transparent 16px),repeating-linear-gradient( 0deg, rgba(0,143,210,0.2) , rgba(0,143,210,0.2) 1px, #fff 1px, #fff 16px);
}

.bg-lattice-blck{
width:100%;
background-size: 16px 16px;
background-position: 50% 50%;
background-image: repeating-linear-gradient( 90deg, rgba(0,0,0,0.1) , rgba(0,0,0,0.1) 1px, transparent 1px, transparent 16px),repeating-linear-gradient( 0deg, rgba(0,0,0,0.1) , rgba(0,0,0,0.1) 1px, #fff 1px, #fff 16px);
}
.fuchi-w-3{
      --x: 0 0 var(--text-outline--width, 3px) var(--text-outline--color, #fff);
      --y: var(--x), var(--x), var(--x), var(--x), var(--x), var(--x) /* 6 */;
      text-shadow: var(--y), var(--y), var(--y), var(--y), var(--y), var(--y) /* 6 * 6 = 36 */;
}

.fuchi-w-6{
      --x: 0 0 var(--text-outline--width, 6px) var(--text-outline--color, #fff);
      --y: var(--x), var(--x), var(--x), var(--x), var(--x), var(--x) /* 6 */;
      text-shadow: var(--y), var(--y), var(--y), var(--y), var(--y), var(--y) /* 6 * 6 = 36 */;
}
.naname {
    font-style: oblique 90deg;
}
.lh-12{line-height: 1.2;}
.lh-13{line-height: 1.3;}
.dot-frame{
border: 2px dotted #333;
}
.bg-l-gray{background: #f0eeeb;}
.bg-wam-green{background: #007440;}
.bg-wam-l-green{background: #e6f6f1;}
.bg-l-yellow {
    background: rgba(255, 252, 216,0.5);
}
.touka-bg-w-40{
  background-color: rgba(255, 255, 255, 0.4);
}
.fc-wam-green{color:#007440;}
.fc-white{color:#fff;}
.fc-high{color:#01A56F;}
.culum-3-none{
    display: flex;
}
.culum-3-none > *{
    padding:1%;
}
.culum-2{display: flex;}
.f-wrap{flex-wrap: wrap;}
.flex-center{display: flex;align-items: center;justify-content: center;}
.mark-underline{background: linear-gradient(transparent 50%, #ffff00 50%);}
.planBox {
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
    background: #fff;
}
.planBox-contents{
    padding:2vh 2vw;
}
.border-r1{border-radius: 1vh;} 
.border-r2{border-radius: 2vh;} 
.float-r,.float-r-none{
    float: right;
    margin-left: 2vw;
    margin-bottom: 3vh;
}
.float-l,.float-l-none{
    float: left;
    margin-right: 2vw;
    margin-bottom: 3vh;
}
.cb {clear: both;}
/*grid*/
.content{
  display:grid;
  grid-template-rows: auto auto auto;
  /*grid-template-columns: 1fr 40%;*/
  grid-template-areas:
    "area1 area2"
    "area3 area2";
  grid-gap: 10px;
  .item1{
    grid-area: area1;
    height:auto;
  }
  .item2{
    grid-area: area2;
    width: auto;   
  }
  .item3{
    grid-area: area3;
    height:auto;  
  }
}
.content-grid40{
  grid-template-columns: 1fr 40%;
}
.content-grid30{
  grid-template-columns: 1fr 30%;
}
.content-grid25{
  grid-template-columns: 1fr 25%;
}

@media screen and (max-width: 640px) {
/* 640pxまでの幅の場合に適応される */
  .content{
    grid-template-areas:
      "area1 area1"
      "area2 area2"
      "area3 area3";
 
    .item2{
      width: 100%;
      height: auto;
    }
  }
.float-r,.float-l{
    width: 100%;
    float: unset;
    margin-left: 0;
    margin-right: 0;
}
.w70,.w60,.w50,.w40,.w30{width: 100%;}
.pct-h-140{
width: 100%;
    height: 140px;
    object-fit: cover;
    object-position: top;
}
.culum-2{flex-direction: column;}
.order-01{order: 1;}
.order-02{order: 2;}
.order-03{order: 3;}
.sp-tac{text-align: center;}
}

/*---------------------------------------------------------
テーブル
---------------------------------------------------------*/
.table01,.table03 {
  border-collapse: collapse;
      width: 100%;
  }
.table01 tr,.table03 tr {
  border-bottom: 1px solid #b5b1b1;
}
.table01 tr:first-child,.table03 tr:first-child{
  border-top: 1px solid #b5b1b1;
}
.table01 th,
.table01 td,
.table03 th,
.table03 td {
  padding: 2vh 1vw;
  border: none;
}

.table01 th,.table03 th {
  width: 20%;
  font-weight: 700;
    border-left: 1px solid #b5b1b1;
    border-right: 1px solid #b5b1b1;
    background: #eee;
}
.table01 td,.table03 td{
    border-right: 1px solid #b5b1b1;
}

/* sp */
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */
.table01 {
  border-collapse: separate;
  }
  .table01 th,
  .table01 td {
    width: 98%;
    display: block;
    border: transparent;
  }

  .table01 th {
    background: #eee;
  }

  .table01 td {
    padding-top: 0;
  }
}
/*---------------------------------------------------------
動画
---------------------------------------------------------*/
.youtube-1-1,.youtube-16-9{
  width: 100%;
  position: relative;
  overflow: hidden;
}
.youtube-1-1{
  padding-bottom: 100%; /* 1:1 のアスペクト比を確保 */
  height: 0;
  overflow: hidden;
}
.youtube-16-9{
  aspect-ratio: 16 / 9;
}
.youtube-1-1 iframe,.youtube-16-9 iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/*---------------------------------------------------------
ボタン
---------------------------------------------------------*/
.btn-fotter-box{
    display: flex;
    justify-content: center;
}
.btn-fotter{
    text-align: center;
    padding: 0.5em 1em;
    text-decoration: none;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 90%;
    max-width: 600px;
    border-radius: 4px;
    position: relative;
    font-size: clamp(1.4rem, 3vw, 2.5rem);
}
.btn-fotter::after  {
    font-family: "Font Awesome 5 Free";
    content: "\f054";
    position: absolute;
    right: 10px;
    bottom: 0;
    font-weight: 900;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    color: #fff;
}
.btn-join{
  background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #ff9d00), color-stop(100%, #e58905));
  background-image: -moz-linear-gradient(top, #ff9d00, #e58905);
  background-image: -webkit-linear-gradient(top, #ff9d00, #e58905);
  background-image: linear-gradient(to bottom, #ff9d00, #e58905);
  box-shadow: 0px 2px 0px #e58905;
  border-color: #ff9d00;
  border:2px solid #ff9d00;
    color: #fff !important;
    text-decoration: none !important;
}
.btn-join:hover{
    background: #fff;
    color: #ff9d00 !important;
}
.btn-join:hover:after{
color: #ff9d00;
}


.cta-btnBox{
    width: 100%;
}
.cta-btnBox-headLP{max-width: 250px;}
.cta-btnBox-headLP > a {
    font-size: clamp(1.1rem, 2vw, 1.2rem);
    padding: 1vh 1vw 1vh 40px;
    width: 250px;
}
.cta-btnBox-txt-big-headLP{
    font-size: clamp(1.5rem, 4vw, 2.25rem);
}
.cta-btnBox-txt-footer-fix{font-size: clamp(1.4rem, 3vw, 2.5rem);}
.cta-comment-inquiry-headLP{
    left: 10px;
}
.cta-comment-headLP{
    width: 40px;
    height: 40px;
}

[data-cat="ao_rec_01"] .section-cv-area {
    background: transparent;
        padding: 0;
}

/*---------------------------------------------------------
実績
---------------------------------------------------------*/
.jisseki-box{
    width: 95%;
    max-width: 650px;
    margin: 0 auto;
    background: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
    border-radius: 10px;
    padding: 2vh 2vw;
}


/*---------------------------------------------------------
ヘッダー
---------------------------------------------------------*/
.lp-head{
    width: 100%;
    padding: 0 1vw 0;
}
.head-box{
    display: flex;
    align-items: center;
  width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    justify-content: space-between;
}
.head-logo{
        display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 6px solid #febf58;
    background: #007440;
    padding: 20px 40px;
}
.header[data-cat="elementary-e"] .gnav {
    background: #800000;
}
.head-logo img{
width: 100%;
}

@media screen and (max-width: 480px) {
.head-logo{
    background: #007440;
    padding: 15px 20px;
    max-width: 200px;
}
.cta-comment-headLP {
    display: none;
}
.cta-btnBox-headLP > a {
    padding: 1vh 1vw 1vh 1vw;
    width: 150px;
    margin: 0 0 5px 20px;
    border-radius: 1vh;
}
}

/*---------------------------------------------------------
FV
---------------------------------------------------------*/
.lp-fvarea{
        background: url(../img/high/ao_rec_lp/fv_bg.jpg);
        background-position: center, center;
    background-repeat: repeat-x;
    height: 70vh;
    background-size: contain;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
.lp-fv-contents{
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
}
.lp-fv-touka-black{
    background-color: rgba(0, 0, 0, 0.26);
    width: 100%;
    height: 100%;
}
.lp-fv-touka-white{
    background-color: rgba(255, 255, 255, 0.6);
    width: 100%;
    height: 100%;
}
.lp-fv-inner{
display: flex;
    justify-content: center;
    align-items: center;
}
.lp-fv-inner img{
width:75%;
    max-width: 1300px;
display: block;margin-left: auto;margin-right: auto;
}
.img-center{
position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
.lavel-pct{
width:80%;display: block;margin-left: auto;margin-right: auto;
}
.lp-fv-inner-contents{
position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
.ao_rec_kokukouritsu-ttl{
    font-size: clamp(1.8rem, 3vw, 3.25rem);
    font-weight: 700;
    text-align: center;
    margin: 0 0 1vh;
    line-height: 1.2;
}
.ao_rec_kokukouritsu-ttl-number{
font-size: clamp(2.25rem, 3vw, 4.5rem);
    color: #e01c24;
}
.ao_rec_kokukouritsu-sub-ttl{
font-size: clamp(2.65rem, 3vw, 4.5rem);
     text-align: center;
     font-weight: 700;
    line-height: 1.1;
    text-align: center;
    color: #e01c24;
    margin: 0 0 2.5vh;
}
.ao_rec_kokukouritsu-txt{
    text-align: center;
    text-align: center;
    font-size: clamp(1.3rem, 2vw, 1.8rem);
    font-weight: 700;
    margin: 0 0 1vh;
}
.lavel-kokkouritu,.lavel-kobetsu{
    line-height: 1;
    padding:1vh 1vw;
    color:#fff;
    font-weight:700;
}
.lavel-kokkouritu{
    background: #7e070d;
}
.lavel-kobetsu{
    background: #004bb9;
}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
.lp-fvarea{
    height: 450px;
    background-size: cover;
}
.lp-fv-inner img{
width:80%;
}
.img-center{
width: 100% !important;
}
.lavel-kokkouritu, .lavel-kobetsu {
padding: .5vh 1vw;
}
}
@media screen and (max-width: 480px) {
.lp-fvarea{
    height: 540px;
}
.lp-fv-inner img{
width:90%;
}
.lavel-pct{
width:100%;
}
}
@media screen and (max-width: 400px) {
.lp-fvarea{
    height: 480px;
    background-size: cover;
}
}
@media screen and (max-width: 350px) {
.ao_rec_kokukouritsu-sub-ttl {
    margin: 0 0 1vh;
}
}
/*---------------------------------------------------------
総合型選抜・推薦入試に対してこんなお悩みはありませんか？
---------------------------------------------------------*/
.nayami-block-ttl{
    line-height: 1.6;
}
.nayami-block{
    display: inline-block;
    background: #000000;
    color: #fff;
    padding: 0 1vw;
}
.nayami-area{
    padding: 0 0 3vh;
}
.nayami-box{
    margin: 2vh 0;
}
.nayami-contents{
    display: flex;
    align-items: center;
}
.nayami-text{
    width: 95%;
    position: relative;
    display: inline-block;
    padding: 1.5vh 1.5vw;
    border-radius: 12px;
    background-color: #ffffff;
    text-align: left;
    line-height: 1.3;
    font-size: clamp(1.4rem, 4vw, 2.5rem) !important;
    font-weight:700;
}
.nayami-text-right {
  margin-right: 16px;
}
.nayami-text-right::after {
  content: "";
  position: absolute;
  top: 35%;
  right: 0;
  border-style: solid;
  border-width: 8px 0 8px 16px;
  border-color: transparent transparent transparent #ffffff;
  translate: 100% -50%;
  transform: skew(0, -10deg);
  transform-origin: left;
}
.nayami-text-left{
    margin-left: 16px;
}
.nayami-text-left::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  border-style: solid;
  border-width: 8px 16px 8px 0;
  border-color: transparent #ffffff transparent transparent;
  translate: -100% -50%;
  transform: skew(0, -10deg);
  transform-origin: right;
}
.nayami-pct img{
    width:60%;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

@media screen and (max-width: 480px) {
.nayami-pct img {
    width: 100px;
    display: block;
    margin-left: unset;
    margin-right: unset;
}
.nayami-area {
    padding: 0 0 1vh;
}
}

/*
.nayami-contents-all{
    height: 11vh;
    margin: 1vh 0;
    text-align: center;
    font-size: clamp(1.3rem, 3.75vw, 2.15rem) !important;
    padding-top: 3vh;
    font-weight: 700;
}
.nayami-contents-right{
padding-right: 7vw;
}
.nayami-contents-left{
padding-left: 7vw;
}
.nayami-contents01{
    background: url(../img/high/ao_rec_lp/nayami-comment-bg01.png);
        background-position: center, center;
    background-repeat: no-repeat;
    background-size: contain;
}
.nayami-contents02{
    background: url(../img/high/ao_rec_lp/nayami-comment-bg02.png);
        background-position: center, center;
    background-repeat: no-repeat;
    background-size: contain;
}
.nayami-contents03{
    background: url(../img/high/ao_rec_lp/nayami-comment-bg03.png);
        background-position: center, center;
    background-repeat: no-repeat;
    background-size: contain;
}
.nayami-contents04{
    background: url(../img/high/ao_rec_lp/nayami-comment-bg04.png);
        background-position: center, center;
    background-repeat: no-repeat;
    background-size: contain;
}
.nayami-contents05{
    background: url(../img/high/ao_rec_lp/nayami-comment-bg05.png);
        background-position: center, center;
    background-repeat: no-repeat;
    background-size: contain;
}
.nayami-contents06{
    background: url(../img/high/ao_rec_lp/nayami-comment-bg06.png);
        background-position: center, center;
    background-repeat: no-repeat;
    background-size: contain;
}
*/


.triangle-arrow {
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 50px solid transparent;
  border-left: 50px solid transparent;
  border-top: 60px solid #ce1c24;
  border-bottom: 0;
    position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
@media screen and (max-width: 480px) {
.triangle-arrow {
  border-right: 30px solid transparent;
  border-left: 30px solid transparent;
  border-top: 30px solid #ce1c24;
}
.nayami-contents-right {
    padding-right: 15vw;
}
.nayami-contents-left {
    padding-left: 12vw;
}
.nayami-contents-all {
    margin: 0;
    padding-top: 3.5vh;
}
}
/*---------------------------------------------------------
WAMの総合型選抜・
推薦入試対策はここが違う!
---------------------------------------------------------*/
.point-ttl-box{
    display: flex;
    align-items: center;
        margin: 0 0 2vh;
}
.point-ttl-box-mark{
    border-radius: 100vh;
    background: #007440;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 90px;
    height: 90px;
    font-weight: 700;
    flex-direction: column;
    line-height: 1;
    font-family: "Roboto", sans-serif;
    font-size: clamp(3rem, 5vw, 5rem)!important;
        margin-right: 1.5vw;
}
.point-ttl-box-mark > span{
    font-size: clamp(1.1rem, 2vw, 1.8rem);
}
.point-ttl-box-ttl{

}
.border-wam-green{
    display: inline-block;
    border: 2px solid #007440;
    padding: .5vh 1vw;
}
@media screen and (max-width: 480px) {
.point-ttl-box-mark{
    width: 60px;
    height: 60px;
}
}

/*---------------------------------------------------------
5つのサポート
---------------------------------------------------------*/
.support-box{
    background: #fff;
    border: 2px solid #ce1c24;
}
.support-number-box{
    background-image: url(../img/high/ao_rec/reason-title-bg_sp.svg);
    height: 100px;
    background-repeat: no-repeat;
    text-align: center;
    position: relative;
}
.support-number{
position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    padding: 0 0 3vh;
    font-size: clamp(1.8rem, 3vw, 2rem) !important;
}
.support-number-num{
font-size: clamp(3.25rem, 4vw, 5rem) !important;
}
.support-number,.support-number-num{
    display: flex;
    align-items: center;
    line-height: 1;
}
@media screen and (max-width: 480px) {
.support-number-box {
    height: 80px;
}
.support-number {

}
}
/*---------------------------------------------------------
ao_rec_02FV
---------------------------------------------------------*/
.ao_rec_02_fvarea{
background-image: linear-gradient(90deg, rgb(255, 255, 255), rgb(250, 250, 220) 30% 70%, rgb(255, 255, 255));
}

/*---------------------------------------------------------
briefing-aoFV
---------------------------------------------------------*/
.briefing-ao_fvarea{
    background:#f2f2f2;
    position: relative;
}
.briefing-ao_fvbox{
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    height: 60vh;
    position: relative;
    z-index: 1;
}

.bg-waseda-keio{
    background: #f2f2f2 url(../img/high/briefing-ao_rec/briefing-ao-waseda-keio-bg.webp);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
/*--webp非対応ブラウザの場合--*/
.no-webp .bg-waseda-keio{
    background: #f2f2f2 url(../img/high/briefing-ao_rec/briefing-ao-waseda-keio-bg.jpg);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bg-gmarch{
    background: #fff url(../img/high/briefing-ao_rec/briefing-ao-gmarch-bg.webp);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
/*--webp非対応ブラウザの場合--*/
.no-webp .bg-gmarch{
    background: #fff url(../img/high/briefing-ao_rec/briefing-ao-gmarch-bg.png);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bg-ntks{
    background: #fff url(../img/high/briefing-ao_rec/briefing-ao-ntks-bg.webp);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
/*--webp非対応ブラウザの場合--*/
.no-webp .bg-ntks{
    background: #fff url(../img/high/briefing-ao_rec/briefing-ao-ntks-bg.png);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bg-kkdr{
    background: #fff url(../img/high/briefing-ao_rec/briefing-ao-kkdr-bg.webp);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
/*--webp非対応ブラウザの場合--*/
.no-webp .bg-kkdr{
    background: #fff url(../img/high/briefing-ao_rec/briefing-ao-kkdr-bg.png);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bg-skkr{
    background: #fff url(../img/high/briefing-ao_rec/briefing-ao-skkr-bg.webp);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
/*--webp非対応ブラウザの場合--*/
.no-webp .bg-skkr{
    background: #fff url(../img/high/briefing-ao_rec/briefing-ao-skkr-bg.png);
    background-position: top, center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.briefing-ao_fvbox-contents{
    background: rgba(255, 255, 255, 0.8);
    padding: 3vh 5vw;
    border-radius: 1vh;
}
.h1-big02 {
    font-size: clamp(2rem, 3.5vw, 3rem);
    line-height: 1.3;
    padding: 0 0.25vw;
}
.fv-ttl-h3 {
    font-size: clamp(2.75rem, 5vw, 5rem);
    line-height: 1.4;
    font-weight: 900;
}
.fv-mark-box{
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: clamp(2rem, 5vw, 4rem);
}
.free-mark{
background: #D00000;
    padding: 1vh 1.5vw;
    margin-right: 1vw;
    border-radius: 1vh;
    line-height: 1.2;
}
.line-bg-high {
    background: linear-gradient(transparent 20%, #c2ead8 70%);
}
[data-cat="briefing-ao_rec_01"] .point-ttl-box-mark {
    background: #01A56F;
    border-radius: 2vh;
}
.arrow-sougo {
    position: relative;
}
.arrow-sougo::after{

}
.arrow-sougo > p{

}
@media screen and (max-width: 1200px) {
.briefing-ao_fvbox{
    height: 70vh;
}
}
@media screen and (max-width: 480px) {

}

/*---------------------------------------------------------
参加者の声
---------------------------------------------------------*/
.entrant-box{
    background: #fff;
    padding: 1vh 1vw;
        box-shadow: 0 0 6px rgba(0, 0, 0, 0.2);
}
.entrant-box > h3 {
  position: relative;
  display: inline-block;
  margin-bottom: 1.5vh;
  padding: 1vh 1vw;
  border-radius: 1vh;
  background-color: #e5f6f0;
  text-align: center;
  font-size: clamp(1.6rem, 4vw, 2rem);
  line-height: 1.2;
  font-weight: 700;
  color:rgba(1, 165, 111, 1);
}

.entrant-box > h3::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 16px 12px 0 12px;
  border-color: #e5f6f0 transparent transparent;
  translate: -50% 100%;
}
.entrant-box > h4{
    font-size: clamp(1.4rem, 3vw, 1.6rem);
    font-weight: 700;
    text-align: center;
    margin: 1.5vh 0;
}
.entrant-box > p{

}

/*---------------------------------------------------------
国公立大の総合型選抜の特徴
---------------------------------------------------------*/
.ttl-number-type{
  position: relative;
  overflow: hidden;
  padding: 1rem 2rem 1rem 120px;
  border: solid 2px #021447;
  font-weight: 700;
    background: #fff;
    margin: 6vh 0 2vh;
}
.ttl-number-type:before{
  position: absolute;
  content: '';
  top: -150%;
  left: -100px;
  width: 200px;
  height: 300%;
  transform: rotate(0deg);
  background: #021447;
}
.ttl-number-type > span{
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	z-index: 1;
	padding-left: 16px;
	color: #fff;
	font-family: "Roboto", sans-serif;
	font-size: clamp(3rem, 5vw, 5rem);
	font-weight:700;
}
.ex-lavel{
    display: inline-block;
    margin: 3vh 0 0;
    background: #021447;
    width: 30%;
    max-width: 100px;
    line-height: 1;
    padding: 1vh 1vw;
    color: #fff;
    text-align: center;
    border-radius: 4px 4px 0px 0px;
    font-weight: 700;
}
.ex-box{
border: 2px solid #021447;
    border-radius: 0px 4px 4px 4px;
    background: #fff;
}
.ex-box-ttl,.ex-box-text{
    padding: 1vh .5vw;
    line-height: 1.1;
}
.ex-box-ttl{
    background: rgba(2, 20, 71, 0.1);
    color: rgba(2, 20, 71, 1);
    font-size: clamp(1.5rem, 3vw, 1.8rem);
    font-weight: 700;
}
.ex-box-text{

}

/*---------------------------------------------------------
無料オンライン個別セミナー
---------------------------------------------------------*/
.ao_rec_03-fv-area{
    background: #effbf0;
}
.ao_rec_03-fv-area-innner{
    margin: 0 auto;
    max-width: 1400px;
    width: 100%;
}

.check-box-list{
margin:0 0 2vh
}
.check-box-list li{
    position: relative;
    padding: 0 1rem 0 0;
    font-weight: 500;
}
.check-box-list li:before{
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: '\f14a';
  color: rgba(0,91,171,1);
  margin: 0 5px 0 0;
}

.list-maru {
  list-style: none;
  margin: 0;
  padding: 0;
}
.list-maru li {
  text-indent: -.5em;
  padding-left: 1em;
}
.list-maru li:before {
  content: "●"; /* 空の要素作成 */
  width: 5px; /* 幅指定 */
  height: 5px; /* 高さ指定 */
  display: inline-block; /* インラインブロックにする */
  color: #f44336; /* 背景色指定 */
  position: relative;
  top: -1px;
  margin-right: 10px;
}

[data-cat="ao_rec_03"] .section-cv-area {
    background: transparent;
        padding: 0;
}
[data-cat="ao_rec_03"] .cta-btnBox > a {
padding: 2vh 1vw 2vh 1vw;
}

.cv-fkidashi{
    padding: 1vh 1.5vw;
    background: #fff;
    border: 2px solid #ee001e;
    border-radius: 50vh;
    position: relative;
  display: inline-block;
  margin: 0 0 1vh;
  font-size: clamp(1.4rem, 3vw, 2rem) !important;
}
.cv-fkidashi::before{
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 20px 10px 0 10px;
  border-color: #ee001e transparent transparent;
  translate: -50% 100%;
}
.cv-fkidashi::after{
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 15.5px 7.8px 0 7.8px;
  border-color: #ffffff transparent transparent;
  translate: -50% 100%;
}
.cv-fkidashi > span{
    font-size: clamp(1.6rem, 4vw, 3.5rem) !important;
    color: #ee001e;
}

/*---------------------------------------------------------
表
---------------------------------------------------------*/
.table03-smi {
  border-collapse: collapse;
      width: 100%;
  }
  
.table03-smi tr {
  border-bottom: 1px solid #46c9e8;
}
.table03-smi tr:first-child{
  border-top: transparent;
}
.table03-smi th,
.table03-smi td {
  padding: 1vh 1vw;
  border: none;
}

.table03-smi th {
  width: 20%;
  font-weight: 700;
    border-left: transparent;
    border-right: transparent;
    background: #e7fcff;
}
.table03-smi td{
    border-right: transparent;
    background: #fff;
}

@media screen and (max-width: 640px) {
/* 640pxまでの幅の場合に適応される */
 .table03-smi th, .table03-smi td {
    display: block;
    width: 100%;
    border-bottom: none;
  }
  .table03-smi th{
    border-bottom: 1px solid #b5b1b1;
  }
  .table03-smi td{
    border-left: 1px solid #b5b1b1;
  }
}

/*---------------------------------------------------------
合格者の声(学校推薦型選抜対策)
---------------------------------------------------------*/
.gokaku-uni-sougou{
background: #fff8fa;
}
.gokaku-uni-box{display: flex;}
.gokaku-uni-box-txt{width: 70%;}
.gokaku-uni-box-pct{width: 30%;}
.gokaku-uni-box-pct-person{
    object-fit: cover;
        height: 150px;
    width: 100%;
    max-width: 150px;
}
.gokaku-uni-box-pct-person-name{
font-size: clamp(1.2rem, 3vw, 1.8rem) !important;
background: #ffff82;
    padding: .5vh .25vw;
    width: 100%;
    text-align: center;
}
.gokaku-uni-box-pct-person-name > span{
font-size: clamp(1rem, 3vw, 1.4rem) !important;
}
.gokaku-uni-name-ttl{
    font-size: clamp(1.8rem, 4vw, 2.5rem) !important;
    line-height: 1.2;
    letter-spacing: -.1rem;
}
.gokaku-uni-name-01,.gokaku-uni-name{
    color: #e50012;
    font-weight:700;
    line-height: 1;
}
.gokaku-uni-name-01{font-size: clamp(1.4rem, 4vw, 2rem) !important;}
.gokaku-uni-name{font-size: clamp(2.75rem, 4vw, 4.75rem) !important;letter-spacing: -.35rem;}
.gokaku-uni-name-box{
padding-left: 80px;
width: 100%;
}
.gokaku-uni-name-box{
background: url(../img/high/ao_rec_03/stamp_gokaku.svg);
    background-repeat: no-repeat;
    background-size: 75px;
    background-position: bottom left;
    position: relative;
}
@media screen and (max-width: 640px) {
/* 640pxまでの幅の場合に適応される */
.gokaku-uni-name-box {
    background-size: 60px;
    background-position: bottom left;
    position: relative;
    height: 60px;
}
.gokaku-uni-box-pct-person {
    object-fit: contain;
    height: 100px;
    width: 100%;
    max-width: 100px;
}
.gokaku-uni-name-box {
    padding-left: 65px;
}
}
/*---------------------------------------------------------
総合型選抜（旧AO入試）は受けなければ絶対に損な入試です!
---------------------------------------------------------*/
.tti_ao-rec{
    color: #005bab;
    font-weight: 700;
    border-left: 5px solid #005bab;
    border-bottom: 1px solid #005bab;
    margin: 2vh 0;
    padding: 0 1vw 0;
    line-height: 1.3;
}

/*---------------------------------------------------------
対策
---------------------------------------------------------*/
.waku-blue-box-bg{
    background-size: auto auto;
    background-color: rgba(255, 255, 255, 1);
    background-image: repeating-linear-gradient(135deg, transparent, transparent 3px, rgba(0,91,171,1) 6px, rgba(0,91,171,1) 3px);
    padding: 10px 0;
    position: relative;
}
.waku-wam-green-box-bg{
    background-size: auto auto;
    background-color: rgba(255, 255, 255, 1);
    background-image: repeating-linear-gradient(135deg, transparent, transparent 3px, rgba(0,114,64,1) 6px, rgba(0,114,64,1) 3px);
    padding: 10px 0;
    position: relative;
}
.br-blue{
    border:2px solid rgba(0,91,171,1);
}
.bg-blue{
    background: rgba(0,91,171,1);
}
.taisaku-person-bg01,.taisaku-person-bg02,.taisaku-person-bg03,.taisaku-person-bg04,.taisaku-person-bg05,.taisaku-person-bg06{
    overflow: hidden;
    width: 150px;
    position: absolute;
    bottom: 10px;
}
.taisaku-person-bg01,.taisaku-person-bg03,.taisaku-person-bg05{
    left: 10%;
}
.taisaku-person-bg02,.taisaku-person-bg04,.taisaku-person-bg06{
    right: 10%;
}
.taisaku-bg{
background: url(../img/high/ao_rec_03/taisaku-warning.png);
    background-repeat: no-repeat;
    background-position: center center;
    position: relative;
    background-size: 150px;
}

.cp_clist-blue{
    display: flex;
    align-items: center;
    color: rgba(0, 91, 171, 1);
}
.cp_clist-blue > span{
background: rgba(0, 91, 171, 1);
    border-radius: 50vh;
    color: #fff;
    width: 20%;
    max-width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 1vw;
}
.taisaku-point-box{
    background: #fff;
    border: 2px solid #007240;
    border-radius: 1vh;
}
.taisaku-point-box > h3{
    background: #007240;
    color: #fff;
    text-align: center;
    font-weight: 700;
    padding: .5vh .5vw;
}
.taisaku-point-box > ul{
margin: 2vh 1.5vw;
}
.taisaku-point-box > ul > li{
    position: relative;
    padding: 0 1rem 0 0;
    font-weight: 700;
      text-indent: -1em;
  padding-left: 1em;
}
.taisaku-point-box > ul > li:before{
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: '\f14a';
  color: #ee001e;
  margin: 0 5px 0 0;
}

.triangle-red {
  color: #ee001e;
  font-size: clamp(5rem, 8vw, 10rem) !important;
  line-height: .5 !important;
}
.link-block{
text-decoration:none !important;
    display: block;
    padding: 1.25vh .5vw;
}

.taisaku-reason-ttl{
background:#ffffe0 url(../img/high/ao_rec_03/icon-reason-check.svg);
    background-repeat: no-repeat;
    background-position: left center;
    position: relative;
    background-size: 30px;
    padding: 2vh 1.5vw;
}
.taisaku-reason-ttl > h4{
margin-left: 40px;
}
.semi-ttl-ao-rec{
text-align: center;
    line-height: 1.2;
    margin: 0 0 3vh;
    font-weight: 900;
}
.semi-ttl-ao-rec-01{
font-size: clamp(2.25rem, 3vw, 4rem) !important;
    font-weight: 700;
}
.semi-ttl-ao-rec-02{
font-size: clamp(3.75rem, 5vw, 6rem) !important;
    font-weight: 700;
}
.semi-ttl-ao-rec-box{
    background: #D00000;
    padding: 1vh 1vw;
    display: inline-block;
    color: #fff;
    font-size: clamp(2.25rem, 3vw, 4rem) !important;
    margin: 1vh 0 0;
}

@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
.taisaku-person-bg01,.taisaku-person-bg03,.taisaku-person-bg05{
    left: 5%;
}
.taisaku-person-bg02,.taisaku-person-bg04,.taisaku-person-bg06{
    right: 5%;
}
}
@media screen and (max-width: 640px) {
/* 640pxまでの幅の場合に適応される */
.taisaku-person-bg01,.taisaku-person-bg02,.taisaku-person-bg03,.taisaku-person-bg04{
    width: 100px;
}
.taisaku-person-bg05,.taisaku-person-bg06{
    width: 80px;
}
.taisaku-person-bg01,.taisaku-person-bg03{
    left: -5%;
}
.taisaku-person-bg05{left: -8%;}
.taisaku-person-bg06{right: -8%;}
.taisaku-person-bg02,.taisaku-person-bg04{
    right: -5%;
}
.taisaku-reason-ttl{
    background-size: 20px;
}
.taisaku-reason-ttl > h4{
margin-left: 30px;
}
}
/*---------------------------------------------------------
リボン（特典）
---------------------------------------------------------*/
.tokuten-img{
width:60%;display: block;margin-left: auto;margin-right: auto;
}
.ribbon-box-cv {
 position: relative;
  margin: -50px 0 30px;
  text-align: center;
      font-size: clamp(2rem, 3vw, 5rem) !important;
}

.ribbon-box-cv:before,
.ribbon-box-cv:after {
  position: absolute;
  z-index: 0;
  bottom: -10px;
  display: block;
  content: '';
  border: 1.25em solid #1c4696;
}

.ribbon-box-cv:before {
  left: -30px;
  border-left-width: 15px;
  border-left-color: transparent;
}

.ribbon-box-cv:after {
  right: -30px;
  border-right-width: 15px;
  border-right-color: transparent;
}

.ribbon-box-cv-innner{
  position: relative;
  z-index: 1;
  display: block;
  padding: 1rem 2rem;
  color: #fff;
  background: linear-gradient(90deg,rgba(6, 12, 60, 1) 0%, rgba(28, 70, 150, 1) 50%, rgba(6, 12, 60, 1) 100%);
    line-height: 1.2;
}

.ribbon-box-cv-innner:before,
.ribbon-box-cv-innner:after {
  position: absolute;
  bottom: -20px;
  display: block;
  width: 10px;
  height: 10px;
  content: '';
  border-style: solid;
  border-color: rgba(6, 12, 60, 1)  transparent transparent transparent;
}

.ribbon-box-cv-innner:before {
  left: 0;
  border-width: 10px 0 0 10px;
}

.ribbon-box-cv-innner:after {
  right: 0;
  border-width: 10px 10px 0 0;
}
.ribbon-box-cv-innner-ttl01{
font-size: clamp(1.2rem, 3vw, 2.5rem) !important;
}

@media screen and (max-width: 640px) {
/* 640pxまでの幅の場合に適応される */
.ribbon-box-cv:after {
    right: -15px;
    border-right-width: 15px;
    border-right-color: transparent;
}
.ribbon-box-cv:before {
    left: -15px;
    border-left-width: 15px;
    border-left-color: transparent;
}
}