
/*** ヘッダー ***/
.e-learning-header{
    background: #111111;
    color: #ffffff;
}
.e-learning-header-content{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    min-height: 72px;
}
.e-learning-header-logo{
    color: #ffffff;
    font-size: 1.5rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-decoration: none;
}
.e-learning-header-logout{
    color: #ffffff;
    font-size: 0.875rem;
    text-decoration: none;
    border: 1px solid rgba(255, 255, 255, 0.5);
    padding: 0.45rem 1rem;
    transition: opacity 0.3s ease;
}
.e-learning-header-logout:hover{
    opacity: 0.75;
}
@media (max-width: 781px){
    .e-learning-header-logo{
        font-size: 1.125rem;
    }
}

/*** フッター ***/
.e-learning-footer{
    background: #111111;
    color: #ffffff;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}
.e-learning-footer-content{
    min-height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.e-learning-footer-copy{
    margin: 0;
    font-size: 0.75rem;
}
footer{
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

/*** 動画 **/
body.e-learning-template-default .wp-site-blocks,
body.post-type-archive-e-learning  .wp-site-blocks,
.e-learning-template-default{
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.e-learning-bg,
.e-learning-main{
    background: linear-gradient(180deg, #f7f7f7 0%, #ffffff 100%);
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 4rem;
  padding-bottom: 4rem;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

body.post-type-archive-e-learning .e-learning-main.movie-front{
    background: linear-gradient(135deg, #111111 0%, #2a2a2a 55%, #111111 100%);
  }
  @media (max-width: 781px){
    body.post-type-archive-e-learning .e-learning-main.movie-front{
      background: #111111;
    }
  }
.container{
  max-width: 100%;
  width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/*** 動画アーカイブ ***/
.e-learning-archive-wrapper{
}
.e-learning-archive-title{
  text-align: center;
  margin-top: 0;
  margin-bottom: 4rem;
}
.e-learning-archive-title-text{
  display: block;
  font-size: 3rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  color: #ffffff;
}
.e-learning-archive-title-sub{
  display: block;
  margin-top: 0.75rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  color: #edff00;
}
.e-learning-cat-list{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto;
  gap: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.e-learning-cat-list li a{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 20px 20px;
  border: 1px solid #cdcdcd;
  background-color: #FFFFFF;
  text-decoration: none;
  color: #7c7c7c;
  font-weight: bold;
  position: relative;
}
.e-learning-cat-list li a::before{
  content: "›";
  display: inline-block;
  font-size: 1.5rem;
  line-height: 1;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  color: #111111;
}

@media (max-width: 781px){
  .e-learning-archive-wrapper{
  }
  .e-learning-archive-title-text{
    font-size: 2rem;
  }
  .e-learning-archive-title-sub{
    font-size: 0.875rem;
  }
  .e-learning-cat-list{
    grid-template-columns: 1fr;
  }
}

/*** 動画カテゴリ ***/
.e-learning-category-wrapper{
}
.e-learning-category-title{
  font-size: 2.25rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.05em;
  margin-top: 0;
  margin-bottom: 4rem;
  text-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff;
}
.e-learning-sub-category-list{
  display: flex;
  flex-direction: column;
  gap: 4rem;
}
.e-learning-sub-category-box{
  background-color: #FFFFFF;
  padding: 4rem;
  border-radius: 20px;
}
.e-learning-sub-category-title{
  font-size: 1.25rem;
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 1.5rem;
}
.e-learning-sub-category-title-icon{
  display: inline-block;
  width: 1.5em;
  height: 1.5em;
  background: url('../images/icon-play.svg') no-repeat center center;
  background-size: contain;
  margin-right: 0.5rem;
  line-height: 1;
  vertical-align: middle;
}
.e_lerning_post-list{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
}
.e_lerning_post-item a{
  display: block;
  text-decoration: none;
  color: inherit;
  transition: all 0.3s ease;
}
.e_lerning_post-item-img{
}
.e_lerning_post-item-img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.e_lerning_post-item-title{
  font-size: 1.13rem;
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 0;
}
.e_lerning_post-item-time{
  font-size: 0.8rem;
}
.e_lerning_post-item-time-icon{
  display: inline-block;
  width: 1.5em;
  height: 1.5em;
  background: url('../images/icon-time.svg') no-repeat center center;
  background-size: contain;
  margin-right: 0.5rem;
  line-height: 1;
  vertical-align: middle;
}
.e_lerning_post-item a:hover{
  opacity: 0.8;
}
@media (max-width: 781px){
  .e-learning-sub-category-box{
    padding: 2rem 1.5rem;
  }
  .e-learning-sub-category-title{
    font-size: 1rem;
  }
  .e-learning-sub-category-title-icon{
    width: 1.25em;
  }
  .e_lerning_post-list{
    grid-template-columns: 1fr;
  }
  .e_lerning_post-item-title{
    font-size: 1rem;
  }
}

/*** ログイン ***/
.login-wrapper{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  background-color: #FFFFFF;
  padding: 4rem;
  border-radius: 20px;
}
.login-wrapper .login-logo-text{
  display: inline-block;
  font-size: 2.5rem;
  font-weight: 900;
  letter-spacing: 0.1em;
}
.login-message{
  margin: 0 0 1rem;
}
.login-message--success{
  color: #1a7f37;
}
.login-message--error{
  color: #c62828;
}
.login-wrapper .login-logo{
  margin-bottom: 2rem;
  text-align: center;
}
.login-wrapper .login-title{
  font-size: 1.5rem;
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 2rem;
  text-align: center;
}
.login-form-item{
  margin-bottom: 1rem;
}
.login-form-item label{
  display: block;
  font-size: 1rem;
  line-height: 1.5;
  margin-bottom: 0.5rem;
}
.login-wrapper .login-input{
  display: block;
  width: 100%;
  padding: 10px 20px;
  border: 1px solid #cdcdcd;
  font-size: 1rem;
  line-height: 1.5;
}
.login-wrapper .login-button{
  display: block;
  width: 100%;
  padding: 10px 20px;
  border: none;
  background: #111111;
  color: #ffffff;
  font-size: 1rem;
  line-height: 1.5;
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.login-wrapper .login-button:hover{
  opacity: 0.85;
}
.login-wrapper .login-button-wrapper{
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 1rem;
}

@media (max-width: 781px){
  .login-wrapper{
    grid-template-columns: 1fr;
    padding: 2rem 1.5rem;
    gap: 2rem;
  }
  .login-wrapper .login-button-wrapper{
    flex-direction: column;
    align-items: flex-start;
  }
}

/*** 動画詳細 ***/
.e-learning-single-wrapper{
  background-color: #FFFFFF;
  padding: 4rem;
  border-radius: 20px;
}
.e-learning-single-title{
    margin-bottom: 1rem;
    padding-bottom: 0.3rem;
    border-bottom: 2px solid #edff00;
    font-size: 1.25rem;
}
.e-learning-single-content h2{
    font-size: 1.25rem;
}
.e-learning-single-content h3{
    font-size: 1rem;
}
.e-learning-single-content p{
    font-size: 1rem;
}

@media (max-width: 781px){
  .e-learning-single-wrapper{
    padding: 2rem 1.5rem;
  }
  .e-learning-single-title{
  }
}


/*** 動画一覧 ***/
.e-learning-movie-list-wrapper{
    max-width: 980px;
    margin: 0 auto;
  }
  .e-learning-movie-list{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem;
    margin: 0;
    padding: 0;
    list-style: none;
  }
  .e-learning-movie-list li{
    background-color: #FFFFFF;
    border-radius: 20px;
    padding: 7% 14%;
  }
  .e-learning-movie-list-title{
    font-size: 1.25rem;
    font-weight: bold;
    margin-top: 0;
    margin-bottom: 2rem;
    text-align: center;
  }
  .e-learning-movie-list-title-text{
    display: inline-block;
    border-bottom: 1px solid currentColor;
    padding: 0 0.5em 0.5em;
  }
  .e-learning-movie-list-description{
    font-size: 1rem;
  }
  .e-learning-movie-list-btn-wrapper{
    text-align: center;
    margin-top: 1.5rem;
  }
  .e-learning-movie-list-btn{
    display: inline-block;
    background-color: #111111;
    font-weight: bold;
    color: #FFFFFF;
    padding: 10px 40px;
    text-decoration: none;
    transition: all 0.3s ease;
    position: relative;
  }
  .e-learning-movie-list-btn:hover{
    opacity: 0.8;
  }
  .e-learning-movie-list-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    width: 0;
    height: 0;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 5px solid #FFF;
    transform: translateY(-50%);
  }
  @media screen and (max-width: 767px) {
    .e-learning-movie-list{
      grid-template-columns: 1fr;
    }
    .e-learning-movie-list li{
      padding: 2rem 1.5rem;
    }
  }