/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap');


body {
   margin: 0;
   font-family: 'Helvetica Neue', sans-serif;
   font-feature-settings: "palt";
   color: #fff;
   overflow-x: hidden;
   width: 100%;
   line-height: 1.4;
}
 video{
   position: absolute;
   z-index: -9999;
   width: 100%;
   margin: -3em 0 0 0;
}
 .container {
   width: 90%;
   max-width: 1200px;
   margin: auto;
   padding: 15px 0 0 0;
   clear: both;
}
 .header {
   background-color: #460073;
   color: #fff;
   padding: 3px 0;
}
 h2{
   font-size: 1.8em;
   margin: 2em 0 1em 0;
   padding: 0;
   color: #fff;
   text-align: center;
   background-image: linear-gradient(-0deg, rgba(3, 12, 57, 0.249) 50%, #0000 50%);

}
 #l-header-logo{
   background: center url(../img/h_logo.svg) no-repeat;
   text-indent: -9999px;
   background-size: 120px auto;
   width: 160px;
   height: 70px;
   display: block;
   float: left;
   margin-right: 10px;
}

 #kpmg-logo{
   background: center url(../img/kpmg_logo.png) no-repeat;
   text-indent: -9999px;
   background-size: 110px auto;
   width: 160px;
   height: 70px;
   display: block;
   float: left;
}

#ttlBox{
   padding: 0 5%;
   clear: both;
}

h1{
   margin: 0;
   padding: 1em 0 0 0;
   text-align: center;
   line-height: 1.5em;
   font-weight: bold;
   text-shadow: 10px 10px 1px rgba(0, 0, 0, 0.3);
   clear: both;
   font-size: 3.2em;
}
 h1 span{
  border-bottom: #f3ff00 5px solid;
 }
.ttlcopy{
  clear: both;
  font-size: 1.3em;
  text-align: center;
}

 .nav-links {
   list-style: none;
   display: flex;
   gap: 20px;
}
 .nav-links a {
   color: #fff;
   text-decoration: none;
}
 #hero {
   color: #fff;
   padding: 0;
   text-align: center;
   position: relative;
   z-index: 9999;
}
.hero-note{
  clear: both;
}
#personBox{
  padding: 0;

}

#personBox li{
  display: inline-block;
  list-style: none;
  background: rgba(2, 14, 60, 0.667);
  border-radius: 55px 0px 55px 55px;
  clear: both;
  padding: 0 1em 0 0;
  margin:0 1em 1em 0;
}

#personBox li img{
  float: left;
  width: 110px;
  height: 110px;
  background: linear-gradient(30deg, #fff 60%, #00000000 100%);
  border-radius: 50%;
}
#personBox li p{
  float: left;
  padding: 0 0 0 1em;
  text-align: left;
}
#personBox li p span{
  display: block;
  font-size: 1em;
  padding-top: 0.5em;
}

 #caltext{
  display: inline-block;
   clear: both;
   text-align: center;
   margin-bottom: 1em;
}
 #caltext img{
  width: 50%;
  min-width: 300px;
}
 #contactBox{
  display: block;
   margin: 0 40px 0 40px;
}
 #bubble{
   position: relative;
   display: block;
   width: 80px;
   height: 80px;
   border-radius: 50%;
   margin: 0px;
   padding: 6px;
   background-color: #f3ff00;
   text-align: center;
   font-size: 16px;
   font-weight: bold;
   line-height: 1.5;
   color: #000;
   float: right;
   z-index: 100;
}
 .entryBtn {
  display: block;
  text-align: center;
  margin: 0 auto;
   color: #333;
   font-size: 1.6em;
   font-weight: bold;
   padding: 13px 1em;
   position: relative;
   z-index: 1;
   clear: both;
   max-width: 400px;
   text-decoration: none;
   border-radius: 10px;
  background: #f3ff00;
}
 .entryBtn:hover {
  background: #988a10;
}



/* よくある質問 */


.faq {
  background: #fff;
  width: 1000px;
  max-width: 100%;
  margin: 3rem auto 0;
  border-radius: 20px;
  box-shadow: 6px 6px 0 #ffe5c7;
}

.faq-item {
  margin: 0 auto 0 10%;
  color: #333;
}


.faq-question {
  font-size: 1.2em;
  color: #1c1c1c;
  position: relative;
  padding: 15px;
  font-weight: bold;
  display: inline-block;
  line-height: 1.4;
  background: #fff;
  border-radius: 0px 20px 20px 20px;
  margin-bottom: 5px;
}
.faq-question::before {
  content: "Q";
  width: 30px;
  text-align: left;
  color: #00489b74;
  margin-right: 8px;
}

.faq-answer {
  color: #fff;
  font-size: 18px;
  position: relative;
  margin: 0 0 20px 0;
  padding: 15px;
  line-height: 1.4;

    width: 90%;
    float: right;
}
.faq-answer::before {
  content: "A";
  display: flex;
  font-size: 24px;
  font-weight: bold;
  float: left;
  width: 30px;
  height: 3.5em;
  text-align: left;
  color: #fff;
}
.faq-section::after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 100%;
  height: 50%;
  background-color: #ffffff;
  transform: skewY(7deg);
  transform-origin: top right;
  z-index: -1;
}

 #hero::after{
   display: block;
   clip-path: polygon(0% 0%, 100% 10%, 100% 90%, 0% 100%);
}
 .section { padding: 0 0;}
 .section.white {
   color: #222;
   padding: 10px 0 90px 0;
   margin: 0px 0 0 0;
}

 .section.dark {
   background-color: #222;
   color: #fff;
   clip-path: polygon(0% 0%, 100% 10%, 100% 90%, 0% 100%);
   padding: 290px 0 90px 0;
   margin: -280px 0 0 0;
}
 .section ul, .section ol {
   padding-left: 0px;
   list-style: none;
}
.name{
    font-size: 1.2em;
    font-weight: bold;
    float: left;
    min-height: 2.5em;
    margin: 0 1em 0 0;
}
.name{margin: 0 1em 0 0;}
.job{ font-size: 1em;
   display: flex;
  margin: 0;}

.outline{
display: table;
margin: 0 auto 2em auto;
padding: 0;
clear: both;
}
.outline li{
  font-size: 1.3em;
  margin: 0;
  padding: 0;
  padding: 0.2em;
}

.target{
display: table;
margin: 0 auto;
padding: 0;
clear: both;
}
.target li{
  font-size: 1.3em;
  margin: 0;
  padding: 0;
  padding: 0.2em;
}


h3{
  font-size: 1.6em;
  display: block;
  color: #00489b;
  border-bottom: 2px solid #00489b;
  margin: 0 0 0.6em 0;
  padding: 0;
}

ol.num-list > li::before {
  color: #00489b74;
  font-size: 1.8em;
  counter-increment: session;
  content: "session" counter(session);
  display: block;
  font-weight: bold;
  margin-bottom: 0;
  font-family: "Oswald", sans-serif;

}

ol.num-list {
  counter-reset: session;
  margin: 0 10% 2em 10%;
  padding: 0;
  color: #333;
}
.num-list > li {
   background: #fffc;
   margin-bottom: 1em;
   padding: 1em 2em 2em 2em;
   list-style: none;
}
.num-list > li > ul li{
  font-size: 1.2em;
}

.bodycopy{
  margin: 0;
  padding: 1em 0 1em 0;
  font-size: 1.2em;
  line-height: 1.6;
  text-align: center;
  clear: both;
}

.optionBox{text-align: center;}
.option{background: #e7eaca;padding: 16px 20px;color: #333; display: inline-block; }
.option h3{font-size: 1.4em; }

 .contact form {
   display: flex;
   flex-direction: column;
   gap: 10px;
}
 .contact input, .contact textarea {
   padding: 10px;
   font-size: 16px;
   width: 100%;
}
 .contact button {
   background-color: #ff6f00;
   color: #fff;
   border: none;
   padding: 10px;
   cursor: pointer;
}
 .footer {
   background-size: 100% auto;
   color: #fff;
   text-align: center;
   padding: 20px 0;
}
 #formAreaSP, #formAreaPC{
  border-radius: 5px
}


/* KF anime1 */
.prof_bar {
  position: relative;
  top: 0;
  background: #fffc;
  animation-timeline: scroll(root);
  margin-bottom: 2em;
  border-radius: 50px 0 0 0;
  height:fit-content;
  display: inline-flex;
}

.prof_bar img {
  height: 110px;
  width: 110px;
  border-radius: 50%;
  position: relative;
  top: -30px;
  float: left;
}
.prof_boxR{
  padding: 1em 1em 0 0.4em;
  color: #333;
  font-size: 1.2em;
  line-height: 1.4;
}
.jobDetail{
  font-size: 0.8em;
}

/* 登壇者紹介 */
    .jobDetail {
      max-height: 0;
      overflow: hidden;
      transition: max-height 0.5s ease;
    }

    .jobDetail.open {
      max-height: 700px; /* 内容に応じて調整 */
    }

    .toggleDetail {
      display: block;
      cursor: pointer;
      background-color: #eee;
      border: none;
      padding: 5px 10px;
      margin: 5px 0 5px 0;
    }

    .prof_bar {
      margin-bottom: 20px;
      border: 1px solid #ccc;
      padding: 10px;
    }

.bg {
  animation:slide 8s ease-in-out infinite alternate;
  background-image: linear-gradient(-60deg, #001139 50%, #012581 50%);
  bottom:0;
  left:-50%;
  opacity:.5;
  position:fixed;
  right:-50%;
  top:0;
  z-index:-1;
}

.bg2 {
  animation-direction:alternate-reverse;
  animation-duration:16s;
}

.bg3 {
  animation-duration:20s;
}


@keyframes slide {
  0% {
    transform:translateX(-25%);
  }
  100% {
    transform:translateX(25%);
  }
}

/* display change */
.entry-pc {
  display: block !important;
}
.entry-sp {
  display: none !important;
}






/* スマホ タブレット対応 */

 @media (max-width: 1000px) {
h1 {
    font-size: 2.8em;
}
 }

 @media (max-width: 900px) {
h1 {
    font-size: 2.2em;
}
 }


 @media (max-width: 767px) {

h1 {
    font-size: 2em;
}

   video {
     margin: 0 0 0 0;
  }
   h3{
    font-size: 1.2em;
  }

  #personBox {float: none; width: auto;}

#personBox li img {
    width: 80px;
    height: 80px;
}

  #ttlBox{width: auto;}

   #contactBox{
     margin: 0 0 0 0;
     float: none;
  }
   #caltext {
     float: none;
     font-size: 1.6em;
     margin-bottom: 0.5em;
  }

  ol.num-list {
  margin: 0 0 2em 0;
}
   .section.dark {
     clip-path: polygon(0% 0%, 100% 5%, 100% 95%, 0% 100%);
  }
   #contactBox {
     float: none;
  }


  .num-list li {
    font-size: 1em;
  }

 .num-list li > ul {
  margin: 0 0 0 1.5em;
  padding: 0;
  }
  .num-list > li > ul li {
    font-size: 1em;
}

  #l-header-logo{
   background-size: 90px auto;
   width: 110px;
   height: 50px;
  }
   #kpmg-logo{
   background-size: 80px auto;
   width: 110px;
   height: 50px;
  }

  /* display change */
.entry-pc {
  display: none !important;
}
.entry-sp {
  display: block !important;
}
}
 

 @media (max-width: 600px) {

  h2 {
    font-size: 1.5em;
    margin: 1em 0 1em 0;
  }
.target {
    display: table;
    margin: 0 0 0 2em;
}
.outline {
    display: table;
    margin: 0 0 1em 2em;
}

#personBox li{
  margin:0 1em 0.5em 0;
}

.name{float: none; min-height: auto;}
.job{font-size: 0.8em;}
.faq-item {
    margin: 0 auto 0 0;
}
.entryBtn {
  max-width: 70%;
}

.bodycopy {
    margin: 0;
    padding: 0 0 1em 0;
}
 }