@charset "UTF-8";
/*---------------------------------------------------------
ボタン
---------------------------------------------------------*/
.btn-g{
    display: block;
    background: #0DB72E;
    color: #fff;
    font-weight: 700;
    text-decoration: none;   
    border: 1px solid #0DB72E;
}
.btn-g:hover{
    text-decoration: none;
    background: #fff;
    color: #0DB72E;
}
.btn-b{
    display: block;
    background: #1A7BBF;
    color: #fff;
    font-weight: 700;
    text-decoration: none;   
    border: 1px solid #1A7BBF;
}
.btn-b:hover{
    text-decoration: none;
    background: #fff;
    color: #1A7BBF;
}

.header-btn{
    font-size: 1.4rem;
    border-radius: 4px;
    padding: 1vh 1vw;
}
.body-btn,.body-btn02{
    text-align: center;
    padding: 1.5vh 1vw;
    width: 90%;
    max-width: 600px;
    margin: 0 auto;
    border-radius: 8px;
}
.body-btn{
    font-size: clamp(1.8rem, 2.5vw, 2.5rem);
}
.body-btn02{
font-size: clamp(1.4rem, 1.4vw, 1.5rem);
}
.btn-w{
width: 100%;
}
.contact-bodyBox{

}
.contact-body-number{
    display: flex;
    justify-content: center;
    margin: 1vh 0 0;
}
.contact-body-number li{
text-align: center;
}
.contact-body-number-tel{
    text-align: center;
    line-height: 1.1;
    margin-left: 1vw;
}
.contact-body-number-tel-link{
text-decoration: none;
    color: #000;
}
.contact-body-number-tel span{
    display: block;
    line-height: 1;
    font-size: clamp(3rem, 4vw, 3rem);
    font-weight: 700;
    font-family: 'poppins';
}
.contact-body-number-tel-time{
    font-size: clamp(1.2rem, 1.5vw, 1.3rem) !important;
    font-weight: 500 !important;
    font-family: 'Noto Sans Japanese', sans-serif !important;
}

@media screen and (max-width: 1440px) {
/* 1440pxまでの幅の場合に適応される */

}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
section{
padding: 6vh 0;
}
}
@media screen and (max-width: 768px) {
/* 768pxまでの幅の場合に適応される */

}
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */
.contact-body-number {
    flex-direction: column;
}
}

/*---------------------------------------------------------
ヘッダー
---------------------------------------------------------*/
.header-container{
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}
.top-logo{
    width: 100%;
    max-width: 160px;
}
.nav-area{
    width: 90%;
    max-width: 1000px;
    display: flex;
    margin: 0;
    align-items: center;
    justify-content: flex-end;
    padding: 1vh 0 1vh;
}
nav{
width: 100%;
}

nav ul{
    display: flex;
    align-items: center;
    justify-content: space-evenly;
}
nav li{
    line-height: 1;
    text-align: center;
    padding: 0 1vw;
}
nav ul li a{
    font-size: 1.4rem;
    color: #333;
    text-decoration: none;
    position: relative;
    height: 50px;
    line-height: 50px;
    display: block;
    font-weight: 700;
}

.header-nav-tab{
    display: none;
}

/*ホバーエフェクト*/
nav ul li a::after {
  content: '';
  display: block;
  height: 2px;
  width: 80%;
  background: #D4131A;
  position: absolute;
  bottom: 0;
  left: 10%;
  transform: scale(0, 1);
  transition: .3s;
}

nav ul li a:hover::after {
  transform: scale(1, 1);
}

@media screen and (max-width: 1440px) {
/* 1440pxまでの幅の場合に適応される */
.header-nav-tab{
    display: none;
}
}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
.header{
    padding: 0.5rem 0 0;
}
.header-btnBox{
    padding: 0;
}
.header-nav-tab{
    display: block;
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
}
.header-btnBox {
    justify-content: flex-end;
}
.header-container {
    align-items: center;
}
}
@media screen and (max-width: 768px) {
/* 768pxまでの幅の場合に適応される */

}
@media screen and (max-width: 640px) {
.logo {
    max-width: 200px;
    padding: 1rem;
    display: inline-block;
}
.cv-btn_header {
    width: 160px;
}
.header-nav{
    display: none;
}
.cv-btn_header span{font-size: 1.4rem;}
.header-nav-tab{
    display: none;
}
}

/*---------------------------------------------------------
mainview
---------------------------------------------------------*/
.main-view-area{
    background: #000;
    position: relative;
}
.main-view-box{
position: relative;
  overflow: hidden;
  width: 100%;
  height: auto;
  aspect-ratio: 8 / 3;
}
video {
position: absolute;
  min-width: 100%;
  min-height: 100%;
  object-fit: contain;
}
.pattern {
  width: 100%;
  height: 100%;
  background: url(./assets/img/yokojima.png);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2;
}
.main-view-contents{
    z-index: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    margin: 1vh 2vw;
}
.main-view-contents h1{
margin: 0 0 1vh;
}
.main-view-contents h1 span{
background: #D4131A;
    padding: 1vh 1vw;
    color: #fff;
    font-size: clamp(2rem, 2.5vw, 3.25rem);
    font-weight: 700;
}
.main-view-contents h2{
    color: #fff;
    font-size: clamp(3rem, 5vw, 8.5rem);
    font-weight: 700;
    line-height: 1.2;
}
.fv-mark{
margin: 1vh 0 0;
}
.fv-mark img{
    width: 60%;
    max-width: 400px;
}

@media screen and (max-width: 1440px) {
/* 1440pxまでの幅の場合に適応される */

}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */

}
@media screen and (max-width: 820px) {
/* 820pxまでの幅の場合に適応される */
.main-view-box{
    height: 400px;
}
}
@media screen and (max-width: 640px) {
/* 640pxまでの幅の場合に適応される */
.main-view-contents {
    width: 90%;
}
.main-view-box {
    height: 350px;
    aspect-ratio: inherit;
}
}
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */

}


/*---------------------------------------------------------
リスキリングを通じたキャリアアップ支援事業とは？
---------------------------------------------------------*/
#about-reskilling{
    background: #D2E6EF;
}
.about-reskilling-ttl{
    background: #D4131A;
    padding: 1.5vh 1vw;
    margin: 4vh 0 0;
    text-align: center;
    color: #fff;
    font-size: clamp(1.8rem, 2.5vw, 2.75rem);
    font-weight: 700;
    line-height: 1.3;
}
.about-reskilling-area{
    background: #fff;
    padding: 1vh 1vw;
}
.target-reskilling-area{
    background: #fff;
    margin: 6vh 0 0;
    padding: 1vh 2vw;
    position: relative;
}
.target-reskilling-ttl,.heatwave-reskilling-box-ttl{
    background: #D4131A;
    padding: 1.5vh 3vw;
    color: #fff;
    display: inline-block;
    font-size: clamp(1.8rem, 2.5vw, 2.5rem);
    font-weight: 700;
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.target-reskilling-p{
margin: 60px 0 0;
}
.target-reskilling-box{
    background: #F7F7F7;
    margin: 4vh 0;
    padding: 2vh 1vw;
}
.target-reskilling-subttl{
    font-size: clamp(1.8rem, 2.5vw, 2.5rem);
    text-align: center;
    font-weight: 700;
    margin: 2vh 0 2vh;
}
.target-reskilling-person{
    display: flex;
    align-items: flex-end;
}
.target-reskilling-person li{
    padding: 1vh 1vw;
}
.target-reskilling-contcttxt{
    font-size: clamp(1.8rem, 2.5vw, 2.75rem);
    font-weight: 700;
    text-align: center;
    line-height: 1.5;
    margin: 2vh 0;
}

@media screen and (max-width: 1440px) {
/* 1440pxまでの幅の場合に適応される */

}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
section{
padding: 6vh 0;
}
}
@media screen and (max-width: 768px) {
/* 768pxまでの幅の場合に適応される */

}
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */
.target-reskilling-p {
    margin: 30px 0 0;
}
.target-reskilling-ttl,.heatwave-reskilling-box-ttl {
    width: 70%;
    text-align: center;
}
.target-reskilling-person{
    flex-wrap: wrap;
}
.target-reskilling-person li {
    width: 45%;
}
}

/*---------------------------------------------------------
ヒートウェーブのリスキリングとは？
---------------------------------------------------------*/
#heatwave-reskilling{
    border-top: 10px solid #D4131A;
}
.heatwave-reskilling-data{
    background: #D0FAFF;
    margin: 4vh auto;
    padding: 4vh 4vw;
}
.heatwave-reskilling-data-ttl{
    text-align: center;
    font-size: clamp(1.8rem, 2.5vw, 2.5rem);
    font-weight: 700;
    margin: 0 0 3vh;
}
.heatwave-reskilling-data-box{
    background: #fff;
    padding: 1vh 1vw;
    margin: 1vh 0;
}
.heatwave-reskilling-data-box p,.heatwave-reskilling-box p{
    font-size: clamp(1.6rem, 2.5vw, 2.25rem);
    text-align: center;
    font-weight: 700;
}
.heatwave-reskilling-data-mark{
    font-size: clamp(2.25rem, 3.5vw, 3.25rem);
    background: linear-gradient(transparent 70%, #93FF00 0%);
    font-weight: 700;
}
.heatwave-reskilling-box{
    border: 3px solid #D4131A;
    padding: 5vh 1vw 2vh;
    border-radius: 12px;
    position: relative;
}

/*---------------------------------------------------------
対象講座
---------------------------------------------------------*/
#course{
    background: #1A7BBF;
}
.course-ttl{
  position: relative;
  display: inline-block;
  padding: 0 55px;
    font-size: clamp(3rem, 3vw, 3.5rem);
    margin: 0 0 4vh;
    color: #fff;
    font-weight: 700;
}
.course-ttl:before, .course-ttl:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 45px;
    height: 4px;
    background-color: #fff;
}
.course-ttl:before {
  left:0;
}
.course-ttl:after {
  right: 0;
}

.course-area{
    background: #fff;
    padding: 4vh 2vw;
    margin: 4vh 0;
}
.course-box{
    display: flex;
}
.movie-area{
    width: 45%;
}
.outline-box{
width: 70%;
}
.outline-area{
display: flex;
    flex-wrap: wrap;
    border: 1px solid #efefef;
    border-top: none;
    margin: 2vh 0;
}
.outline-area dt,.outline-area dd{
    font-size: clamp(1.1rem, 1.4vw, 1.5rem);
    line-height: 1.4;
}
.outline-area dt{
    background: #efefef;
    width: 30%;
    padding: 10px;
    box-sizing: border-box;
    border-top: 1px solid #efefef;
}
.outline-area dd{
    padding: 10px;
    margin: 0;
    border-left: 1px solid #efefef;
    border-top: 1px solid #efefef;
    width: 70%;
    background: #fff;
    box-sizing: border-box;
}
/*動画*/
.movie {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.movie iframe {
  width: 100%;
  height: 100%;
}
.text-area{
    width: 55%;
    padding: 0 4vw 0 4vw;
}
.course-box > li > h3{
    font-size: clamp(2.5rem, 4vw, 4.5rem);
    font-weight: 700;
    line-height: 1.2;
    color: #1A7BBF;
    margin: 0 0 4vh;
}
.icon-hiyou,.icon-kyufu{
    padding: 0.5rem 0.5rem;
    margin-right: 1rem;
    font-size: 1.4rem;
}
.icon-hiyou{
    color: #1A7BBF;
    border: 1px solid #1A7BBF;
}
.icon-kyufu{
    color: #D4131A;
    border: 1px solid #D4131A;
}

@media screen and (max-width: 1440px) {
/* 1440pxまでの幅の場合に適応される */

}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
section{
padding: 6vh 0;
}
}
@media screen and (max-width: 820px) {
/* 820pxまでの幅の場合に適応される */
section {
    padding: 4vh 0;
}
}
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */
.course-box > li > h3{
    margin: 1vh 0 4vh;
}
.course-area {
    margin: 2vh 0;
}
.course-box {
    flex-direction: column;
}
.movie-area {
    width: 100%;
    order:1;
}
.text-area {
    width: 100%;
    padding: 0 1vw 0 1vw;
    order:2;
}
.outline-box{
width: 100%;
}
}
/*---------------------------------------------------------
受講者の要件/サービス
---------------------------------------------------------*/
#service-heatwave{

}
.service-area{

}
.service-area-ttl-box,.service-area-ttl{
    display: flex;
    align-items: center;
}
.service-area-ttl-box{
    margin: 4vh 0 0;
}
.service-area-ttl{
    font-size: clamp(2rem, 3vw, 3.5rem);
    font-weight: 700;
    color: #D4131A;
}
.service-area-ttl span{
    display: flex;
    width: 50px;
    height: 50px;
    background: #D4131A;
    color: #fff;
    align-items: center;
    justify-content: center;
    margin-right: 1rem;
    font-family: 'Poppins';
    font-size: clamp(3rem, 3vw, 2.5rem);
}
.icon-free{
    margin: 0 1%;
    color: #D4131A;
    border: 1px solid #D4131A;
    padding: 0.25rem 1rem;
    border-radius: 4px;
}
.other-area{
    background: #F7F7F7;
    padding: 1vh 1vw 2vh;
    position: relative;
        margin: 2vh 0 2vh;
}
.other-area-ttl{
background: #6F6868;
    padding: 1vh 1vw;
    color: #fff;
    font-size: clamp(1.6rem, 2vw, 1.8rem);
    font-weight: 700;
    text-align: center;
    display: inline-block;
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.other-area-ttl-p{
margin: 60px 0 0;
}
.job-Info-area{
    background: #E0F1FF;
    padding: 1vh 1vw;
    margin: 4vh 0 0;
}
.job-Info-ttl{
    font-size: clamp(2rem, 3vw, 3rem);
    text-align: center;
    font-weight: 700;
    margin: 3vh 0;
    color: #003B6C;
    line-height: 1.3;
}
@media screen and (max-width: 1440px) {
/* 1440pxまでの幅の場合に適応される */

}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
section{
padding: 6vh 0;
}
}
@media screen and (max-width: 768px) {
/* 768pxまでの幅の場合に適応される */

}
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */

}
/*---------------------------------------------------------
ヒートウェーブの実績
---------------------------------------------------------*/
#achievement-area{
    background: #F2F2F2;
}
.achievement-heatwave-ttl{
    font-size: clamp(2rem, 3vw, 3rem);
    margin: 4vh 0;
    display: flex;
    align-items: center;
}
.achievement-heatwave-ttl:after{
  content: '';
  height: 1px;
  background-color: #333;
  flex-grow: 1;
}
.achievement-heatwave-ttl:after{
  margin-left: 1rem;
}
.achievement-heatwave-box{
    display: flex;
    align-items: center;
    margin: 4vh 0;
}
.achievement-heatwave-box li {
    width: 25%;
}

/* セキュリティ業界へ転職した先輩たち */
.voice-area{
background-color: #fff;
    background-image: linear-gradient(#CCEDFF 1px, transparent 1px), linear-gradient(to right, #CCEDFF 1px, #fff 1px);
    background-size: 16px 16px;
    position: relative;
}
.voice-area-ttl{
text-align: center;
    padding: 4vh 0;
}
.voice-area-ttl span{
background: #D4131A;
    padding: 1vh 1vw;
    color: #fff;
    font-size: clamp(2rem, 2.5vw, 3.25rem);
    font-weight: 700;
}
.voice-area-box{
    display: flex;
    padding: 0vh 2vw;
    width:95%;
   max-width: 1600px;
    margin: 0 auto;
}
.voice-area-box > div{
    width: 50%;
}
.voice-area-pct{

}
.voice-box-ttl{
    color: #D4131A;
    font-size: clamp(1.6rem, 2.25vw, 2.1rem);
    font-weight: 700;
    margin: 2vh 2%;
    line-height: 1.4;
}
.voice-box-p{
    padding: 2%;
}
.voice-area-box03{
display: flex;
}
.voice-area-box03 > li{
width: 50%;
}

/* 卒業後の就職先 */
.employment-company-area{
background: #fff;
    padding: 2vh 2vw;
    margin: 4vh 0 0;
}
.employment-companybox{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
}
.employment-companybox li{
    width: 21%;
    padding: 2%;
}

@media screen and (max-width: 1440px) {
/* 1440pxまでの幅の場合に適応される */

}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
section{
padding: 6vh 0;
}
}
@media screen and (max-width: 820px) {
/* 820pxまでの幅の場合に適応される */
.voice-area-box03 {
    flex-direction: column;
}
.voice-area-box03 > li {
    width: 100%;
}
}
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */
.voice-area-box {
    flex-direction: column;
    width: 95%;
}
.achievement-heatwave-box{
    flex-wrap: wrap;
}
.achievement-heatwave-box li {
    width: 50%;
}
.voice-area-box03 {
    flex-direction: column;
}
.voice-area-box03 > li {
    width: 100%;
}
.voice-area-box > div {
    width: 100%;
    padding: 0 0 3vh;
}
.voice-area-ttl {
    padding: 4vh 0 1vh;
}
}
/*---------------------------------------------------------
お問い合わせ
---------------------------------------------------------*/
.contact{
border-top: 10px solid #D4131A;
    background: #F2F2F2;
}

/*---------------------------------------------------------
会社・教室案内
---------------------------------------------------------*/
#company-info {

}
.company-info-list > div{
padding: 1% 2%;
}
.table01 {
  border-collapse: collapse;
  }
.table01 tr {
  border-bottom: 1px solid #b5b1b1;
}

.table01 th,
.table01 td {
  padding: 2vh 1vw;
  border: none;
}

.table01 th {
  width: 20%;
  font-weight: 700;
}
.map {
  width: 100%;
  position: relative;
  padding-top: 56.25%;
}

.map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.table01 th,
.table01 td{
 font-size: clamp(1.4rem, 1.5vw, 1.4rem);
 }
 
/* sp */
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */
.table01 {
  border-collapse: separate;
  }
  .table01 th,
  .table01 td {
    width: 100%;
    display: block;
  }

  .table01 th {
    width: 100%;
    background: #eee;
  }

  .table01 td {
    padding-top: 0;
  }
  .map{
          height: 400px;
    }
    .company-info-list > div {
    padding: 1% 0;
}
}

/*---------------------------------------------------------
Footer
---------------------------------------------------------*/
footer {
background: #000;
}
footer a{
color: #fff;
    text-decoration: none;
    font-size: 1.4rem;
}
.f-link-wrap {
    display: flex;
    padding: 2vh 0;
    align-items: center;
    width: 100%;
    justify-content: space-between;
}
.f-link {
    margin-bottom: 0;
}
.f-link li {
    display: inline-block;
}
.f-link li:not(:first-child) {
    margin-left: 25px;
}
.f-marks {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
}
.privacy-mark {
    margin-bottom: 0;
}
.f-marks li:not(:first-child) {
    margin-left: 25px;
}
.privacy-mark img{
width: 100px;
}

#btn-bottom {
    display: block;
    position: fixed;
    bottom: 0px;
    left: 0px;
    width: 100%;
    height: auto;
    background: rgba(255,255,255,0.95);
    z-index: 999;
    padding: 0;
    border-top: 2px solid #eee;
    box-shadow: 5px 10px 20px rgb(0 0 0 / 45%);
}
.footer-tel-btn{
font-size: clamp(2.15rem, 4vw, 5rem);
    color: #000;
    text-decoration: none;
    font-weight: 700;
    font-family: 'poppins';
    line-height: 1;
}
.footer-tel-btn-txt{
display: block;
    font-size: clamp(1.2rem, 2vw, 1.6rem);
    font-weight: 500;
    line-height: 1;
font-family: 'Noto Sans Japanese', sans-serif !important;
}
.copyright{
    background: #fff;
}
.copyright p{
    text-align: center;
    color: #000;
    font-size: clamp(1.2rem, 1.4vw, 1.3rem);
}
@media screen and (max-width: 768px) {
/* 768pxまでの幅の場合に適応される */

}
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */
.f-link-wrap {
    flex-direction: column;
}
}

@media (min-width: 751px) {
a[href*="tel:"] {
pointer-events: none;
cursor: default;
text-decoration: none;
font-weight: 600;
}
}

/*---------------------------------------------------------
ALL
---------------------------------------------------------*/
/* font */
.mincho{
    font-family: 'Noto Serif JP',serif;
}
/* section */
section{
padding: 8vh 0;
}
/* 見出し */
.main-ttl {
  position: relative;
  display: inline-block;
  margin-bottom: 1vh;
    font-size: clamp(1.8rem, 3vw, 3.5rem);
    font-weight:700;
    color:#000;
}
.main-ttl:before {
  content: '';
  position: absolute;
  bottom: -15px;
  display: inline-block;
  width: 200px;
  height: 5px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: #D4131A;
  border-radius: 2px;
}
.main-ttl-h3{
  position: relative;
  display: inline-block;
  padding: 0 3vw;
    font-size: clamp(2.5rem, 3vw, 3rem);
    margin: 4vh 0 2vh;
    color: #D4131A;
    font-weight: 700;
}
.main-ttl-h3:before, .main-ttl-h3:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 60px;
    height: 2px;
    background-color: #D4131A;
}
.main-ttl-h3:before {
  left:0;
}
.main-ttl-h3:after {
  right: 0;
}
@media screen and (max-width: 1440px) {
/* 1440pxまでの幅の場合に適応される */

}
@media screen and (max-width: 1024px) {
/* 1024pxまでの幅の場合に適応される */
section{
padding: 6vh 0;
}
}
@media screen and (max-width: 768px) {
/* 768pxまでの幅の場合に適応される */

}
@media screen and (max-width: 480px) {
/* 480pxまでの幅の場合に適応される */
section{
padding: 4vh 0;
}
.main-ttl-h3:before, .main-ttl-h3:after {
    background-color: transparent;
}
}
