@import url('https://fonts.googleapis.com/css2?family=Allura&family=Archivo+Black&family=Bebas+Neue&family=Herr+Von+Muellerhoff&family=Sacramento&family=Shippori+Mincho&family=Waiting+for+the+Sunrise&display=swap');

@font-face {
  font-family: 'curve';
  src: url('img/font/Southpaw.otf') format('truetype');
}

/* common */
html {
  --vh: 100%; 
}
body{
  height: 100vh;
  color: #000000bd;
  width: 100vw;
  -webkit-animation: bugfix infinite 1s;
  font-family: YuGothic, "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro";
  font-size: 16px;
  letter-spacing: .025em;
  line-height: 1.8;
  max-width: 500px;
  margin: 0 auto;
}
.sub_title{
  line-height: 1.4;
  font-family: "Shippori Mincho";
  font-size: 20px;
  margin-bottom: 0px;
  margin-left: 7%;
  color: #000000;
  margin-top: 0px;
}
.ano_sub_title{
  line-height: 1.4;
  font-family: "Shippori Mincho";
  font-size: 18px;
  margin-bottom: 7vw;
  text-align: center;
  color: #000000;
}
.a_link{
  text-align:center;
  margin-top: 4.8vw;
  text-align: center;
  margin-bottom: 22vw;
  font-size: 13px;
}
.a_link a{
  text-decoration: underline;
  font-family: "Shippori Mincho";
}
.p-50{
  padding: 22vw 50px 0px 0px;
}
.w-50{
  width: 50%;
}
.title{
  font-weight: 500;
}

/* header */
.header_area{
  height: 60px;
}
.header_area p{
  margin: auto;
}
header .d_flex{
  justify-content: space-around;
  position: fixed;
  width: 100%;
  height: 60px;
  background: white;
  color: #000000bd;
  z-index: 10000;
  border-bottom: 1px solid #f3efef;
}
@keyframes bugfix {
  from {
    padding: 0;
  }
  to {
    padding: 0;
  }
}
@-webkit-keyframes bugfix {
  from {
    padding: 0;
  }
  to {
    padding: 0;
  }
}
#overlay-button {
  position: fixed;
  right: 10px;
  padding: 26px 11px;
  z-index: 5;
  cursor: pointer;
  user-select: none;
  top: 0;
}
#overlay-button span {
  height: 2px;
  width: 20px;
  border-radius: 2px;
  background-color: #fff;
  position: relative;
  display: block;
  transition: all .2s ease-in-out;
}
#overlay-button span:before {
  top: -8px;
  visibility: visible;
}
.btn_bgr span:before{
  top: -11.5px !important;
}
#overlay-button span:after {
  top: 8px;
}
#overlay-button span:before, #overlay-button span:after {
  height: 2px;
  width: 20px;
  border-radius: 2px;
  background-color: #fff;
  position: absolute;
  content: "";
  transition: all .2s ease-in-out;
}
.btn_bgr:hover span:before, .btn_bgr:hover span:after {
  background: black !important;
}
.btn_bgr span:before, .btn_bgr span:after{
  background: black !important;
}
input[type=checkbox] {
  display: none; 
}
input[type=checkbox]:checked ~ #overlay {
  visibility: visible; 
}
input[type=checkbox]:checked ~ #overlay-button:hover span, input[type=checkbox]:checked ~ #overlay-button span {
  background: transparent;
}
input[type=checkbox]:checked ~ #overlay-button span:before {
  transform: rotate(45deg) translate(7px, 7px);

}
input[type=checkbox]:checked ~ #overlay-button span:after {
  transform: rotate(-45deg) translate(7px, -7px);
}
#overlay {
  height: 100vh;
  width: 100vw;
  max-width: 500px;
  background: linear-gradient(to bottom, #f3f3f3 70%, #5f5f5f 70%);
  z-index: 3;
  visibility: hidden;
  position: fixed;
  top: 0;
}
#overlay ul {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  text-align: center;
  height: 100vh;
  padding-left: 0;
  list-style-type: none;
  margin-top: -10vh;
}
#overlay ul li {
  padding: 1em;
}
#overlay ul li a {
  color: black;
  text-decoration: none;
  font-size: 1.5em;
  font-family: "Shippori Mincho";
  font-size: 18px;
}
#overlay ul li a:hover {
  color: #000!important;
}
.sns_icon_area{
  position: absolute;
  bottom: 18vh;
  display: flex;
  justify-content: center;
  width: 100%;
  gap: 7vw;
}
.sns_icon_area img{
  width: 25px;
}

/* intro */
#first_area{
  position: absolute;
  top: 38%;
  width: 100%;
  max-width: 500px;
}
#first_area video{
  width:100%;
}

/* main image */
.background{
  /* position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  display: flex;
  justify-content: center; */
  height: calc(var(--vh, 1vh) * 100); 
  position: fixed;
  top: 0;
  left: 50%;         /* 親要素の中央に配置 */
  width: 100%;
  height: 100vh;
  max-width: 500px;  /* 最大幅を500pxに設定 */
  overflow: hidden;
  display: flex;
  justify-content: center;
  transform: translateX(-50%);
}
.background video {
  width: 100%;
  height: 100%;
  max-width: 500px;
  object-fit: cover;
  position: relative;
}
.intro_sec{
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 100px;
  text-align: left;
  position: fixed;
  top: 75%;
  right: 20px;
  letter-spacing: 2;
  color: white;
  line-height: 1.3;
  max-width: 400px;
  font-size: 20px;
  height: calc(var(--vh, 1vh) * 100); 
}
.intro_sec p{
  margin: 0px;
}
.main_sub_passage{
  font-size: 13px;
  letter-spacing: 1.3px;
  font-family: "Shippori Mincho";
}

/* container */
.container{
  position: relative;
  z-index: 1; 
  width: 100%;
  margin: 0 auto;
  max-width: 500px;
}

/* intoro_message */
.sub_title_passage{
  font-size: 13px;
  margin-left: 7%;
  margin-right: 7%;
  font-family: "Shippori Mincho";
}
.mt-155{
  margin-top: 120px;
}
.sub_title_area img{
  width: 100%;
  aspect-ratio: 1.5 / 1;
  object-fit: cover;
  border-radius: 1rem;
  margin-top: 2.5rem;
}

/* About */
.sub_title_area{
  margin: 0 8%;
  margin-bottom: 18vw;
}
.about_img{
  width: 100%;
  height: 290px;
  object-fit: cover;
}
.sp_about_area .title{
  margin-bottom: 30px;
  margin-top: 0px;
  color: black;
  text-align: left;
  margin-left: 15px;
  font-size: 18px;
}

/* Journal */
.d_flex{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.img_area{    
  width: 32%;
}
.d_flex{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 7vw;
  font-family: "Shippori Mincho";
}
.d_flex img{
  width:100%;
  padding-bottom: 10px;
  object-fit: cover;
  aspect-ratio: 1.8 / 1 !important;
}

/* slider */
.slider{
  width:100%;
  margin:0 auto;
}
.slider img{
  width:100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 1/1;
}
.slider .slick-slide{
  height:auto!important;
}
.slider .slick-arrow{
  z-index:2!important;
}
.slider .slick-next,
.slider .slick-prev{
  display: none !important;
}
.slick-slide{
  margin-right: 1vw!important;
  margin-left: 1vw!important;
}



.img_area p{
  margin-bottom: 1rem;
}
a {
  text-decoration: none;
  color: #333;
}
ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.news {
  padding: 70px 0px 0px 0px;
  font-size:25px;
}
.inner {
  width: 100%;
  background-color: #e6e6e636;
  margin: 0 auto;
  padding: 65px 0 100px;
}
.straw01{
  width: 35% !important;
  height: auto !important;
  object-fit: contain !important;
  display: block;
  margin-left: auto;
  margin-top: 2rem;
}
.img_area_title{
  margin-bottom: 0px !important;
  font-size: 14px !important;
  padding-top: 0.5rem;
}
.img_area_title p{
  font-size: 14px;
}
.img_area:not(:first-child){
  border-top: none;
}
.img_area:last-child{
  border-bottom: none;
}
.img_area p {
  font-size: 13px;
  padding-bottom: 0.5rem;
}
.sub_ttl {
  font-size: 30px;
  text-align: center;
  margin-bottom: 40px;
}
.news_list {
  margin: 0 8%;
}
.news_list_item {
  padding: 25px 0;
  border-bottom: 1px solid #E6E6E6;
}
.news_list_item:first-child {
  border-top: 1px solid #E6E6E6;
}
.news_list_item a {
  position: relative;
  display: flex;
  padding-right: 30px;
}
.news_item {
  background:#75cce8 ;
  border-radius: 14px;
  width: 6em;
  color: #fff;
  text-align: center;
  margin-left: 20px;
}
.more_button{
  background:#75cce8 ;
}
.blog{
  border-bottom: 2px solid #fedcd2;
  font-size: 12px;
  color: #000000bd;
  padding-bottom: 3px;
}
.photo{
  border-bottom: 2px solid #d4f0f0;;
  font-size: 11px;
  color: #000000bd;
  padding-bottom: 3px;
}
.sec{
  margin-left: 20px;
}
.about_flex{
  display: flex;
}
.about_flex img{
  width: 100%;
}
.about_title{
  font-size: 60px;
  margin: 0px;
  color: #000000bd;
}
.name{
  text-align: right;
  font-family: 'Waiting for the Sunrise';
  font-size: 20px;
  padding-right: 15px;
  color: #fff;
  margin-bottom: 0px;
}
.box_one{
  color: #fff;
  text-align: center;
  width: 45px;
  margin: auto;
  left: 0;
  position: absolute;
  font-size: 12px;
}
.txt_a_ac{
  color: #fff;
  font-family: "Shippori Mincho";
}
.s_01 .accordion_one {
  max-width: 1024px;
  margin: 0 auto;
}
.s_01 .accordion_one .accordion_header {
  background-color: #ffffffa8;
  color: #fff;
  font-size: 26px;
  font-weight: bold;
  /* padding: 20px 11%; */
  text-align: center;
  position: relative;
  z-index: +1;
  cursor: pointer;
  transition-duration: 0.2s;
  border-radius: 40px;
  width: 16px;
  padding: 5px 15px;
}
.s_01 .accordion_one:nth-of-type(2) .accordion_header {
    background-color: #ff9a05;
}
.s_01 .accordion_one:nth-of-type(3) .accordion_header {
    background-color: #1c85d8;
}
.s_01 .accordion_one .accordion_header:hover {
  opacity: .8;
}
.s_01 .accordion_one .accordion_header .i_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 5%;
  width: 40px;
  height: 40px;
  border: 1px solid #fff;
  margin-top: -20px;
  box-sizing: border-box;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}
.s_01 .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 18px;
  height: 18px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}
.s_01 .accordion_one .accordion_header.open .i_box {
  -webkit-transform: rotate(-360deg);
  transform: rotate(-360deg);
}
.s_01 .accordion_one .accordion_header .i_box .one_i:before, .s_01 .accordion_one .accordion_header .i_box .one_i:after {
  display: flex;
  content: '';
  background-color: #fff;
  border-radius: 10px;
  width: 18px;
  height: 4px;
  position: absolute;
  top: 7px;
  left: 0;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
}
.s_01 .accordion_one .accordion_header .i_box .one_i:before {
  width: 4px;
  height: 18px;
  top: 0;
  left: 7px;
}
.s_01 .accordion_one .accordion_header.open .i_box .one_i:before {
  content: none;
}
.s_01 .accordion_one .accordion_header.open .i_box .one_i:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.s_01 .accordion_one .accordion_inner {
  display: none;
  border:none;
  box-sizing: border-box;
}
.s_01 .accordion_one:nth-of-type(2) .accordion_inner {
  border-left: 2px solid #ff9a05;
  border-right: 2px solid #ff9a05;
  border-bottom: 2px solid #ff9a05;
}
.s_01 .accordion_one:nth-of-type(3) .accordion_inner {
  border-left: 2px solid #1c85d8;
  border-right: 2px solid #1c85d8;
  border-bottom: 2px solid #1c85d8;
}
.s_01 .accordion_one .accordion_inner p.txt_a_ac {
  margin: 0;
}
.s_01 .accordion_one .accordion_header {
  font-size: 16px;
  text-align: left;
}
.s_01 .accordion_one .accordion_header img {
width: 15px;
}

/*====================================================================
以下は不要です。
====================================================================*/


@media screen and (max-width: 1024px) {
  body {
    font-size: 16Spx;
  }
}
.section {
  max-width: 1024px;
  margin: 0 auto;
  z-index: 1;
  position: absolute;
  width: 45px;
  right: 60;
  top: 15;
  border-radius: 40px;
}
.section p._a {
  font-size: 12px;
  font-weight: bold;
  margin: 30px 0 0;
}
.section p._a .link {
  display: inline-block;
  color: #607D8B;
  padding-left: 1.3em;
  text-indent: -1.3em;
}
.section p._a .link:before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  border-top: 2px solid #607D8B;
  border-right: 2px solid #607D8B;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  margin-right: 10px;
}

.d_flex.header_area {
  font-size: 18px !important;
}

@media screen and (max-width: 1024px) {
  .news_list_item a {
    display: block;
  }
}
@media screen and (max-width: 769px) {
  .news_list_item a  {
    font-size: 14px;
  }
}
@media screen and (max-width: 480px) {
  .arrow {
    display: none;
  }
  .news_list_item a {
    padding-right: 0;
  }
}
.slide-in {
  overflow: hidden;
  display: inline-block;
}
.slide-in_inner {
  display: inline-block;
  text-shadow: 0px 0px 2px #7b7b7b8f;
}
.leftAnime{
  opacity: 0;
}
.slideAnimeLeftRight {
  animation-name:slideTextX100;
  animation-duration:0.8s;
  animation-fill-mode:forwards;
  opacity: 0;
}
@keyframes slideTextX100 {
  from {
    transform: translateX(-100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}
.slideAnimeRightLeft {
  animation-name:slideTextX-100;
  animation-duration:0.8s;
  animation-fill-mode:forwards;
  opacity: 0;
}
@keyframes slideTextX-100 {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}
.icon{
  width: 30px !important;
  padding-bottom: 0px !important;
  padding-right: 3px;
  
}
.footer{
  height: 200px;
  padding: 30px;
  text-align: center;
  background: #000000bd;
  color: #fff;
  font-size: 13px;
  font-family: "Shippori Mincho";
}
.footer p{
  margin-top: 1rem;
}

/* @media screen and (max-width: 767px) { */
  .intro{
    font-size: 15px;
    letter-spacing: normal;
    font-weight: bold;
  }
  .intro_sec {
    font-size: 22px;
    letter-spacing: 5;
    font-weight: 400;
    line-height: 2.3;
    top: 75%;
    left: 30;
    width: 100%;
    margin: auto;
    font-family: "Shippori Mincho";
  }
  .icon{
    width: 20px !important;
    padding-bottom: 0px !important;
    padding-right: 3px;
  }
  .about_title{
    font-size: 30px;

  }
  .title{
    font-size: 20px;
    margin-bottom: 0px;
  }
  .news {
    padding: 50px 0px 0px 0px;
  }
  .news_item{
    font-size: 11px;
  }
  .news_list_date {
    font-size: 12px;
  }
  .news_elem{
    margin: 0px;
    margin-top: 5px;
  }
  .news_list_item{
    padding: 15px;
  }
  .inner{
    padding: 30px 0 70px;
  }
  .p-50 {
    padding: 22vw 0px 0px 0px;
    margin: 0 8%;
  }
  .img_area{
    width: 100%;
    border-top: 1px solid #E6E6E6;
    border-bottom: 1px solid #E6E6E6;
  }
  .img_area img{
    margin-top: 0.5rem;
  }
  .sp_about_area{
    display: block;
    padding-bottom: 0px;
    font-family: "Shippori Mincho";
  }
  .pc_about_area{
    display: none;
  }
  .sp_about_area img{
    width: 100%;
    height: 250px;
    object-fit: cover;
  }
  .about_txt{
    padding-left: 8%;
    padding-right: 8%;
    margin-top: 18vw;
  }
  .about_title {
    font-size: 27px;
    text-align: center;
    padding-bottom: 15px
  }
  .about_photo{
    position: relative;
  }
  .about_photo img{
    width: 90%;
    height: 500px;
    object-fit: cover;
    display: block;
    margin: auto;
    box-shadow: 0 8px 15px rgba(0, 0, 0, 0.3);
  }
 .about_photo div{
    font-family: 'curve';
    position: absolute;
    top: 85%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 28px;
    color: #fff;
    font-weight: bold;
    width: 100%;
    text-align: center;
    text-shadow: -2px 3px 20px #00000014;
  }
  .about_sub{
    font-size: 13px;
    padding-left: 15px;
    color: black;
    line-height: 2.0 !important;
  }
  .insta{
    padding: 20px  10px 0px  10px;
    text-align: center;
  }
  .insta button{
    background: #f3c1c2;
    border: none;
    width: 200px;
    padding: 10px 2rem;
    margin-top: 1.7rem;
    color: #fff;
  }
  .snapwidget-widget{
    width: 100% !important;
  }
  .thumbnail-wrapper .thumbnail .thumbnail-image .object-fit{
    padding: 10px !important;
  }
  .thumbnail-wrapper .thumbnail .thumbnail-image{
    padding: 10px !important;
  }

/* } */
.about_flex .header_area{
  font-size: 18px !important;
  font-weight: bold;
}
.d-none{
  display: none;
}
.pre_tamonsta{
  height: 70px;
  background: #f3c1c2;
  text-align: center;
}
.pre_tamonsta a{
  color: #fff;
  font-weight: bold;
  font-size: 15px;
  display: inline-block;
  margin-top: 21px;
  font-family: "Shippori Mincho";
}
.contact .title{
  font-size: 18px;
  font-family: "Shippori Mincho";
  color: black;
  margin-bottom: 7vw;
  text-align: center;
}
.text_center{
  margin: auto;
  text-decoration: underline;
  text-align: center;
  font-family: "Shippori Mincho";
}
.contact{
  margin-bottom: 30vw;
}
.contact .img_area{
  border-bottom: 1px solid #E6E6E6 !important; 
  padding-bottom: 55px;
  padding-top: 30px;
}
.scroll-section{
  background-color: #f3f3f3; 
  padding-top: 18vw;
  margin-top: 100vh; 
  /* width: 100%; */
}
.sub_title_area .sub_title_passage{
  margin-top: 7vw !important;
  font-weight: initial;
  line-height: 2.0;
  color: black;
}
#main_area{
  display: none;
}
.archive img{
  width: 100%;
  padding-bottom: 10px;
}
.archive .img_area{
  width: 100%;
}
.archive_lik{
  margin-bottom: 25vw !important;
}
.archive{
  margin: auto;
  padding-top: 15vw !important;
}
.archive_passage{
  margin: 0 8%;
  padding-top: 2rem;
  font-size: 14px;
}
.insta .title{
  color: black;
  font-family: "Shippori Mincho";
  margin-bottom: 5vw;
}
.mb_30{
  margin-bottom: 30px !important;
}
.footer_elem{
  background: #dddddd1a;
  padding: 5px;
  width: 100%;
  display: inline-block;
  color: #fff;
  border-radius: 3px;
  margin-bottom: 10px;
  font-size: 13px;
}

@media (min-width: 500px) {
  .scroll-section{
    padding-top: 8vh;
  }
  .p-50 {
    padding: 10vh 0px 0px;
  }
  .sp-50{
    padding: 13vh 0px 0px;
  }
  .sub_title_area .sub_title_passage {
    margin-top: 3vh !important;
  }
  .sub_title_area {
    margin-bottom: 8vh;
  }
  .d_flex{
    margin-top: 2vh;
  }
  .ano_sub_title{
    margin-bottom: 0px;
  }
  .about_photo .ano_sub_title{
    margin-bottom: 1.5vh;
  }
  .a_link{
    margin-top: 3vh;
    margin-bottom: 12vh;
  }
  .about_txt{
    margin-top: 6vh;
  }
  .archive{
    margin-top: 12vh;
    padding-top: 0px !important;
  }
  .slick-slide {
    margin-right: 0.5vh !important;
    margin-left: 0.5vh !important;
  }
  .archive_lik{
    margin-bottom: 3vh !important;
  }
  .contact .title{
    margin-bottom: 3vh;
  }
  .contact{
    margin-bottom: 13vh;
  }
  .insta .title,
  .sp-template {
    margin-bottom: 1vh;
  }
  .sns_icon_area{
    position: absolute;
    bottom: 7vh;
    display: flex;
    justify-content: center;
    width: 100%;
    gap: 3vw;
  }
  #overlay {
    background: linear-gradient(to bottom, #f3f3f3 80%, #5f5f5f 80%);
  }
  .sns_icon_area img{
    width: 32px;
  }
}