@charset "UTF-8";


/* -----------------------------------------------------------------
   Base
   ----------------------------------------------------------------- */
html {
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}

body {
    color: #000;
    font-size: 16px;
    font-family: "レクサスロダン Pro M", "LexusRodinPro-M", sans-serif;
    font-weight:200;
    line-height: 1.6;
    background-color: #fff;
    -webkit-touch-callout: none;
    -webkit-tap-highlight-color: transparent;
    min-width:320px;
    letter-spacing: 0.05em;
}
a {
    color: #000;
    text-decoration: none;
}
a:hover {
    text-decoration: none;
}
h1, h2, h3, h4, h5, h6 {
    font-weight: normal;
}
img {
    vertical-align: bottom;
}
button {
    background-color: transparent;
    border: none;
    padding: 0;
    outline: none;
}
em {
    font-size: 62.5%;
    vertical-align: super;
}
.none {
    display: none;
}

/****************************************************************************************************

LEXUS style

*****************************************************************************************************/
br.tbv{
  display:none;
}
br.spv{
  display:none;
}
@media all and (max-width: 1023px) {
  br.tbv{
    display:inline;
  }
}
@media all and (max-width: 767px) {
  br.spv{
    display:inline;
  }
}
/* ---------------------------------------------------------
base layout
--------------------------------------------------------- */
.section{
  padding:0 60px;
  overflow: hidden;
}
.section__inner{
  max-width:1000px;
  margin:0 auto;
  padding:60px 0;
}
.section img{
  width:100%;
  height:auto;
}
@media all and (max-width: 767px) {
  .section{
    padding:0 6.25%;
    padding:0 6.25vw;
  }
  .section__inner{
    padding:9.375% 0;
    padding:9.375vw 0;
  }
}


/* ---------------------------------------------------------
common parts
--------------------------------------------------------- */
/*応募ボタン*/
.cmn-oubo{
  text-align:center;
}
.cmn-btn{
 max-width:900px;
 margin:0 auto 26px;
}
.cmn-btn a,
.cmn-btn__end{
  display:block;
  background: #0b2f6f;
  color:#fff;
  font-size:23px;
  line-height:90px;
  font-family: "レクサスロダン Pro B", "LexusRodinPro-B", sans-serif;
  border-radius: 500px;
  transition:all 0.2s ease;
  box-shadow: 0 6px 0 0 rgba(0,0,0,0.13);
}

.cmn-btn a:hover{
  background:#1655ae;
  box-shadow: 0 0px 0 0 rgba(0,0,0,0.13);
  transform: translate3d(0, 6px, 0);
}
.cmn-btn a br{
  display:none;
}
.cmn-btn a span{
  position: relative;
}
.cmn-btn a span::after{
  content:"";
  display:block;
  width:24px;
  height:24px;
  background: url(../img/arw_right_w.png) center center no-repeat;
  background-size:cover;
  position: absolute;
  right:-30px;
  top:0;
  transition:all 0.2s ease;
}

.cmn-btn__end{
  box-shadow: 0 0 0 0 rgba(0,0,0,0);
  background: #ccc;
  color:#666;
}

.cmn-att{
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  position: relative;
  display:inline-block;
  padding:0 0 0 28px;
}
.cmn-att a{
  transition:all 0.2s ease;
  background: url(../img/arw_btm.png) right center no-repeat;
  background-size:19px 19px;
  padding:0 28px 0 0;
  font-size:18px;
  line-height:1.3;
  display:inline-block;
}
.cmn-att a:hover{
  opacity: 0.4;
}


/*反転*/
.-navy .cmn-btn a{
  color:#0b2f6f;
  background:#fff;
  box-shadow: 0 6px 0 0 rgba(204,204,204,1);
  transition:all 0.2s ease;
}
.-navy .cmn-btn a span::after{
  background-image: url(../img/arw_right_n.png);
}

.-black .cmn-btn a{
  color:#000;
  background:#fff;
  box-shadow: 0 6px 0 0 rgba(204,204,204,1);
}
.-black .cmn-btn a span::after{
  background-image: url(../img/arw_right_b.png);
}
.-navy .cmn-btn a:hover,
.-black .cmn-btn a:hover{
  box-shadow: 0 0px 0 0 rgba(204,204,204,1);
  transform: translate3d(0, 6px, 0);
}
.-navy .cmn-btn a:hover{
  color:#536893;
}
.-black .cmn-btn a:hover{
  color:#666;
}
.-navy .cmn-btn a:hover span::after,
.-black .cmn-btn a:hover span::after{
  opacity:0.6;
}

@media all and (max-width: 1024px) {
  .cmn-oubo{
    margin:0 6.25%;
    margin:0 6.25vw;
  }
  .cmn-oubo.-navy,
  .cmn-oubo.-black,
  .cmn-oubo.-nomg{
    margin:0;
  }
  .cmn-btn a{
      font-size:2vw;
      line-height:1.5;
      padding:10px 0;
  }
  .cmn-btn a span{
    display:block;
  }
  .cmn-btn a span::after{
    right:12px;
    top:50%;
    margin-top:-9px;
    width:18px;
    height:18px;
  }
  .cmn-btn a br{
    display:inline;
  }
}

@media all and (max-width: 767px) {
  .cmn-btn{
   max-width:100%;
   margin:0 auto 3.75%;
   margin:0 auto 3.75vw;
  }
  .cmn-btn a{
    font-size:3.125vw;
  }
  .cmn-btn__end{
    font-size:3.75vw;
    line-height:11.25vw;
    border-radius: 11.25vw;
  }
  .cmn-att{
    padding:0 0 0 4.375%;
    padding:0 0 0 4.375vw;
  }
  .cmn-att a{
    background-size:19px 19px;
    padding:0 4.375% 0 0;
    padding:0 4.375vw 0 0;
    font-size:3.75vw;
    display:inline-block;
    background-size:10px 10px;
  }
}
/* ---------------------------------------------------------
mv
--------------------------------------------------------- */
.mv h2 img{
  width:100%;
  height:auto;
}


/* ---------------------------------------------------------
end
--------------------------------------------------------- */
.section--end{
  text-align:center;
  padding:70px 20px 0;
}
.section--end .section__inner{
  position: relative;
  padding:0 0 0 0;
}
.section--end .section__inner:before{
  content:"";
  display:block;
  width:100%;
  height:2px;
  background: #b90711;
  position: absolute;
  top:50%;
  margin-top:-1px;
}
.section--end span{
  color:#b90711;
  background: #fff;
  position: relative;
  z-index: 3;
  font-size: 35px;
  line-height:1;
  font-family: "レクサスロダン Pro B", "LexusRodinPro-B", sans-serif;
  padding:0 1em;
}
@media all and (max-width: 767px) {
  .section--end{
    padding-top:8%;
    padding-top:8vw;
  }
  .section--end span{
    font-size: 16px;
    font-size: 4.26vw;
    padding:0 0.5em;
    white-space: nowrap;
  }
}

/* ---------------------------------------------------------
lead
--------------------------------------------------------- */
.section--lead{
  padding:55px 0 10px;
}
.section--lead .section__inner{
  padding:0;
  text-align:center;
  max-width:100%;
}
.lead__ttl{
  font-size:36px;
  line-height:1.44444;
  text-align:center;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  margin:0 0 22px;
  letter-spacing: 0.05em;
}
.lead__end{
  font-size:25px;
  padding:14px 0 16px;
  border-top:2px solid #000;
  border-bottom:2px solid #000;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}
.lead__end-num{
  font-family: "Nobel-Regular", sans-serif;
  font-size:28px;
}
.lead__end-small{
  font-size:18px;
}


.lead__txt{
  font-size:18px;
  line-height:2;
  padding:30px 0 26px;
  letter-spacing: 0;
}
.lead__txt br.under1024{
  display:none;
}
.lead__att{
  font-size:15px;
  line-height:1.6;
  margin:0 0 42px;
}

@media all and (max-width: 1024px) {
  .lead__txt br.under1024{
    display:inline;
  }
}
@media all and (max-width: 1000px) {
  .lead__ttl{
    line-height:1.3;
  }
}
@media all and (max-width: 767px) {
  .section--lead{
    padding:4.625% 0 6.25%;
    padding:4.625vw 0 6.25vw;
  }
  .lead__ttl{
    font-size:20px;
    margin:0 0 4.6875%;
    margin:0 0 4.6875vw;
  }
  .lead__end{
    font-size:18px;
    line-height:1.2;
    padding:3.125% 0;
    padding:3.125vw 0;
  }

  .lead__end-num{
    font-size:22px;
  }
  .lead__end-small{
    font-size:16px;
  }
  .lead__txt{
    font-size:14px;
    line-height:1.8;
    padding:5.625% 6.25% 6.25%;
    padding:5.625vw 6.25vw 6.25vw;
    text-align:left;
  }
  .lead__txt br,
  .lead__txt br.under1024{
    display:none;
  }
  .lead__att{
    font-size:3.75vw;
    margin:0 6.25% 6.25%;
    margin:0 6.25vw 6.25vw;
    text-align:left;
  }
}
/* ---------------------------------------------------------
present
--------------------------------------------------------- */
.section--present{
  padding:0;
}
.section--present .section__inner{
  max-width:100%;
}
.present__ttl__wrap{
  padding:0 60px;
}
.present__ttl{
  max-width:1000px;
  font-size:32px;
  line-height:1.9;
  text-align:center;
  border-top:2px solid #000;
  border-bottom:2px solid #000;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  margin:0 auto 30px;
}
.present__lead{
  font-size:18px;
  line-height:1.7777;
  text-align:center;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  margin:0 0 30px;
}
.present__lead p{
  margin:0 0 7px;
}
.present__lead br.under1024{
  display:none;
}

.course{
  padding:0 60px;
  margin:0 0 58px;
}
.course__inner{
  max-width:1000px;
  margin:0 auto;
  overflow: hidden;
}
.course__img{
  width:50%;
  float:left;
}
.course__cont{
  width:46%;
  float:right;
}


.course__ttl{
  font-size:20px;
  line-height:1.4;
  margin:0 0 28px;
}
.course__ttl__lead{
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  font-size:18px;
  line-height:1.4;
}
.course__ttl__name{
  padding:12px 0 15px;
}
.course__ttl__place{
  display:inline;
  font-size:40px;
  line-height:1;
  font-family: "Nobel-Regular", sans-serif;
  letter-spacing: 0.1em;
}
.course__ttl__address{
  display:inline;
  font-size:20px;
}
.course__ttl--border{
  font-size:18px;
  display:inline-block;
  border:1px solid #000;
  font-family: "Nobel-Regular", sans-serif;
  line-height:1;
  padding:6px 10px 5px;
  letter-spacing: 0.05em;
}
.course__ttl--border sup{
  font-size:11px;
  vertical-align:super;
}
.course__txt{
  font-size:15px;
  line-height:1.73;
  margin:0 0 13px;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}
.course__about{
  padding:15px 0 15px;
  border-top:1px solid #000;
}
.course__about dt{
  font-size:16px;
  line-height:1.5;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}

.course__about dd{
  font-size:14px;
  line-height:1.85;
}
.course__att p{
  text-indent:-1em;
  padding:0 0 0 1em;
  font-size:12px;
  line-height:1.65;
}

.column__link{
  text-align:center;
  margin:0 0 58px;
}
.column__link a{
  text-decoration: none;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  font-size:18px;
  position: relative;
  transition:all 0.2s ease;
  border-bottom:1px solid #000;
}
.column__link a:hover{
  text-decoration: none;
  color:#999;
  border-bottom:1px solid #999;
}
.column__link a::before{
  content:"";
  display:block;
  width:19px;
  height:19px;
  background: url(../img/arw_right.png) 0 0 no-repeat;
  background-size: 100% auto;
  position: absolute;
  left:-20px;
  top:50%;
  margin:-9px 0 0 0;
  transition:all 0.2s ease;
}
.column__link a:hover::before{
  opacity:0.4;
}



@media all and (max-width: 767px) {
  .section--present{
    padding:0;
  }
  .section--present .section__inner{
    padding-top:0;
  }
  .present__ttl__wrap{
    padding:0 6.25%;
    padding:0 6.25vw;
  }

  .present__ttl{
    font-size:24px;
    margin-bottom:5%;
    margin-bottom:5vw;
  }
  .present__lead{
    margin-bottom:3.125%;
    margin-bottom:3.125vw;
    font-size:14px;
  }


  .course{
    background:none;
    padding:0 6.25%;
    padding:0 6.25vw;
    margin-bottom:6.25%;
    margin-bottom:0 6.25vw;
  }

  .course__img{
    float:none;
    width:100%;
    margin:0 0 3.125%;
    margin:0 0 3.125vw;
  }
  .course__cont{
    width:100%;
    float:none;
  }

  .course__ttl{
    margin-bottom:3.125%;
    margin-bottom:3.125vw;
  }
  .course__ttl__lead{
    font-size:16px;
  }
  .course__ttl__place{
    display:block;
  }
  .course__ttl__address{
    font-size:16px;
  }
  .course__ttl--border{
    font-size:14px;
    white-space: nowrap;
  }
  .course__txt{
    margin-bottom:3.125%;
    margin-bottom:3.125vw;

  }

  .course__about{
    padding:5% 0 0;
    padding:5vw 0 0;
    margin-bottom:6.25%;
    margin-bottom:6.25vw;
  }
  .course__about dt br{
    display:none;
  }

  .column__link{
    text-align:left;
    margin:0 6.25% 9.375%;
    margin:0 6.25vw 9.375vw;
    padding-left:25px;
  }
  .column__link a{
    font-size:3.75vw;
    line-height:1.6;
  }
  .column__link a::before{
    left:-25px;
  }
}


/* ---------------------------------------------------------
func
--------------------------------------------------------- */
.section--func{
  padding:0;
}
.section--func .section__inner{
  max-width:100%;
  padding-top:8px;
}
.func__ttl{
  background: url(../img/func_ttl.jpg) center top no-repeat;
  background-size:cover;
  padding:0 60px;
}
.func__ttl__inner{
  max-width:1000px;
  margin:0 auto;
  position: relative;
}
.func__ttl__inner::after{
  content:"";
  display:block;
  max-width:1000px;
  height:35px;
  background: #fff;
}
.func__main__ttl{
  font-size:30px;
  line-height:1.2;
  padding:33px 0 0 18px;
  border-left:2px solid #000;
  margin:0 0 20px;
  letter-spacing: 0.08em;
}

.func__sub__ttl{
  font-size:14px;
  line-height:1.5;
  margin:0 0 8px;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}
.func__sub__ttl span{
  display:block;
  font-family: "Nobel-Regular", sans-serif;
}
.func__lead{
  font-size:14px;
  line-height:1.7;
  margin:0 0 29px;
}



.func__cont{
  padding:0 60px;
}
.func__item__wrap{
  max-width:1000px;
  margin:0 auto 30px;
  padding:0 40px;
  display:flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.func__item{
  width:48.26%;
}

.item__img{
  margin:0 0 24px;
}
.item__ttl{
  font-size:22px;
  line-height:1.4;
  position: relative;
  margin:0 0 10px;
}

.item__ttl::after{
  content:"";
  display:block;
  width:60px;
  height:1px;
  background:#000;
  margin:12px 0 0;
}
.item__txt{
  font-size:14px;
  line-height:1.6;
  margin:0 0 10px;
}

.item__icon{
}

.item__icon ul{
  overflow: hidden;
  padding:0 0 0 1px;
}
.item__icon ul li{
  float:left;
  background: #000;
  color:#fff;
  font-size:12px;
  border-radius: 4px;
  line-height:1.6;
  padding:0 10px;
  text-align:center;
  margin:0 3px 3px 0;
  font-family: "Nobel-Book", sans-serif;
}
.item__icon ul li.att{
  color:#000;
  background:transparent;
}


.func__att{
  font-size:12px;
  max-width:920px;
  margin:0 auto;
}

@media all and (max-width: 1000px) {

}


@media all and (max-width: 767px) {
  .section--func .section__inner{
    padding:0;
  }
  .func__ttl{
    padding:0 6.25% 6.25%;
    padding:0 6.25vw 6.25vw;
    background-image:url(../img/func_ttl_sp.jpg);
    background-position: center bottom;
  }
  .func__ttl__inner::after{
    display:none;
  }

  .func__main__ttl{
    padding:6.25% 0 0 3.125%;
    padding:6.25vw 0 0 3.125vw;
    margin-bottom:3.75%;
    margin-bottom:3.75vw;
    /*font-size:5vw;*/
    font-size:18px;
    line-height:1.4;
  }
  .func__sub__ttl{
    /*font-size:4.375vw;*/
  }
  .func__lead{
    /*font-size:4.375vw;*/
    line-height:1.6;
    margin-bottom:0;
  }
  .func__lead br{
    display:none;
  }

  .func__cont{
    padding:6.25%;
    padding:6.25vw;
  }
  .func__item__wrap{
    padding:0;
    margin:0;
    display:block;
  }
  .func__item{
    width:100%;
    margin:0 0 9.375%;
    margin:0 0 9.375vw;
  }
  .func__att{
    line-height:1.5;
  }
  .func__att br{
    display:block;
  }

  .item__icon ul li{
    padding:0 8px;
  }
}


/* ---------------------------------------------------------
lineup
--------------------------------------------------------- */
.section--lineup{
  padding:0;
  background: #f7f7f7;
}
.section--lineup .section__inner{
  padding-top:0;
  max-width:100%;
}
.lineup__header{
}
.lineup__header__inner{
  max-width:1000px;
  margin:0 auto 72px;
  padding:44px 0 0 18px;
  border-left:2px solid #000;
}
.lineup__ttl{
  font-size:45px;
  letter-spacing: 0.1em;
  font-family: "Nobel-Regular", sans-serif;
}


.lineup__lead{
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  font-size:18px;
  line-height:1.6;
}
.lineup__list{
  display:flex;
  flex-wrap: wrap;
  max-width:1000px;
  margin:0 auto;
}
.lineup__list_car{
  width:25%;
  border-left:1px solid #c4c4c4;
  margin:0 0 32px;
  cursor: pointer;
}
.lineup__list_car:last-child,
.lineup__list_car:nth-of-type(4n){
  border-right:1px solid #c4c4c4;
}

.lineup__list_car .modal-btn{
  padding:20px 15px 32px;
  transition:all 0.2s ease;
  position: relative;
  cursor: pointer;
}
.lineup__list_car .modal-btn:hover{
  opacity: 0.4;
  cursor: pointer;
}
.lineup__list_car img{
  width:100%;
  height:auto;
}
.car__model{
  display:flex;
  padding:0 0 0 15px;
  position: relative;
}
.car__model::after{
  content:"";
  display:block;
  width:11px;
  height:13px;
  background:url(../img/lineup_arw.png) 0 0 no-repeat;
  background-size:100% auto;
  position: absolute;
  right:0;
  top:50%;
  margin-top:-5px;
}
.car__name{
  font-family: "Nobel-Book", sans-serif;
  font-size:40px;
  line-height:1;
  margin:0 5px 0 0;
}
.car__grade{
  font-family: "Nobel-Book", sans-serif;
  font-size:14px;
  line-height:1.28;
  color:#646464;
  padding:2px 0 0;
  white-space: nowrap;
}
.lineup__att{
  font-size:12px;
  line-height:1.6;
  padding:5px 0 0;
  max-width:1000px;
  margin:0 auto;
}
@media all and (max-width: 1120px) {
  .lineup__list{
    max-width:750px;
  }
  .lineup__list_car{
    width:33.33333%;
  }
  .lineup__list_car:nth-of-type(4n){
    border-right:0;
  }
  .lineup__list_car:nth-of-type(3n){
    border-right:1px solid #c4c4c4;
  }
  .lineup__att{
    max-width:750px;
  }

}
@media all and (max-width: 767px) {

  .section--lineup .section__inner{
    padding:0 0 13.75%;
    padding:0 0 13.75vw;
  }


  .lineup__header{
    padding:0 7.8125% 0;
    padding:0 7.8125vw 0;
  }
  .lineup__header__inner{
    margin:0 0 9.375%;
    margin:0 0 9.375vw;
    padding:9.375% 0 0 3.125%;
    padding:9.375vw 0 0 3.125vw;
  }

  .lineup__ttl{
    margin:0 0 3.125%;
    margin:0 0 3.125vw;
    font-size:7.5vw;
  }
  .lineup__lead{
    font-size:3.75vw;
    line-height:1.3;
  }

  .lineup__list{
    max-width:100%;
  }
  .lineup__list_car{
    width:50%;
    border-left:0;
    margin:0 0 5%;
    margin:0 0 5vw;
  }
  .lineup__list_car:nth-of-type(3n){
    border-right:0;
  }
  .lineup__list_car:nth-of-type(2n+1){
    border-right:1px solid #c4c4c4;
  }

  .lineup__list_car .modal-btn{
    display:block;
    padding:0 4.375% 7.5%;
    padding:0 2.1875vw 3.125vw;
  }

  .car__model{
    display:flex;
    padding:0 0 0 4.375%;
    padding:0 0 0 2.1875vw;
  }
  .car__name{
    font-size:8.125VW;
    margin:0 1.5625% 0 0;
    margin:0 1.5625vw 0 0;
  }
  .car__grade{
    font-size:3.125vw;
    letter-spacing:0;
    padding-top:0;
  }
  .lineup__att{
    font-size:11px
    padding: 0 4.375% 10%;
    padding: 0 4.375vw 10vw;
  }
}



/* ---------------------------------------------------------
summary
--------------------------------------------------------- */

.section--summary{
  background: url(../img/summary_bg.jpg) center center #000 no-repeat;
  background-size:cover;
  color:#fff;
}
.section--summary .section__inner{
  padding-top:0;
}
.summary__ttl{
  font-size:36px;
  letter-spacing: 0.1em;
  padding:54px 0 0 18px;
  margin:0 0 25px;
  border-left:2px solid #fff;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}

.summary__table{
  margin:0 0 31px;
}
.summary__table dl{
  display:flex;
  flex-wrap: wrap;
}
.summary__table dl:last-child dt,
.summary__table dl:last-child dd{
  border-bottom:0;
}
.summary__table dt{
  font-size:15px;
  line-height:1.7;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  width:150px;
  border-bottom:1px solid #fff;
  padding:18px 0;
}
.summary__table dd{
  font-size:15px;
  line-height:1.7;
  width:calc(100% - 150px);
  border-bottom:1px solid #fff;
  border-left:1px solid #fff;
  padding:20px 0 20px 30px;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}
.summary__table dd span{
  font-size:12px;
  line-height:20px;
  display:block;
}
.summary__agree{
  background-color: rgba(255,255,255,0.2);
  padding:23px 25px;
  margin:0 0 45px;
}
.summary__agree dt{
  font-size:13px;
  font-family: "レクサスロダン Pro B", "LexusRodinPro-B", sans-serif;
  margin:0 0 5px;
}
.summary__agree dd{
  font-size:12px;
  line-height:1.7;
  text-indent:-1em;
  padding:0 0 0 1em;
  letter-spacing: -0.07em;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}



@media all and (max-width: 767px) {

  .section--summary{
    background: url(../img/summary_bg_sp.jpg) center center #000 no-repeat;
    background-size:cover;
  }
  .section--summary .section__inner{
    padding-bottom:11.25%;
    padding-bottom:11.25vw;
  }
  .summary__ttl{
    margin: 0 0 6.25%;
    margin: 0 0 6.25vw;
    padding:9.375% 0 0 3.125%;
    padding:9.375vw 0 0 3.125vw;
    font-size: 7.5vw;
    letter-spacing: 0.05em;
  }
  .summary__table{
    margin:0 0 4.6875%;
    margin:0 0 4.6875vw;
  }
  .summary__table dl{
    display:block;
    padding:3.125% 0;
    padding:3.125vw 0;
    border-bottom:1px solid #fff;
  }
  .summary__table dl:last-child{
    border-bottom:0;
  }
  .summary__table dt{
    font-size:14px;
    width:100%;
    border-bottom:0;
    padding:0;
    font-family: "レクサスロダン Pro B", "LexusRodinPro-B", sans-serif;
  }
  .summary__table dd{
    font-size:14px;
    line-height:1.5;
    width:100%;
    border-bottom:0;
    border-left:0;
    padding:0;
  }
  .summary__table dd br{
    display:none;
  }
  .summary__agree{
    padding:6.25% 5%;
    padding:6.25vw 5vw;
    margin:0 0 9.375%;
    margin:0 0 9.375vw;
  }
  .summary__agree dt{
    font-size:13px;
    margin:0 0 2.5%;
    margin:0 0 2.5vw;
  }
  .summary__agree dd{
    font-size:13px;
  }
}



/* ---------------------------------------------------------
howto
--------------------------------------------------------- */
.section--howto{
  background: #000;
  color:#fff;
}
.section--howto .section__inner{
  padding-top:0;
}
.howto__ttl{
  font-size:36px;
  letter-spacing: 0.1em;
  padding:60px 0 0 18px;
  margin:0 0 50px;
  border-left:2px solid #fff;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}


.howto__flow-spimg{
  display:none;
}

.howto__flow{
  display:flex;
  justify-content: space-between;
  margin:0 0 60px;
}
.howto__flow__order{
  width:29.2%;
}
.order__img{
  margin:0 0 20px;
}
.order__img img{
  width:100%;
  height:auto;
}

.order__header{
  display:flex;
  align-items: center;
  margin:0 0 15px;
}
.order__header--num{
  font-family: "Nobel-Light", sans-serif;
  font-size:55px;
  margin:0 14px 0 0;
}
.order__header--txt{
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  font-size:18px;
  line-height:1.4;
  white-space: nowrap;
}
.order__txt{
  font-size:14px;
  line-height:1.5;
  letter-spacing: -0.02em;
}
.order__btn{
  margin:13px 0 0;
}

.order__btn a{
  display:block;
  border:1px solid #fff;
  background: transparent;
  color:#fff;
  transition:all 0.2s ease;
  font-size:14px;
  text-align:center;
  padding:6px 0;
}
.order__btn a:hover{
  background: #fff;
  color:#000;
}

@media all and (max-width: 1000px) {

  .howto__flow-spimg{
    margin-bottom:6.25%;
    margin-bottom:6.25vw;
  }
  .order__header{
    display:block;
  }
  .order__header--num{
    display:block;
    text-align:center;
  }
  .order__header--txt{
    display:block;
    text-align:center;
  }
}
@media all and (max-width: 767px) {
  .howto__ttl{
    margin: 0 0 9.375%;
    margin: 0 0 9.375vw;
    padding:9.375% 0 0 3.125%;
    padding:9.375vw 0 0 3.125vw;
    font-size: 7.5vw;
    letter-spacing: 0.05em;
  }
  .howto__flow-spimg{
    display:block;
  }
  .howto__flow{
    display:block;
    margin:0 0 9.375%;
    margin:0 0 9.375vw;
  }
  .howto__flow__order{
    width:100%;
    margin:0 0 9.375%;
    margin:0 0 9.375vw;
  }
  .order__img{
    display:none;
    margin:0 12.5% 5.625%;
    margin:0 12.5vw 5.625vw;
  }
  .order__txt{
    /*font-size:4.375vw;*/
  }
  .order__btn a{
    /*font-size:4.375vw;*/
    padding:1.875% 0;
    padding:1.875vw 0;
  }

  .order__header{
    display:flex;
    align-items: center;
    margin:0 0 4.375%;
    margin:0 0 4.375vw;
  }
  .order__header--num{
    /*font-size:18.75vw;*/
  }
  .order__header--txt{
    /*font-size:6.25vw;*/
    text-align:left;
  }
}

/* ---------------------------------------------------------
campaign
--------------------------------------------------------- */
.section--campaign{
  background:#f2f2f2;
}
.section--campaign .section__inner{
  padding:0 0 43px;
}
.campaign__ttl{
  font-size:36px;
  letter-spacing: 0.1em;
  padding:66px 0 0 18px;
  margin:0 0 32px;
  border-left:2px solid #000;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
}
.campaign-list{
  padding:0 0 2em;
}
.campaign-list--2{
  padding-bottom:35px;
}
.campaign-list li{
  font-size:12px;
  line-height:1.6;
  letter-spacing: 0;
}
.campaign-list li.mb{
  margin-bottom:2em;
}
.campaign-list li a{
  text-decoration:underline;
}
.campaign-list li a:hover{
  text-decoration:none;
}
.campaign-list li .btn-border{
  padding:10px 0 15px;
  margin:0 0 0 1em;
}
.campaign-list li .btn-border a{
  display:block;
  max-width: 300px;
  border:1px solid #000;
  background: transparent;
  color:#000;
  transition:all 0.2s ease;
  font-size:14px;
  text-align:center;
  padding:6px 0;
  text-decoration:none;
  line-height: 1;
}
.campaign-list li .btn-border a:hover{
  background-color: #000;
  color:#fff;
}

.dealer-btn{
  text-align:center;
  max-width:450px;
  margin:0 auto;
}
.dealer-btn a{
  display:block;
  border:2px solid #3b3b3b;
  color:#3b3b3b;
  font-size:22px;
  line-height:55px;
  font-family: "レクサスロダン Pro B", "LexusRodinPro-B", sans-serif;
  border-radius: 500px;
  transition:all 0.2s ease;
}
.dealer-btn a:hover{
  background:#3b3b3b;
  color:#fff;
}


@media all and (max-width: 767px) {
  .campaign__ttl{
    margin: 0 0 4.6875%;
    margin: 0 0 4.6875vw;
    padding:9.375% 0 0 3.125%;
    padding:9.375vw 0 0 3.125vw;
    font-size: 7.5vw;
  }
  .campaign-list{
    padding:0 0 9.375%;
    padding:0 0 9.375vw;
  }
  .campaign-list--2{
    padding:0 0 12.5%;
    padding:0 0 12.5vw;
  }
  .campaign-list li{
  }
  .campaign-list li.mb{
    margin-bottom:3.125%;
    margin-bottom:3.125vw;
  }
  .section--campaign .cmn-oubo{
    display:block;
  }
  .section--campaign .cmn-btn{
      width: 100%;
  }
  .section--campaign .cmn-btn--oubo{
    padding-bottom:3.125%;
    padding-bottom:3.125vw;
    margin-bottom:0;
  }
}
/* ---------------------------------------------------------
pagetop
--------------------------------------------------------- */
.section--pagetop{
  background:#f2f2f2;
}
.section--pagetop .section__inner{
  padding:0 0 22px;
}
.pagetop{
  text-align:right;
}
.pagetop a{
  transition:all 0.2s ease;
  font-family: "Nobel-Regular", sans-serif;
  font-size:16px;
  line-height:20px;
  display:inline-block;
}
.pagetop a img{
  width:20px;
  height:auto;
  vertical-align: bottom;
}
.pagetop a:hover{
  opacity: 0.4;
}
@media all and (max-width: 767px) {
  .section--pagetop .section__inner{
    padding:0 0 6.25%;
    padding:0 0 6.25vw;
  }

  .dealer-btn{
    width:80%;
    margin-top:3.125%;
    margin-top:3.125vw;
  }
  .dealer-btn a{
    font-size:3.125vw;
    line-height:1;
    padding:10px 0;
  }
  .dealer-btn a:hover{
    background:#3b3b3b;
    color:#fff;
  }

  .pagetop a{
    line-height:5vw;
  }
  .pagetop a img{
    width:5vw;
  }
}
/* ---------------------------------------------------------
program
--------------------------------------------------------- */
.section--program{
  background: #000;
  color:#fff;
}
.section--program .section__inner{
  position: relative;
}

.program__ttl{
  float:left;
}

.program__ttl--logo{
  display:block;
  max-width:440px;
  margin:0 0 7px;
}
.program__ttl--en{
  display:block;
  font-family: "Nobel-Regular", sans-serif;
  font-size:55px;
  margin:0 0 14px;
}

.program__ttl--jpwrap{
  display:flex;
  flex-direction: row;
  margin:0 0 40px;
}

.program__ttl--jp{
  display:block;
  font-size:24px;
  margin:0 10px 0 0;
}
.program__link a,
.program__link--sp a{
  font-size:16px;
  text-decoration: underline;
  font-family: "Nobel-Book", sans-serif;
}
.program__time{
  font-size:22px;
  line-height:1.2;
  margin:0 0 13px;
  padding:102px 0 0;
  position: absolute;
  right:0;
  top:0;
}
.program__time span{
  font-size:14px;
  line-height:1.3;
  border:1px solid #fff;
  display:inline-block;
  padding:0 20px;
  margin:0 0 3px 0;
}
.program__link--sp{
  display:none;
}
.program__att{
  font-size:10px;
  line-height:1;
  text-align:right;
}
.profile{
  clear:both;
  display:flex;
  justify-content: space-between;
  align-items: flex-start;
  margin:0 0 25px;
}
.profile--img{
  width:168px;
}
.profile--txt{
  width:calc(100% - 194px);
}
.profile--ttl{
  font-size:16px;
  margin:0 0 20px;
}
.profile--name{
  margin:0 0 10px;
}
.profile--name-en{
  font-family: "Nobel-Light", sans-serif;
  font-size:16px;
}
.profile--name-jp{
  font-family: "Nobel-Light", sans-serif;
  font-size:30px;
}
.profile--txt p{
  font-size:15px;
  line-height:2;
}

@media all and (max-width: 1100px) {
  .program__ttl--jpwrap{
    margin-bottom:15px;
    display: block;
  }
  .program__ttl--jp{
    margin:0 0 20px;
  }
  .program__link{
    display:none;
  }
  .program__time{
    position: relative;
    margin-bottom:10px;
    clear:both;
    padding-top:0;
    line-height:22px;
  }
  .program__time br{
    display:none;
  }
  .program__time span{
    position: relative;
    top:-2px;
    margin-right:10px;
  }
  .program__link--sp{
    display:block;
    margin-bottom:40px;
  }
}


@media all and (max-width: 1030px) {
  .profile{
    align-items:flex-start;
  }
}




@media all and (max-width: 767px) {
  .section--program .section__inner{
    padding:12% 0;
    padding:12vw 0;
  }
  .program__ttl--logo{
    margin:0 0 3.125%;
    margin:0 0 3.125vw;
  }
  .program__ttl--en{
    font-size:15vw;
    margin:0 0 3.125%;
    margin:0 0 3.125vw;
  }
  .program__ttl--jp{
    font-size:3.75vw;
    margin:0 0 6.25%;
    margin:0 0 6.25vw;
    white-space: nowrap;
  }
  .program__time{
    font-size:3.75vw;
    line-height:1.5;
    margin:0 0 1.875%;
    margin:0 0 1.875vw;
    white-space: nowrap;
  }
  .program__time span{
    font-size:3.75vw;
    line-height:1.8;
    padding:0 1.875%;
    padding:0 1.875vw;
    margin:0 2.1875% 0 0;
    margin:0 2.1875vw 0 0;
  }
  .program__link--sp{
    margin:0 0 12.5%;
    margin:0 0 12.5vw;
  }
  .program__link--sp a{
    font-size:3.125vw;
  }
  .program__att{
    line-height:1.3;
    text-align: left;
  }
  .program__att span{
    font-size:3.125vw;
    display:block;
    margin:0 0 1.5625%;
    margin:0 0 1.5625vw;
  }


  .profile{
    display:block;
  }
  .profile--img{
    width:75%;
    margin:0 auto 6.25%;
    margin:0 auto 6.25vw;
  }
  .profile--txt{
    width:100%;
  }
  .profile--ttl{
    font-size:5vw;
    margin:0 0 3.125%;
    margin:0 0 3.125vw;
  }
  .profile--name{
    font-size:7.5vw;
    margin:0 0 3.125%;
    margin:0 0 3.125vw;
  }
  .profile--name-en{
    font-size:5vw;
    margin:0 0 3.125%;
    margin:0 0 3.125vw;
  }
  .profile--name-jp{
    font-size:9.375vw;
  }

  .profile--txt p{
    font-size:3.75vw;
    line-height:1.7;
  }

}



/* ---------------------------------------------------------
modal
--------------------------------------------------------- */

.modal{
  position: fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  z-index: 10;
  display:none;
  opacity:0;
}
.modal.is-active{
  display:block;
  opacity:1;
}

.modal::after{
  content:"";
  background: rgba(255, 255, 255, 0.9);
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  z-index: 9;
}
.carinfo{
  width:80%;
  width:80vw;
  height: 800px;
  overflow: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 10;
  background: #fff;
  padding:50px;
  border:1px solid #bfbfbf;
  display:none;
  opacity:0;
}
.carinfo.is-active{
  display:block;
  opacity:1;
}

.carinfo__name{
  font-family: "Nobel-Regular", sans-serif;
  font-size:55px;
  line-height:1;
  margin:0 0 10px;
}
.carinfo__grade{
  font-family: "Nobel-Light", sans-serif;
  padding:0 0 20px;
}
.carinfo__img{
  text-align:center;
  border-top:1px solid #e2e2e2;
}
.carinfo__img img{
  width:100%;
  max-width:640px;
  height:auto;
}
.carinfo__ttl{
  font-size:20px;
  line-height:1.6;
  font-family: "レクサスロダン Pro DB", "LexusRodinPro-DB", sans-serif;
  margin:0 0 5px;
}
.carinfo__txt{
  font-size:16px;
  line-height:2;
}
.carinfo__close{
 height:50px;
 width:50px;
 display:block;
 position: absolute;
 right:30px;
 top:20px;
 cursor: pointer;
}

.carinfo__close:before,
.carinfo__close:after{
content:'';
 height:2px;
 width:50px;
 display:block;
 background:#333;
 position:absolute;
 top:25px;
 left:1px;
 transform:rotate(-45deg);
-webkit-transform:rotate(-45deg);
-moz-transform:rotate(-45deg);
-o-transform:rotate(-45deg);
-ms-transform:rotate(-45deg);
}

.carinfo__close:after{
transform:rotate(45deg);
-webkit-transform:rotate(45deg);
-moz-transform:rotate(45deg);
-o-transform:rotate(45deg);
-ms-transform:rotate(45deg);
}
@media all and (max-width: 1200px) {
  .carinfo__txt{
    font-size:14px;
  }
}
@media all and (max-width: 900px) {
  .carinfo__name{
    display:inline-block;
  }
  .carinfo__grade{
    display:inline-block;
  }
  .carinfo__img{
    margin:0 auto;
  }
}
@media all and (max-width: 900px) {
  .carinfo{
    padding:40px;
    width:90%;
    width:90vw;
  }
  .carinfo__ttl{

  }
  .carinfo__txt{
    font-size:14px;
  }
}
@media all and (max-height: 800px) {
  .carinfo{
    overflow: auto;
    bottom:auto;
    height:100%;
  }
}
@media all and (max-width: 767px) {
  .carinfo{
    width:100%;
    padding:6%;
    border:0;
  }

  .carinfo__name{
    display:block;
  }
  .carinfo__grade{
    display:block;
  }
  .carinfo__ttl{
    font-size:18px;
    font-size:4.8vw;
    line-height:1.5;
  }
  .carinfo__txt{
    font-size:12px;
    font-size:3.2vw;
  }
  .carinfo__close{
    right:20px;
  }
}
@media all and (min-width: 1520px) {/*1520px以上でサイドバーが表示のため調整*/
  .carinfo{
    width: calc(80% - 240px);
    width: calc(80vw - 240px);
    left:240px;
  }
}
