:root {
  --theme_big: #000741;
  --theme_basic: #0382c0;
  --theme_bup: #164A84;
  --theme_haken: #9E2730;
  --theme_webins: #D1151B;
  --theme_beginner: #00817C;
  --theme_date: #D66C00;
  --theme_reservation: #2a6cae;
}

body{ font: 400 14px "Helvetica Neue", "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Arial, メイリオ, Meiryo, sans-serif;}

a{transition:opacity .3s;}

a:hover{opacity: .6;}

@media screen and (max-width: 768px) {
  #base {
    width: 100%;
  }
}

/*
    メインビジュアル
================================*/

.mainvisual--top {
  background-image: url("/resource/img/middle/co_scale/bg_big_c_top.jpg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  height: auto;
  .mainvisual-wrap {
    margin: 0 auto;
    width: 1220px;
    position: relative;
    height: auto;
  }
  .slick-slider {
    width: 970px;
  }
  .slick-slide img {
    -o-object-fit: cover;
    object-fit: cover;
    height: auto;
    width: 100%;
  }
}

.mainvisual--flex {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.mainvisual-subContents {
  flex: 1;
  margin: 10px auto;
  max-width: 245px;
}

.mainvisual-linkBox {
  max-width: 220px;
  margin: auto;
}

.mainvisual-linkBox_item {
  background-color: #fff;
  border: 2px solid;
  border-radius: 3px;
  padding: 10px;
  position: relative;
  text-align: center;

  &:not(:first-child) {
      margin-top: 20px;
  }

  &.__jissekiNum {
    border-color: var(--theme_big);
    color: #333;
    text-align: left;
    font-weight: bold;
    font-family: YuGothic, '游ゴシック', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN', Meiryo, 'メイリオ', sans-serif;

    .mainvisual-linkBox_text {
      font-size: 12px;
      line-height: 1.2;
      display: flex;
      align-items: baseline;
    }

    .mainvisual-linkBox_text+.mainvisual-linkBox_text {
      margin-top: 5px;
    }

    .mainvisual-linkBox_attension {
      font-size: 10px
    }

    .mainvisual-linkBox_numText {
      font-size: 20px;
      margin-left: auto;
    }

    .mainvisual-linkBox_attentionText {
      margin-top: 5px;
      font-size: 10px;
      font-weight: normal;
    }

    .mainvisual-linkBox_attentionText+.mainvisual-linkBox_attentionText {
        margin-top: 3px;
    }
  }

  &.__reservation {
    color: #2a6cae;

    .mainvisual-linkBox_link {
      color: inherit;
      display: flex;
      justify-content: center;
      align-items: center;
      font-weight: bold;
      font-size: 14px;
      gap: 0.5em;

      &::before {
        content: "";
        display: block;
        width: 24px;
        height: 19px;
        margin-block: auto;
        background-color: var(--theme_reservation);
        -webkit-mask-image: url('/resource/img/inquiry/footer-icon_business-discussion.svg');
        mask-image: url('/resource/img/inquiry/footer-icon_business-discussion.svg');
        -webkit-mask-position: center;
        mask-position: center;
        -webkit-mask-repeat: no-repeat;
        mask-repeat: no-repeat;
        -webkit-mask-size: contain;
        mask-size: contain;
      }

      &::after {
        content: "";
        display: block;
        position: absolute;
        inset: -1px;
        transition: .3s background-color;
      }

      &:hover::after {
        background-color: rgba(255, 255, 255, .4);
      }
    }
  }

  &.__faq {
    color: #333333;
    .mainvisual-linkBox_link {
      color: inherit;
      display: flex;
      justify-content: center;
      align-items: center;
      font-weight: bold;
      font-size: 14px;
      gap: 0.5em;

      &::before {
        content: "";
        display: block;
        width: 24px;
        height: 19px;
        margin-block: auto;
        background-color: #333333;
        -webkit-mask-image: url('/resource/img/gnav/icon_navi-b01_qa.svg');
        mask-image: url('/resource/img/gnav/icon_navi-b01_qa.svg');
        -webkit-mask-position: center;
        mask-position: center;
        -webkit-mask-repeat: no-repeat;
        mask-repeat: no-repeat;
        -webkit-mask-size: contain;
        mask-size: contain;
      }

      &::after {
        content: "";
        display: block;
        position: absolute;
        inset: -1px;
        transition: .3s background-color;
      }

      &:hover::after {
        background-color: rgba(255, 255, 255, .4);
      }
    }
  }
}


.mainvisual-linkBox_btn {
  background-color: #ccc;
  border-radius: 9999px;
  color: #fff;
  justify-content: center;
  line-height: 1;
  padding: 5px;

  &:not(:only-child) {
    margin-top: 5px;
  }

  :is(.__webins) & {
    background-color: var(--theme_webins);
  }

  :is(.__webins) &::before {
    background-color: #fff;
  }
}

.mainvisual--bar {
  background-color: var(--theme_big);
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  height: 32px;
  line-height: 32px;
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  padding-right: calc(50vw - 50%);
  padding-left: calc(50vw - 50%);
  position: relative;
  text-align: center;
  z-index: 99999;
}

@media screen and (max-width: 768px) {
   /*.mainvisual {
    display: none;
    width: 100%;
    height: 0;
    padding-top: 47.81%;
    background-size: contain;
    background-repeat: no-repeat;
  }*/

   /*.mainvisual--top {
    aspect-ratio: 640 / 300;
    background-image: url(/resource/img/middle/co_scale/big_c_top_1.jpg);
    display: block;
    height: auto;
    padding-top: 0;
    width: auto;
  }*/
  .mainvisual--top .mainvisual-wrap {
    width: auto;
  }
  .mainvisual--top .slick-slider{
    width: 100%;
  }
  .mainvisual--bar {
    font-size: 16px;
    height: auto;
    margin-right: auto;
    margin-left: auto;
    padding-right: 0;
    padding-left: 0;
  }
}


/*
    メインビジュアル下ナビ
    ＋検索ボックス
================================*/
.nav--container {
  background-color: #EDEDF1;
  padding-bottom: 20px;
  @media screen and (max-width: 768px) {
    padding:40px 20px 20px 20px;
  }
  .searchField {
    @media screen and (max-width:768px) {
      margin: 0 auto;
    }
  }
  .searchField__inner {
    background-color: transparent;
    margin: auto;
    width: 985px;
    padding: 10px 0;
    @media screen and (max-width:768px) {
      width: 100%;
    }
  }
}
.nav--container.js_is_fixed{
  position:fixed;
  top:0;
  z-index:99999;
}

/*トップ画*/
.top_img_Bbox {
  position: relative;
  max-width: 730px;
}
.top_img_box {
  position: absolute;
  top: 50%;
  left: 0;
  display: inline-block;
  padding: 4px 8px;
  background: rgba(22, 21, 17, 0.6);
  transform: translateY(-50%);
}
.top_title {
  color: #fff;
  font-size: 18px;
  font-weight: normal;
}
.top_subTitle {
  color: #fff;
  font-size: 12px;
  font-weight: normal;
  text-align: center;
  letter-spacing: .1em;
}
.top_title+.top_subTitle {
  margin-top: 4px;
}
@media screen and (max-width: 768px) {
  .top_img_box {
    position: static;
    padding: 0;
    background: none;
    transform: none;
  }
  .top_title {
    color: inherit;
    font-weight: bold;
    font-size: 16px;
  }
  .top_title+.top_subTitle {
    margin-top: 0;
  }
  .top_subTitle {
    display: none;
  }
}
/** nav **/
.nav {
  position: relative;
  width: 100%;
}
.nav-top2 {
  width: 100%;
  padding: 20px 0 12px;
  background: #E8EAEF;
}
.nav-top2__title {
  width: 1220px;
  margin: 0 auto 10px;
  line-height: 1;
  color: var(--theme_big);
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  position: relative;
}
.nav-top2__title_sub {
  font-size: 12px;
  position: absolute;
  bottom: 0;
}
.nt2 {
  width: 1220px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
  gap: 15px;
}
.nt2__list {
  display: flex;
  width: 100%;
  border:1px solid var(--theme_big);
}
.nt2__link {
  position: relative;
  display: block;
  width: 100%;
  padding: 8px 16px;
  box-shadow: 3px 3px 6px rgba(0, 0, 0, 0.16);
  font-size: 15px;
  font-weight: bold;
  color: #333;
  background: #fff;
}
.nt2__link::after{
  color: #080404;
  position: absolute;
  font-family: "Font Awesome 5 Free"; 
  font-weight: 900;
  content: "\f0ab";
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
}
.nt2__link:hover {
  background: var(--theme_big);
  color: #fff;
}
.nt2__link:hover::after {
  color: #fff;
}
/* .nt2__link::after {
  content: attr(data-example);
  position: absolute;
  top: 8px;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 80%;
  padding: 4px 8px;
  border: 1px solid #ccc;
  border-radius: 3px;
  color: #333;
  text-align: left;
  font-size: 11px;
  background: #fff;
  opacity: 0;
  transition: .7s opacity;
} */

/* .nt2__link:hover::after {
  opacity: 1;
} */
.nt2__link.is_current {
  background: var(--theme_big);
  color: #fff;
}
.nt2__link.is_current::after {
  content: none;
}
.nav-top2--win {
  background: #EDEDF1;
}
.nav-top2--win .nt2__link--skill:hover {background: var(--theme_big);}
.nav-top2--win .nt2__link--hierarchy:hover {background: var(--theme_big);}
.nav-top2--win .nt2__link--gyoshu:hover {background: var(--theme_big);}
.nav-top2--win .nt2__link--dokuritu:hover {background: var(--theme_big);}
.nav-top2--win .nt2__link--section:hover {background: var(--theme_big);}
.nav-top2--win .nt2__link--needs:hover {background: var(--theme_big);}
.nav-top2--win .nt2__link--new:hover {background: var(--theme_big);}

.nav-top2.js_is_fixed{
  position: fixed;
  top: 0;
  left:0;
  z-index:99999;
  padding: 10px 0;
}
.nav-top2.js_is_fixed .nt2{
  row-gap: 2px;
  column-gap: 10px;
}
.nav-top2.js_is_fixed .nt2__link{
  padding: 3px 16px;
}

@media screen and (max-width: 768px) {
  .nav-top2__title {
    width: 100%;
  }
  .nav-top2__title_sub{
    display: block;
    line-height: 1.6;
    margin-top: 5px;
    position: unset;
  }
  .nt2 {
    width: 100%;
    display: block;
  }
  .nt2__list + .nt2__list{  border-top: none}
  .nt2__link {
    font-size: 12px;
    line-height: 1.4;
  }
}

/* ボタン追加 */
.js_is_fixed .nt2{
    width: 100%;
}

.js_is_fixed .nt2__content{
  display: flex;
  width: 1290px;
  margin: 0 auto;
  gap: 10px;
}

.js_is_fixed.nav-top2 {
  margin: 0;
}

.nt2__content {
  display: flex;
}

.nt2-btn {
  display: none;
}

.js_is_fixed .nt2-btn {
  display: flex;
  gap: 10px;
}

.nt2-btn__item {
  font-size: 15px;
  font-weight: bold;
  width: 90px;
  height: 90px;
}

.nt2-btn__link{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 90px;
  height: 90px;
  border: 1px solid;
  border-radius: 50%;
  text-decoration: none;
  color: inherit;
  transition: .3s opacity;
  background-color: #FFFF;
  box-shadow: 3px 3px 10px rgba(158, 39, 48,.16);
}

.nt2-btn__link--inquiry {
  border-color: #E5002D;
}

.nt2-btn__link--inquiry::before {
  content: url("/resource/img/inquiry/footer-icon_inquiry.svg");
  top: 5px;
}

.nt2-btn__link--business {
  border-color: #2A6CAE;
}

.nt2-btn__link--business::before {
  content: url("/resource/img/inquiry/footer-icon_business-discussion.svg");
}

@media screen and (max-width: 768px) {
  .js_is_fixed .nt2-btn {
    display: none;
  }
  .js_is_fixed .nt2__content {
  width: 100%;
  }
}

/* スライダー */
.bxslider {
  opacity: 0;
  visibility: hidden;
  transition: .3s;
}
ul.bxslider > li:not(:first-child) {
  display: none;
}
.bxslider.slick-initialized {
  display: block;
  opacity: 1;
  visibility: visible;
}
.slick-slider {
  opacity: 0;
  position: relative;
  transition: opacity .3s linear;
  z-index: 9999;
}
.slick-slider.slick-initialized {
  opacity: 1;
}
.mainvisual-subContents {
  display: none;
}
.slick-initialized+.mainvisual-subContents {
  display: flex;
  background-color: rgba(255, 255, 255, 0.2);
}
@media screen and (max-width: 768px) {
  .slick-initialized+.mainvisual-subContents{
    display: none;
  }
}

/* スライダーのボタン */
.slick-prev,
.slick-next {
  position: absolute;
  top: 0;
  bottom: 0;
  display: block;
  width: 24px;
  height: 80px;
  margin: auto 0;
  border: none;
  background: #777;
  text-indent: -9999px;
  cursor: pointer;
}

.slick-prev::before,
.slick-next::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  width: 12px;
  height: 12px;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
  margin: auto;
}

.slick-prev {
  left: 0;
  transform: translateX(-100%);
}

.slick-next {
  right: 0;
  transform: translateX(100%);
}

.slick-prev::before {
  transform: translateX(4px) rotate(-135deg);
}

.slick-next::before {
  transform: translateX(-4px) rotate(45deg);
}

/* スライダーのページャー */
.slick-dots {
  display: flex;
  justify-content: center;
  position: absolute;
  bottom: -48px;
  left: calc(50% + 125px);
  transform: translate(-50%, 100%);
}

.slick-dots .slick-active:only-child {
  display: none;
}

.slick-dots button {
  display: block;
  height: 8px;
  width: 80px;
  margin: 0 8px;
  border: none;
  border-radius: 0;
  background: #fff;
  text-indent: -9999px;
  line-height: 0;
  cursor: pointer;
}

.slick-dots button:hover,
.slick-dots .slick-active button {
  background: var(--theme_big);
}
@media screen and (max-width: 768px) {
  .slick-dots button{
    width: 40px;
  }
}

/* スライダー */
body {
  :is(.bxslider) {
    .slick-prev,
    .slick-next {
      background-color: var(--theme_big);
      border-radius: 9999px;
      height: 27px;
      top: auto;
      bottom: -67px;
      width: 27px;
    }
    .slick-prev {
      left: calc((50% + 125px) - 450px);
    }
    .slick-next {
      right: calc((50% - 125px) - 450px);
    }
    .slick-prev::before,
    .slick-next::before {
      height: 8px;
      width: 8px;
    }
    .slick-prev::before {
      transform: translateX(2px) rotate(-135deg);
    }
    .slick-next::before {
      transform: translateX(-2px) rotate(45deg);
    }
  }
  .nav-top2 {
    padding-top: 42px;
    @media screen and (max-width: 768px) {
      padding-top: 0;
    }
  }
  .mainvisual--top:has(.slick-dots .slick-active:only-child)+.nav--container {
    .nav-top2 {
        padding-top: 12px;
    }
  }
}
@media screen and (max-width: 768px) {
  .slick-dots{
    bottom: -80px;
    left: calc(50%);
    transform: translate(-50%);
  }
}

/*
  new_message
================================*/

.co_newMessage {
  width: 1220px;
  margin: auto;
}
.co_newMessage_box {
  padding: 20px;
  background-color: #fff;
  position: relative;
  margin-top: 15px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}
.co_newMessage_title{
  color: var(--theme_big);
  font-size: 16px;
  font-weight: normal;
}
.co_newMessage_txt {
  margin-top:5px;
}
.co_newMessage_date{
  display: block;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .co_newMessage{
    width: 100%;
  }
}

/*
  #cont
================================*/
.p_wrapper {
  width: 1220px;
  margin: 34px auto 0;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px){
  .p_wrapper {
    width: 100%;
  }  
}

/* 目次 */
.simple + .simple {
  margin-top: 60px;
}
/* .simple{
  align-items: center;
  font-size: 20px;
  font-weight: bold;
  display: flex;
  line-height: 1.2;
  position: relative;
} */
.simple h2{
  align-items: center;
  font-size: 20px;
  font-weight: bold;
  display: flex;
  line-height: 1.2;
  position: relative;
  border-left: none;
  padding-left: 0;
  padding-bottom: 0;
  margin-bottom: 15px;
}
.simple h2::before{
  content: url(/resource/img/bup/middle/openseminar_middle_icon_1_2.png);
  background-color: var(--theme_big);
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  margin-right: 10px;
  width: 40px;
  height: 40px;
}
.simple h2::after{
  background-color: var(--theme_big);
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
}
.m_fLineup__ttl{
  font-size: 18px;
  margin-bottom: 5px;
}

/* 新着ニュース・提案書 */
.p_newsList__date{
  font-size: 12px;
}
.p_newsList__tags{
  display: none;
}
.p_newsList__target{
  color: #333;
  font-size: 13px;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.p_newsList__item{
  padding: 6px 0; 
}
.p_newsList__item + .p_newsList__item{
  border-top: 1px dotted #BEBEBE;
}
.p_newsList__ttl{
}
.news_container{
  display: flex;
  gap: 20px;
}
.news_contents ul{
  max-height: 354px;
  overflow: auto;
  border-top: 1px solid #BEBEBE;
  border-bottom: 1px solid #BEBEBE;
}
.news_contents .p_heading,
.proposal_contents .p_heading,
.companiesList_contents .p_heading,
.issue_contents .p_heading{
  font-size: 16px;
  border-left: none;
  color: var(--theme_big);
  font-weight: bold;
  margin-bottom: 5px;
}
.proposal_contents{
  min-width: 370px;
  width :100%;
}
.p_proposal__item + .p_proposal__item{
  margin-top:10px;
}
.p_proposal__ttl{
  font-size: 17px;
  font-weight: bold;
  color: #333;
}
.p_proposal__img{
  margin-top: 5px;
}
.p_proposal__img > img{
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
.p_proposal__date{
  font-size: 11px;
  text-align: right;
  color: #333;
}
.p_proposal__btnWrap{
  margin-top: 5px;
  display: flex;
  column-gap : 5px;
  justify-content: right;
}
.p_proposal__btn{}
.p_proposal__btn + .p_proposal__btn{}
.p_proposal__btnTarget{
  width: 120px;
  display: block;
  padding: 2px 0;
  border: 2px solid #333;
  border-radius: 8px;
  text-align: center;
  color: #fff;
  font-size: 11px;
  background: #333;
}
.p_proposal__btnTarget:hover{
  color: #333;
  background: #fff;
}
.p_proposal__btnTarget::after{
  /*content: "\f019";*/
  content: none;
  display: inline-block;
  margin-left: 0;
  line-height: 1;
  font-weight: normal;
  font-family: FontAwesome;
}
.p_proposal__btnTarget--web{
  border: 2px solid #1F2A63;
  background-color:#1F2A63;
}
.p_proposal__btnTarget--web::after{
  content: none;
}
.l_fieldWrap{
  margin-top: 60px;
}
@media screen and (max-width: 768px){
  .news_container{
    display: block;
  }
  .proposal_contents{
    min-width: auto;
    width: 100%;
    margin-top: 34px;
  }
}

/* ニュースをもっと見る */
.p_newsList__btnTarget{
  display: flex;
  justify-content: space-between;
}
.p_newsList__btnTarget__txt{
  position:relative;
}
.m_fLineup__txtLink_wrap{
 margin: 10px 0 20px; 
}
.m_fLineup__txtLink{
  margin: 10px 0 20px;
}
.m_fLineup__txtLink{
  position: relative;
}
.p_newsList__btnTarget__txt::after{
  content: "\f054";
  font-family: "Font Awesome 5 Free";
  position: relative;
  padding-left: 10px;
  transform: translateY(-50%);
  font-weight: bold;
  font-size: 10px;
}

.m_fLineup__txtLink::after{
  content: "\f054";
  font-family: "Font Awesome 5 Free";
  padding-left: 10px;
  right: -16px;
  top: 50%;
  transform: translateY(-50%);
  font-weight: bold;
  font-size: 10px;
}
@media screen and (max-width: 768px){
  .m_fLineup__txtLink_wrap{
    margin-top: 5px;
    text-align: right; 
  }
}

/* 企業一覧 */
.companiesList_container{}
.companiesList_container .p_heading{
  display: flex;
}
.companiesList_container .p_heading:before{
  content: "\f4c4";
  color: #fff;
  font-family: "Font Awesome 5 Free";
  font-weight: 600;
  background-color: var(--theme_big);
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  margin-right: 10px;
  width: 30px;
  height: 30px;
  font-size: 18px;
  border-radius: 50%;
}

.companiesList__list.l_grid--fLineup{
  margin-top: 0px;
}
.companiesList__item{
  position: relative;
}
.companiesList__item:nth-of-type(n + 4):before{
  content:"";
  display: inline-block;
  position: absolute;
  top: 0;
  left: 15px;
  background-color: #efefef;
  height: 1px;
  width:calc(100% - 30px);
}
.companiesList_container .m_fCardLg{
  display: flex;
  flex-direction: column;
  height: 100%;
}
.companiesList_container .m_fCardLg__ttl{
  font-size: 14px;
  height: auto;
}
.companiesList_container .m_fCardLg__ttl::after{
  content: none;
}
.companiesList__date{
  margin-top: auto;
  font-size: 11px;
}
@media screen and (max-width: 768px){
  .companiesList__item:nth-of-type(n + 3):before{
    content:"";
    display: inline-block;
    position: absolute;
    top: 0;
    left: 15px;
    background-color: #efefef;
    height: 1px;
    width:calc(100% - 30px);
  }
  .companiesList_container .m_fCardLg__ttl{
    max-height: none;
  }
}
@media screen and (max-width: 599px){
  .companiesList__item:nth-of-type(n + 3):before{
    content: none;
  }
  .companiesList__list.l_grid--fLineup > .l_grid__item:first-of-type {
    border-top: none;
  }
}

/* ボタン */
.m_fBtn {
  display: flex;
  align-items: stretch;
  justify-content: flex-end;
  font-size: 14px;
}
.m_fBtn__target {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1em;
  border: 1px solid var(--theme_big);
  border-radius: 4px;
  color: var(--theme_big);
  transition: .3s opacity;
}



/* よくあるご質問 */
.l_faqWrap{
  margin-top: 60px;
}
#cont #faqWrap h2 {
  margin-bottom: 0;
  line-height: 0;
  padding-bottom: 0;
}
.faq_contents h2:before{
  content: "\f128";
  color: #fff;
  font-size: 30px;
  font-family: FontAwesome;
  font-weight: normal;
}
.m_sec_faq {
  padding-top: 100px;
}
.m_sec_faq_itm {
  position: relative;
  border-bottom: 1px solid #CBCBCB;
}
.m_sec_faq_itm::before,
.m_sec_faq_itm::after {
  content: "";
  position: absolute;
  display: block;
  margin: auto;
  background-color: #000;
  transition: all 0.4s linear;
  border-radius: calc(1px / 0);
  z-index: 1;
}
.m_sec_faq_itm::before {
  width: calc(16 / 16* 1.6rem);
  height: calc(2 / 16* 1.6rem);
  right: calc(13 / 16* 1.6rem);
  top: calc(23/16 * 1.6rem);
}
.m_sec_faq_itm::after {
  width: calc(2 / 16* 1.6rem);
  height: calc(16 / 16* 1.6rem);
  top: calc(16/16 * 1.6rem);
  right: calc(20 / 16* 1.6rem);
}
.m_sec_faq_itm.js_open::after {
  font-family: "Helvetica Neue";
  -webkit-transform: rotate(90deg) translateY(0px);
  transform: rotate(90deg) translateY(0px);
}
.m_sec_faq_itm_Ttl {
  position: relative;
  padding: 25px 60px;
  font-size: 16px;
  font-weight: 700;
  z-index:2;
}
.m_sec_faq_itm_Ttl::before {
  content: "Q";
  position: absolute;
  width: 35px;
  height: 55px;
  left: 0;
  top: 50%;
  bottom: 50%;
  transform: translateY(-50%);
  font-size: 40px;
  color: var(--theme_big);
}
.m_sec_faq_itm_Cont {
  position: relative;
  margin-top: 10px;
  padding: 25px 60px;
}
.m_sec_faq_itm_Cont::before {
  content: "A";
  position: absolute;
  width: 35px;
  height: 55px;
  left: 2px;
  top: 0;
  font-size: 40px;
  font-weight: 700;
  color: var(--theme_haken);
}
.m_sec_faq_itm_Cont_Txt+.m_sec_faq_itm_Cont_Txt {
  padding-top: 20px;
}
.m_sec_faq_itm_Cont_Txt a {
  color: #052674;
}

@media (any-hover: hover) {
  .m_sec_faq_itm_Ttl:hover {
    cursor: pointer;
  }
  .m_sec_faq_itm_Cont_Txt a:hover {
    text-decoration: underline;
    opacity: 0.8;
  }
}

@media screen and (max-width:768px) {
  .m_sec_faq_itm::before {
    top: calc(22/16 * 1.6rem);
  }
  .m_sec_faq_itm::after {
    top: calc(15/16 * 1.6rem);
  }
  .m_sec_faq_itm_Ttl::before {
    top: 0;
    bottom: auto;
    transform: translateY(0);
  }
}

/* Fグリット */
.m_fLineup__wrap{
  display: flex;
  gap: 11px;
}
.m_fLineup__txt{
  flex: 1 1 auto;
}
.m_fLineup__img{
  flex: 0 0 31%;
}
.m_fLineup__img img{
  max-width: 100%;
  height: auto;
}
.l_grid--fLineup {
  margin: -15px;
}
.l_grid {
  display: flex;
  align-items: stretch;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.l_grid--fLineup > .l_grid__item {
  padding: 15px;
}
.l_grid__item {
  display: flex;
}
@media screen and (max-width: 599px){
  .m_fLineup__wrap{
    display: block;
  }
  .m_fLineup__img{
    margin-top: 5px;
  }
  .l_grid--fLineup{
    margin-top: 0;
  }
  .l_grid--fLineup > .l_grid__item {
    border-top: 1px solid #efefef;
  }
}

/* F式カード（大） */
.m_fCardLg{
  display: block;
  width: 100%;
  color: inherit;
  transition: opacity .3s;
}
.m_fCardLg:hover{
  opacity: .7;
}
.m_fCardLg__ttl{
  position: relative;
  margin-bottom: 4px;
  line-height: 1.4;
  font-weight: bold;
  font-size: 18px;
  height: calc(18px * 2 * 1.4);
  overflow: hidden;
}
.m_fCardLg__ttl::after{
  content: '';
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 3em;
  height: calc(18px * 1.4);
  background: linear-gradient(to left,#fff,rgba(255,255,255,0.96) 25%,rgba(255,255,255,0) 100%)
}
.m_fCardLg__body{}
.m_fCardLg__infos{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin: 0 -5px;
}
.m_fCardLg__infosWrap{}
.m_fCardLg__info{
  font-size: 12px;
  padding: 0 5px;
}
.m_fCardLg__info--type{
  color: #666;
}
.m_fCardLg__info--type::before{
  display: block;
  color: #666;
  padding: 2px 3px;
  border: 1px solid;
  border-radius: 2px;
  line-height: 1;
  font-size: 11px;
  min-width: 40px;
  text-align: center;
}
.m_fCardLg__info--date{
  color: #d66c00;
}
.m_fCardLg__infosWrap + .m_fCardLg__img{
  margin-top: 5px;
}
.m_fCardLg__img{
  line-height: 0;
  text-align: center;
  min-height: 92px;
}
.m_fCardLg__img img{
  max-width: 100%;
  height: auto;
}
.m_fCardLg__img--certification{}
.m_fCardLg__img--certification img{
  max-height: 100px;
}

.m_fCardLg__img + .m_fCardLg__cont{
  margin-top: 10px;
}
.m_fCardLg__infosWrap + .m_fCardLg__cont{
  margin-top: 10px;
}
.m_fCardLg__cont{
  position: relative;
  max-height: calc(13px * 3 * 1.6);
  line-height: 1.6;
  font-size: 13px;
  overflow: hidden;
}
.m_fCardLg__cont::after{
  content: '';
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 3em;
  height: calc(13px * 1.6);
  background: linear-gradient(to left,#fff,rgba(255,255,255,0.96) 25%,rgba(255,255,255,0) 100%)
}
@media screen and (max-width: 768px){
  .m_fCardLg__ttl{
    height: auto;
    max-height: calc(18px * 2 * 1.4);
  }
}
/* F式カード（小） */
.m_fCardMd{
  display: flex;
  align-items: center;
  width: 100%;
  color: inherit;
  transition: opacity .3s;
}
.m_fCardMd:hover{
  opacity: .7;
}
.m_fCardMd__body{
  flex: 1 1 auto;
}
.m_fCardMd__ttl{
  position: relative;
  height: calc(14px * 2 * 1.5);
  margin-bottom: 4px;
  font-weight: bold;
  font-size: 14px;
  line-height: 1.5;
  overflow: hidden;
}
.m_fCardMd__ttl::after{
  content: '';
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 3em;
  height: calc(14px * 1.5);
  background: linear-gradient(to left,#fff,rgba(255,255,255,0.96) 25%,rgba(255,255,255,0) 100%)
}
.m_fCardMd__infosWrap{}
.m_fCardMd__infos{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin: 0 -5px;
}
.m_fCardMd__info{
  font-size: 12px;
  padding: 0 5px;
}
.m_fCardMd__info--type{
  color: #666;
}
.m_fCardMd__info--type::before{
  display: block;
  padding: 2px 3px;
  border: 1px solid;
  border-radius: 2px;
  line-height: 1;
  font-size: 11px;
  min-width: 40px;
  text-align: center;
}
.m_fCardMd__info--date{
  color: #d66c00;
}
.m_fCardMd__body + .m_fCardMd__img{
  margin-left: 4px;
}
.m_fCardMd__img{
  flex: 0 0 86px;
  line-height: 0;
  text-align: center;
}
.m_fCardMd__img img{
  max-width: 100%;
  height: auto;
}
@media screen and (max-width: 768px){
  .m_fCardMd__ttl{
    height: auto;
    max-height: calc(14px * 2 * 1.5);
  }
}
/* ラベル */
[service_type=douga]::before {
  content: "\52d5\753b\95a2\9023"!important;
  color: #cc2d5e!important;
  background: none!important;
}
[service_type=middle]::before {
  content: "\307e\3068\3081"!important;
  color: #842e30!important;
  background: none!important;
}
[service_type=haken]::before {
  content: "\6D3E\9063"!important;
  color: #842e30!important;
  background: none!important;
}
[service_type=bup]::before {
  content: "\516C\958B"!important;
  color: #0c3f71!important;
  background: none!important;
}
[service_type=other]::before {
  content: "\4ed6\ff7b\ff70\ff8b\ff9e\ff7d"!important;
  color: #e6002d!important;
  background: none!important;
}
[service_type=it]::before {
  content: "IT\FF7B\FF70\FF8B\FF9E\FF7D"!important;
  color: #008d79!important;
  background: none!important;
}
[service_type=free]::before {
  content: "\7121\6599\FF7E\FF90\FF85\FF70"!important;
  color: #333!important;
  background: none!important;
}
[service_type=cont]::before {
  content: "\8AAD\307F\7269"!important;
  color: #0c3f71!important;
  background: none!important;
}
[service_type=consul]::before {
  content: "\30B3\30F3\30B5\30EB"!important;
  color: #7a614f!important;
  background: none!important;
}
[service_type="certification"]::before {
  content: "\901a\4fe1\6559\80b2" !important;
  color: #E35951 !important;
  background: #fff !important;
}

/* Leaf Lightning STUDIO対応 */
[href="/it-tool/studio-pbl.html"] .m_fCardLg__ttl{
  font-size: 0;
}
[href="/it-tool/studio-pbl.html"] .m_fCardLg__ttl::before{
  content: "Leaf lightning STUDIO～定額制eラーニング視聴サービス";
  font-size: 18px;
}

/**********
utility
**********/
/*横幅*/
.u_col1{width:8.333%;}
.u_col2{width:16.667%;}
.u_col25{width:20%;}
.u_col3{width:25%;}
.u_col4{width:33.333%;}
.u_col5{width:41.666%;}
.u_col6{width:50%;}
.u_col7{width:58.333%;}
.u_col8{width:66.666%;}
.u_col9{width:75%;}
.u_col10{width:83.33%;}
.u_col11{width:91.666%;}
.u_col12{width:100%;}
@media screen and (max-width:768px){
.u_resMdCol1{width:8.333%;}
.u_resMdCol2{width:16.667%;}
.u_resMdCol3{width:25%;}
.u_resMdCol4{width:33.333%;}
.u_resMdCol5{width:41.666%;}
.u_resMdCol6{width:50%;}
.u_resMdCol7{width:58.333%;}
.u_resMdCol8{width:66.666%;}
.u_resMdCol9{width:75%;}
.u_resMdCol10{width:83.33%;}
.u_resMdCol11{width:91.666%;}
.u_resMdCol12{width:100%;}
}
@media screen and (max-width:599px){
.u_resSmCol1{width:8.333%;}
.u_resSmCol2{width:16.667%;}
.u_resSmCol3{width:25%;}
.u_resSmCol4{width:33.333%;}
.u_resSmCol5{width:41.666%;}
.u_resSmCol6{width:50%;}
.u_resSmCol7{width:58.333%;}
.u_resSmCol8{width:66.666%;}
.u_resSmCol9{width:75%;}
.u_resSmCol10{width:83.33%;}
.u_resSmCol11{width:91.666%;}
.u_resSmCol12{width:100%;}
}

/*文字間*/
.u_ls0{ letter-spacing: 0;}
.u_lsN1{ letter-spacing: -1px;}

/*画像のみ*/
.u_onlyImg{
  display: block;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  line-height: 0;
}
.u_onlyImg--link{
  cursor: pointer;
  transition: .3s opacity;
}
.u_onlyImg--link:hover{
  opacity: .7;
}
/*間隙*/
.u_mt5{margin-top: 5px;}
.u_mt10{margin-top: 10px;}
.u_mt15{margin-top: 15px;}

/* 脚注 */
.u_footNote{
  position: relative;
  padding-left: 1em;
  font-size: 12px;
}
.u_footNote::before{
  content: "※";
  position: absolute;
  left: 0;
  display: block;
}
/* 脚注 */
.u_res_br{
  display: none;
}
@media screen and (max-width: 768px) {
  .u_res_br{
    display: block;
  }
}