@charset "utf-8";
body{
    font-family: "Noto Sans JP","Noto Serif JP", serif;
    background-color: #073059;
    background-image: url(img/fixedBg-pc.jpg);
    background-repeat: no-repeat;
    background-attachment: fixed;
    line-height: 1.8;
}
html{
    font-size: 62.5%;
}
div.wrapper{
    width: 100%;
    margin: 0 auto;
    font-size: 1.6rem;
    color: #073059;
 }
main,
footer{
    background-color: #fff;
    max-width: 1400px;
    margin: 0 auto;
}
section.guidance,
section.regret{
    background-color:#e9ecf0;
    padding-bottom: 50px;
}
section.learning{
    background-color: rgb(250, 247, 242);
    padding-bottom: 50px;
}
 p{
    text-align: center;
    font-size: 1.8rem;
 }
p.bottom{
    margin-bottom: 50px;
}
p.bottom_s,
div.bottom{
    margin-bottom: 30px;
}
div.height{
    height: 200px;
}
span{
    display: block;
}
span.sp{
    display: inline;
}
span.bold{
    font-weight: 900;
    font-family: "Noto Serif JP";
    font-size: 2.8rem;
    display: inline;
}
span.bold_moreover{
    font-weight: 900;
    font-family: "Noto Serif JP";
    font-size: 5rem;
    display: inline;
}
em.serif{
    font-weight: 900;
    font-family: "Noto Serif JP";
    font-size: 2.8rem;
    display: inline;
    background:linear-gradient(transparent 60%, #f4ed78 60%)
}
span.bold_s{
    font-weight: 900;
    font-family: "Noto Sans JP";
    display: inline;
    border-bottom: solid 2px #073059;
    
}
span.bold_sans,strong{
    font-weight: 700;
    font-family: "Noto Sans JP";
    font-size: 2.8rem;
    display: inline;
    background:linear-gradient(transparent 60%, #f4ed78 60%)
}
span.bold_sans_n{
    font-weight: 900;
    font-family: "Noto Sans JP";
    display: inline;
    font-size: 2.8rem;
}
span.red{
    color: red;
    font-weight: 900;
    font-size: 5rem;
    font-family: "Noto Serif JP";
}
p.red{
    color: red;
    font-weight: 900;
    font-size: 2.8rem;
    font-family: "Noto Serif JP";   
}
p.bold_serif{
    font-weight: 900;
    font-family: "Noto Serif JP";
    font-size: 2.8rem;
    display: inline;
    background:linear-gradient(transparent 0%, red 0%);
    color:#fff;
}
p.bold_serif_black,
p.bold_serif_black span{
    font-weight: 900;
    font-family: "Noto Serif JP";
    font-size: 2.8rem;
    display: inline;
    background:linear-gradient(transparent 0%, #073059 0%);
    color:#fff;

}

header{
    background-color: #073059;
    position: relative;
}
header h1 span.main_visual_pc_st{
   width: 100%;
   height: auto;
}
header h1 span.main_visual_sp_st{
   display: none;
 }
/* h2 */
main section h2,
footer section h2{
    margin: 0 auto;
    padding: 40px 0;
}
main section h2.introduction{
    max-width: 300px;
}
main section h2.guidance{
    max-width: 500px;
}
main section h2.learning{
   max-width: 600px;
}
main section h2.trick{
    max-width: 900px;
}
main section h2.regret{
    max-width: 900px;
}
main section h2.new_days{
    max-width: 900px;
}
footer section h2{
    margin: 0 auto;
}
footer section h2.lastly{
    max-width: 300px;
}
/* h2 */
section div.message{
    text-align: center;
    margin-bottom: 50px;
}
section div.pr{
    height: 300px;
}
section p.president {
    max-width: 500px;
    margin: 0 auto;
}
section div.orientation{
   text-align: center;
   margin-bottom: 50px;
}
section p.skills{
    max-width: 800px;
    margin: 0 auto;
    padding-bottom: 50px;
}
section p.method{
    max-width: 600px;
    margin: 0 auto;
    padding-bottom: 50px;
}
section p.utilization{
    text-align: center;
}
section p.hang{
    max-width: 900px;
    margin: 0 auto;
    margin-bottom: 50px;
}
section p.hang_sp{
    display: none;
}
section p.rapid_succession{
    text-align: center;
    margin-bottom: 20px;
}
section p.regret_five_stand{
    max-width: 1000px;
    margin: 0 auto;
}
section p.continued_support{
    max-width: 800px;
    margin: 0 auto;
    margin-bottom: 50px;
}
p.marketing_wall{
    max-width: 1000px;
    margin: 0 auto;
    margin-bottom: 50px;
}
p.writer_status_survey{
    max-width: 700px;
    margin: 0 auto;
}

div.plan_flex{
    display: flex;
    gap: 20px;
    justify-content: space-evenly;
    max-width: 1000px;
    margin: 0 auto;
}
div.auto{
    text-align: center;
}
p.standard_plan_extension{
    max-width: 500px;
}
p.ek{
    max-width: 500px;
}
p.This_much_changes{
    max-width: 800px;
    margin: 0 auto;
    margin-bottom: 30px;
}
section.learning h2{
    max-width: 900px;
}
div.run{
    display: flex;
    gap: 40px;
    justify-content: space-evenly;
    max-width: 1000px;
    margin: 0 auto;
    margin-bottom: 20px;
}
div.stai{
    margin: 0 auto;
}
div.st,
div.stai,
div.ek{
    max-width: 500px;
}
div.pc{
    display: inline;
}
div.sp{
    display: none;
}
div.plan_flex_cta_pc{
    display: flex;
    gap: 40px;
    justify-content: space-evenly;
    max-width: 1000px;
    margin: 0 auto;
}

p.run_through_st_ai{
    max-width: 500px;
    margin: 0 auto;
    margin-bottom: 20px;
}
p.sp_cta{
    display: none;
}

p.news {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: right;
}

p.news a{
    color: #073059;
}
footer section.lastly{
    padding-bottom: 80px;
}
footer section.small{
    background-color: #073059;
    text-align: center;
}
small{
    font-size: 1.4rem;
    line-height: 100px;
    color: #fff;
}
.yureru-j {
    animation: yureru-j 2s infinite;
}
@keyframes yureru-j {
    0% {
        transform: translate(0px, 5px);
    }
    5% {
        transform: translate(0px, -5px);
    }
    10% {
        transform: translate(0px, 2px);
    }
    15% {
        transform: translate(0px, -2px);
    }
    20% {
        transform: translate(0px, 2px);
    }
    25% {
        transform: translate(0px, -2px);
    }
    30% {
        transform: translate(0px, 0px);
    }
}
div.alone{
    max-width: 1000px;
    margin: 0 auto;
    
}
p.alone{
    display: inline;
}
p.alone_sp{
    display: none;
}




@media screen and (max-width:768px){
body{
        line-height: 1.8;
        background-color: #073059;
        background: none;
    }
div.wrapper{
    width: 100%;
}
header h1 span.main_visual_sp_st{
    max-width: 700px;
    display: inline;
}
header h1 span.main_visual_pc_st{
    display: none;
  }
section{
    padding: 0 10px;
  }
  main section h2.introduction,
  footer section h2.lastly{
    max-width: 200px;
}
main section h2.guidance{
    max-width: 250px;
}
main section h2.learning{
    max-width: 300px;
}
div.plan_flex,
div.run{
    flex-wrap: wrap;
}

p{
    font-size: 1.5rem;
}
p.bootcamp_cta,
p.standard_cta{
    max-width: 400px;
    display: none;
}
p.bootcamp_cta_sp,
p.standard_cta_sp{
   display: inline;
}
p.rapid_succession{
    margin-bottom: 20px;
}
p.regret_five_boot img{
    margin-bottom: 30px;
}
p.bottom{
    margin-bottom: 20px;
}
p.news{
    font-size: 1rem;
}
div.height{
    height: 150px;
}
section p.continued_support{
    margin-bottom: 40px;
}
section p.hang{
    display: none;
}
section p.hang_sp{
    display: inline;
    max-width: 390px;
    margin: 0 auto;
    margin-bottom: 50px; 
}
section p.hang_sp img{
    margin-bottom: 50px;
}
span{
    display: inline;
}
span.red{
    font-size: 3rem;
}
span.sp{
    display: block;
}
span.bold_sans,strong{
    font-weight: 600;
    font-family: "Noto Sans JP";
    font-size: 2rem;
    display: inline;
    background:linear-gradient(transparent 60%, #f4ed78 60%)
}
span.bold{
    font-weight: 900;
    font-family: "Noto Serif JP";
    font-size: 2rem;
    display: inline;
}
section div.pr{
    height: 200px;
}
section p.skills{
    padding-bottom: 0;
}
footer section.lastly{
    padding-top: 0;
}
em.serif{
    font-weight: 900;
    font-family: "Noto Serif JP";
    font-size: 2rem;
    display: inline;
    background:linear-gradient(transparent 60%, #f4ed78 60%)
}

div.run{
    flex-direction: column-reverse;
}
span.bold_moreover{
    font-weight: 900;
    font-family: "Noto Serif JP";
    font-size: 2.8rem;
    display: block;
}
div.red{
    margin-bottom: 20px;
}
p.red{
    font-size: 2rem;
}
p.bold_serif{
    font-size: 1.9rem;
}
p.bold_serif_black, p.bold_serif_black span{
    font-size: 1.9rem;
}
div.plan_flex_cta{
    display: block;
}
div.alone{
    padding-bottom: 20px;
    max-width: 300px;
    margin: 0 auto;
}
p.alone{
    display: none;
}
p.alone_sp{
    display: inline;
}
div.pc{
    display: none;
}
div.sp{
    display: inline;
}
p.sp_cta{
    display: inline;
}
section p.regret_five_stand{
    margin-bottom: 20px;
}
.buruburu {
    display: inline-block;
    animation: hurueru .5s  infinite;
}

@keyframes hurueru {
    0% {transform: translate(0px, 0px) rotateZ(0deg)}
    25% {transform: translate(0px, 3px) rotateZ(0deg)}
    50% {transform: translate(0px, 3px) rotateZ(0deg)}
    75% {transform: translate(0px, 3px) rotateZ(0deg)}
    100% {transform: translate(0px, 0px) rotateZ(0deg)}
}


}

.links {
    display: flex;
    justify-content: center;
    padding: 3.75rem 0 0;
}
.links a {
    color: #fff;
    margin: 0 .9375rem;
}

.links a:visited {
    color: #fff;
}

@media screen and (max-width:768px){
    .links {
        font-size: 75%;
    }
}
.plan_list {
    justify-content: space-evenly;
    max-width: 800px;
    margin: 0 auto;
}
.plan_list-img{
    filter: drop-shadow(5px 5px 7px #aaa);
}
.cta_Section{
    justify-content: space-evenly;
    max-width: 750px;
    margin: 50px auto 0;
}

.__pdtop15 {
    padding-top: 15px !important;
}
.__pdtop30 {
    padding-top: 30px !important;
}
@media screen and (max-width: 768px) {
    .cta_Section{
        max-width: 95%;
        margin: 30px auto 0;
    }
}
/*===================================================================
*
* kotsu
*
====================================================================*/
.kotsuColor01 {
    color: #1A669D;
}
.kotsuColor02 {
    color: #31a18b !important;
}
.kotsuColor03 {
    color: #8C8C32 !important;
}
.kotsu_block {
    max-width: 800px;
    margin: 30px auto 0;
}
.kotsu_title01 {
    background: #1A669D;
    padding: 2rem;
    text-align: center;
}
.kotsu_title02 {
    background: #31a18b;
    padding: 2rem 0;
}
.kotsu_title03 {
    background: #8C8C32;
    padding: 2rem 0;
}
.kotsu_title_icon {
    background: rgba(255, 255, 255, 0.90);
    max-width: 150px;
    color: #1A669D;
    font-family: "Noto Serif JP";
    font-weight: 700;
    font-size: 14px;
    padding: 0.75rem 0.75rem;
    border-radius: 50px;
    margin: 0 auto;
}
.kotsu_title_txt {
    color: #fff;
    font-family: "Noto Serif JP";
    font-weight: 700;
    padding: 0.75rem 0.75rem 0;
    margin: 0 auto;
}
.kotsu_title_txt p {
    font-size: 32px;
    color: #fff;
}
.kotsu_main_txt {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 30px;
    padding: 2rem;
    color: #1a1a1a;
}
.kotsuBoa1 {
    flex-basis: 60%;
}
.kotsuBoa1 p{
    text-align: left;
}
.kotsuBoa2 {
    flex-basis: 40%;
    margin-top: 20px;
    text-wrap: wrap;
}

/* スマートフォン向けのスタイル */
@media screen and (max-width: 767px) {
.kotsu_title_icon {
    background: rgba(255, 255, 255, 0.90);
    max-width: 150px;
    color: #1A669D;
    font-family: "Noto Serif JP";
    font-weight: 700;
    font-size: 12px;
    padding: 0.2rem 0.2rem;
    border-radius: 50px;
    margin: 0 auto;
}
.kotsu_title_txt p {
    font-size: 24px;
    line-height: 1.2;
}
.kotsu_main_txt {
    display: block;
}
.kotsuBoa2 {
    text-align: center;
    margin: 10px auto;
}
.kotsuBoa2 img {
    width: 80%;
}
}

.dot_comment01 {
    text-align: center;
    position: relative;
    border: 5px outset #1A669D;
    border-radius: 10px;
    margin: 0 auto 1.5em;
    padding: 7px 10px;
    min-width: 120px;
    max-width: 95%;
    color: #1a1a1a;
    font-size: 16px;
    font-weight: 700;
    background: #e0edff;
}
.dot_comment02 {
    text-align: center;
    position: relative;
    border: 5px outset #31a18b;
    border-radius: 10px;
    margin: 0 auto 1.5em;
    padding: 7px 10px;
    min-width: 120px;
    max-width: 95%;
    color: #1a1a1a;
    font-size: 16px;
    font-weight: 700;
    background: #e0edff;
}
.dot_comment03 {
    text-align: center;
    position: relative;
    border: 5px outset #8C8C32;
    border-radius: 10px;
    margin: 0 auto 1.5em;
    padding: 7px 10px;
    min-width: 120px;
    max-width: 95%;
    color: #1a1a1a;
    font-size: 16px;
    font-weight: 700;
    background: #e0edff;
}
/*===================================================================
*
*
* 
*
*
====================================================================*/
.__pc {
  display: block;
}

.__sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .__sp {
    display: block;
  }
  .__pc {
    display: none;
  }
}

/*===引用===*/
blockquote {
    width: 650px;
    margin: 0 auto;
    position: relative;
    padding: 30px 30px 10px 32px;
    box-sizing: border-box;
    font-style: italic;
    color: #464646;
    background: #e0e0e0;
    margin-bottom: 30px;
}

blockquote:before{
    display: inline-block;
    position: absolute;
    top: -6px;
    left: -15px;
    content: "“";
    font-family: sans-serif;
    color: #e0e0e0;
    font-size: 70px;
    line-height: 1;
    z-index: 2;
}

blockquote:after{
    position: absolute;
    content: '';
    left: 0;
    top: 0;
    border-width: 0 0 40px 40px;
    border-style: solid;
    border-color: transparent #E9ECF0;
}

blockquote p {
    position: relative;
    padding: 0;
    margin: 10px 0;
    z-index: 3;
    line-height: 1.7;
}

blockquote cite {
    display: block;
    text-align: right;
    color: #888888;
    font-size: 0.9em;
}

@media screen and (max-width:768px){
    blockquote{
        width: 100%;
        padding: 30px 20px 10px 20px;
    }
}

/*===================================================================
*
* Scroll
*
====================================================================*/
@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:wght@300;400&display=swap');

.scroll_down{
  position:absolute;
  bottom: 3.125rem;
  left:50%;
  animation: arrowmove 1s ease-in-out infinite;
}

.scroll_down a{
  position: absolute;
  left: -24px;
  bottom: 30px;
  color: #fff;
  font-size: 14px;
  font-family: 'Josefin Sans', sans-serif;
  letter-spacing: .2em;
  text-transform: uppercase;
  width: 24px;
  text-decoration: none;
}

.text {
  display: block;
  margin-top: 70px;
  margin-left: -14px;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  text-transform: uppercase;
  white-space: nowrap;
  letter-spacing: 2px;
}

.arrow {
  position: absolute;
  width: 28px;
  height: 5px;
  opacity: 0;
  transform: scale3d(0.5, 0.5, 0.5);
  animation: move 3s ease-out infinite;
}

.arrow:first-child {
  animation: move 3s ease-out 1s infinite;
}

.arrow:nth-child(2) {
  animation: move 3s ease-out 2s infinite;
}

.arrow:before,
.arrow:after {
  content: ' ';
  position: absolute;
  top: 0;
  height: 100%;
  width: 51%;
  background: #fff;
}

.arrow:before {
  left: 0;
  transform: skew(0deg, 30deg);
}

.arrow:after {
  right: 0;
  width: 50%;
  transform: skew(0deg, -30deg);
}

@keyframes move {
  25% { opacity: 1; }
  33% { opacity: 1; transform: translateY(30px); }
  67% { opacity: 1; transform: translateY(40px); }
  100% { opacity: 0; transform: translateY(55px) scale3d(0.5, 0.5, 0.5); }
}

@media screen and (max-width:768px){
.scroll_down{
    position:absolute;
    bottom:50px;
    right:50%;
    animation: arrowmove 1s ease-in-out infinite;
    }
    
    .scroll_down a{
    position: absolute;
    left: -24px;
    bottom: 30px;
    color: #1c2a53;
    font-size: 14px;
    font-family: 'Josefin Sans', sans-serif;
    letter-spacing: .2em;
    text-transform: uppercase;
    width: 24px;
    height: 24px;
    text-decoration: none;
    }
    
    .text {
    display: block;
    margin-top: 70px;
    margin-left: -14px;
    font-size: 12px;
    font-weight: 700;
    color: #1c2a53;
    text-transform: uppercase;
    white-space: nowrap;
    letter-spacing: 2px;
    }
    
    .arrow {
    position: absolute;
    width: 28px;
    height: 5px;
    opacity: 0;
    transform: scale3d(0.5, 0.5, 0.5);
    animation: move 3s ease-out infinite;
    }
    
    .arrow:first-child {
    animation: move 3s ease-out 1s infinite;
    }
    
    .arrow:nth-child(2) {
    animation: move 3s ease-out 2s infinite;
    }
    
    .arrow:before,
    .arrow:after {
    content: ' ';
    position: absolute;
    top: 0;
    height: 100%;
    width: 51%;
    background: #1c2a53;
    }
    
    .arrow:before {
    left: 0;
    transform: skew(0deg, 30deg);
    }
    
    .arrow:after {
    right: 0;
    width: 50%;
    transform: skew(0deg, -30deg);
    }
}