@charset "utf-8";
/*==========================
First View
==========================*/
.main__container {
    display: flex;
    flex-direction: column;
    height: 100vh;
    width: 100%;
    position: relative;
}

.image-container {
    flex: 1;
    height: 50vh;
    overflow: hidden;
    width: 100%;
  }

.image-container.top {
    position: absolute;
    top: 0;
    animation: slideInTop 3.5s ease-out forwards;
    left: -100%;
  }

  .image-container.bottom {
    position: absolute;
    bottom: 0;
    animation: slideInBottom 3.5s ease-out forwards;
    left: 100%;
  }

  @keyframes slideInTop {
    0% {
      left: -100%;
    }
    100% {
      left: 0;
    }
  }

  @keyframes slideInBottom {
    0% {
      left: 100%;
    }
    100% {
      left: 0;
    }
  }

.image-container img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    object-position: center;
}

/* First View pc none */



/*==========================
Top
==========================*/
.section {
    padding-top: 125px;
    display: flex;
    align-items: center;
    flex-direction: column;
}

.section--top {
    padding-top: 100px;
}

.top {
    font-size: clamp(2.133rem, 6.666vw, 3.333rem); /* 375px: 2.5rem */
    line-height: 1.8;
    letter-spacing: 0.2em;
    text-align: center;
}

.text {
    font-size: clamp(1.194rem, 3.733vw, 1.866rem); /* 375px: 1.4rem */
    line-height: 2; /* 200% */
    letter-spacing: 0.2em;
    text-align: center;
    padding-top: 40px;
}

.image-scroll {
    width: 100%;
    height: 70.2px;
    width: 100vw;
    object-fit: cover;
    object-position: 0 0;
}

.image-scroll.top_flower {
    padding-top: 60px;
}

/* About Us pc */
@media screen and (min-width:769px) {
    .spBr {
        display: none;
    }

    .section {
        padding-top: 150px;
    }

    .top {
        font-size: clamp(2.136rem, 2.777vw, 4.444rem); /* 375px: 4rem */
        line-height: 1.1;
    }

    .text {
        font-size:  clamp(1.5rem, 1.25vw, 2rem); /* 375px: 1.8rem */
        line-height: 2.5;
        padding-top: 60px;
    }

    .top_flower {
        padding: 80px 8.3% 0;
    }
}/* pc 769px */

/*==========================
ourOrigin
==========================*/
.section--ourOrigin {
    padding-top: 125px;
}

.ourOrigin__item {
    position: relative;
}

.item01 {
    padding-top: 70px;
}

.subTitle {
    position: absolute;
    font-size: clamp(1.962rem, 6.133vw, 3.066rem); /* 375px: 2.3rem */
    text-align: center;
    line-height: 1.5;
    letter-spacing: 0.2em;
}

.item01 p {
    bottom: 24px;
    left: 4.8%;
    text-align: left;
}

.item02 p {
    top: 24px;
    right: 4.8%;
    text-align: right;
}

.cross__container {
    position: relative;
    width: 9.3%;
    height: 9.3%;
    margin: 50px auto;
    padding-bottom: 9.3%;
}

.cross__container span {
    position: absolute;
    display: block;
    width: 100%;
    height: 2px;
    background-color: #FDFDFD;
    top: 50%;
    left: 50%;
    transform-origin: center;
}

.cross__container span:nth-child(1) {
    transform: translate(-50%, -50%) rotate(45deg);
}

.cross__container span:nth-child(2) {
    transform: translate(-50%, -50%) rotate(-45deg);
}

.section--ourOrigin .subTopic {
    font-size: clamp(1.706rem, 5.333vw, 2.666rem); /* 375px: 2rem */;
    line-height: 2.3;
    letter-spacing: 0.2em;
    text-align: center;
    padding-top: 40px;
}

.spanPc {
    display: none;
}

/* ourOrigin pc */
@media screen and (min-width:769px) {
    .spBr {
        display: none;
    }

    .spanPc {
        display: block;
    }

    .section--ourOrigin {
        padding-top: 250px;
        width: 72.222vw;
        margin: 0 auto;

    }
    
    .ourOrigin__item01 {
        padding-top: 100px;
    }

    .section--ourOrigin .subTopic {
        font-size: clamp(1.869rem, 2.43vw, 3.888rem); /* 375px: 3.5rem */
        line-height: 1.4;
        padding-top: 80px;
        display: flex;
    }

    .item01 {
        padding-top: 100px;
    }

    .subTitle {
        font-size: clamp(1.602rem, 2.083vw, 3.333rem); /* 375px: 3rem */
    }

    .ourOrigin__item p {
        top: 50%;
        bottom: unset;
        left: 50%;
        transform: translate(-50%, 50%);
        text-align: left;
    }

    .item02 p {
        right: unset;
        transform: translate(-50%, -50%);
    }

    .ourOrigin__01{
        padding-right: 50%;
    }

    .ourOrigin__02{
        padding-left: 50%;
    }

    .cross__container {
        width: 7.3%;
        height: 7.3%;
        padding-bottom: 6.3%;
    }
}/* pc 769px */

/*==========================
OurMission
==========================*/
.section--ourMission .subTopic {
    font-size: clamp(1.706rem, 5.333vw, 2.666rem); /* 375px: 2rem */
    line-height: 2;
    text-align: center;
    padding-top: 70px;
}

.section--ourMission .text {
    line-height: 2.1;
    padding-top: 40px;
}

/* ourMission pc */
@media screen and (min-width:769px) {
    .section--ourMission {
        padding-top: 250px;
    }
    
    .section--ourMission .subTopic {
        font-size: clamp(1.495rem, 1.944vw, 3.111rem); /* 375px: 2.8rem */
        line-height: 1.4;
    }
    
    .section--ourMission .text {
        line-height: 1.6;
        padding-top: 50px;
    }
}

/*==========================
Message
==========================*/
.section--message img{
    width: 43.7vw;
    padding-top: 70px;
}

.message__container {
    display: flex;
    flex-direction: column;
    align-items: center;  
}

.text__container {
    display: flex;
    flex-direction: column;
    width: 90.4%;
    margin: 40px auto 0;
}

.role {
    font-size: clamp(1.4rem, 4.266vw, 2.133rem); /* 375px: 1.6rem */
}

.name {
    font-size: clamp(2.048rem, 6.4vw, 3.2rem); /* 375px: 2.4rem */;
    padding-top: 15px;
}

.text__container .text {
    padding-top: 23px;
    text-align: left;
}

/* ourMission pc */
@media screen and (min-width:769px) {
    .section--message {
        padding-top: 250px;
        width: 72.2222vw;
        margin: 0 auto;
    }

    .message__container {
        display: flex;
        padding-top: 100px;
        gap: 100px;
        flex-direction: row;
    }

    .text__container {
        display: flex;
        flex-direction: column;
        width: unset;
        margin: unset;
    }

    .message__container img {
        width: 32.2222vw;
        max-width: 100%;
        padding-top: unset;
    }

    .role {
        font-size: clamp(1.068rem, 1.388vw, 2.222rem); /* 375px: 2rem */
    }

    .name {
        font-size: clamp(1.602rem, 2.083vw, 3.333rem); /* 375px: 3rem */
    }
}

/*==========================
Company
==========================*/
.spacePc {
    display: none;
}

.spBr {
    display: block;
}

.company__container {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 90.4vw;
    margin: 0 auto;
}

.company__container img{
    width: 41.333vw;
    padding-top: 70px;
}

.company-info {
    padding-top: 55px;
    display: grid;
    grid-template-columns: 30% 70%;
    row-gap: 10px;
    font-size: clamp(1.4rem, 3.733vw, 1.866rem); /* 375px: 1.4rem */
    letter-spacing: 0.2em;
    line-height: 1.8;
}

.company-info .row {
    display: contents;
}

.company-info .label {
    font-weight: normal;
    text-align: left;
    border-bottom: 1px solid #fff;
    padding: 15px;
}

.company-info .value {
    border-bottom: 1px solid #fff;
    padding: 15px;
}

/* Company pc */
@media screen and (min-width:769px) {
    .topic.text-animationA.active {
        display: flex;
    }
    
    .spacePc {
        display: block;
    }
    
    .spBr {
        display: none;
    }

    .company__container {
        display: flex;
        flex-direction: unset;
        align-items: unset;
        width: 72.2222vw;
    }

    .company__container img{
        width: 27.7777vw;
        padding-top: 100px;
        padding-right: 80px;
    }

    .company-info {
        font-size: clamp(1.6rem, 1.25vw, 2rem); /* 375px: 1.8rem */
        width: 100%;
        padding-top: 100px
    }

    .company-info .label {
        padding-left: 23px;
    }
}

/*==========================
Access,Gallery
==========================*/
.map {
    width: 100%;
    padding-top: 70px;
    filter: grayscale(50%) invert(90%) contrast(90%);
}

.access__item__container {
    font-size: clamp(1.4rem, 3.733vw, 1.866rem); /* 375px: 1.4rem */
    line-height: 1.28;
    letter-spacing: 0.2em;
}

.access__item {
    padding-top: 40px;
}

.access__label {
    border-bottom: 1px solid white;
    padding-bottom: 5px;
    padding-left: 20px;
}

.access__content.address {
    padding-top: 7px;
    padding-left:10px;
}

.access__content.second {
    padding-top: 5px;
}

.access__container {
    display: flex;
    padding-right: 10px;
}

.access__contenttitle {
    width: 10.9vw;
    padding-left: 10px;
}

.access__container.train {
    padding-top: 7px;
    padding-right: 0px;
}

.access__container.car {
    padding-top: 10px;
}

/* Gallery */
.galleryAboutUs {
    display: flex;
    padding: 100px 4.8vw 0;
    flex-direction: column;
    background-image: url(../images/icon/gallery.png);
    background-position: top center;
    background-repeat: repeat;
    background-size: 100% auto;
    background-attachment: scroll;
}

.scroll-wrapper {
    padding-bottom: 50px;
}

.image-scroll {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 0 0;
}

.container_scroll-wrapper {
    display: flex;
    justify-content: flex-end;
}

/* Access pc */
@media screen and (min-width:769px) {
    .map {
        width: 72.222vw;
    }

    .access__item__container {
        font-size: clamp(1.6rem, 1.25vw, 2rem); /* 375px: 1.8rem */
    }

    .access__contenttitle {
        width: 6vw;
    }
    
    .access__label {
        padding-left: 25px;
        padding-bottom: 10px;
    }

    .access__content.address {
        padding-top: 10px;
        padding-left:20px;
    }

    .access__contenttitle {
        padding-left: 20px;
    }

    .access__container {
        padding-right: 20px;
    }

    .access__container.train {
        padding-top: 10px;
        padding-right: 0px;
    }

    /* Gallery pc */
    .galleryAboutUs {
        padding: 150px 16vw;
    }

    .scroll-wrapper {
        padding-bottom: 0px;
    }

    .container_scroll-wrapper {
        align-items: center;
    }

    .gallery01__img03 {
        width: clamp(127px, 39.9vw, 639px);
        position: relative;
    }
}

/*==========================
Last section P
==========================*/
.section--lastP {
    text-align: center;
    line-height: 2.2;
    letter-spacing: 0.2em;
}

.lastP__maintxt {
    font-size: clamp(1.962rem, 6.133vw, 3.066rem); /* 375px: 2.3rem */
}

.lastP__subtxt {
    font-size: clamp(1.536rem, 4.8vw, 2.4rem); /* 375px: 1.8rem */
    padding-top: 70px;
}

.lastP__logo {
    width: 72.226vw;
    padding: 100px 0 200px 0;
}

/* Access pc */
@media screen and (min-width:769px) {
    .spBr {
        display: none;
    }

    .section--lastP {
        text-align: center;
        line-height: 3.3;
        letter-spacing: 0.2em;
    }

    .lastP__maintxt {
        font-size: clamp(2.136rem, 2.777vw, 4.444rem); /* 375px: 4rem */
    }

    .lastP__subtxt {
        font-size: clamp(1.602rem, 2.083vw, 3.333rem); /* 375px: 3rem */
        padding-top: 70px;
    }

    .lastP__logo {
        width: 20vw;
        padding: 150px 0 250px 0;
    }
}