@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200');

/* background
   ========================================================================== */
@media screen and (max-width: 767px) {
  .hero__title{
    position: relative;
  }
  .hero__title::before{
    position: absolute;
    display: block;
    content: "";
    aspect-ratio: 940/1600;
    background-image: url("../../img/sp_background.jpg");
    background-size: contain;
    background-repeat: no-repeat;
    width: 100%;
    top: 0;
    z-index: -1;
  }
}
@media screen and (min-width: 768px) {
  .background{
    position: fixed;
    width: 100%;
    height: 100%;
  }
  .background::before{
    position: absolute;
    display: block;
    content: "";
    aspect-ratio: 570/1080;
    background-image: url("../../img/pc_background_left.png");
    background-size: contain;
    background-repeat: no-repeat;
    height: calc(100vh - 20px);
    bottom: 0;
    left: 0;
  }
  .background::after{
    position: absolute;
    display: block;
    content: "";
    aspect-ratio: 448/1080;
    background-image: url("../../img/pc_background_right.png");
    background-size: contain;
    background-repeat: no-repeat;
    height: calc(100vh - 20px);
    right: 0;
    bottom: 0;
  }
}

/* hero
   ========================================================================== */
.hero__inner{
  position: relative;
  width: 100%;
  height: 100vh;
  height: 100dvh;
}
.hero__image{
  background-image: url("../../img/hero_image_pc.jpg");
  background-size: cover;
  background-position: center center;
}
.hero__title img{
  width: 100%;
}

@media screen and (max-width: 767px) {
  .hero {
    padding-top: 80px;
  }
  .hero__inner {
    height: calc(100vh - 80px);
    height: calc(100dvh - 80px);
  }
  .hero__image{
    right: 0;
    top: 0;
    width: 100%;
    height: calc(100vh - 300px);
    height: calc(100dvh - 300px);
  }
  .hero__title{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 220px;
  }
  .hero__title > div{
    width: 80%;
    margin: 0 auto;
  }
  .sub__title{
    margin-top: .4em;
  }
}
@media screen and (min-width:768px) and (max-width:1279px) {
  .hero {
    padding-top: 100px;
  }
  .hero__inner {
    height: calc(100vh - 100px);
  }
  .hero__image{
    position: absolute;
    right: 0;
    bottom: 0;
    width: 68%;
    height: 100%;
  }
  .hero__title{
    position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    width: 45%;
  }
  .sub__title{
    margin-top: 3%;
  }
}
@media screen and (min-width: 1280px) {
  .hero {
    padding-top: 100px;
  }
  .hero__inner {
    height: calc(100vh - 100px);
  }
  .hero__image{
    position: absolute;
    right: 0;
    bottom: 0;
    width: 68%;
    height: 100%;
  }
  .hero__title{
    position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    width: 33%;
  }
  .sub__title{
    margin-top: 3%;
  }
}


/* contents
   ========================================================================== */
.contents__wrapper{
  position: relative;
  top: 0;
}
@media screen and (max-width:599px) {
  
}
@media screen and (min-width:600px){
  
}



/* About
   ========================================================================== */
.about{
}
.about .inner{
  width: 100%;
  margin: 0 auto;
}
.company__info{
  font-size: 16px;
}
.company__info h4{
  font-weight: 600;
  font-size: 18px;
  padding-bottom: 20px;
  line-height: 1;
  border-bottom: solid 1px #000;
}
.company__info th,
.company__info dt{
  font-weight: normal;
}
.company__info dl{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.company__info dl dt{
  text-align: center;
  width: 3em;
}
.company__info dl dd{
  width: calc(100% - 3em);
  padding-left: 2em;
}

@media screen and (max-width: 1023px) {
  .about{
    width: 90%;
    margin: 100px auto 80px;
  }
  .about__img__main{
    width: 100%;
    aspect-ratio: 1/1;
    background-image: url("../../img/about_img01.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
  }
  .about__img__btm{
    width: 100%;
    aspect-ratio: 800/560;
    background-image: url("../../img/about_img02.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
    margin-top: 60px;
  }
  .about__title{
    font-size: 38px;
    line-height: 1;
    margin-top: 40px;
  }
  .about__txt{
    margin-top: 30px;
  }
  .about__txt p+p{
    margin-top: 1em;
  }
  
  .company__info{
    margin-top: 60px;
  }
  .company__info th,
  .company__info td{
    border-bottom: dotted 1px #EBEBEB;
    padding: 1em 0;
  }
  .company__info th{
    width: 8.5em;
  }
}
@media screen and (min-width: 1024px) {
  .about{
    width: 100%;
    margin: 140px 0;
  }
  .about .inner{
    display: flex;
    height: 100%;
  }
  .about__img{
    width: 50%;
    background-image: url("../../img/about_img.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
  }
  .about__txt__wrap{
    width: 50%;
    padding-left: 5%;
    font-size: 18px;
    line-height: 2;
  }
  .about__title{
    font-size: 58px;
    line-height: 1;
  }
  .about__txt{
    margin-top: 50px;
    max-width: 640px;
    width: 90%;
    font-feature-settings: "palt";
  }
  .about__txt p+p{
    margin-top: 1.6em;
  }
  .about__txt br{
    display: block;
  }
  
  .company__info{
    max-width: 640px;
    width: 90%;
    margin-top: 120px;
  }
  .company__info th,
  .company__info td{
    border-bottom: dotted 1px #EBEBEB;
    padding: 1em 0;
  }
  .company__info th{
    width: 8.5em;
  }
}
@media screen and (max-width: 1500px) {
  .about__txt br{
    display: none;
  }
}



/* activities
   ========================================================================== */
.activities{
  background: #fff;
  position: relative;
  top: 0;
}
.activities__img-left .img,
.activities__img-right .img,
.activities__img-center{
  background-size: cover;
  background-position: center center;
}
.activities__img-left .img:nth-child(1){background-image: url("../../img/hinolino_img01.jpg");}
.activities__img-left .img:nth-child(2){background-image: url("../../img/hinolino_img02.jpg");}
.activities__img-left .img:nth-child(3){background-image: url("../../img/hinolino_img03.jpg");}
.activities__img-left .img:nth-child(4){background-image: url("../../img/hinolino_img04.jpg");}
.activities__img-center{background-image: url("../../img/hinolino_img05.jpg");}
.activities__img-right .img:nth-child(1){background-image: url("../../img/hinolino_img06.jpg");}
.activities__img-right .img:nth-child(2){background-image: url("../../img/hinolino_img07.jpg");}
.activities__img-right .img:nth-child(3){background-image: url("../../img/hinolino_img08.jpg");}
.activities__img-right .img:nth-child(4){background-image: url("../../img/hinolino_img09.jpg");}

.activities__img__btm .img:nth-child(1){background-image: url("../../img/hinolino_img01.jpg");}
.activities__img__btm .img:nth-child(2){background-image: url("../../img/hinolino_img02.jpg");}
.activities__img__btm .img:nth-child(3){background-image: url("../../img/hinolino_img03.jpg");}
.activities__img__btm .img:nth-child(4){background-image: url("../../img/hinolino_img04.jpg");}
.activities__img__btm .img:nth-child(5){background-image: url("../../img/hinolino_img06.jpg");}
.activities__img__btm .img:nth-child(6){background-image: url("../../img/hinolino_img07.jpg");}

@media screen and (max-width:899px) {
  .activities__img.sp_ver{
    position: relative;
    display: block;
  }
  .activities__img.pc_ver{
    display: none;
  }
  .activities__img .num{
    position: absolute;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
    width: 100px;
  }
  .activities__img__main{
    width: 100%;
    aspect-ratio: 1/.8;
    background-image: url("../../img/hinolino_img05.jpg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
  }
  .activities__img__btm{
    margin-bottom: 100px;
  }
  .activities__img__btm ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
  }
  .activities__img__btm ul li{
    width: 33%;
    aspect-ratio: 1/1;
  }
  .activities__img__btm ul li:nth-child(n+4){
    margin-top: .4%;
  }
  .activities__img__btm .img{
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
  }
}
@media screen and (min-width:768px) and (max-width:1023px) {
}
@media screen and (min-width:900px){
  .activities__img.pc_ver{
    display: flex;
    position: relative;
  }
  .activities__img.sp_ver,
  .activities__img__btm{
    display: none;
  }
  .activities__img .num{
    position: absolute;
    bottom: -70px;
    left: 50%;
    transform: translateX(-50%);
    width: 140px;
  }
  .activities__img-center{
    width: 26%;
  }
  .activities__img-left,
  .activities__img-right{
    display: flex;
    flex-wrap: wrap;
    width:37%;
  }
  .activities__img-left .img,
  .activities__img-right .img{
    width: calc(50% - 4px);
    height: calc(100vh/4.5);
  }
  .activities__img-left .img{
    margin-right: 4px;
  }
  .activities__img-right .img{
    margin-left: 4px;
  }
  .activities__img-left .img:nth-child(n+3),
  .activities__img-right .img:nth-child(n+3){
    margin-top: 4px;
  }
}
@media screen and (min-width:1280px){
  .activities__img-left .img,
  .activities__img-right .img{
    width: calc(50% - 4px);
    height: calc(100vh/3);
  }
}


/* hinolino
   ========================================================================== */
.hinolino{
  
}

@media screen and (max-width:1023px) {
  .hinolino{
    width: 90%;
    margin: 100px auto;
  }
  .hinolino__txt h3{
    max-width: 260px;
    margin: 0 auto;
  }
  .hinolino__txt p{
    margin-top: 50px;
    line-height: 2;
  }
  .hinolino__txt p br{
    display: none;
  }
  .hinolino__graph{
    margin-top: 50px;
  }
}
@media screen and (min-width:1024px){
  .hinolino{
    width: 90%;
    max-width: 1280px;
    margin: 140px auto 160px;
  }
  .hinolino__intro{
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  /*.hinolino__txt{
    text-align: center;
    width: 50%;
  }*/
  .hinolino__txt{
    width: 50%;
  }
  .hinolino__txt p+p{
    margin-top: .5em;
  }
  .hinolino__txt h3{
    max-width: 320px;
    margin: 0 auto;
  }
  .hinolino__txt p{
    margin-top: 50px;
    line-height: 2;
  }
  .hinolino__graph{
    width: 45%;
  }
}


/* hinolino__access
   ========================================================================== */
.hinolino__access{
  
}
.hinolino__access__info .instagram{
  display: flex;
  align-items: center;
}
.hinolino__access__info .instagram::before{
  content: "";
  display: block;
  background-image: url("../img/icon_instagram.png");
  background-size: cover;
  width: 24px;
  height: 24px;
  margin-right: .8em;
}
.hinolino__access__info .instagram a{
  color: #000;
}
@media (hover: hover) and (pointer: fine) {
  .hinolino__access__info .instagram a{
    transition: color .3s;
  }
  .hinolino__access__info .instagram a:hover{
    color: #5DAF5A;
  }
}

@media screen and (max-width:1023px) {
  .hinolino__access{
    margin-top: 80px;
  }
  .hinolino__access__map {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 100%;
  }
  .hinolino__access__map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .hinolino__access__title{
    padding-bottom: 20px;
    margin-top: 60px;
    margin-bottom: 20px;
    border-bottom: dotted 1px #707070;
    font-size: 28px;
    line-height: 1;
  }
  .hinolino__access__shopname{
    font-size: 14px;
  }
  .hinolino__access__shopname span{
    font-size: 20px;
  }
  .hinolino__access__info p{
    font-size: 16px;
    margin-top: 20px;
  }
  .hinolino__access__info .instagram{
    margin-top: 20px;
    font-size: 18px;
  }
}
@media screen and (min-width:1024px){
  .hinolino__access{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 100px;
  }
  .hinolino__access__map {
    position: relative;
    width: 50%;
    height: 0;
    padding-top: 40%;
  }
  .hinolino__access__map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .hinolino__access__info{
    width: 45%;
  }
  .hinolino__access__title{
    padding: 30px 0;
    margin-bottom: 30px;
    border-bottom: dotted 1px #707070;
    font-size: 38px;
    line-height: 1;
  }
  .hinolino__access__shopname{
    font-size: 14px;
  }
  .hinolino__access__shopname span{
    font-size: 24px;
  }
  .hinolino__access__info p{
    font-size: 16px;
    margin-top: 20px;
  }
  .hinolino__access__info .instagram{
    margin-top: 20px;
    font-size: 20px;
  }
}


/* report/vision
   ========================================================================== */
.report__block,
.vision__block{
  position: relative;
  background: #fff;
  padding: 80px 40px 50px;
  font-size: 16px;
}
.report__block h4,
.vision__block h4{
  text-align: center;
}
.report__block p,
.vision__block p{
  margin-top: 1em;
}
@media screen and (max-width:767px) {
  .report,
  .vision{
    position: relative;
    background: #F8F7EE;
    padding: 100px 0 60px 0;
  }
  .report__title,
  .vision__title{
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #FBCB29;
    text-align: center;
    border-radius: 100vh;
    font-size: 22px;
    line-height: 1;
    transform: translateX(-50%);
    top: -30px;
    left: 50%;
    width: 220px;
    height: 60px;
  }
  .vision__title{
    top: 0;
  }
  .report__inner,
  .vision__inner{
    width: 90%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .vision__inner{
    margin-top: 40px;
  }
  .report__block,
  .vision__block{
    padding: 50px 30px 30px;
  }
  .report__block+.report__block,
  .vision__block+.vision__block{
    margin-top: 50px;
  }
  .report__block h4,
  .vision__block h4{
    font-size: 20px;
  }
  .report__block p,
  .vision__block p{
    margin-top: .5em;
  }
  .report__block .num,
  .vision__block .num{
    position: absolute;
    top:-35px;
    left: 50%;
    transform: translateX(-50%);
    width: 70px;
  }
}
@media screen and (min-width:768px) and (max-width:1023px) {
  .report,
  .vision{
    position: relative;
    background: #F8F7EE;
    padding: 140px 0 80px 0;
  }
  .report__title,
  .vision__title{
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #FBCB29;
    text-align: center;
    border-radius: 100vh;
    font-size: 28px;
    line-height: 1;
    left: calc(50% - 140px);
    top: -40px;
    width: 280px;
    height: 80px;
  }
  .vision__title{
    top: 0px;
  }
  .report__inner,
  .vision__inner{
    width: 86%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .vision__inner{
    margin-top: 40px;
  }
  .report__block,
  .vision__block{
    width: 48%;
  }
  .report__block:nth-child(n+3),
  .vision__block:nth-child(n+3){
    margin-top: 80px;
  }
  .report__block h4,
  .vision__block h4{
    font-size: 22px;
  }
  .report__block .num,
  .vision__block .num{
    position: absolute;
    top:-45px;
    left: 50%;
    transform: translateX(-50%);
    width: 90px;
  }
}
@media screen and (min-width:1024px){
  .report,
  .vision{
    position: relative;
    background: #F8F7EE;
    padding: 140px 0 80px 0;
  }
  .report__title,
  .vision__title{
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #FBCB29;
    text-align: center;
    border-radius: 100vh;
    font-size: 28px;
    line-height: 1;
    left: calc(50% - 140px);
    top: -40px;
    width: 280px;
    height: 80px;
  }
  .vision__title{
    top: 0px;
  }
  .report__inner,
  .vision__inner{
    width: 86%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .vision__inner{
    margin-top: 40px;
  }
  .report__block,
  .vision__block{
    width: 30%;
  }
  .report__block:nth-child(n+4),
  .vision__block:nth-child(n+4){
    margin-top: 80px;
  }
  .report__block h4,
  .vision__block h4{
    font-size: 22px;
  }
  .report__block .num,
  .vision__block .num{
    position: absolute;
    top:-45px;
    left: 50%;
    transform: translateX(-50%);
    width: 90px;
  }
}


/* donation
   ========================================================================== */
.donation{
}
.donation__right h4{
  font-size: 22px;
  margin-bottom: .5em;
}
.donation__right h4.border{
  border-top: dotted 1px #707070;
}
.donation__link a{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
  background: #5DAF5A;
  color: #fff;
}
.donation__contact{
  margin-top: 1.5em;
}
@media screen and (max-width:1023px) {
  .donation{
    width: 90%;
    margin: 80px auto 0;
  }
  .donation__img{
    text-align: center;
  }
  .donation__right{
    border-top: dotted 1px #707070;
    margin-top: 40px;
    padding-top: 40px;
  }
  .donation__title{
    font-size: 24px;
    line-height: 1.4;
    text-align: center;
  }
  .donation__left p{
    font-size: 18px;
    margin-top: 30px;
  }
  .donation__left p br{
    display: none;
  }
  .donation__right h4.border{
    margin-top: 40px;
    padding-top: 40px;
  }
  .donation__link a{
    line-height: 1;
    padding: 2em 1em;
    margin: 30px 0;
    border-radius: 5px;
  }
  .donation__link h4{
    font-size: 22px;
  }
  .donation__link p{
    font-size: 14px;
  }
  .donation__right .kouza{
    background: #EBEBEB;
    padding: 1em;
    text-align: center;
    border-radius: 5px;
    margin-top: 30px;
  }
}
@media screen and (min-width:1024px){
  .donation{
    display: flex;
    justify-content: space-between;
    width: 90%;
    max-width: 1280px;
    margin: 140px auto 0;
  }
  .donation__left{
    width: 40%;
  }
  .donation__right{
    width: 52%;
  }
  .donation__title{
    font-size: 40px;
    line-height: 1.4;
  }
  .donation__left p{
    font-size: 18px;
    margin-top: 40px;
  }
  .donation__right h4.border{
    margin-top: 40px;
    padding-top: 40px;
  }
  .donation__link a{
    line-height: 1;
    padding: 2em 1em;
    margin: 30px 0;
    border-radius: 5px;
  }
  .donation__link h4{
    font-size: 24px;
  }
  .donation__link p{
    font-size: 14px;
  }
  .donation__right .kouza{
    background: #EBEBEB;
    padding: 1em;
    text-align: center;
    border-radius: 5px;
    margin-top: 30px;
  }
}

@media (hover: hover) and (pointer: fine) {
  .donation__link a{
    transition: background .3s;
  }
  .donation__link a:hover{
    background: #4E4E4E;
  }
}


