@charset "UTF-8";
/*
Theme Name: flipframe
Theme URI: /wp-content/themes/flipframe/
Author URI:
Version: 1.0
*/

:root{
    --base-width: 1440;
}

html {
    font-family: "zen-kaku-gothic-new", sans-serif;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.06em;
}

.gill_bold{
    font-family: "gill-sans-nova", sans-serif;
    font-weight: 700;
    font-style: normal;
}

.gill_semibold{
    font-family: "gill-sans-nova", sans-serif;
    font-weight: 600;
    font-style: normal;
}
.gill_book{
    font-family: "gill-sans-nova", sans-serif;
    font-weight: 400;
    font-style: normal;
}


*,
*:before,
*:after {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
}

img,
video {
    width: 100%;
    vertical-align: bottom;
    height: auto;
}

body{
    background: #fff;
}


a {
    display: inline-block;
    text-decoration: none;

}

li {
    list-style: none;
}


.fv{
    margin: 40px;
    position: relative;
    background: #fff;
    height: calc(100svh - 80px);
    width: calc(100svw - 80px);
    overflow: hidden;
}

.fv__video{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    min-width: 100%;
    min-height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

video{
    display: block;
    min-width: 100%;
    min-height: 100%;
    object-fit: cover;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);

}

.fv__video::before{
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1;
}

.fv__catch{
    position: absolute;
    left: min(90px, calc(90 / var(--base-width) * 100vw));
    bottom: min(90px, calc(90 / var(--base-width) * 100vw));
    z-index: 2;
    display: flex;
    align-items: flex-end;
    gap: min(60px, calc(60 / var(--base-width) * 100vw));
}

.fv__logo{
    width: min(524px, calc(524 / var(--base-width) * 100vw));
}

.fv__title{
    font-size: min(29px, calc(29 / var(--base-width) * 100vw));
    font-weight: 700;
    color: #fff;
    line-height: 1.5em;
    letter-spacing: 0.08em;
}

.about{
    padding: min(150px, calc(150 / var(--base-width) * 100vw)) 0 min(86px, calc(86 / var(--base-width) * 100vw)); 
    position: relative;
    background-color: #fff;
}

.about::before{
    content: "";
    width: 100%;
    height: min(277px, calc(277 / var(--base-width) * 100vw));
    position: absolute;
    left: 0;
    bottom: 0;
    background: #F4F4F4;
    z-index: 0;
}

.about::after{
    content: "";
    width: 100%;
    height: min(256px, calc(256 / var(--base-width) * 100vw));
    position: absolute;
    left: 0;
    bottom: min(277px, calc(277 / var(--base-width) * 100vw));
    background: linear-gradient(to right bottom,#fff 0 , #fff 50%, #F4F4F4 50%, #F4F4F4 100%);
    z-index: 0;
}

.about__wrap{
    width: 90%;
    margin: auto;
    max-width: 1030px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

.about__title{
    width: 100%;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: 1.75em;
    letter-spacing: 0;
    color: #818181;
    display: flex;
    align-items: center;
    gap: min(7px, calc(7 / var(--base-width) * 100vw));
    margin-bottom: min(30px, calc(30 / var(--base-width) * 100vw));
}

.about__txt{
    position: relative;
    z-index: 1;
}

.about__left{
    width: min(457px, calc(457 / var(--base-width) * 100vw));
}

.about__deco{
    width: min(28px, calc(28 / var(--base-width) * 100vw));
}

.about__catch{
    font-size: min(44px, calc(44 / var(--base-width) * 100vw));
    line-height: 1.5em;
    letter-spacing: min(0.08em, calc(0.08em / var(--base-width) * 100vw));
    color: #3D3D3D;
    font-weight: 700;
    margin-bottom: min(15px, calc(15 / var(--base-width) * 100vw));
}

.about__en{
    font-size: min(13px, calc(13 / var(--base-width) * 100vw));
    color: #818181;
    line-height: 1.4em;
}

.about__right{
    width: min(567px, calc(567 / var(--base-width) * 100vw));
}

.about__detail{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 2.7em;
    margin-bottom: min(30px, calc(30 / var(--base-width) * 100vw));
    letter-spacing: 0.02em;
}

.viewmore {
    padding: min(10px, calc(10 / var(--base-width) * 100vw)) 0;
    width: min(300px, calc(300 / var(--base-width) * 100vw));
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    position: relative;
    background: linear-gradient(90deg, #E60012 50%, #262626 50%);
    background-size: 200% 100%;
    background-position: right center;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: background-position 1s ease;
    overflow-x: hidden;
}

.viewmore--red{
    padding: min(10px, calc(10 / var(--base-width) * 100vw)) 0;
    width: min(300px, calc(300 / var(--base-width) * 100vw));
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    position: relative;

    color: #E60012;
    display: inline-block;
}

.viewmore:hover {
    background-position: left center;
}

.viewmore--red .viewmore__line{
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: min(1.5px, calc(1.5 / var(--base-width) * 100vw));
    background:#E60012;
    background-size: 100% 100%;
    background-position: right bottom;
    transition: 1s;
}

.viewmore .viewmore__line {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 200%;
    height: min(1.5px, calc(1.5 / var(--base-width) * 100vw));
    background: linear-gradient(to right, #E60012 50%, #262626 50%);
    background-size: 100% 100%;
    background-position: right bottom;
    transition: 1s;
    transform: translateX(-50%);
  }
  
  .viewmore:hover .viewmore__line {
    transform: translateX(0%);
  }

.viewmore:hover:before{
    background: #E60012;
}

.viewmore__arrow{
    display: block;
    width: min(10px, calc(10 / var(--base-width) * 100vw));
    height: min(10px, calc(10 / var(--base-width) * 100vw));
    overflow: hidden;
    background-image: url(./assets/img/arrow-b.svg);
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}

.viewmore__arrow{
    display: block;
    width: min(10px, calc(10 / var(--base-width) * 100vw));
    height: min(10px, calc(10 / var(--base-width) * 100vw));
    overflow: hidden;
    background-image: url(./assets/img/arrow-b.svg);
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}

.viewmore:hover .viewmore__arrow{
    animation: arrowSlide 1s linear forwards;
}

.viewmore--red .viewmore__arrow{
    background-image: url(./assets/img/arrow-r.svg);
}

@keyframes arrowSlide {
    0% {
      transform: translate(0, -50%);
      opacity: 1;
    }
    40% {
      transform: translate(50%, -50%);
      opacity: 0;
    }
    41% {
      transform: translate(-100%, -50%);
      opacity: 0;
    }
    100% {
      transform: translate(0, -50%);
      opacity: 1;
    }
  }

.about__txt{
    margin-top: min(53px, calc(53 / var(--base-width) * 100vw));
    width: 100%;
    height: min(78.4px, calc(78.4 / var(--base-width) * 100vw));
    -webkit-animation: bg-slider 46s linear infinite;
    animation: bg-slider 46s linear infinite;
    background: url(./assets/img/about-deco.svg) repeat-x 50%;
    background-size: auto min(78.4px, calc(78.4 / var(--base-width) * 100vw));
}

@keyframes bg-slider {
    0% {
        background-position: 0 0
    }

    to {
        background-position: -4840px 0
    }
}

@-webkit-keyframes bg-slider {
    0% {
        background-position: 0 0
    }

    to {
        background-position: -4840px 0
    }
}

.service{
    padding: min(232px, calc(232 / var(--base-width) * 100vw)) 0 min(277px, calc(277 / var(--base-width) * 100vw));
    position: relative;
    background-color: #F4F4F4;

}

.service::before{
    content: "";
    position: absolute;
    left: 0;
    top: 2px;
    z-index: 1;

    width: 0;
    height: 0;
    border-style: solid;
    border-color: transparent transparent transparent #262626;
    border-width: min(232px, calc(232 / var(--base-width) * 100vw)) 0px 0px 100vw;
}
.service::after{
    content: "";
    position: absolute;
    left: 0;
    bottom: 2px;
    z-index: 1;
    width: 0;
    height: 0;
    border-style: solid;
    border-color: #262626 transparent transparent transparent;
    border-width: min(277px, calc(277 / var(--base-width) * 100vw)) 100vw 0px 0px;
}
.service__wrap{
    background: #262626;
    padding-bottom: min(109px, calc(109 / var(--base-width) * 100vw));
}

.service__ttl{
    color:#fff;
    font-size: min(80px, calc(80 / var(--base-width) * 100vw));
    letter-spacing: 0;
    line-height: 1em;
    max-width: 1232px;
    width: 90%;
    margin: 0 auto  min(90px, calc(90 / var(--base-width) * 100vw));
    position: relative;
    z-index: 2;
    font-family: "gill-sans-nova", sans-serif;
    font-weight: 700;
    font-style: normal;

}

.service__container{
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    overflow: hidden;
  }

  .service__container__inner {
    content: '';
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity 0.5s ease;
    width: 100%;
    height: 100%;
    display: block;
    pointer-events: none;
  }

  .service__container__inner.bg-active {
    opacity: 1;
  }

.service__link{
    display: block; 
    width: 100%;
    padding: min(80px, calc(80 / var(--base-width) * 100vw)) 0;
    position: relative;
    z-index: 1;
}

.service__link:hover{
    cursor: url(./assets/img/cursor.svg) 60 60, auto;
}

.service__txt{
    display: block;
    width: 90%;
    max-width: 1232px;
    margin: auto;
    color: #fff;
}

.service__label{
    display: flex;
    align-items: flex-end;
    gap: min(18px, calc(18 / var(--base-width) * 100vw));
    margin-bottom: min(12px, calc(12 / var(--base-width) * 100vw));
}

.service__ja{
    font-size: min(25px, calc(25 / var(--base-width) * 100vw));
    line-height:1.6em;
    letter-spacing: 0.08em;
    font-weight: 700;
    text-align: center;
}

.service__en{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 2em;
    letter-spacing: 0;
}

.service__detail{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 2em;

}

.service__line{
    width: 100%;
    height: 1px;
    background: #fff;
    position: relative;
    z-index: 1;
}

.works{
    background-color: #F4F4F4;
    padding-top: min(170px, calc(170 / var(--base-width) * 100vw));
        position: relative;
}

.works__wrap{
    width: 90%;
    max-width:1200px;
    margin: auto;
    margin-bottom: min(60px, calc(60 / var(--base-width) * 100vw));
    display: flex;
    align-items: flex-end;
    justify-content: space-between;


}

.works__left{
    position: relative;
    z-index: 1;
}

.works__ttl{
    font-size: min(80px, calc(80 / var(--base-width) * 100vw));
    line-height: 1em;
    letter-spacing: 0;
    margin-bottom: min(33px, calc(33 / var(--base-width) * 100vw));
}

.works__detail{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 2em;
    font-weight: 500;
}

.works__item{
    padding: 0 min(7px, calc(7 / var(--base-width) * 100vw));
}

.works__link{
    display: block;
}

.works__slider--under {
    direction: rtl;
    margin-top: min(30px, calc(30 / var(--base-width) * 100vw));
}

.works__slider--under .works__item {
    direction: ltr; /* 中の要素は元に戻す */
}

.news{
    padding: min(170px, calc(170 / var(--base-width) * 100vw)) 0 min(180px, calc(180 / var(--base-width) * 100vw));
    background-color: #fff;
}

.news__wrap{
    padding: min(45px, calc(45 / var(--base-width) * 100vw)) min(55px, calc(55 / var(--base-width) * 100vw));
    border: min(15px, calc(15 / var(--base-width) * 100vw)) solid #262626;
    width: 90%;
    max-width: 1200px;
    margin: auto;
}

.news__top{
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: min(50px, calc(50 / var(--base-width) * 100vw));
}

.news__ttl{
    font-size: min(36px, calc(36 / var(--base-width) * 100vw));
    line-height: 1em;
    letter-spacing: 0;
    display: flex;
    align-items: center;
    gap: min(7px, calc(7 / var(--base-width) * 100vw));
}

.news__container{
    margin-top: min(50px, calc(50 / var(--base-width) * 100vw));
}

.news__item{
    border-bottom: 1px solid #E2E2E2;
}

.news__link{
    padding: min(28px, calc(28 / var(--base-width) * 100vw)) min(20px, calc(20 / var(--base-width) * 100vw)) min(28px, calc(28 / var(--base-width) * 100vw)) 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.news__left{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: calc(100% - min(10px, calc(10 / var(--base-width) * 100vw)));
}

.news__date{
    width: min(136px, calc(136 / var(--base-width) * 100vw));
    font-weight: 600;
    font-size: min(18px, calc(18 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0;
    color: #8E8E8E;
    display: inline-block;
}

.news__detail{
    width: calc(100% - min(136px, calc(136 / var(--base-width) * 100vw)));
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    font-weight: 500;
    line-height: 100%;
    letter-spacing: 0.05em;
    color: #424242;
    display: inline-block;
}

.news__arrow{
    display: block;
    width: min(10px, calc(10 / var(--base-width) * 100vw));
    height: min(10px, calc(10 / var(--base-width) * 100vw));
    overflow: hidden;
    background-image: url(./assets/img/arrow-g.svg);
    background-repeat: no-repeat;
    background-position: center;
}

.contact__link{
    padding: min(140px, calc(140 / var(--base-width) * 100vw)) 0;
    display: block;
    background-image: url(./assets/img/contact-back.png);
    background-size: cover;
    background-position: center;
    color: #fff;
    position: relative;
}

.contact__link::before{
    width: 0;
    height: 100%;
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    background-color: rgba(230, 0, 18, 0.7);
    transition: 0.3s;
    transition-timing-function: ease-in-out;
    z-index: 1;
}

.contact__link:hover::before{
    width: 100%;
}

.contact__left{
    font-weight: 500;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height:2em;
    letter-spacing: 0.1em;
}

.contact__inner{
    width: 90%;
    max-width: 1200px;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    z-index: 2;
}

.contact__ttl{
    font-weight: 700;
    font-size: min(80px, calc(80 / var(--base-width) * 100vw));
    line-height: 2.3em;
    letter-spacing: 0.02em;   
}


/*以下ハンバーガーメニューcss*/
.sp-hum {
    display: none;
}

.pc-only{
    display: inline-block;
}

.sp-only{
    display: none;
}

.sp-header-nav{
    display: none;
}

.addr{
    width: min(450px, calc(450 / var(--base-width) * 100vw));
}


@media screen and (max-width:1024px) {
    :root{
        --base-width: 390;
    }
    .pc-only{
        display: none;
    }
    
    .fv{
        margin: 0;
        height: 100svh;
        width: 100%;;
    }


    .fv__video{
        width: 100%;
        height: auto;
        overflow: hidden;
        position: relative;
        height: calc(100svh - calc(46 / var(--base-width) * 100vw));
    }
    
    .fv__video video{
        height: calc(100vh - calc(46 / var(--base-width) * 100vw));
        width: auto;
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
    }
    
    .fv__catch{
        position: absolute;
        left: calc(27 / var(--base-width) * 100vw);
        bottom: calc(55 / var(--base-width) * 100vw);
        z-index: 2;
        display: flex;
        align-items: flex-end;
        flex-wrap: wrap;
        gap: calc(25 / var(--base-width) * 100vw);
    }
    
    .fv__title{
        order: 1;
    }
    
    .fv__logo{
        order: 2;
        width: calc(197.37 / var(--base-width) * 100vw);
    }
    
    .about {
        padding: calc(80 / var(--base-width) * 100vw) 0 calc(68 / var(--base-width) * 100vw);
        position: relative;
    }

    .about::before{
        height: calc(239 / var(--base-width) * 100vw);
    }

    .about::after{
        height: calc(71 / var(--base-width) * 100vw);
        bottom: calc(239 / var(--base-width) * 100vw);
    }
    
    .about__title{
        font-size: calc(16 / var(--base-width) * 100vw);
        margin-bottom: calc(20 / var(--base-width) * 100vw);
    }
    
    .about__deco{
        width: calc(21 / var(--base-width) * 100vw);
    }
    .about__catch{
        font-size: calc(30 / var(--base-width) * 100vw);
        margin-bottom: calc(12 / var(--base-width) * 100vw);
    }
    .about__en {
        font-size: calc(10 / var(--base-width) * 100vw);
    }

    
    .about__left{
        width: 100%;
    }

    .about__right{
        width: 100%;
        margin-top: calc(32 / var(--base-width) * 100vw);
    }
    .about__detail{
        font-size: calc(12 / var(--base-width) * 100vw);
        margin-bottom: calc(32 / var(--base-width) * 100vw);
    }
    .viewmore{
        width: calc(200 / var(--base-width) * 100vw);
        font-size: calc(12 / var(--base-width) * 100vw);
    }
    
    .viewmore--red{
        width: calc(200 / var(--base-width) * 100vw);
        font-size: calc(12 / var(--base-width) * 100vw);
    }

    .about__txt {
        margin-top: calc(28 / var(--base-width) * 100vw);
        width: 100%;
        height: calc(42 / var(--base-width) * 100vw);
        background-size: auto calc(42 / var(--base-width) * 100vw);
    }
    .service::before{
        top: 2px;
        border-width: calc(70 / var(--base-width) * 100vw) 0px 0px 100vw;
    }
    .service{
        padding: calc(70 / var(--base-width) * 100vw) 0 ;
    }
    .service__ttl{
        font-size: calc(50 / var(--base-width) * 100vw);
        margin-bottom: calc(78 / var(--base-width) * 100vw);
    }
    .service__container{
        background-image: none !important;
    }
    .service__link {
        display: block;
        width: 100%;
        padding: calc(40 / var(--base-width) * 100vw) 0;
        position: relative;
        z-index: 1;
    }
    .service__ja {
        font-size: calc(18 / var(--base-width) * 100vw);
        line-height: calc(30 / var(--base-width) * 100vw);
    }
    .service__en {
        font-size: calc(14 / var(--base-width) * 100vw);
        line-height: calc(30 / var(--base-width) * 100vw);
        letter-spacing: 0;
    }
    .service__detail{
        font-size: calc(12 / var(--base-width) * 100vw);
    }
    .sp-only{
        display: inline-block;
    }
    
    .service__wrap{
        padding-bottom: calc(116 / var(--base-width) * 100vw);
    }
    
    .service__link--first{
        background-image: url(./assets/img/service-first.png);
        background-size: cover;
        background-position: center;
    }
    
    .service__link--second{
        background-image: url(./assets/img/service-second.png);
        background-size: cover;
        background-position: center;
    }

    .service__bottom{
        width: 90%;
        margin: auto;
        display: block;
    }


    .service::after{
        bottom: 2px;
        border-width: calc(70 / var(--base-width) * 100vw) 100vw 0px 0px;
    }
    .works{
        padding: calc(75 / var(--base-width) * 100vw) 0 calc(60 / var(--base-width) * 100vw);
    }
    .works__ttl{
        font-size: calc(50 / var(--base-width) * 100vw);
        margin-bottom: calc(30 / var(--base-width) * 100vw);
    }
    .works__detail{
        font-size: calc(12 / var(--base-width) * 100vw);
    }
    .works__wrap{
    
    }
    .works__item {
        padding: 0 calc(6.5 / var(--base-width) * 100vw);
    }
    .works__right{
        margin-top: calc(32 / var(--base-width) * 100vw);
        margin-left: 5vw;
    }
    
    .news{
        padding: calc(60 / var(--base-width) * 100vw) 0 calc(150 / var(--base-width) * 100vw);
    }
    
    .news__wrap{
        padding: calc(25 / var(--base-width) * 100vw);
    }
    
    .news__container{
        margin-top: calc(12 / var(--base-width) * 100vw);
    }
    
    .news__ttl{
        font-size: calc(28 / var(--base-width) * 100vw);
    }
    
    .news__link{
        display: flex;
        flex-wrap: wrap;
        padding: calc(20 / var(--base-width) * 100vw) 0;
    }

    
    .news__left{
        width: calc(100% - calc(10 / var(--base-width) * 100vw));
        flex-wrap: wrap;
    }
    
    .news__date{
        width: 100%;
        margin-bottom: calc(4 / var(--base-width) * 100vw);
        font-size: calc(12 / var(--base-width) * 100vw);
    }
    
    .news__detail{
        width: 100%;
        font-size: calc(14 / var(--base-width) * 100vw);
        line-height: 1.5em;
    }
    
    .news__list{
        margin-bottom: calc(32 / var(--base-width) * 100vw);
    }
    
    .contact__link {
        padding: calc(163 / var(--base-width) * 100vw) 0;
        background-size: auto 100%;
        background-image: url(./assets/img/contact-back-sp.png);
    }
    .contact__inner{
        flex-wrap: wrap;
        width: 100%;
        text-align: center;
        justify-content: center;
    }
    
    .contact__left{
        font-size: calc(16 / var(--base-width) * 100vw);
        margin-right: -1em;
        margin-bottom: calc(20 / var(--base-width) * 100vw);
    }
    
    .contact__ttl{
        font-size: calc(40 / var(--base-width) * 100vw);
    }

    .addr{
        width: calc(221.98 / var(--base-width) * 100vw);
    }
    
}
.aboutPage__fv{
    padding: min(300px, calc(300 / var(--base-width) * 100vw)) 0 min(120px, calc(120 / var(--base-width) * 100vw));
    position: relative;
    border: 1px solid rgba(187, 187, 187, 1);
}

.moviePage__fv{
    padding: min(300px, calc(300 / var(--base-width) * 100vw)) 0 min(120px, calc(120 / var(--base-width) * 100vw));
    position: relative;
}

.aboutPage__fv__title{
    width: 90%;
    max-width: min(1200px, calc(1200 / var(--base-width) * 100vw));
    margin: auto;
}

.aboutPage__fv__title__main{
    font-size: min(71px, calc(71 / var(--base-width) * 100vw));
    line-height: 1.5em;
    letter-spacing: 0;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: min(24px, calc(24 / var(--base-width) * 100vw));
    color: #818181;
}

.aboutPage__fv__title__main__logo{
    width: min(92px, calc(92 / var(--base-width) * 100vw));
}



.aboutPage__fv__title__sub{
    font-family: Zen Kaku Gothic New,"zen-kaku-gothic-new";
    font-weight: 700;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: min(34px, calc(34 / var(--base-width) * 100vw));
    letter-spacing: 0.04;
    color: rgba(61, 61, 61, 1);
}

.aboutPage__fv__title__sub__en{
    font-size: min(24px, calc(24 / var(--base-width) * 100vw));
    line-height: min(44px, calc(44 / var(--base-width) * 100vw));
    letter-spacing: 0%;
    color: rgba(61, 61, 61, 1);
}

.aboutPage__mission{
    padding: min(172px, calc(172 / var(--base-width) * 100vw)) 0 min(166px, calc(166 / var(--base-width) * 100vw));
    background: linear-gradient(to bottom, #fff 0,#fff 45%,#F4F4F4 45% , #F4F4F4 100%);
}

.aboutPage__wrap{
    width: 90%;
    max-width: min(1040px, calc(1040 / var(--base-width) * 100vw));
    margin: auto;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.aboutPage__left{
    margin-top: min(32px, calc(32 / var(--base-width) * 100vw));
}

.aboutPage__left__title{
    font-size: min(40px, calc(40 / var(--base-width) * 100vw));
    line-height: 1em;
    letter-spacing: 0;
    margin-bottom: min(7px, calc(7 / var(--base-width) * 100vw));
    position: relative;
}

.aboutPage__left__text{
    font-weight: 700;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: 1.7em;
    letter-spacing: 0.04em;
    color: rgba(153, 153, 153, 1);
}

.aboutPage__ttl{
    font-weight: 700;
    font-size: min(45px, calc(45 / var(--base-width) * 100vw));
    line-height: min(100px, calc(100 / var(--base-width) * 100vw));
    letter-spacing: 0.06em;
    color: rgba(230, 0, 18, 1);
    margin-bottom: min(35px, calc(35 / var(--base-width) * 100vw));
    position: relative;
    background-color: #fff;
}

.aboutPage__ttl::after{
    content: "";
    width: min(80px, calc(80 / var(--base-width) * 100vw));
    height: min(8px, calc(8 / var(--base-width) * 100vw));
    position: absolute;
    right: calc(100% + min(30px, calc(30 / var(--base-width) * 100vw)));
    top: 50%;
    transform: translateY(-50%);
    background-color: #262626;
}

.aboutPage__detail{
    font-weight: 700;
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 2.7em;
    letter-spacing: 0.02em;
    position: relative;
}

.aboutPage__right{
    position: relative;
}

.aboutPage__right::before{
    content: "";
    display: block;
    border: min(10px, calc(10 / var(--base-width) * 100vw)) solid #262626;
    background-color: #fff;
    position: absolute;
    left: max(-70px, calc(-70 / var(--base-width) * 100vw));
    top: max(-40px, calc(-40 / var(--base-width) * 100vw));
    bottom: max(-68px, calc(-68 / var(--base-width) * 100vw));
    right: min(113px, calc(113 / var(--base-width) * 100vw));
}

.aboutPage__txt{
    margin-top: min(141px, calc(141 / var(--base-width) * 100vw));
    width: 100%;
    height: min(56px, calc(56 / var(--base-width) * 100vw));
    -webkit-animation: bg-slider 46s linear infinite;
    animation: bg-slider 46s linear infinite;
    background: url(./assets/img/aboutPage-deco.svg) repeat-x 50%;
    background-size: auto min(56px, calc(56 / var(--base-width) * 100vw));
}

.aboutPage__txt--moviePage{
    margin-top: min(82px, calc(82 / var(--base-width) * 100vw));
    width: 100%;
    height: min(56px, calc(56 / var(--base-width) * 100vw));
    -webkit-animation: bg-slider 46s linear infinite;
    animation: bg-slider 46s linear infinite;
    background: url(./assets/img/moviePage-deco.svg) repeat-x 50%;
    background-size: auto min(56px, calc(56 / var(--base-width) * 100vw));
    z-index: 1;
    position: relative;
}

.aboutPage__txt--webPage{
    background: url(./assets/img/webPage-deco.svg) repeat-x 50%;

}

@keyframes bg-slider {
    0% {
        background-position: 0 0;
    }

    to {
        background-position: -4840px 0;
    }
}

@-webkit-keyframes bg-slider {
    0% {
        background-position: 0 0;
    }

    to {
        background-position: -4840px 0;
    }
}

.message{
    padding: min(100px, calc(100 / var(--base-width) * 100vw)) 0 0;
    background-color: #262626;
    position: relative;
}

.message__wrap{
    position: relative;
    z-index: 1;
    width: 90%;
    max-width: min(1240px, calc(1240 / var(--base-width) * 100vw));
    margin: auto;
    padding: min(100px, calc(100 / var(--base-width) * 100vw)) 0 min(80px, calc(80 / var(--base-width) * 100vw));
}

.message__ttl{
    margin-bottom: min(52px, calc(52 / var(--base-width) * 100vw));
}

.message__label{
    width: min(1171.45px, calc(1171.45 / var(--base-width) * 100vw));
}

.message__detail{
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: 2.4em;
    letter-spacing: 0.06em;
    color: #fff;
    font-weight: 700;
}

.message__detail--first{
    margin-bottom: min(24px, calc(24 / var(--base-width) * 100vw));
}

.message__name{
    width: min(179px, calc(179 / var(--base-width) * 100vw));
    margin-top: min(55px, calc(55 / var(--base-width) * 100vw));
}

.message__deco{
    width: min(834px, calc(834 / var(--base-width) * 100vw));
    position: absolute;
    right: 0;
    bottom: 0;
}

.message__deco2{
    width: min(199px, calc(199 / var(--base-width) * 100vw));
    position: absolute;
    left: 0;
    top: min(92px, calc(92 / var(--base-width) * 100vw));
}

.profile{
    position: relative;
}

.profile::before{
    content: "";
    width: 100%;
    height: min(255px, calc(255 / var(--base-width) * 100vw));
    position: absolute;
    left: 0;
    bottom: min(255px, calc(255 / var(--base-width) * 100vw));
    background: linear-gradient(to left top,#F4F4F4 0 , #F4F4F4 50%, #fff 50%, #fff 100%);
    z-index: -1;
}

.profile::after{
    content: "";
    width: 100%;
    height: min(255px, calc(255 / var(--base-width) * 100vw));
    position: absolute;
    left: 0;
    bottom: 0;
    background:#F4F4F4;
    z-index: -1;
}

.profile__wrap{
    padding: min(120px, calc(120 / var(--base-width) * 100vw)) 0 min(180px, calc(180 / var(--base-width) * 100vw));
    max-width: min(1040px, calc(1040 / var(--base-width) * 100vw));
    width: 90%;
    margin: auto;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.profile__ttl{
    font-size: min(40px, calc(40 / var(--base-width) * 100vw));
    margin-bottom: min(6px, calc(6 / var(--base-width) * 100vw));
}

.profile__sub{
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    color: #999999;
    font-weight: 700;
}

.profile__right__item{
    display: flex;
    align-items: center;
    padding: min(28px, calc(28 / var(--base-width) * 100vw)) 0;
    border-bottom: 1px solid #DADADA;
}

.profile__right__item--first{
    border-top: 1px solid #DADADA;
}

.profile__right__item__ttl{
    width: min(170px, calc(170 / var(--base-width) * 100vw));
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    font-weight: 500;
    letter-spacing: 0.06em;
}

.profile__right__item__text{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    letter-spacing: 0.06em;
    width: calc(100% - min(170px, calc(170 / var(--base-width) * 100vw)));
}

.moviePage__fv{
    position: relative;
    border: none;
}

.moviePage__fv::before{
    width: calc(100% - 80px);
    height: calc(100% - 80px);
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background-image: url(./assets/img/moviePage-fv.jpg);
    background-position: center;
    background-size: cover;
    z-index: -1;
}

.webPage__fv::before{
    background-image: url(./assets/img/webPage-fv.jpg);

}

.aboutPage__fv__title__main--white{
    color: #fff;
}

.aboutPage__fv__title__sub--white{
    color: #fff;
}


.moviePage__second{
    margin-top: min(15px, calc(15 / var(--base-width) * 100vw));
    padding: min(120px, calc(120 / var(--base-width) * 100vw)) 0;
    background-color: #F4F4F4;
}

.moviePage__second__text{
    font-weight: 700;
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 2.7em;
    letter-spacing: 0.06em;
    max-width: min(1200px, calc(1200 / var(--base-width) * 100vw));
    width: 90%;
    margin: auto;   
    position: relative;
    z-index: 1;
}

.point{
    background-image: url(./assets/img/point-back.png);
    background-size: cover;
    background-position: center;
}

.point--web{
    background-image: url(./assets/img/point-back-web.png);
    
}

.point__wrap{
    width: 90%;
    max-width: min(1040px, calc(1040 / var(--base-width) * 100vw));
    margin: auto;
    padding: min(120px, calc(120 / var(--base-width) * 100vw)) 0;
}

.point__ttl{
    font-size: min(40px, calc(40 / var(--base-width) * 100vw));
    line-height: 1.75em;
    letter-spacing: 0;
    color: rgba(230, 0, 18, 1);
}

.point__sub{
    font-weight: 700;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: 1.75em;
    letter-spacing: 0.04em;
    color: #fff;
}

.point__main{
    margin-top: min(40px, calc(40 / var(--base-width) * 100vw));
}

.point__label{
    text-align: center;
    border: min(2px, calc(2 / var(--base-width) * 100vw)) solid rgba(255, 255, 255, 1);
    color: #fff;
    padding: min(26px, calc(26 / var(--base-width) * 100vw)) 0;
    font-weight: 700;
    font-size: min(28px, calc(28 / var(--base-width) * 100vw));
    line-height: 1.35em;
    letter-spacing: 0.06em;
}

.point__close{
    width: min(60px, calc(60 / var(--base-width) * 100vw));
    height: min(60px, calc(60 / var(--base-width) * 100vw));
    position: relative;
    margin: min(13px, calc(13 / var(--base-width) * 100vw)) auto;
}

.point__close::before{
    content: "";
    width: min(85px, calc(85 / var(--base-width) * 100vw));
    height: min(2px, calc(2 / var(--base-width) * 100vw));
    position: absolute;
    left: 0;
    top: 0;
    transform: rotate(45deg);
    background-color: #fff;
    transform-origin: left center;
}

.point__close::after{
    content: "";
    width: min(85px, calc(85 / var(--base-width) * 100vw));
    height: min(2px, calc(2 / var(--base-width) * 100vw));
    position: absolute;
    right: 0;
    top: 0;
    transform: rotate(-45deg);
    background-color: #fff;
    transform-origin: right center;
}

.movieService{
    background: rgba(38, 38, 38, 1);
    padding: min(120px, calc(120 / var(--base-width) * 100vw)) 0;
}

.movieService__wrap{
    width: 90%;
    max-width: min(1040px, calc(1040 / var(--base-width) * 100vw));
    margin: auto;
}

.movieService__ttl{
    font-weight: 700;
    font-size: min(40px, calc(40 / var(--base-width) * 100vw));
    line-height: 1em;
    margin-bottom: min(16px, calc(16 / var(--base-width) * 100vw));
    letter-spacing: 0%;
    color: #fff;
}

.movieService__sub{
    font-weight: 700;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: 1em;
    letter-spacing: 0.04;
    color: rgba(153, 153, 153, 1);
}

.movieService__list{
    margin-top: min(70px, calc(70 / var(--base-width) * 100vw));
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: wrap;
    gap: min(36px, calc(36 / var(--base-width) * 100vw));
}

.movieService__item{
    width: calc(50% - min(18px, calc(18 / var(--base-width) * 100vw)));
    border: min(5px, calc(5 / var(--base-width) * 100vw)) solid rgba(255, 255, 255, 1);
}

.movieService__txt{
    padding: min(24px, calc(24 / var(--base-width) * 100vw));
}

.movieService__item__ttl{
    font-weight: 700;
    font-size: min(24px, calc(24 / var(--base-width) * 100vw));
    line-height: 1em;
    letter-spacing: 0.1;
    color: rgba(230, 0, 18, 1);
    margin-bottom: min(8px, calc(8 / var(--base-width) * 100vw));
}

.movieService__item__text{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 2em;
    color: #fff;
}


.newsPage{
    padding: min(100px, calc(100 / var(--base-width) * 100vw)) 0  min(120px, calc(120 / var(--base-width) * 100vw));
    background-color: rgba(244, 244, 244, 1);
}

.newsPage__wrap{
    max-width: min(1040px, calc(1040 / var(--base-width) * 100vw));
    width: 90%;
    margin: auto;
}

.newsPage__list{
    margin-top: min(8px, calc(8 / var(--base-width) * 100vw));
}

.newsPage__label{
    padding: min(8px, calc(8 / var(--base-width) * 100vw)) min(10px, calc(10 / var(--base-width) * 100vw));
    background-color: #262626;
    color: #fff;
    display: inline-block;
    font-weight: 600;
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0;
}

/* .news__date--page{
    width: min(100px, calc(100 / var(--base-width) * 100vw));
} */

.news__cate{
    font-weight: 700;
    font-size: min(14px, calc(14 / var(--base-width) * 100vw));
    line-height: 100%;
    /* width: min(76px,calc(76 / var(--base-width) * 100vw)); */
    text-align: center;
    letter-spacing: 0%;
    padding: min(6px, calc(6 / var(--base-width) * 100vw)) min(10px, calc(10 / var(--base-width) * 100vw));
    background-color: rgba(0, 120, 215, 1);
    white-space: nowrap;
    color: #fff;
    margin-right: min(40px, calc(40 / var(--base-width) * 100vw));
}

.news__link--page{
    padding-right: min(100px, calc(100 / var(--base-width) * 100vw));
}

.news__detail--page{
    width: calc(100% - min(208px, calc(208 / var(--base-width) * 100vw)));
}

.news__arrow--page{
    right: min(100px, calc(100 / var(--base-width) * 100vw));
}

.movie__goods{
    margin-top: min(132px, calc(132 / var(--base-width) * 100vw));
}

.movie__goods__ttl{
    font-weight: 700;
    font-size: min(28px, calc(28 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0.1em;
    text-align: left;
    color: rgba(129, 129, 129, 1);
    margin-bottom: min(24px, calc(24 / var(--base-width) * 100vw));
    padding-bottom: min(20px, calc(20 / var(--base-width) * 100vw));
}

.movie__goods__item{
    width: 80%;
    padding: min(32px, calc(32 / var(--base-width) * 100vw)) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 1);
}

.movie__goods__item--first{
    border-top: 1px solid rgba(255, 255, 255, 1);
}

.movie__goods__label{
    font-weight: 700;
    font-size: min(24px, calc(24 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0.1;
    margin-bottom: min(17px, calc(17 / var(--base-width) * 100vw));
    color: #fff;
}

.movie__goods__detail{
    color: #fff;
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 2em;
    letter-spacing: 0.1em;
}

.flow{
    padding: min(120px, calc(120 / var(--base-width) * 100vw)) 0;
    background: linear-gradient(to bottom,#F4F4F4 0%,#F4F4F4 calc(100% - min(259px, calc(259 / var(--base-width) * 100vw))),#fff calc(100% - min(259px, calc(259 / var(--base-width) * 100vw))),#fff 100%);
}

.flow__wrap{
    width: 90%;
    max-width: min(1200px, calc(1200 / var(--base-width) * 100vw));
    margin: auto;
}

.flow__ttl{
    font-size: min(40px, calc(40 / var(--base-width) * 100vw));
    line-height: 1.75em;
    letter-spacing: 0;
}

.flow__sub{
    font-weight: 700;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: 1.75em;
    letter-spacing: 0.04em;
    color: rgba(153, 153, 153, 1);
    margin-bottom: min(75px, calc(75 / var(--base-width) * 100vw));
}

.flow__list{
    display: flex;
    justify-content: space-between;
    position: relative;
}

.flow__list::before{
    content: "";
    width: calc(100% - min(7px, calc(7 / var(--base-width) * 100vw)));
    height: min(5px, calc(5 / var(--base-width) * 100vw));
    background-color: #DFDFDF;
    position: absolute;
    top: min(100px, calc(100 / var(--base-width) * 100vw));
    left: min(7px, calc(7 / var(--base-width) * 100vw));
    z-index: 0;
}

.flow__item{
    width: min(237px, calc(237 / var(--base-width) * 100vw));
    position: relative;
    z-index: 1;
}

.flow__img{
    margin-bottom: min(16px, calc(16 / var(--base-width) * 100vw));
}

.flow__detail{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    padding-left: min(7px, calc(7 / var(--base-width) * 100vw));
}

.worksPage{
    position: relative;
        padding-top: min(120px, calc(120 / var(--base-width) * 100vw));
    padding-bottom: min(216px, calc(216 / var(--base-width) * 100vw));
}
.worksPage::before{
    content: "";
    width: 100%;
    height: min(768px, calc(768 / var(--base-width) * 100vw));
    position: absolute;
    top: min(144px, calc(144 / var(--base-width) * 100vw));
    left: 0;
    z-index: -1;
    background-image: url(./assets/img/worksPage-deco1.png);
    background-size: 100% 100%;
    background-position: center;
}

.worksPage::after{
    content: "";
    width: 100%;
    height: min(570px, calc(570 / var(--base-width) * 100vw));
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
    background-image: url(./assets/img/worksPage-deco2.png);
    background-size: 100% 100%;
    background-position: center;
}

.worksPage__list{
    display: none;
    min-height: min(950px, calc(950 / var(--base-width) * 100vw));
}

.worksPage__list.active{
    display: block;
}

.worksPage__wrap{
    max-width: min(864px, calc(864 / var(--base-width) * 100vw));
    width: 90%;
    margin: auto;
}

.worksPage__left{
    width: 35%;
}

.worksPage__right{
    width: 65%;
    padding-left: min(19px, calc(19 / var(--base-width) * 100vw));
}

.worksPage__nav{
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: min(96px, calc(96 / var(--base-width) * 100vw));
}

.worksPage__nav__item{
    width: 50%;
    padding: min(18px, calc(18 / var(--base-width) * 100vw)) 0;
    line-height: 1em;
    text-align: center;
    background-color: #DFDFDF;
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    color: #262626;
    font-weight: 600;
    cursor: pointer;
    border-bottom: min(3px, calc(3 / var(--base-width) * 100vw)) solid #DFDFDF;
}

.worksPage__nav__item.active{
    background-color: #262626;
    color: #fff;
    border-bottom: min(3px, calc(3 / var(--base-width) * 100vw)) solid #E60012;
}

.worksPage__item{
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 0;
    margin-bottom: min(64px, calc(64 / var(--base-width) * 100vw));
    color: #262626;
}

.worksPage__item:last-child{
    margin-bottom: 0;
}

.worksPage__cate{
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: min(15px, calc(15 / var(--base-width) * 100vw));
    margin-bottom: min(20px, calc(20 / var(--base-width) * 100vw));
}

.worksPage__cate__item {
    display: inline-block;
    white-space: nowrap;
    padding: min(1px, calc(1 / var(--base-width) * 100vw)) min(16px, calc(16 / var(--base-width) * 100vw));
    border-radius: 100px;
    background-color: rgba(204, 73, 111, 1);
    color: #fff;
    font-size: min(14px, calc(14 / var(--base-width) * 100vw));
}

.worksPage__cate__item.cm{
    background-color: #3F77D3;
}

.worksPage__cate__item.cg{
 background-color: #01BFB0;
}

.worksPage__title{
    font-weight: 700;
    font-size: min(18px, calc(18 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0.14em;
    margin-bottom: min(16px, calc(16 / var(--base-width) * 100vw));
}

.worksPage__companyName{
    font-weight: 700;
    font-size: min(12px, calc(12 / var(--base-width) * 100vw));
    line-height: 1.5em;
    letter-spacing: 0.06em;
    color: #818181;
    margin-bottom: min(4px, calc(4 / var(--base-width) * 100vw));

}

.worksPage__text{
    font-weight: 500;
    font-size: min(12px, calc(12 / var(--base-width) * 100vw));
    line-height: min(19px, calc(19 / var(--base-width) * 100vw));
    letter-spacing: 0.05em;
}

.worksPage__pagenation{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: min(22px, calc(22 / var(--base-width) * 100vw));
}

.worksPage__pagenation a{
    font-weight: 500;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0%;
    display: inline-block;
    width: min(36px, calc(36 / var(--base-width) * 100vw));
    height: min(36px, calc(36 / var(--base-width) * 100vw));
    line-height: min(36px, calc(36 / var(--base-width) * 100vw));
    text-align: center;
    color: #fff;
    background-color: #818181;
}
.worksPage__pagenation span{
    font-weight: 500;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0%;
    display: inline-block;
    width: min(36px, calc(36 / var(--base-width) * 100vw));
    height: min(36px, calc(36 / var(--base-width) * 100vw));
    line-height: min(36px, calc(36 / var(--base-width) * 100vw));
    text-align: center;
    color: #fff;
    background-color: #262626;
}

.works__deco{
    width: 56%;
    position: absolute;
    right: 0;
    top: 0;
}

.contactPage {
    padding: min(120px, calc(120 / var(--base-width) * 100vw)) 0;
}

.contactPage__wrap {
    width: 90%;
    max-width: min(747px, calc(747 / var(--base-width) * 100vw));
    margin: auto;
}

.contactPage__row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: min(48px, calc(48 / var(--base-width) * 100vw));
}

.contactPage__label {
    width: min(200px, calc(200 / var(--base-width) * 100vw));
    font-weight: 700;
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0%;
}

.contactPage__label__inner {
    position: relative;
    display: inline-block;
}

.contactPage__label.must .contactPage__label__inner::before {
    content: "必須";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: calc(100% + min(8px, calc(8 / var(--base-width) * 100vw)));
    color: #fff;
    display: inline-block;
    font-size: min(13px, calc(13 / var(--base-width) * 100vw));
    line-height: 1em;
    width: min(48px, calc(48 / var(--base-width) * 100vw));
    height: min(23px, calc(23 / var(--base-width) * 100vw));
    line-height: min(23px, calc(23 / var(--base-width) * 100vw));
    text-align: center;
    background-color: #E60012;
}

.contactPage__content {
    width: calc(100% - min(200px, calc(200 / var(--base-width) * 100vw)));
}

.contactPage__input {
    width: 100%;
    padding: 0 min(16px, calc(16 / var(--base-width) * 100vw));
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    height: min(40px, calc(40 / var(--base-width) * 100vw));
    border: 1px solid #BDBDBD;
}

.contactPage__row--textarea {
    align-items: flex-start;
}

.contactPage__row--textarea .contactPage__label {
    padding-top: min(4px, calc(4 / var(--base-width) * 100vw));
}

.contactPage__textarea {
    width: 100%;
    padding: 0.5em min(16px, calc(16 / var(--base-width) * 100vw));
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    border: 1px solid #BDBDBD;
    height: min(246px, calc(246 / var(--base-width) * 100vw));
}

.contactPage__pri {
    text-align: center;
    margin-bottom: min(30px, calc(30 / var(--base-width) * 100vw));
}

.contactPage__check {
    text-align: center;
    margin-bottom: min(56px, calc(56 / var(--base-width) * 100vw));
    position: relative;
}

.contactPage__check label.error{
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
}

label.error{
    color:red;
}

.contactPage__content{
    position: relative;

}

.contactPage__content label.error{
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
}

.contactPage__send {
    font-weight: 700;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    letter-spacing: 0%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: auto;
    height: min(60px, calc(60 / var(--base-width) * 100vw));
    width: min(280px, calc(280 / var(--base-width) * 100vw));
    border: min(3px, calc(3 / var(--base-width) * 100vw)) solid #262626;
    transition: 0.3s;
}

.contactPage__send:hover {
    background: #262626;
    color: #fff;
}

.thanks {
    position: relative;
}

.thanks__deco {
    position: absolute;
    right: 0;
    top: min(42px, calc(42 / var(--base-width) * 100vw));
    width: 90%;
    z-index: -1;
}

.thanks__wrap {
    padding: min(206px, calc(206 / var(--base-width) * 100vw)) 0 min(102px, calc(102 / var(--base-width) * 100vw));
    text-align: center;
    position: relative;
}

.thanks__ttl {
    font-size: min(80px, calc(80 / var(--base-width) * 100vw));
    line-height: 1em;
    letter-spacing: 0.02em;
    color: #E60012;
    margin-bottom: min(24px, calc(24 / var(--base-width) * 100vw));
}

.thanks__detail {
    text-align: left;
    display: inline-block;
    font-weight: 500;
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 1.7;
    letter-spacing: 0.1em;
    margin-bottom: min(96px, calc(96 / var(--base-width) * 100vw));
}

.thanks__link {
    padding: min(10px, calc(10 / var(--base-width) * 100vw)) min(89px, calc(89 / var(--base-width) * 100vw));
    border: min(3px, calc(3 / var(--base-width) * 100vw)) solid #262626;
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    line-height: min(39px, calc(39 / var(--base-width) * 100vw));
    letter-spacing: 0;
    color: #262626;
    text-align: center;
}

.footer{
    padding: min(100px, calc(100 / var(--base-width) * 100vw)) 0 min(50px, calc(50 / var(--base-width) * 100vw));
    background-color: #262626;
}

.footer__wrap{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 90%;
    max-width: min(1200px, calc(1200 / var(--base-width) * 100vw));
    margin: auto;
}

.footer__left{
    width: min(225px, calc(225 / var(--base-width) * 100vw));
}

.footer__right{
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    gap: min(80px, calc(80 / var(--base-width) * 100vw));
    padding-right: min(225px, calc(225 / var(--base-width) * 100vw));
}

.footer__item{
    margin-bottom: min(40px, calc(40 / var(--base-width) * 100vw));
}

.footer__item:last-child{
    margin-bottom: 0;
}

.footer__link{
    font-size: min(24px, calc(24 / var(--base-width) * 100vw));
    line-height: min(20px, calc(20 / var(--base-width) * 100vw));
    letter-spacing: 0.04em;
    color: #fff;
}

.footer__item__list{
    margin-top: min(16px, calc(16 / var(--base-width) * 100vw));
    padding-left: min(38px, calc(38 / var(--base-width) * 100vw));
}

.footer__item__link{
    display: block;
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: min(20px, calc(20 / var(--base-width) * 100vw));
    letter-spacing: 0.04em;
    color: #fff;
    position: relative;
    margin-bottom: min(12px, calc(12 / var(--base-width) * 100vw));
}

.footer__item__link::before{
    content: "";
    display: inline-block;
    height: min(2px, calc(2 / var(--base-width) * 100vw));
    background-color: #E60012;
    position: absolute;
    width: min(10px, calc(10 / var(--base-width) * 100vw));
    left: min(-20px, calc(-20 / var(--base-width) * 100vw));
    top: 50%;
    transform: translateY(-50%);
}

.footer__item__pri{
    margin-top: min(40px, calc(40 / var(--base-width) * 100vw));
}

.footer__item__pri__link{
    font-size: min(12px, calc(12 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0%;
    color: #fff;
}

.footer__copy{
    color:#6A6A6A;
    font-size: min(12px, calc(12 / var(--base-width) * 100vw));
    width: 90%;
    max-width: min(1200px, calc(1200 / var(--base-width) * 100vw));
    margin: min(90px, calc(90 / var(--base-width) * 100vw)) auto 0;
}

.newsPage__pagination{
    text-align: center;
    margin-top: 67px;
    display: flex;
    justify-content: center;
    gap: min(20px, calc(20 / var(--base-width) * 100vw));
    align-items: center;

}

.page-numbers{
    width: min(36px,calc(36 / var(--base-width) * 100vw));
    height: min(36px,calc(36 / var(--base-width) * 100vw));
    font-size: min(20px, calc(20 / var(--base-width) * 100vw));
    background-color: #818181;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.page-numbers.current{
    background-color: #262626;
}

@media screen and (max-width:1024px) {
   .moviePage__fv{
    padding: 0;
    height: 100svh;
   }

   .moviePage__fv__title{
    position: absolute;
    bottom: calc(47 / var(--base-width) * 100vw);
    left: 30px;
   }


    .webPage__fv{
        background-image: none;
        background-size: contain;
    
    }
    .moviePage__fv::before{
        width: 100%;
        height: 100%;
        background-image: url(./assets/img/moviePage-fv-sp.jpg);
    }

    .webPage__fv::before{
         background-image: url(./assets/img/webPage-fv-sp.jpg);

    }

    .aboutPage__fv__title__main{
        font-size: calc(44 / var(--base-width) * 100vw);
        position: relative;
        line-height: 1.2em;
    }

    .aboutPage__fv__title__main__logo--service{
        width: calc(63 / var(--base-width) * 100vw);
        position: absolute;
        left: calc(161 / var(--base-width) * 100vw);
        top: calc(26 / var(--base-width) * 100vw);
        transform: translateY(-50%);
    }

    .aboutPage__fv__title__main__logo{
        width: calc(63 / var(--base-width) * 100vw);
    }

    .aboutPage__fv__title__main__logo__web{
        left: calc(123 / var(--base-width) * 100vw);
    }

    .aboutPage__fv__title__main__logo--pri{
   position: absolute;
right: calc(116 / var(--base-width) * 100vw);
        top: 24%;
        transform: translateY(-50%);
    }

    .aboutPage__fv__title__sub{
        font-size: calc(16 / var(--base-width) * 100vw);
    }

    .aboutPage__fv{
        padding: calc(180 / var(--base-width) * 100vw) 0 calc(61 / var(--base-width) * 100vw);
    }


    .aboutPage__mission{
        padding: calc(100 / var(--base-width) * 100vw) 0 calc(122 / var(--base-width) * 100vw);
    }

    .moviePage__second {
        margin-top: 0;
        padding: calc(78 / var(--base-width) * 100vw) 0;
        background-color: #F4F4F4;
    }

    .aboutPage__wrap{
        flex-wrap: wrap;
    }

    .aboutPage__left{
        width: 100%;
        padding: 0;
        position: relative;
        z-index: 1;
    }

    .aboutPage__right{
        width: 100%;
        padding: 0;
    }

    .aboutPage__ttl{
        font-size: calc(21 / var(--base-width) * 100vw);
        line-height: calc(44 / var(--base-width) * 100vw);
        letter-spacing: 0.1em;
        margin-bottom: calc(10 / var(--base-width) * 100vw);
        white-space: nowrap;
    }

    .aboutPage__ttl::after{
        width: calc(3.5 / var(--base-width) * 100vw);
        height: calc(30 / var(--base-width) * 100vw);
        position: absolute;
        left: calc(8 / var(--base-width) * 100vw);
        bottom: calc(100% + calc(38 / var(--base-width) * 100vw));
        top: auto;
        transform: translateY(50%);
    }
    .aboutPage__txt {
        margin-top: calc(92 / var(--base-width) * 100vw);
        height: calc(21 / var(--base-width) * 100vw);
        -webkit-animation: bg-slider 92s linear infinite;
        animation: bg-slider 92s linear infinite;
        background-size: auto calc(21 / var(--base-width) * 100vw);
    }

    .message__label{
        width: calc(286.47 / var(--base-width) * 100vw);
    }

    .aboutPage__detail{
        padding-right: calc(30 / var(--base-width) * 100vw);
        font-size: calc(12 / var(--base-width) * 100vw);
        line-height: 2.5em;
    }

    .aboutPage__left__title{
        font-size: calc(28 / var(--base-width) * 100vw);
        letter-spacing: 0;
    }

    .aboutPage__left__text{
        font-size: calc(12 / var(--base-width) * 100vw);
    }

    .aboutPage__right{
        margin-top: calc(22 / var(--base-width) * 100vw);
        padding-top: calc(38 / var(--base-width) * 100vw);
        padding-left: calc(22 / var(--base-width) * 100vw);
    }

    .aboutPage__right::before {
        border: calc(4.4 / var(--base-width) * 100vw) solid #262626;
        left: calc(0 / var(--base-width) * 100vw);
        top: calc(0 / var(--base-width) * 100vw);
        bottom: calc(-25 / var(--base-width) * 100vw);
        right: calc(0 / var(--base-width) * 100vw);
    }


    .message__name{
        margin-top: calc(50 / var(--base-width) * 100vw);
        width: calc(179 / var(--base-width) * 100vw);
    }
    
    .message__ttl{
        margin-bottom: calc(35 / var(--base-width) * 100vw);
    }
    
    .message__detail{
        font-size: calc(16 / var(--base-width) * 100vw);
    }
    
    .message__deco{
        width: 100%;
    }
    
    .profile::before{
        height: calc(70 / var(--base-width) * 100vw);
        bottom: calc(276 / var(--base-width) * 100vw);
    }
    
    .profile::after{
        height: calc(276 / var(--base-width) * 100vw);
    }
    
    .profile__right__item{
        padding: calc(20 / var(--base-width) * 100vw) 0;
        flex-wrap: wrap;
    }
    
    .profile__right__item__ttl{
        font-size: calc(16 / var(--base-width) * 100vw);
        color: #818181;
        width: 100%;
        margin-bottom: calc(8 / var(--base-width) * 100vw);
    }
    
    .profile__right__item__text{
        font-size: calc(16 / var(--base-width) * 100vw);
        width: 100%;
    }
    
    .profile__left{
        margin-bottom: calc(31 / var(--base-width) * 100vw);
        width: 100%;
        padding: 0;
    }
    
    .profile__ttl{
        font-size: calc(28 / var(--base-width) * 100vw);
    }
    
    .profile__sub{
        font-size: calc(12 / var(--base-width) * 100vw);
    }
    
    .profile__wrap{
        padding: calc(75 / var(--base-width) * 100vw) 0 calc(150 / var(--base-width) * 100vw);
        flex-wrap: wrap;
    }
    
    .profile__right{
        width: 100%;
    }
    
    .moviePage__second__text{
        font-size: calc(14 / var(--base-width) * 100vw);
        line-height: 2.5em;
    }
    
    .aboutPage__txt--moviePage{
        margin-top: calc(40 / var(--base-width) * 100vw);
        height: calc(42 / var(--base-width) * 100vw);
        background-size: auto calc(42 / var(--base-width) * 100vw);
        -webkit-animation: bg-slider 70s linear infinite;
    }
    .point__wrap{
        padding: 0;
    }
    
    .point{
        padding: calc(80 / var(--base-width) * 100vw) 0;
        background: url("./assets/img/point-back-sp.png");
    }

    .point--web{
        background: url("./assets/img/point-back-web-sp.png");
    }
    
    .point__ttl{
        font-size: calc(32 / var(--base-width) * 100vw);
        line-height: 1em;
    }
    
    .point__sub{
        font-size: calc(16 / var(--base-width) * 100vw);
        line-height: 1em;
        margin-top: calc(10 / var(--base-width) * 100vw);
    }
    
    .point__main{
        margin-top: calc(40 / var(--base-width) * 100vw);
    }
    
    .point__label{
        border: calc(2 / var(--base-width) * 100vw) solid rgba(255, 255, 255, 1);
        padding: calc(26 / var(--base-width) * 100vw) 0;
        font-size: calc(16 / var(--base-width) * 100vw);
        line-height: 1.35em;
        letter-spacing: 0.06em;
    }

    .point__label--second{
           font-size: calc(14 / var(--base-width) * 100vw);

    }

    .contact__link::before{
        display: none;
    }
    
    .point__close{
        width: calc(44 / var(--base-width) * 100vw);
        height: calc(44 / var(--base-width) * 100vw);
        position: relative;
        margin: calc(12 / var(--base-width) * 100vw) auto;
    }
    
    .point__close::before,
    .point__close::after{
        width: calc(62 / var(--base-width) * 100vw);
        height: calc(2 / var(--base-width) * 100vw);
    }
    
    .movieService{
        padding: calc(80 / var(--base-width) * 100vw) 0;
    }
    
    .movieService__ttl{
        font-size: calc(32 / var(--base-width) * 100vw);
        margin-bottom: calc(10 / var(--base-width) * 100vw);
    }
    
    .aboutPage__fv__title__sub{
        font-size: calc(16 / var(--base-width) * 100vw);
    }
    
    .movieService__list{
        margin-top: calc(40 / var(--base-width) * 100vw);
        gap: calc(36 / var(--base-width) * 100vw);
    }
    
    .movieService__item{
        width: 100%;
    }
    
    .movieService__txt{
        padding: calc(16 / var(--base-width) * 100vw);
    }
    
    .movieService__item__ttl{
        font-size: calc(20 / var(--base-width) * 100vw);
        margin-bottom: calc(8 / var(--base-width) * 100vw);
    }

    .movieService__item__text{
        font-size: calc(12 / var(--base-width) * 100vw);
    }
    
    .movie__goods{
        margin-top: calc(80 / var(--base-width) * 100vw);
    }
    
    .movie__goods__ttl{
        font-size: calc(20 / var(--base-width) * 100vw);
        margin-bottom: calc(17 / var(--base-width) * 100vw);
        padding-bottom: 0;
    }
    
    .movie__goods__item{
        width: 100%;
        padding: calc(20 / var(--base-width) * 100vw) 0;
    }
    
    .movie__goods__label{
        font-size: calc(16 / var(--base-width) * 100vw);
        margin-bottom: calc(8 / var(--base-width) * 100vw);
    }
    
    .movie__goods__detail{
        font-size: calc(12 / var(--base-width) * 100vw);
    }
    
    .flow{
        padding: calc(80 / var(--base-width) * 100vw) 0;
        background: linear-gradient(to bottom,#F4F4F4 0%,#F4F4F4 calc(274 / var(--base-width) * 100vw),#fff calc(274 / var(--base-width) * 100vw),#fff 100%)  ;
    }
    
    .flow__ttl{
        font-size: calc(32 / var(--base-width) * 100vw);
        line-height: 1em;
        margin-bottom: calc(10 / var(--base-width) * 100vw);
    }
    
    .flow__sub{
        font-size: calc(16 / var(--base-width) * 100vw);
        line-height: 1em;
        margin-bottom: calc(40 / var(--base-width) * 100vw);
    }
    
    .flow__list{
        flex-wrap: wrap;
        width: calc(237 / var(--base-width) * 100vw);
        margin: auto;
        gap: calc(36 / var(--base-width) * 100vw);
    }
    
    .flow__item{
        width: 100%;
    }

    .worksPage{
        padding-top: calc(80 / var(--base-width) * 100vw);
        padding-bottom: calc(150 / var(--base-width) * 100vw);
    }
    
    .worksPage__left{
        width: 100%;
    }
    
    .worksPage__right{
        width: 100%;
        padding: 0;
    }
    
    .worksPage__nav{
        margin-bottom: calc(39 / var(--base-width) * 100vw);
    }
    
    .worksPage__item{
        gap: calc(16 / var(--base-width) * 100vw);
        margin-bottom: calc(36 / var(--base-width) * 100vw);
    }
    
    .worksPage__cate{
        gap:calc(5 / var(--base-width) * 100vw) calc(3.4 / var(--base-width) * 100vw);
        margin-bottom: calc(8 / var(--base-width) * 100vw);
    }
    
    .worksPage__title{
        font-weight: 700;
        font-size: calc(18 / var(--base-width) * 100vw);
        line-height: 100%;
        letter-spacing: 0.14em;
        margin-bottom: calc(16 / var(--base-width) * 100vw);
    }
    
    .worksPage__pagenation{
        margin-top: calc(68 / var(--base-width) * 100vw);
    }
    
}

.header {
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    padding: 0 57px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 10;
    mix-blend-mode: difference;
}

.header__title{
    mix-blend-mode: difference;
}

.header__logo {
    width: 79px;
  
}

.header__deco{
    position: fixed;
    left: 99px;
    top: 30.5px;
    width: 11px;
    z-index: 10;
}


.header__title{
    position: fixed;
    left: 57px;
    top: 0px;
    height: 72px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    z-index: 11;
}

.header__button{
    display: flex;
    align-items: center;
}

.header__list{
    display: flex;
    align-items: center;
    justify-content: flex-end
}

.header__item{
    position: relative;
    display: flex;
    align-items: center;
    padding: min(14px, calc(14 / var(--base-width) * 100vw)) 0;
}


.header__item__nav{
    position: fixed;
    top: 100%;
    padding: min(20px, calc(20 / var(--base-width) * 100vw)) 0;
    background: #fff;
    padding: 10px;
    z-index: 9999;
    width: 220px;
    display: none;
}

.header__item__nav__link{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    color: #000;
    white-space: nowrap;
    margin-bottom: min(10px, calc(10 / var(--base-width) * 100vw));
    position: relative;
}

.header__item__nav__link:last-child{
    margin-bottom: 0;
}

.header__item__nav__link::before{
    content: "";
    display: inline-block;
    width: 0%;
    height: min(2px, calc(2 / var(--base-width) * 100vw));
    background: #000;
    position: absolute;
    left: 0;
    bottom: -5px;
    transition: 0.3s;
    transition-timing-function: ease-in-out;
}

.header__item__nav__link:hover::before{
    width: 100%;
}



.header__link{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 100%;
    letter-spacing: 0.03em;
    color: #fff;
    mix-blend-mode: difference;
    position: relative; 
    cursor: pointer;   
    padding: min(14px, calc(28 / var(--base-width) * 100vw)) min(20px, calc(20 / var(--base-width) * 100vw)); 
}

.header__link::before{
    content: "";
    width: 0;
    height: min(2px, calc(2 / var(--base-width) * 100vw));
    background: #fff;
    position: absolute;
    left: 0;
    bottom: 0;
    transition: 0.3s;
    transition-timing-function: ease-in-out;
}

.header__link:hover::before{
    content: "";
    width: 100%;
    background: #fff;
    position: absolute;
    left: 0;
    bottom: 0;
}
.moviePage__second{
    position: relative;
}

.moviePage__deco{
    width: min(1083px, calc(1083 /  var(--base-width) * 100vw));
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: 0;
}

.newsSingle__wrap{
    width: 90%;
    max-width: min(864px, calc(864 / var(--base-width) * 100vw));
    margin: auto;
    padding: min(120px , calc(120 / var(--base-width) * 100vw)) 0;
}

.newsSingle__info{
    display: flex;
    align-items: center;
    gap: min(16px, calc(16 / var(--base-width) * 100vw));
    margin-bottom:  min(16px, calc(16 / var(--base-width) * 100vw));
}

.newsSingle__date{
    font-size: min(18px , calc(18/ var(--base-width) * 100vw));
    color: #8E8E8E;
}

.newsSingle__ttl{
    font-size: min(24px, calc(24 / var(--base-width) * 100vw));
    margin-bottom: min(24px, calc(24 / var(--base-width) * 100vw));
}

.newsSingle__content img{
    margin-bottom: min(36px, calc(36 / var(--base-width) * 100vw));
    max-width: 100%;
    width: auto;
}

.newsSingle__content p{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    line-height: 1.8em;
}

.newsSingle__btn{
    text-align: center;
    margin-top: min(48px, calc(48 / var(--base-width) * 100vw));
}

.privacy__wrap{
    width: 90%;
    max-width: 1000px;
    margin: min(120px, calc(120 / var(--base-width) * 100vw)) auto;

}

.privacy__bold{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    font-weight: 700;
    margin-bottom: min(8px, calc(8 / var(--base-width) * 100vw));
}

.privacy__detail{
    font-size: min(16px, calc(16 / var(--base-width) * 100vw));
    margin-bottom: min(24px, calc(24 / var(--base-width) * 100vw));
    line-height: 1.5em;
}

.privacy__detail b{
    display: block;
    font-weight: 600;
    margin-bottom: min(4px, calc(4 / var(--base-width) * 100vw));
}

@media screen and (max-width:1024px) {
    .header__link{
        font-size: 14px;
    }
    .header__item{
        padding: 17px 0;
    }
}

@media screen and (max-width:1024px) {
    .header{
        padding: 0 calc(36 / var(--base-width) * 100vw);
        top: 33px;
    }
    .header__nav{
        display: none;
    }
    .sp-hum {
        display: block;
    }

    .header-hum {
        display: block;
    }

    .header-hum__wrap {
        position: relative;
        display: block;
        width: 30px;
        height: 17px;
    }

    .header-hum__wrap.open {
        height: 23px;
    }

    .sp-header-nav {
        position: fixed;
        width: 100%;
        left: 0;
        top: 0;
        padding: 0 5%;
        background: #262626;
        height: 100vh;
        overflow: scroll;
        transition: 0.3s;
        transition-property: height, padding;
        z-index: 11;
        align-items: center;
        justify-content: center;
    }

    .sp-header-nav__close{
        position: absolute;
       top: 27px;
        right: 30px;
        width: 30px;
        height: 30px;
        background: #262626;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .sp-header-nav__close::before{
        content: "";
        width: 20px;
        height: 2px;
        background: #fff;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%) rotate(45deg);
    }

    .sp-header-nav__close::after{
        content: "";
        width: 20px;
        height: 2px;
        background: #fff;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%) rotate(-45deg);
    }

    .header-nav__link {
        padding: calc(20 / var(--base-width) * 100vw) 0;
        width: 100%;
        color: #fff;
        text-align: center;
        font-size: calc(18 / var(--base-width) * 100vw);
        letter-spacing: 0.03em;
    }

    .header-hum__line {
        display: block;
        margin: auto;
        width: 100%;
        height: 2px;
        background: #fff;
        transition: 0.3s;
        position: absolute;
    }

    .header-hum__line--top {
        top: 0;
        left: 0;
        transform: translateY(0%);
    }

    .header-hum__line--top.open {
        top: 0;
        left: 0;
        transform: translateY(0%) rotate(-45deg);
        transform-origin: right;
    }

    .header-hum__line--center {
        top: 50%;
        left: 0;
        transform: translateY(-50%);
    }

    .header-hum__line--under {
        bottom: 0;
        left: 0;
        transform: translateY(0%);
    }

    .header-hum__line--center.open {
        opacity: 0;
    }

    .header-hum__line--under.open {
        bottom: 0;
        left: 0;
        transform: translateY(0%) rotate(45deg);
        transform-origin: right;
    }

    .footer__wrap{
        flex-wrap: wrap;
    }

    .footer__left{
        width: calc(178 / var(--base-width) * 100vw);
        margin-bottom: calc(50 / var(--base-width) * 100vw);
    }

    .footer__right{
        padding: 0;
        flex-wrap: wrap;
        gap: calc(20 / var(--base-width) * 100vw);
    }

    .footer__list{
        width: 100%;
    }

    .footer__item {
        margin-bottom: calc(20 / var(--base-width) * 100vw);
    }

    .footer__link {
        font-size: calc(20 / var(--base-width) * 100vw);
        letter-spacing: 0.03em;
    }
    .footer__item__list {
        margin-top: calc(12 / var(--base-width) * 100vw);
        padding-left: calc(34 / var(--base-width) * 100vw);
    }

    .footer__item__link {
        font-size: calc(12 / var(--base-width) * 100vw);
    }
    .footer__item__pri {
        margin-top: calc(20 / var(--base-width) * 100vw);
    }
    .footer__copy {
        margin: calc(60 / var(--base-width) * 100vw) auto 0;
    }
    .header__button{
        display: flex;
        align-items: center;
    }


    .contactPage__row{
        flex-wrap: wrap;
        margin-bottom: 20px;
    }

    .contactPage__label{
        width: 100%;
        margin-bottom: 10px;
    }

    .contactPage__content{
        width: 100%;
    }

    .contactPage__pri{
        font-size: 12px;
    }

    .contactPage__send,
    .thanks__link {
        font-size: calc(14 / var(--base-width) * 100vw);
        height: calc(50 / var(--base-width) * 100vw);
        width: calc(230 / var(--base-width) * 100vw);
        border: calc(2 / var(--base-width) * 100vw) solid #262626;
        padding: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        margin: auto;
        transition: 0.3s;
    }

    .contactPage{
        padding: 60px 0 ;
    }

    .thanks__deco{
        z-index: -1;
    }

    .thanks__wrap{
        width: 90%;
        margin: auto;
        padding: 90px 0;
    }

    .thanks__ttl{
        font-size: 36px;
    }

    .thanks__detail{
        font-size: 14px;
        margin-bottom: 45px;
    }
    .message__wrap{
        padding-top: 0;
    }

    .message{
        padding-top: calc(50 / var(--base-width) * 100vw);
    }
    .message__wrap{
        padding-bottom: calc(120 / var(--base-width) * 100vw);
    }

    .moviePage__deco{
        width: 84%;
    }
    .newsSingle__info{
        margin-bottom: calc(12 / var(--base-width) * 100vw);

    }
    .newsSingle__ttl {
        font-size: calc(20 / var(--base-width) * 100vw);
        margin-bottom: calc(18 / var(--base-width) * 100vw);
    }
    .newsSingle__wrap{
        padding: calc(80 / var(--base-width) * 100vw) 0;
    }
    .newsSingle__content img {
        margin-bottom: calc(18 / var(--base-width) * 100vw);
    }
    .newsSingle__content p {
        font-size: calc(14 / var(--base-width) * 100vw);
        line-height: 1.8em;
    }

    .privacy__bold{
        line-height: 1.4em;
    }

    .privacy__detail{
        line-height: 2em;
    }

    .privacy__wrap{
        margin: calc(60 / var(--base-width) * 100vw) auto;
    }

    .news__link--page{
        padding-right: 0;
    }
    .news__cate{
        margin: 0;
        font-size:calc(12 / var(--base-width) * 100vw);
        padding: calc(5 / var(--base-width) * 100vw) calc(10 / var(--base-width) * 100vw);
    }
    .news__detail--page{
        width: 100%;
    }
    .newsPage,
    .newsSingle__wrap{
        padding-bottom: calc(150 / var(--base-width) * 100vw);
    }
    .worksPage::after{
        background-image: url("./assets/img/worksPage-deco2-sp.png");
        height: calc(556 / var(--base-width) * 100vw);
        bottom: calc(188 / var(--base-width) * 100vw);
    }

    .header__title{
        height: auto;
        left:35px;
        top: 15px;
    }
    .header__deco {
        /* position: fixed;
        left: 66px;
        top: 27px;
        width: 11px;
        z-index: 10; */
        top: 31px;
        left: 75px;
    }
    
    .works__deco{
        width: 90%;
        top: calc(140 / var(--base-width) * 100vw);
    }

    .aboutPage__fv__title__main{
        gap: calc(12 / var(--base-width) * 100vw);
        font-size: calc(34 / var(--base-width) * 100vw);
    }

    .aboutPage__fv__title__main--white{
        font-size: calc(44 / var(--base-width) * 100vw);
        color: #fff;
    }

    .viewmore:hover{
        background: #000;
            background-size: 200% 100%;
    background-position: right center;
    -webkit-background-clip: text;
    }

    .viewmore .viewmore__line{
        background: #000 !important;
    }
    .news__date--page{
        width: auto;
        font-size: calc(14 / var(--base-width) * 100vw);
        margin-right: 10px;
        display: inline-block;
        margin-bottom: 0;
    }

    .news__link--page .news__left{
        align-items: center;
    }
   .news__detail--page{
    margin-top: 5px;
   }
   .worksPage__text{
    font-size: calc(12 / var(--base-width) * 100vw);
    line-height: calc(19 / var(--base-width) * 100vw);
    }
    .worksPage__companyName{
            font-size: calc(12 / var(--base-width) * 100vw);
    }
}

img.alignnone,
img.alignleft,
img.aligncenter,
img.alignright {
  max-width: 100%;
  height: auto;
  display: block;
}

/* 左寄せ */
img.alignleft {
  float: left;
  margin-right: 1.5em;
  margin-bottom: 1em;
}

/* 右寄せ */
img.alignright {
  float: right;
  margin-left: 1.5em;
  margin-bottom: 1em;
}

/* 中央寄せ */
img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1em;
}

.worksPage__nav__item.disabled {
  pointer-events: none;
  cursor: not-allowed;
}