@charset "UTF-8";

/* 各セクションの背景色と余白 */
#infomation, #overview, #thought, #access {
  padding: 80px 0;
}
#infomation, #thought {
  background-color: #F6EFE3;
}
#overview, #access {
  background-color: #F6EDD2;
}


/* main-visual */
#main-visual {
  background-image: url(../image/index/main-pc.JPG);
  background-repeat: no-repeat;
  background-size: cover;
  height: 100vh;
}

.mv-right {
  position: absolute;
  top: 45%;
  right: 5%;
  max-width: 40%;
}
.mv-right img {
  max-width: 100%;
}

/* Infomation */
.info-msg {
  text-align: center;
  margin-top: 30px;
}

.info-msg span {
  font-size: medium;
}

.supports {
  display: flex;
  justify-content: center;
}

.support-info {
  width: 30%;
  text-align: center;
  background-color: #AF0401;
  padding: 15px 10px;
  margin: 0 10px 50px 10px;
  border-radius: 15px;
  border: solid 1.5px #AF0401;
}

.support-info:hover {
  background-color: #fff;
  border: solid 1.5px #AF0401;
  transition: 0.3s;
  opacity: 0.8;
}

.support-info:hover p {
 color: #AF0401;
}

.accounts {
  display: flex;
  justify-content: space-around;
}

.account-info {
  width: 48%;
  text-align: center;
  margin-bottom: 50px;
  background-color: #fff;
  padding: 15px 10px;
  border-radius: 15px;
}

.official-line {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.qr-code {
  height: 200px;
}

.subscribe-button {
  margin: 30px;
}

.subscribe-button p {
  font-size: 1rem;
  margin-bottom: 15px;
}

.subscribe-button img {
  width: 100px;
}

.insta-follow {
  text-align: center;
  position: relative;
  background: linear-gradient(to top right, #E4844F 0%, #B220A0 100%);
  height: 26px;
  max-width: 60%;
  margin: 0 auto;
  border: solid 2px #B220A0;
  border-image: linear-gradient(to top right, #E4844F 0%, #B220A0 100%);
  border-image-slice: 1;
}
.insta-follow:hover {
  background: #fff;
  transition: 0.6s;
  opacity: 0.8;
}

.insta-follow a {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  font-size: 0.8rem;
  color: #fff;
}
.insta-follow:hover a {
  background: linear-gradient(to top right, #E4844F 0%, #B220A0 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.insta-follow a::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  margin: -3px 5px 0 0;
  background: url("../image/index/Instagram-logo_White.svg") no-repeat;
  background-size: contain;
  vertical-align: middle;
}

.insta-follow:hover a::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  margin: -3px 5px 0 0;
  background: url("../image/index/Instagram-logo_Gradient.svg") no-repeat;
  background-size: contain;
  vertical-align: middle;
}


.activities-wrapper {
  max-width: 1024px;
  overflow: hidden;
  width: 100%;
  position: relative;
  padding-bottom: 5%;
}

.slider {
  width: 200%;
  display: flex;
  margin: 0 auto;
  justify-content: space-around;
}

.activities-box {
  width: 10%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.slider1 {
  transform: translateX(15%);
  transition: all 0.3s;
}

.slider2 {
  transform: translateX(-5%);
  transition: all 0.3s;
}

.slider3 {
  transform: translateX(-25%);
  transition: all 0.3s;
}

.slider4 {
  transform: translateX(-45%);
  transition: all 0.3s;
}

.slider5 {
  transform: translateX(-65%);
  transition: all 0.3s;
}

.next {
  width: 60px;
  height: 60px;
  position: absolute;
  right: 27%;
  bottom: 50%;
  transition: all 0.3s;
  z-index: 10;
  cursor: pointer;
  border-radius: 50%;
}

.next::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  border-top: solid 3px #B77B54;
  border-right: solid 3px #B77B54;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  right: 40%;
  top: 33%;
}

.next:hover {
  background-color: #FFFBE6;
  transition: all 0.4s;
}

.prev {
  width: 60px;
  height: 60px;
  position: absolute;
  left: 27%;
  bottom: 50%;
  transition: all 0.3s;
  z-index: 10;
  cursor: pointer;
  border-radius: 50%;
}

.prev::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  border-top: solid 3px #B77B54;
  border-right: solid 3px #B77B54;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
  position: absolute;
  left: 38%;
  top: 33%;
}

.prev:hover {
  background-color: #FFFBE6;
  transition: all 0.4s;
}

.indicator {
  width: 100%;
  position: absolute;
  bottom: 1%;
  display: flex;
  z-index: 10;
  justify-content: center;
  align-items: center;
}

.indicator li {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  position: relative;
  list-style: none;
  border: 1px #B77B54 solid;
  margin-left: 10px;
  margin-right: 10px;
  cursor: pointer;
}

.enable {
  background-color: #B77B54;
}

/* overview */
.poster-pc_tb { display: block;}
.poster-sp { display: none;}

.overview-poster {
  text-align: center;
}

.overview-poster img {
  margin: 0 auto 5px;
  height: auto;
  max-width: 100%;
}

.overview_tbl {
  margin: 0 auto;
  width: 100%;
  background: #fff;
  border: 1px solid #c39d7e;
  border-collapse: separate;
  border-spacing: 2px;
  line-height: 150%;
}

.overview_tbl th {
  width: 30%;
  background-color: #BD9F82;
  padding: 10px 0;
  border: 1px solid #BD9F82;
}

.overview_tbl td {
  width: 70%;
  padding: 10px 0 10px 40px;
  border: 1px solid #BD9F82;
}



/* thought */
.concept-copy {
  max-width: 100%;
  margin: 15px auto;
  padding: 20px;
  background: rgba(255, 255, 255, 0.6);
  border-radius: 30px;
  margin-bottom: 30px;
}

.thought-msg {
  background-color: rgba(255, 255, 255, 0.6);
  background-image: url(../image/index/thought-msg.png);
  background-blend-mode: soft-light;
  background-repeat: no-repeat;
  background-size: 55%;
  background-position: 95% 90%;
}

.thought-roots {
  background-image: url(../image/index/thought-roots.png);
  background-color: rgba(255, 255, 255, 0.5);
  background-blend-mode: lighten;
  background-repeat: no-repeat;
  background-size: 30%;
  background-position: 90% 85%;
}

.main-copy {
  font-size: 1.5rem;
  margin-bottom: 30px;
  font-weight: normal;
  text-align: center;
}

.concept-text {
  margin-bottom: 20px;
  line-height: 1.8;
}



/* access */
.access-box {
  text-align: center;
}

#access iframe {
  width: 100%;
  aspect-ratio: 16/9;
  border: 4px double #BD9F82;
}

.access-tbl {
  margin: 0 auto;
  width: 100%;
  background: #fff;
  border: 1px solid #c39d7e;
  border-collapse: separate;
  border-spacing: 2px;
  line-height: 120%;
}

.access-tbl th {
  width: 30%;
  background-color: #BD9F82;
  padding: 15px 0;
  border: 1px solid #BD9F82;
}

.access-tbl td {
  width: 70%;
  padding: 15px 0 15px 40px;
  border: 1px solid #BD9F82;
}



/* レスポンシブ対応：タブレット */
@media screen and (max-width:960px) {
  /* main-visual */
  #main-visual {
    background-image: url(../image/index/main-tb.JPG);
    max-height: inherit;
    padding-top: 60px;
  }
  
  .mv-wrapper {
    height: 100%;
  }

  .mv-right {
    position: absolute;
    top: 40%;
    right: 10%;
    background-color: rgba(255, 237, 213, 0.6);
    border-radius: 15px;
    max-width: 80%;
    height: 25%;
    padding: 5px 30px;
    margin: 0 auto;
    text-align: center;
  }
  .mv-right img {
    position: relative;
    top: 12%;
    max-width: 100%;
  }

  /* Infomation */
  .accounts{
    display: block;
  }
  .account-info {
    width: 65%;
    margin-left: auto;
    margin-right: auto;
    
  }
  .qr-code{
    width: 200px;
    height: auto;
  }
  .subscribe-button {
    margin: 15;
  }
  .subscribe-button p {
    margin-bottom: 15px;
  }
  .subscribe-button img{
    width: 150px;
  }
  .slider {
    width: 500%;
  }

  .activities-box {
    width: 30%;
  }

  .slider1 {
    transform: translateX(0);
    transition: all 0.3s;
  }

  .slider2 {
    transform: translateX(-20%);
    transition: all 0.3s;
  }

  .slider3 {
    transform: translateX(-40%);
    transition: all 0.3s;
  }

  .slider4 {
    transform: translateX(-60%);
    transition: all 0.3s;
  }

  .slider5 {
    transform: translateX(-80%);
    transition: all 0.3s;
  }

  .next {
    width: 70px;
    height: 150px;
    position: absolute;
    right: 0;
    bottom: 45%;
    border-radius: 0;
  }

  .next::after {
    width: 60px;
    height: 60px;
  }

  .prev {
    width: 70px;
    height: 150px;
    position: absolute;
    left: 0;
    bottom: 45%;
    border-radius: 0;
  }

  .prev::after {
    width: 60px;
    height: 60px;
  }

  .prev:hover {
    background-color: #FFFBE6;
    transition: all 0.4s;
  }

  /* overview */
  .overview-poster img {
    height: inherit;
    max-width: 90%;
  }

  .overview_tbl {
    width: 90%;
  }

  /* thought */
  .concept-copy {
    max-width: 90%;
    margin: 15px auto;
    padding: 20px;
    background: rgba(255, 255, 255, 0.6);
    border-radius: 3%;
    margin-bottom: 30px;
  }

  .thought-msg {
    background-color: rgba(255, 255, 255, 0.6);
    background-image: url(../image/index/thought-msg.png);
    background-size: 75%;
    background-repeat: no-repeat;
    background-position: 95% 95%;
  }

  .thought-roots {
    background-color: rgba(255, 255, 255, 0.5);
    background-image: url(../image/index/thought-roots.png);
    background-size: 50%;
    background-repeat: no-repeat;
    background-position: 95% 95%;
  }


  /* access */
  #access iframe {
    width: 90%;
  }

  .access-tbl {
    width: 90%;
  }
}

/* レスポンシブ対応：スマートフォン */
@media screen and (max-width:767px) {
  /* main-visual */
  #main-visual {
    background-image: url(../image/index/main-sp.JPG);
    max-height: inherit;
    padding-top: 60px;
  }

  .mv-right img {
    top: 25%;
    max-width: 110%;
  }

  .text {
    font-size: 1rem;
    width: 100%;
  }

  /* Infomation */
  .account-info {
    width: 100%;
  }
  .qr-code{
    width: 125px;
    height: auto;
  }
  .subscribe-button {
    margin: 10px;
  }
  .subscribe-button p {
    font-size: 0.9rem;
    margin-bottom: 15px;
  }
  .subscribe-button img{
    width: 100px;
  }

  .slider {
    margin: 0 auto 0px auto;
  }

  .slider1 {
    transform: translateX(0);
    transition: all 0.3s;
  }

  .slider2 {
    transform: translateX(-20%);
    transition: all 0.3s;
  }

  .slider3 {
    transform: translateX(-40%);
    transition: all 0.3s;
  }

  .slider4 {
    transform: translateX(-60%);
    transition: all 0.3s;
  }

  .slider5 {
    transform: translateX(-80%);
    transition: all 0.3s;
  }

  .instagram-media {
    width: 326px; /* 最小サイズ  */
  }
  .next {
    display: none;
  }

  .next::after {
    display: none;
  }

  .prev {
    display: none;
  }

  .prev::after {
    display: none;
  }


  /* overview */
  .poster-pc_tb { display: none;}
  .poster-sp { display: block;}

  .overview-poster img {
    max-width: 96%;
  }

  .overview_tbl {
    width: 96%;
  }

  .overview_tbl th {
    width: 35%;
  }

  .overview_tbl td {
    width: 65%;
    padding: 10px 0 10px 20px;
  }

  /* thought */
  .concept-copy {
    background: rgba(255, 255, 255, 0.9);
    max-width: 100%;
    padding: 15px;
    font-size: 1rem;
  }

  .thought-msg {
    background-color: rgba(255, 255, 255, 0.8);
    background-image: url(../image/index/thought-msg.png);
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: 95% 90%;
  }

  .thought-roots {
    background-color: rgba(255, 255, 255, 0.7);
    background-image: url(../image/index/thought-roots.png);
    background-size: 50%;
    background-repeat: no-repeat;
    background-position: 95% 95%;
  }

  /* access */
  #access iframe {
    width: 100%;
    aspect-ratio: 4/3;
  }

  .access-tbl {
    width: 100%;
    line-height: 110%;
  }

  .access-tbl th {
    width: 30%;
    padding: 10px 0;
  }

  .access-tbl td {
    width: 70%;
    padding: 10px 45px 10px 20px;
  }
}