@charset "UTF-8";
/* CSS Document */
/*---------------------------------

  mainvisual

---------------------------------*/
#ReadCopyBlock {
  background: url("../images/bg.png") no-repeat top / 100% auto;
  padding: 5rem 0;
  position: relative;
}
#ReadCopyBlock .wrap {
  margin: auto;
  width: 95%;
  position: relative;
}
#main-slider {}
#main-slider .splide__slide {}
#main-slider .splide__slide img {
  border-radius: 2rem;
  opacity: .3;
  transform: scale(.8);
  transition: .7s;
}
#main-slider .splide__slide.is-active img {
  opacity: 1;
  transform: scale(1);
  z-index: 1;
}
#main-slider .splide__slide img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  vertical-align: bottom;
}
#ReadCopyBlock .wrap figure {
  max-width: 70rem;
  position: absolute;
  bottom: -3rem;
  left: 10%;
  width: 90%;
  z-index: 10;
}
#ReadCopyBlock .wrap figure img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
#ReadCopyBlock .txt {
  font-size: 1.2em;
  font-weight: 500;
  max-width: fit-content;
  position: absolute;
  top: 10%;
  right: 10%;
  width: 90%;
}
#ReadCopyBlock .txt p {
  background: #fff;
  display: inline;
  padding: .2rem;
  line-height: 2.2;
}
@media screen and (max-width: 1440px) {
  #ReadCopyBlock .txt {
    right: 2.5%;
  }
  #ReadCopyBlock .wrap figure {
    left: 5%;
  }
}
@media screen and (max-width: 1024px) {
  #ReadCopyBlock .txt {
    font-size: 1em;
    top: 5%;
    right: 0;
  }
  #ReadCopyBlock .wrap figure {
    max-width: 50rem;
    left: 0;
  }
}
@media screen and (max-width: 896px) {
  #ReadCopyBlock {
    padding-bottom: 2rem;
  }
  #ReadCopyBlock .wrap {}
  #ReadCopyBlock .wrap figure {
    max-width: 40rem;
    left: 0;
  }
  #ReadCopyBlock .txt {
    margin: 5rem auto 0;
    text-align: center;
    position: inherit;
  }
  #ReadCopyBlock .txt p {
    background: transparent;
    display: block;
    padding: 0;
    line-height: 1.8;
  }
}
@media screen and (max-width: 480px) {
  #ReadCopyBlock .wrap figure {
    max-width: 30rem;
  }
}
/*---------------------------------

  mainColum

---------------------------------*/
#mainContainer {
  background: #f3f3f3;
  padding: 7rem 0 12rem;
}
#mainColum {
  display: flex;
  justify-content: space-between;
  margin: auto;
  max-width: 1200px;
  width: 90%;
}
@media screen and (max-width: 1024px) {}
@media screen and (max-width: 896px) {
  #mainContainer {
    padding: 4rem 0 7rem;
  }
  #mainColum {
    flex-direction: column;
  }
}
@media screen and (max-width: 480px) {}
/*---------------------------------

  informationBlock

---------------------------------*/
.informationBlock {
  flex-basis: 60%;
}
.informationBlock .wrap {}
.informationBlock .wrap .title {
  margin-bottom: 2rem;
}
.informationBlock .wrap .title h2 {
  font-size: 1.6em;
  font-weight: 600;
}
.informationBlock .wrap .infoList {
  display: flex;
  flex-direction: column;
  grid-gap: 1rem;
}
.informationBlock .wrap .infoList dl {
  background: #fff;
  border-radius: 1.5rem;
  display: flex;
  overflow: hidden;
  -webkit-transition: all .3s;
  transition: all .3s;
}
.informationBlock .wrap .infoList dl:hover {
  transform: scale(1.05);
  box-shadow: 0 0 2rem 0 rgba(0, 0, 0, 0.2);
}
.informationBlock .wrap .infoList dl dt._catLink {
  flex: 0 0 13rem;
}
.informationBlock .wrap .infoList dl dt._catLink a {
  background: #ccc;
  color: #fff;
  display: grid;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: .9em;
  line-height: 1.3;
  padding: 1rem .5rem;
  height: 100%;
}
.informationBlock .wrap .infoList dl dt._catLink a br {
  display: none;
}
.informationBlock .wrap .infoList dl dt._catLink a:hover {
  opacity: 1;
}
.informationBlock .wrap .infoList dl dd._infoTxt {
  flex: 1 1 calc(100% - 13rem);
}
.informationBlock .wrap .infoList dl dd._infoTxt a {
  color: #333;
  display: block;
  padding: 1rem 1.5rem 1.5rem;
}
.informationBlock .wrap .infoList dl dd._infoTxt time {
  color: #777;
  font-size: .9em;
}
.informationBlock .wrap .infoList dl dd._infoTxt p {
  font-weight: 500;
  line-height: 1.4;
}
.informationBlock .wrap .infoList dl dd._infoTxt a:hover {
  color: #754c24;
  opacity: 1;
}
/* 各色 */
.informationBlock .wrap .infoList dl dt._catLink.__higasi a {
  background: var(--higasi);
}
.informationBlock .wrap .infoList dl dt._catLink.__nisi a {
  background: var(--nishi);
}
.informationBlock .wrap .infoList dl dt._catLink.__doubata a {
  background: var(--douhata);
}
.informationBlock .wrap .infoList dl dt._catLink.__nisioosima a {
  background: var(--nisioosima);
}
.informationBlock .wrap .infoList dl dt._catLink.__kouennisi a {
  background: var(--kouennisi);
  border: 1px solid #d5d5d5;
  border-right: none;
  border-radius: 1.5rem 0 0 1.5rem;
  color: #888;
}
.informationBlock .wrap .infoList dl dt._catLink.__tiiki a {
  background: var(--tiiki);
}
.informationBlock .wrap .infoList dl dt._catLink.__tabiko a {
  background: var(--tabiko);
}
@media screen and (max-width: 1024px) {}
@media screen and (max-width: 896px) {}
@media screen and (max-width: 480px) {
  .informationBlock .wrap .infoList {
    grid-gap: 2rem;
  }
  .informationBlock .wrap .infoList dl {
    border-radius: 1rem;
    display: block;
  }
  .informationBlock .wrap .infoList dl dt._catLink a {
    padding: 1.5rem;
  }
  .informationBlock .wrap .infoList dl dt._catLink a span {
    background: url("../images/arr_s_w.svg") no-repeat center right/ .5rem;
    display: inline-block;
    padding-right: 1.5rem;
  }
  .informationBlock .wrap .infoList dl dt._catLink.__kouennisi a {
    border-right: 1px solid #d5d5d5;
    border-bottom: none;
    border-radius: 1rem 1rem 0 0;
  }
  .informationBlock .wrap .infoList dl dt._catLink.__kouennisi a span {
    background-image: url("../images/arr_s_b.svg");
  }
}
/*---------------------------------

  totalInfoBlock

---------------------------------*/
.totalInfoBlock {
  border-left: 1px solid;
  flex-basis: 35%;
}
.totalInfoBlock ._sticky {
  position: sticky;
  top: 5%;
}
.totalInfoBlock .wrap {
  padding-left: 10%;
}
.totalInfoBlock .wrap .title {
  border-top: 2px solid;
  border-bottom: 1px solid #ccc;
  padding: 1.5rem 0;
}
.totalInfoBlock .wrap .title h2 {
  font-size: 1.2em;
}
.totalInfoBlock .wrap .infoList {
  list-style: none;
}
.totalInfoBlock .wrap .infoList li {
  border-bottom: 1px dotted #ccc;
}
.totalInfoBlock .wrap .infoList li a {
  color: #333;
  display: block;
  line-height: 1.5;
  padding: 2rem 0;
}
.totalInfoBlock .wrap .infoList li a:hover {
  opacity: 1;
  transform: translateX(1rem);
}
.totalInfoBlock .wrap .infoList li a time {
  color: #666;
  font-size: .9em;
  display: block;
  margin-bottom: .5rem;
}
.totalInfoBlock .wrap .infoList li a p {
  font-weight: 500;
}
.totalInfoBlock .wrap .btn {
  margin: 3rem auto 0;
  max-width: 25rem;
  text-align: center;
}
.totalInfoBlock .wrap .btn a {
  background: #000;
  border-radius: 5rem;
  color: #fff;
  display: block;
  padding: 1rem;
}
.totalInfoBlock .wrap .btn a span {
  background: url("../images/arr_s_w.svg") no-repeat center right/ .5rem;
  display: inline-block;
  padding-right: 2rem;
}
@media screen and (max-width: 1024px) {}
@media screen and (max-width: 896px) {
  .totalInfoBlock {
    border-left: none;
    margin-top: 5rem;
  }
  .totalInfoBlock ._sticky {
    position: inherit;
    top: 0;
  }
  .totalInfoBlock .wrap {
    padding-left: 0;
  }
}
@media screen and (max-width: 480px) {}