body{ overflow-x: hidden; }
@media screen and (max-width: 1100px) {
  body{ overflow-x: auto; }
}

/* MAIN VISUAL
--------------------------- */
#main_image_area_src {
  display: flex;
  justify-content:center;
  align-items:center;
  background:url(/img/fm/csi01/mv/mv-home.jpg) center center no-repeat;
  background-size:cover;
}
#mv_inner {
  margin-top: -180px;
}
#mv_inner  p {
  margin-top: 0;
  text-align: center;
  font-family: "Noto Sans JP";
  font-weight: bold;
  color: #fff;
  text-shadow: 1px 1px 10px #0d324f;
  line-height: 1.3em;
}
/* -- PC -- */
@media screen and (min-width: 768px) {
  #main_image_area_src {
    aspect-ratio: 48/25;
  }
  #mv_inner p.MainText {
    margin-bottom: 20px;
    font-size: 44px;
    color:#fff;
  }
  #mv_inner p.SubText {
    margin-bottom: 0;
    font-size: 28px;
  }
}
@media screen and (max-width: 767px) {
  #main_image_area_src {
    aspect-ratio: 48/25;
    background: url(/img/fm/csi01/mv/mv-home.jpg) no-repeat;
    background-size:contain;
  }
  #mv_inner {
    margin-top: 0px;
  }
  #mv_inner p.MainText {
    margin-bottom: 10px;
    font-size: 20px;
  }
  #mv_inner p.SubText {
    margin-bottom: 0;
    font-size: 15px;
  }
}

/* //////////////////////////////////////////// */

/* SECTION PADDING
--------------------------- */
/* -- PC -- */
@media screen and (min-width: 768px) {
  section.ContentArea {
    padding: 100px 0;
  }
}
/* -- SMP -- */
@media screen and (max-width: 767px) {
  section.ContentArea {
    padding: 50px 10px;
  }
}

/* COMMON
--------------------------- */
.HdgStyleE_ {
  margin-bottom: 70px;
}
/* -- SMP -- */
@media screen and (max-width: 767px) {
  .HdgStyleE_ {
    margin-bottom: 30px;
  }
  .HeadingBox_ h2{
    font-size: 20px;
    font-weight: bold;
  }
}

/* 写真とセットボックスの横並び */
/* -- PC -- */
@media screen and (min-width: 768px) {
  .CardWrap{
    display: flex;
    margin-bottom: 70px;
    width: 100%;
  }
  .CardWrap.Reverse{
    flex-direction: row-reverse;
  }
  .CardWrap:last-child{
    margin-bottom: 0;
  }

  .CardWrap .ImageBox_ {
    z-index: 1;
    margin: 0;
    width: 50%;
    text-align: left;
  }
  .CardWrap.Reverse .ImageBox_ {
    text-align: right;
  }

  .CardWrap .SetBox_ {
    z-index: 2;
    width: 50%;
  }
  .CardWrap.Reverse .SetBox_{
    margin-left: 0;
  }
}
/* -- SMP -- */
@media screen and (max-width: 767px) {
  .CardWrap{
    margin-bottom: 10px;
  }
  .CardWrap .ImageBox_ {
    margin-bottom: 0;
    line-height: 0;
  }
}

/* //////////////////////////////////////////// */

/* こんなお悩み
--------------------------- */
.HeadingBox_.Problem {
  margin-bottom: 20px;
  padding: 10px 30px;
  background-color: #2a85cd;
  color: #fff;
}
.CardWrap.ProblemCard .TextBox_ {
  padding: 0 30px 0 10px;
  font-size: 20px;
}
.CardWrap.ProblemCard .ImageBox_{
  padding-top: 20px;
}
.CardWrap.ProblemCard .ImageBox_ img{
  width: 470px;
  height: auto;
}

/* SP */
@media screen and (max-width: 767px) {
  .CardWrap.ProblemCard .TextBox_ {
    font-size: 18px;
  }
  #resolution .FS28_{
    font-size: 18px !important;
  }
}

/* チェックボックスの調整 */
ul.ListCheckB_ { margin: 0; }
ul.ListCheckB_ li {
  margin: 0 0 15px;
  padding: 5px 0 5px 50px;
  background: url(/img/fm/csi01/home/check.png) left center no-repeat;
  background-size: 44px;
}


/* サービス */
#personal_menu {
  background-color: #ecfceb;
}
#organization_menu {
  background-color: #e5f1f9;
}
#personal_menu,
#organization_menu {
  padding: 50px 30px;
  text-align: center;
}
#personal_menu ul,
#organization_menu ul{
  padding: 0;
  text-align: center;
  list-style-type: none;
}
#personal_menu li,
#organization_menu li{
  border-radius: 50px;
  margin-top: 30px;
  padding: 20px 0;
  background-color: #fff;
  font-size: 20px;
}
#personal_menu li {
  border: 3px #499244 solid;
}
#organization_menu li{
  border: 3px #2b86cc solid;
}
/* -- SMP -- */
@media screen and (max-width: 767px) {
  #personal_menu li,
  #organization_menu li{
    font-size: 18px;
  }
}

/* ピックアップ
--------------------------- */
section#pickup_area{
  background: url(/img/fm/csi01/frame/bg-pickup.jpg) center center no-repeat;
  background-size: cover;
}
/* -- PC -- */
@media screen and (min-width: 768px) {
  section#pickup_area {
    background-attachment: fixed;
  }
}
/* -- SMP -- */
@media screen and (max-width: 767px) {
  section#pickup_area{
    background-position: center left;
  }
}

/* 見出しを白に */
#pickup_area .HdgStyleE_,
#pickup_area .HdgStyleE_ span {
  color: #fff;
}

#pb_pickup .CB_ {
  padding: 5px 5px 30px;
}
#pb_pickup .ImageBox_ {
  padding: 0 0 20px;
}
#pb_pickup .ImageBox_ img{
  object-fit: cover;
  width: 100%;
  height: 250px;
}
#pb_pickup .HeadingBox_ {
  padding: 0 0 20px;
}

/* INFORMATION
--------------------------- */
#information_area {
  padding: 0px 50px;
}
ul#information_list {
  box-sizing: border-box;
  margin: 0 auto 20px;
  padding: 0;
  width: 100%;
  list-style-type: none;
}
#information_list li {
  display: flex;
  align-items: flex-start;
  gap: 15px;
  border-bottom: 1px dotted gray;
  padding: 20px;
}
#information_list .Date {
  min-width: 100px;
  font-weight: bold;
}
#information_list .Category{
  min-width: 110px;
  border-radius: 50px;
  padding: 3px;
  background-color: #4a9242;
  text-align: center;
  font-size: 13px;
  color: #fff;
}
#information_list .Title {
  flex-basis: auto;
  padding-left: 5px;
}
/* SP */
@media screen and (max-width: 767px) {
  #information_area {
    padding: 20px;
  }
  #information_area li{
    flex-wrap: wrap;
    padding: 10px;
  }
  #information_list .Title {
    flex-grow: 1;
    min-width: 100%;
    padding-left: 0px;
  }
}

/* 書籍紹介
--------------------------- */
/* -- PC -- */
@media screen and (min-width: 768px) {
  .CardWrap.Books {
    padding: 30px;
  }
  .CardWrap.Books .ImageBox_ {
    width: 40%;
  }
  .CardWrap.Books .SetBox_ {
    padding: 0 30px 30px;
    width: 60%;
  }
}
.CardWrap.Books {
  background-color: #fff;
}

.HeadingBox_.BookTitle{
  margin-bottom: 30px;
  text-align: center;
}
.HeadingBox_.Author{
  margin-bottom: 10px;
}
/* SP */
@media screen and (max-width: 767px) {
  .CardWrap.Books .ImageBox_ img{
    padding-top: 10px;
    width: 250px;
  }
  .HeadingBox_.BookTitle span{
    font-size: 16px;
  }
}
