/*
Theme Name: 荒木商店1202
Theme URI:
Version: 1.0
Author: takami
Author URI: https://yoshida-designbu.com/
License: takami
*/


 /*----------
 common
 ----------*/
*,*::after,*::before{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html{
    font-size: 62.5%;
}

body{
    font-size: min(3.6vw);
    font-family: "Zen Old Mincho", 'YuMincho', 'Yu Mincho', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'メイリオ', 'Meiryo', 'ＭＳ ゴシック', serif;
    line-height: 1.8;
    letter-spacing: 0.01em;
    color: var(--c-white);
    background-color: var(--c-navy);
    background-image: url(img/bg.webp);
    background-repeat: repeat;
    background-size: 80%;
    background-attachment: fixed;
    -webkit-background-attachment: fixed;
    font-weight: 500;
    position: relative;
    z-index: 1;
}
body::before{
    position: fixed;
    content: "";
    background: url(img/pc-bg-deco.webp);
    background-attachment: fixed;
    -webkit-background-attachment: fixed;
    background-repeat: no-repeat;
    background-size: 100%;
    width: 100%;
    height: 100%;
    background-position: center 98%;
    bottom: 0;
    left: 0;
    z-index: 1;
    display: none;
}

:root{
    --c-black:#000;
    --c-white:#fefefe;
    --c-orange:#db4f2e;
    --c-gold:#dbbc75;
    --c-yellow:#fcf050;
    --c-navy:#17284d;
    --blur: 2rem;
    --size: 12rem;
    --box-blur: calc(0.5 * var(--blur));
    --b-dashed:dashed 1px var(--c-dBrown);
    --b-brown:solid 2px var(--c-dBrown);
    --font-224rem:min(2.24rem,4.83vw);
    --font-183rem:min(4vw);
    --font-14rem:min(1.3rem,3.24vw);
    --section-margin:min(8rem,16vw);
    --ps-margin:min(32px,6.5vw);
    --transition:.8s cubic-bezier(.215, .61, .355, 1);
    --transition2:.6s cubic-bezier(.215, .61, .355, 1);
    --cha-contents-width: min(530px,35vw);
}

li{
    list-style: none;
}

a{
	text-decoration:none;
    color: var(--c-white);
    position: relative;
    transition: .6s ease-out;
}

img{
    max-width:100%;
    height: auto;
    box-sizing: border-box;
    vertical-align: bottom;
}

table{
    clear: both;
    border-collapse: collapse;
    width: 100%;
}

th{
    padding: 12px 0 12px 12px;
    vertical-align: top;
}

td{
    padding: 12px;
}

.contents{
    margin: 0 4%;
}

.contents-wrapper{
    position: relative;
}

/*--404--*/
.notFound{
    margin: min(32vw, 10rem) 0 min(10vw, 5rem);
    text-align: center;
}

.notFound h2{
    width: min(70%);
    margin: 0 auto;
}

.notFound h2 span{
    display: block;
    padding-top: min(1.4rem);
}

.notFound p{
    padding: min(3rem, 6vw) 0;
}

.notFound a{
    text-decoration: underline;
}

/*--thumbnail--*/
.thumbnail {
    position: relative;
    display: block;
    overflow: hidden;
    padding-top: 62.25%;
}
.thumbnail img{
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: var(--transition);
}

/*--title--*/
.contents-title{
    text-align: center;
}

.contents-title:has(span.contents-title_item){
    display: flex;
    gap: min(4vw);
}

.contents-title>span.contents-title_item{
    width: 50%;
}

/*--linkBox--*/
.linkBox{
    border: min(0.3rem, .7vw) solid var(--c-black);
    border-radius: 9999px;
    color: var(--c-white);
    display: block;
    text-align: center;
    width: 80%;
    margin: auto;
    padding: min(3vw);
    font-weight: 600;
    text-transform: uppercase;
}

.linkBox span{
    width: min(48vw, 17rem);
    display: block;
    margin: 0 auto;
    position: relative;
    padding-right: min(2.4rem, 6vw);
}
.linkBox span img{
    display: block;
}

.linkBox svg{
    fill: var(--c-black);
    display: block;
    transition: var(--transition);
}

.linkBox span::before{
    position: absolute;
    content: "";
    vertical-align: middle;
    color: var(--c-black);
    line-height: 1;
    width: 0;
    height: 0;
    border-style: solid;
    border-color: transparent;
    border-width: min(1rem, 2.4vw) min(1.5rem, 3.4vw);
    border-left-color: currentColor;
    border-right: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}

.links-wrapper{
    margin-top: min(3rem,6vw);
}

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

.noLinks{
    opacity: .4;
}
.noLinks:hover{
    transform: none;
}

/*--bread--*/
.breadcrumbs{
    font-size: min(1.2rem, 2.8vw);
    margin: min(1rem,2vw);
    text-align: left;
    color: var(--c-white);
}

.breadcrumbs span{
    padding: 0 2px;
    font-weight: 500;
    color: var(--c-white);
    letter-spacing: 0;
}

.breadcrumbs a{
    color: var(--c-white);
    text-decoration: underline;
}

#page-top {
    position: absolute;
    top: 2%;
    right: min(32px, 3vw);
    width: min(9rem, 16vw);
    z-index: 2;
}

#page-top a{
    display: block;
}

#page-top a:hover{
    transform: translateY(-6%);
}


/*---- youtube/googleMap -----*/
.youtube{
    position:relative;
    width:100%;
    padding-top:56.25%;
}

.youtube iframe{
    position:absolute;
    top:0;
    right:0;
    width:100%;
    height:100%;
}


/*--- animation ---*/

.fade-in2,
.menu-scrollFallIn{
    opacity: 0;
}

.fade-in2.is-active{
    animation: fadeInPopup .4s cubic-bezier(0.34, 1.56, 0.64, 1) .5s forwards;
}
@keyframes fadeInPopup {
    0%{
        transform: translate(0, 10px);
    }
    60%{
        transform: translate(0, -8px);
        opacity: 1;
    }
    100%{
        transform: translate(0, 0);
        opacity: 1;
    }
}

.scroll-contents{
    opacity: 0;
    transform: translate(0, -6%);
    -webkit-transform: translate(0, -6%);
}

.scroll-contents.is-active{
    opacity: 1;
    transform: translate(0, 0%);
    -webkit-transform: translate(0, 0%);
    transition: opacity .8s .3s ease-out, transform .8s .3s ease-out;
    -webkit-transition: opacity .8s .3s ease-out, transform .8s .3s ease-out;
}

.scroll-SVGtitle span.contents-title_item{
    opacity: 0;
    filter: blur(2px);
    transform: translateY(-5%);
}
.scroll-SVGtitle.is-active span.contents-title_item{
    opacity: 1;
    filter: blur(0);
    transform: translateY(0%);
    transition: transform 1.5s calc(2s * var(--delay)) cubic-bezier(.215, .61, .355, 1), filter 1.5s calc(.6s * var(--delay)) cubic-bezier(.215, .61, .355, 1), opacity 1.5s calc(2s * var(--delay)) cubic-bezier(.215, .61, .355, 1);
}

.scroll-picture img{
    transform: scale(1.1);
    filter: blur(2px);
    opacity: 0;
}
.scroll-picture.is-active img{
    opacity: 1;
    filter: blur(0);
    transform: scale(1);
    transition: opacity 1.5s .3s cubic-bezier(.215, .61, .355, 1), filter 1.5s .6s cubic-bezier(.215, .61, .355, 1), transform 1.5s .5s cubic-bezier(.215, .61, .355, 1);
}

picture.scroll-picture{
    overflow: hidden;
    display: block;
}

/*--SVG--*/
@media screen and (min-width:1024px){
    /*--svg--*/
    #page-top{
        width: min(90px, 5vw);
            top: 4%;
    }
}

@media screen and (min-width:769px){
    body::before{
        display: block;
    }

    /*--linkBox--*/
    .linkBox {
        transition: var(--transition);
        padding: min(1.5rem);
    }

    .contents-title:has(span.contents-title_item){
        gap: min(2rem,4vw);
    }

}


/*----------
  Header
----------*/
#js-top {
    opacity: 0;
    position: fixed;
    z-index: 3;
    transition: var(--transition);
    visibility: hidden;
    width: 100%;
}

#js-top.is-show {
    opacity: 1;
    transition: var(--transition);
    visibility: visible;
}

/*----------*/
/* hamburger
/*----------*/
.openbtn{
    cursor: pointer;
    position: relative;
    z-index: 200;
    transition: var(--transition);
    width: min(13vw, 8rem);
    height: 3vw;
}

.openbtn.active::before{
    background: url(img/title-close.png) no-repeat center;
    background-size: 100%;
}

.openbtn span{
    background: var(--c-white);
    width: 100%;
    height: min(.5vw, .2rem);
    position: absolute;
    left: 0%;
    transition: var(--transition2);
    transform-origin: center;
}

.openbtn span:nth-child(1){
    top: 0;
}
.openbtn span:nth-child(2){
    bottom: 0;
}

.openbtn.active span:nth-child(1){
    transform: rotate(-12deg) translateY(1.4vw);
}
.openbtn.active span:nth-child(2){
    transform: rotate(12deg) translateY(-0.9vw);
}

.g-nav{
    position: fixed;
    z-index: 100;
    top: 0;
    width:100%;
    height: 100svh;
    clip-path: inset(0 0 100% 0);
    transition: clip-path .6s cubic-bezier(0.6, 0, 0.2, 1);
    transform: translateZ(0);
    visibility: hidden;
    background:var(--c-navy);
}
.g-nav::before{
    position: fixed;
    content: "";
    background: url(img/pc-bg-deco.webp) no-repeat bottom;
    background-size: 100%;
    bottom: 3%;
    left: 0;
    width: 190%;
    height: 50vw;
}

#g-nav.panelactive{
    opacity: 1;
    visibility: inherit;
    overflow-x: hidden;
    overflow-y: auto;
    clip-path: inset(0 0 0% 0);
}

.g-nav_wrapper{
    position: relative;
    width: min(80%, 48rem);
    margin: min(22vw, 6rem) auto 0;
    text-align: center;
}

.g-nav_logo{
    width: min(48vw, 25rem);
    margin: 0 auto min(8vw, 4rem);
}

.g-nav_logo>a{
    display: block;
    overflow: hidden;
}
.g-nav_logo>a{
    opacity: 0;
    transform: scale(.9);
    -webkit-transform: scale(.9);
    display: block;
}

#g-nav.panelactive .g-nav_logo>a{
    opacity: 1;
    transform: scale(1);
    -webkit-transform: scale(1);
    transition-delay: .55s;
    transition: var(--transition2);
}

#g-nav li a{
    opacity: 0;
    transform: scale(.9);
    -webkit-transform: scale(.9);
    display: block;
}

#g-nav.panelactive li a{
    opacity: 1;
    transform: scale(1);
    -webkit-transform: scale(1);
}

#g-nav.panelactive li:nth-of-type(1) a{
    transition-delay: .6s;
}
#g-nav.panelactive li:nth-of-type(2) a{
    transition-delay: .65s;
}
#g-nav.panelactive li:nth-of-type(3) a{
    transition-delay: .7s;
}
#g-nav.panelactive li:nth-of-type(4) a{
    transition-delay: .75s;
}
#g-nav.panelactive li:nth-of-type(5) a{
    transition-delay: .8s;
}
#g-nav.panelactive li:nth-of-type(6) a{
    transition-delay: .85s;
}
#g-nav.panelactive li:nth-of-type(7) a{
    transition-delay: .9s;
}

.g-nav_mainMenu{
    display: flex;
    flex-direction: column;
    gap: min(4vw, 2rem);
    font-size: min(4vw, 2rem);
}

.g-nav_mainMenu li.-nav_menuItem{
    width: 82%;
    margin: min(5vw) auto 0;
}

.fixedLogo{
    z-index: 3;
    width: min(24rem, 17vw);
}
.fixedLogo a{
    mix-blend-mode: difference;
}

.fixedMenu{
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: var(--transition);
    padding: min(16px, 3vw) 12px;
    background: linear-gradient(0deg, rgba(23, 40, 77, 0) -2%, rgba(23, 40, 77, 0.95) 80%, rgba(23, 40, 77, 1) 100%);
}

.fixedMenu.is-hidden{
    opacity: 0;
    visibility: hidden;
}

.fixedMenu-wrapper{
    display: flex;
    align-items: center;
    gap: min(8px, 2vw);
}

.fixedIcon{
    position: fixed;
    z-index: 3;
    bottom: min(2vw);
    right: min(3vw);
    display: flex;
    flex-direction: column;
    gap: min(1rem);
}

.fixedIcon .fixedMenu-link{
    text-align: center;
    border-radius: 50%;
    background: var(--c-black);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-weight: 800;
    line-height: 1.3;
    width: min(10rem, 25vw);
    height: min(10rem, 25vw);
    font-size: 114%;
    margin: 0 0 0 auto;
}

#js-fixedIcon{
    opacity: 0;
    position: fixed;
    z-index: 3;
    transition: var(--transition);
    visibility: hidden;
}
#js-fixedIcon.is-show{
    opacity: 1;
    transition: var(--transition);
    visibility: visible;
}

/*----------*/
/* site layout
/*----------*/
main.main-wrapper{
    position: relative;
    width: 100%;
    background-image: url(img/bg.webp);
    background-repeat: repeat;
    background-size: 50%;
    background-attachment: fixed;
}

.site-main {
    background: var(--c-navy);
    box-sizing: border-box;
    overflow: hidden;
    order:2;
    position: relative;/**/
}


/*----------
loading
----------*/
.loading{
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
    z-index: 100;
    overflow: hidden;
    background: var(--c-black);
}

.loading-wrapper{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(63vw);
    height: min(25vw);
}

/*----------*/
/* KV
/*----------*/
.kv{
    z-index: 1;
    position: relative;
    height: 100svh;
    min-height: 600px;
    max-height: 200vw;
}

picture.kv-main{
    height: 100svh;
    min-height: 600px;
    max-height: 200vw;
    display: block;
    position: relative;
    z-index: -2;
    overflow: hidden;
}
picture.kv-main img{
    position: absolute;
    bottom: 0;
    transition: var(--transition);
    opacity: 0;
    filter: blur(6px);
    transform-origin: center;
    transform: scale(1.2);
    animation: KV-mainAnim 2.5s cubic-bezier(.215, .61, .355, 1) .4s forwards;
}

@keyframes KV-mainAnim {
    0%{
        opacity: 0;
        filter: blur(6px);
        transform: scale(1.2);
    }
    100%{
        opacity: 1;
        filter: blur(0);
        transform: scale(1);
    }
}


.kv-textWrap{
    position: absolute;
    top: 4%;
    left: 6%;
    opacity: 0;
    filter: blur(2px);
    transform: translateY(-5%);
    animation: KV-fallIn 1.5s cubic-bezier(.215, .61, .355, 1) calc(var(--delay) * 1.2s) forwards;
}
.kv-textWrap>p{
    line-height: 2;
    text-shadow: var(--c-black) 1px 0 6px;
    font-weight: 600;
    font-size: min(1.83rem,3.4vw);
}
.kv-textWrap>.kv-textWrap_logo{
    width: min(41%);
    margin-bottom: min(3vw, 6%);
}

.svg-or{
    fill: var(--c-orange);
}
.svg-wh{
    fill:var(--c-white);
}

.kv-copy{
    position: absolute;
    top: 4%;
    right: 8%;
    width: min(27%, 15rem);
}
.kv-copy h2{
    display: flex;
    gap: min(3vw, 3rem);
}
.kv-copy h2 span{
    position: relative;
    opacity: 0;
    filter: blur(2px);
    transform: translateY(-5%);
    animation: KV-fallIn 2.5s cubic-bezier(.215, .61, .355, 1) calc(var(--delay) * 1.5s) forwards;
}
.kv-copy h2 span::before{
    position: absolute;
    content: "";
    background: var(--c-gold);
    width: .4vw;
    height: 100%;
    top: 0;
    right: -15%;
}
.kv-copy h2 span:nth-child(1){
    width: 50%;
}
.kv-copy h2 span:nth-child(2){
    width: 41%;
}

@keyframes KV-fallIn {
    0%{
        opacity: 0;
        filter: blur(2px);
        transform: translateY(-5%);
    }
    100%{
        opacity: 1;
        filter: blur(0);
        transform: translateY(0);
    }
}

.kv-title{
    position: absolute;
    bottom: 0;
    left: 4%;
    width: 66%;
    filter: blur(3px);
    opacity: 0;
    animation: KV-blur 2s cubic-bezier(.215, .61, .355, 1) 2s forwards;
}
.kv-title p{
    width: 52%;
}
.kv-title>h2{
    position: relative;
    left: -5%;
}

@keyframes KV-blur {
    0%{
        filter: blur(3px);
        opacity: 0;
    }
    100%{
        filter: blur(0);
        opacity: 1;
    }
}

.kv-image{
    position: absolute;
    bottom: -4%;
    right: -18%;
    width: 80%;
    z-index: -1;
}
.kv-image .shapeImage>img{
    animation: KV-blurImg 2s cubic-bezier(.215, .61, .355, 1) 2.05s forwards;
    transform: scale(1.1);
    filter: blur(2px);
    opacity: 0;
}

@keyframes KV-blurImg {
    0%{
        transform: scale(1.1);
        filter: blur(2px);
        opacity: 0;
    }
    100%{
        transform: scale(1);
        filter: blur(0);
        opacity: 1;
    }
}


@media screen and (min-width:521px){
    picture.kv-main img{
        bottom: -8%;
    }
}

@media screen and (min-width:769px){
    #js-top{
        width: min(612px, 100%);
    }

    /*----------*/
    /* Gnav
    /*----------*/
    .fixedMenu{
        display: none;
    }

    .g-nav{
        display: none;
    }

    .fixedIcon .fixedMenu-link:hover{
        transform: scale(.95);
    }

    /*----------*/
    /* Loading
    /*----------*/
    .loading-wrapper{
        width: min(43rem, 42vw);
        height: min(19rem, 19vw);
    }

    /*----------*/
    /* KV
    /*----------*/
    .kv,picture.kv-main{
        max-height: 730px;
    }

    .kv-copy{
        width: 27%;
    }
    .kv-copy h2{
        gap: min(10%);
    }
    .kv-copy h2 span::before{
        width: min(.2rem);
        right: -8%;
    }

    .kv-textWrap>p{
        font-size: 84%;
    }
}


@media screen and (min-width:1024px){
    #js-top{
        width: var(--cha-contents-width);
    }

    .fixedInformation a:hover img,
    .openbtn:hover,
    .fixedLogo a:hover{
        transform: scale(1.06);
    }

    .fixedLogo{
        width: min(170px, 34vw);
    }

    /*----------*/
    /* KV
    /*----------*/
    .kv{
        max-height: 914px;
    }
    picture.kv-main{
        max-height: 914px;
    }
    picture.kv-main img{
        bottom: 0%;
    }
    .kv-textWrap>p{
        font-size: min(1.6rem,3.4vw);
    }

}

/*----------*/
/* side content
/*----------*/
.fixed{
    position: fixed;
}

.pcMainImage{
    position: relative;
}

.site-sideLeft{
    position: sticky;
    top: 0;
    height: 100svh;
    overflow: hidden;
    z-index: 1;
    display: none;
    opacity: 0;
    transition: var(--transition);
    opacity: 0;
    transition: var(--transition);
    transform: scale(.9);
}

.site-sideRight{
    order: 3;
    position: sticky;
    top: 0;
    overflow: hidden;
    z-index: 1;
    display: none;
    opacity: 0;
    transform: translate(0, -4%);
    -webkit-transform: translate(0, -4%);
}

.site-sideLeft,
.site-sideRight{
    opacity: 0;
    filter: blur(2px);
    transform: translateY(-5%);
    animation: KV-fallIn 2s cubic-bezier(.215, .61, .355, 1) calc(var(--delay) * 1.2s) forwards;
}

@media screen and (min-width:769px){
    .site-main{
        width: min(420px, 100%);
        margin-left: min(5rem);
    }

    .site-sideRight{
        width: calc(calc(100% + min(5rem)) - min(420px, 100%));
        height: 100dvh;
        display: block;
    }

    .site-sideRight_menuList{
        position: absolute;
        width: min(77%, 46rem);
        margin-left: min(3vw);
        top: 50%;
        transform: translateY(-50%);
    }

    .site-sideRight_menuList ul{
        display: flex;
        flex-direction: column;
        gap: min(1rem);
        font-size: var(--font-183rem);
    }
    .site-sideRight_menuList ul li span{
        position: relative;
        padding-left: 3rem;
    }
    .site-sideRight_menuList ul li span::before{
        position: absolute;
        content: "";
        background: url(img/diamond.svg) no-repeat center;
        background-size: 100%;
        width: 2.4rem;
        height: 2rem;
        top: 50%;
        left: 0;
        transform: translate(0%, -50%);
    }

    .site-sideRight_menuList ul a:hover{
        position: relative;
        opacity: .5;
    }

    #js-fixedIcon.fixedIcon{
        width: calc(min(420px, 100%) - 9%);
    }

    .fixedIcon{
        left: min(7rem);
    }
}

@media screen and (min-width:1024px){
    .site-main{
        z-index: 2;
        position: relative;
        width: var(--cha-contents-width);
        margin-left: 0;
    }

    .site-sideRight {
        width: calc((100% - var(--cha-contents-width)) / 2);
        height: 100dvh;
        display: block;
    }

    .site-sideLeft{
        width: calc((100% - var(--cha-contents-width)) / 2);
        display: block;
    }

    .site-sideLeft>.pc-logo{
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%);
        width: min(29rem, 20vw);
    }

    #js-fixedIcon.fixedIcon{
        width: calc(var(--cha-contents-width) - 3%);
    }

    .fixedIcon{
        transform: translateX(-50%);
        left: 50%;
        bottom: min(2rem);
    }
}

/*----------*/
/* main contents
/*----------*/
/*-- road bg --*/
.roadBg-main{
    position: relative;
    margin-top: max(-140px, -60%);
}
.roadBg-main::before{
    position: absolute;
    content: "";
    background: url(img/index-bg.png) no-repeat top;
    background-size: 100%;
    width: 100%;
    height: 100%;
}


/*----------*/
/* concept
/*----------*/
.concept{
    margin: min(13%) 0 calc(var(--section-margin) / 2);
}

.concept-contents p{
    margin: 0 8%;
}

.concept-contents_main{
    display: flex;
    align-items: center;
    flex-direction: row-reverse;
    margin-right: 8%;
    margin-bottom: calc(var(--section-margin) / 3);
}

.concept-contents_main h2.contents-title{
    width: min(24%);
}
.concept-contents_main .concept-contents_image{
    width: calc(100% - min(24%));
}

/*----------*/
/* concept2
/*----------*/
.concept2{
    position: relative;
    z-index: 1;
}
figure.concept2-mainImage{
    z-index: -1;
    position: relative;
    overflow: hidden;
}

.concept2-contents{
    position: relative;
    display: flex;
    align-items: center;
    margin: min(10%) 8% 0;
    gap: min(6vw);
}

.concept2-contents>.contents-title{
    width: 40%;
}
.concept2-contents>p{
    width: calc((100% - min(6vw)) - 40%);
}

.concept2-shapes{
    position: absolute;
    z-index: -1;
    top: -86%;
    right: -28%;
}

.concept2-shapes figure.shapeImage:nth-child(1){
    width: min(71vw);
}
.concept2-shapes figure.shapeImage:nth-child(2){
    width: min(44vw);
    position: absolute;
    top: 55%;
    left: -36%;
}


/*----------*/
/* products
/*----------*/
.products{
    background: url(img/me-bg.webp) no-repeat center;
    background-size: 100%;
    margin-bottom: min(22%);
    margin-top: min(12%);
}

.products-wrapper{
    padding: min(18vw) min(10vw) min(10vw);
}

.products-mainImage{
    position: relative;
    width: min(50vw);
    margin: 0 auto;
}

.products-mainImage>.products-mainImage_title{
    position: absolute;
    width: min(11vw);
    top: 0;
    right: -27%;
}

.products-details{
    margin-top: -8%;
    z-index: 1;
    position: relative;
}

.products-details h2,.products-details p,.products-details .products-mainImage_price{
    padding-bottom: min(4vw);
}

.products-mainImage_btn{
    width: min(66vw);
    margin: 0 auto
}
.products-mainImage_btn>a{
    display: block;
}

/*----------*/
/* introduction
/*----------*/
.introduction{
    position: relative;
    z-index: 1;
    padding: min(55vw) 0 min(42vw);
    margin: min(16vw) 0;
}

.introduction-bg{
    position: absolute;
    clip-path: polygon(50% 0%, 0% 16.4%, 0% 86.4%, 50% 100%, 100% 86.4%, 100% 16.4%);
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
}
.introduction-bg img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.shapeImage{
    -webkit-mask-image: url(img/diamond.svg);
    mask-image: url(img/diamond.svg);
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    display: block;
    position: relative;
}
.shapeImage>img{
    width: 100%;
    height: 100%;
    object-position: center;
    object-fit: cover;
    transition: var(--transition);
}

.introduction-details.contents{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row-reverse;
    margin: 0 8%;
    gap: min(8vw);
    z-index: 1;
    position: relative;
}

.introduction-details>.introduction-details_title{
    width: 26%;
}

.introduction-details>.introduction-details_text{
    width: calc((100% - min(8vw)) - 26%);
}

.introduction-shapes{
    position: absolute;
    width: 100%;
    height: 29%;
}

.introduction-shapes.-shapes1{
    top: -3%;
    right: -19%;
}

.introduction-shapes.-shapes2{
    bottom: 0;
    left: -22%;
}

.introduction-shapes figure.shapeImage{
    /*transform: translate(var(--x, 0), var(--y, 0)) scale(1);*/
    transition: var(--transition);
    position: absolute;
}

.introduction-shapes.-shapes1 figure.shapeImage:nth-child(2){
    bottom: -37%;
    left: -37%;
    width: 66%;
}
.introduction-shapes.-shapes1 figure.shapeImage:nth-child(3){
    left: -8%;
    top: -14%;
    width: 34%;
}

.introduction-shapes.-shapes2 figure.shapeImage:nth-child(1){
    top: -12%;
    left: 8%;
}
.introduction-shapes.-shapes2 figure.shapeImage:nth-child(2){
    bottom: 0%;
    right: -29%;
    width: 49%;
}
.introduction-shapes.-shapes2 figure.shapeImage:nth-child(3){
    top: 0%;
    right: -20%;
    width: 31%;
}

@media screen and (min-width:769px){
    /*----------*/
    /*concept
    /*----------*/
    .concept2-shapes figure.shapeImage:nth-child(1){
        width: min(67%);
        margin: 0 0 0 auto
    }
    .concept2-shapes figure.shapeImage:nth-child(2){
        width: min(44%);
        left: 7%;
        top: 59%;
    }

    .concept2-contents{
        gap: min(4rem);
    }

    .concept2-contents>p{
        width: calc((100% - min(4rem)) - 40%);
        font-size: var(--font-183rem);
    }

    /*----------*/
    /*products
    /*----------*/
    .products{
        margin-bottom: calc(var(--section-margin) / 2);
        margin-top: min(4%);
    }
    .products-wrapper{
        padding: min(10rem) min(6rem) min(8rem);
    }

    .products-details h2,
    .products-details p,
    .products-details .products-mainImage_price{
        padding-bottom: min(2rem);
    }

    .products-mainImage{
        width: min(70%);
    }
    .products-mainImage>.products-mainImage_title{
        width: min(18%);
        top: 6%;
        right: -23%;
    }
    .products-mainImage_btn{
        width: min(83%);
    }

    /*----------*/
    /* introduction
    /*----------*/
    .introduction{
        padding: min(54%) 0 min(40%);
        margin: 16% 0 10%;
    }
    .introduction-details.contents{
        gap: min(9%);
    }
    .introduction-details>.introduction-details_text{
        width: calc((100% - min(9%)) - 26%);
        font-size: var(--font-183rem);
    }

    .introduction-shapes{
        height: 30%;
    }

    .introduction-shapes.-shapes1{
        top: -4%;
        right: -23%;
    }

    .introduction-shapes.-shapes1 figure.shapeImage:nth-child(2){
        bottom: -45%;
        left: -40%;
        width: 72%;
    }

    .introduction-shapes.-shapes1 figure.shapeImage:nth-child(3){
        left: -11%;
        top: -11%;
    }

    .introduction-shapes.-shapes2 figure.shapeImage:nth-child(2){
        width: 50%;
        bottom: -3%;
    }

    .introduction-shapes.-shapes2 figure.shapeImage:nth-child(3){
        top: 0%;
        right: -19.5%;
    }

    .introduction-bg{
        clip-path: polygon(50% 0%, 0% 17%, 0% 87%, 50% 100%, 100% 87%, 100% 17%);
    }
}

@media screen and (min-width:1024px){
    .introduction-shapes{
        height: min(27rem, 17.83vw);
    }
}


/*----------*/
/*difference
/*----------*/
.difference{
    margin: var(--section-margin) 0;
}

.difference>.contents{
    z-index: 1;
    position: relative;
}

.difference-titleWrap{
    position: relative;
    z-index: 1;
}
.difference-titleWrap>h2.difference-mainTitle{
    width: min(56vw);
    margin: 0 auto min(3rem,3vw);
}

.difference-titleWrap::before{
    position: absolute;
    content: "";
    background: url(img/deco-diamond_gl.webp) no-repeat center;
    background-size: 100%;
    width: 65vw;
    height: 38vw;
    z-index: -1;
    top: -37%;
    left: -13%;
}

.difference-contents{
    position: relative;
    padding: min(7vw) min(5vw) min(9vw);
}

.difference-contents h3 img{
    display: block;
}

.difference-contents.-contents1{
    background: url(img/d-zuwaigani_bg.webp) no-repeat center;
    background-size: 100%;
}
.difference-contents.-contents2{
    background: url(img/d-matsubagani_bg.webp) no-repeat center;
    background-size: 100%;
}

.difference-contents_images{
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: min(5vw) 0;
}

.difference-contents_images .difference-foodImg{
    width: 82%;
}
.difference-contents_images h4{
    width: calc((100%) - 82%);
    padding: 0 min(5%);
}

/*----------*/
/* voice
/*----------*/
.voice{
    padding: var(--section-margin) 0 calc(var(--section-margin) / 8);
    background: var(--c-orange);
    position: relative;
    margin-bottom: min(44vw, 24rem);
}
.voice::before{
    position: absolute;
    content: "";
    clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
    background: var(--c-orange);
    width: 100%;
    height: 15%;
    bottom: -14.9%;
    left: 0;
    transform: rotate(180deg);
}

h2.voice-mainTitle{
    width: min(46vw);
    margin: 0 auto min(6vw);
}

p.voice-introText{
    font-size: var(--font-183rem);
    padding-bottom: min(6vw);
}

.voice-contents{
    margin-bottom: calc(var(--section-margin) / 3);
    display: flex;
    gap: min(1rem);
}

.voice-contents>.voice-contents_details {
    width: min(65%);
    background: var(--c-white);
    color: var(--c-black);
    padding: calc(var(--section-margin) / 4);
    letter-spacing: 0;
}

.voice-contents>.voice-contents_image {
    width: calc(100% - 65%);
}

/*----------*/
/* How to eat
/*----------*/
.HtoEat{
    margin: var(--section-margin) 0;
}
.HtoEat-mainTitle{
    width: min(46vw);
    margin: 0 auto min(6vw);
}

.HtoEat-contents{
    background: url(img/hte_bg.webp) no-repeat center;
    background-size: 100%;
    padding: min(10vw) min(7vw);
}

h3.HtoEat-contents_title{
    width: min(27vw);
    margin: 0 auto min(8vw);
}

.HtoEat-contents_details{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: min(8vw)
}


/*----------*/
/* How to enjoy
/*----------*/
.HtoE{
    position: relative;
    z-index: 1;
    padding: min(23vw) 0 min(32vw);
    margin-top: min(-14vw);
}

h2.HtoE-mainTitle{
    width: min(58vw);
    margin-left: min(4vw);
    margin-bottom: -3vw;
    z-index: 1;
    position: relative;
}

.HtoE-bg{
    clip-path: polygon(100% 0%, 100% 100%, 0% 80%, 0% 20%);
    position: absolute;
    z-index: -1;
    top: 0;
    right: 0;
    height: 100%;
    width: 100%;
}
.HtoE-bg img{
    width: 100%;
    height: 100%;
    object-position: center;
    object-fit: cover;
}
.HtoE-bg.-bg_or{
    left: 0;
    transform: scaleX(-1);
    background: var(--c-white);
}

.HtoE-contents{
    position: relative;
}
.HtoE-contents::before{
    position: absolute;
    content: "";
    background: var(--c-white);
    width: 89vw;
    height: 90%;
    bottom: -6%;
}

.HtoE-contents.-contents1::before,
.HtoE-contents.-contents3::before{
    left: 0;
}
.HtoE-contents.-contents2::before{
    right: 0;
}

.HtoE-contents_wrapper{
    position: relative;
    display: flex;
    gap: min(5vw);
    margin-bottom: calc(var(--section-margin) / 1.4);
}

.HtoE-contents.-contents1 .HtoE-contents_wrapper,
.HtoE-contents.-contents3 .HtoE-contents_wrapper{
    margin-left: min(4vw);
}
.HtoE-contents.-contents2 .HtoE-contents_wrapper{
    margin-right: min(4vw);
    flex-direction: row-reverse;
}

h3.HtoE-contents_title{
    width: min(8vw);
    padding-top: min(19%);
}
h3.HtoE-contents_title span.contents-title_item{
    display: block;
    height: auto;
}

.HtoE-contents_details{
    width: calc((100% - min(5vw)) - min(8vw));
}

.HtoE-contents.-contents2 h3.HtoE-contents_title{
    width: min(21vw);
}

.HtoE-contents.-contents2 .HtoE-contents_details{
    width: calc((100% - min(5vw)) - min(21vw));
}

.HtoE-contents_detailsText{
    color: var(--c-black);
    font-size: var(--font-183rem);
    font-weight: 500;
    padding-top: min(3vw, 1rem);
}

.HtoE-contents.-contents2 .HtoE-contents_detailsText{
padding-left: min(13vw);
}

/*----------*/
/* order
/*----------*/
.order{
    margin-top: -9%;
    margin-bottom: calc(var(--section-margin) / 2);
}

.order h2{
    width: 63%;
    margin: 0 auto min(3rem);
}

.order a{
    width: 90%;
    margin: 0 auto;
    display: block;
    transition: .6s 
ease-out;
}


@media screen and (min-width:769px){
    /*----------*/
    /*difference
    /*----------*/
    .difference{
        margin: 0 auto var(--section-margin);
    }
    .difference-titleWrap::before{
        width: min(32rem, 24vw);
        height: min(19rem, 14vw);
    }
    .difference-titleWrap>h2.difference-mainTitle{
        width: min(19vw, 25rem);
    }
    .difference-contents{
        padding: min(7vw, 4rem) min(5vw, 3rem) min(10vw, 5rem)
    }

    .difference-contents_images{
        margin: min(3rem) 0;
    }
    /*----------
    voice
    ----------*/
    .voice{
        margin-bottom: min(18rem, 18vw);
    }

    h2.voice-mainTitle{
        width: min(21rem, 17vw);
        margin: 0 auto min(3rem, 3vw);
    }
    p.voice-introText{
        padding-bottom: min(3rem);
    }
    /*----------
    How to eat
    ----------*/
    .HtoEat-mainTitle{
        margin: 0 auto min(3rem, 3vw);
        width: min(21rem, 16vw);
    }

    .HtoEat-contents{
        padding: min(6rem, 5vw) min(5rem, 3vw);
    }

    h3.HtoEat-contents_title{
        width: min(13rem, 10vw);
        margin: 0 auto min(4rem, 3vw);
    }

    .HtoEat-contents_details{
        gap: min(4rem, 3vw);
    }

    /*----------
    How to eat
    ----------*/
    .HtoE{
        padding: min(9rem, 7vw) 0 min(13rem, 11vw);
        margin-top: min(-12%);
    }
    .HtoE-contents.-contents1 .HtoE-contents_wrapper, .HtoE-contents.-contents3 .HtoE-contents_wrapper{
        margin-left: min(3rem, 2vw);
    }
    .HtoE-contents.-contents2 .HtoE-contents_wrapper{
        margin-right: min(3rem, 2vw);
    }

    .HtoE-contents::before{
        width: 92%;
        height: 87%;
        bottom: -5%;
    }

    h2.HtoE-mainTitle{
        width: min(19vw, 24rem);
        margin-left: min(3rem, 2vw);
        margin-bottom: -4%;
    }

    .HtoE-contents_wrapper{
        gap: min(3rem, 2vw);
    }

    h3.HtoE-contents_title{
        width: min(3.24rem, 3vw);
    }

    .HtoE-contents_details{
        width: calc((100% - min(3rem, 2vw)) - min(3.24rem, 3vw));
    }

    .HtoE-contents.-contents2 h3.HtoE-contents_title{
        width: min(8rem, 8vw);
    }
    .HtoE-contents.-contents2 .HtoE-contents_details{
        width: calc((100% - min(3rem, 2vw)) - min(8rem, 8vw));
    }
    .HtoE-contents.-contents2 .HtoE-contents_detailsText{
        padding-left: min(9rem, 6vw);
    }

    .order a:hover,
    .products-mainImage_btn a:hover{
        transform: scale(.95);
    }
}


/*----------
 footer
----------*/
footer{
    text-align: center;
    position: relative;
    padding: min(12vw, 2rem) 0;
    z-index: 1;
}

.footer-logo{
    width: min(26rem, 55vw);
    margin: min(2rem) auto min(6rem, 12vw);
}

small.copyright{
    text-align: center;
    display: block;
    font-size: min(1.24rem, 2.4vw);
    font-weight: 400;
}

/*--------------*/
/*レスポンシブ基本CSS
/*--------------*/
.pcheader{
    display:block;
}

.pc{
    display:none;
}

.mobile{
    display: none!important;
}


@media screen and (min-width:769px){
    :root{
        --font-183rem:min(1.83rem,1.34vw);
        --section-margin: min(8rem, 6vw);
    }

    body{
        font-size: min(1.6rem,3.83vw);
    }

    main.main-wrapper{
        display: flex;
    }

    /*--------------*/
    /*g nav
    /*--------------*/
    .g-nav{
        width: min(612px, 100%);
    }

    .fixedLogo{
        width: min(180px, 44vw);
    }
    .fixedLogo:hover{
        transform: scale(1.05);
    }

    li a:hover{
        transform: scale(1.05);
    }

    small.copyright{
        font-size: min(1.24rem, 1vw);
    }

}

@media screen and (min-width:1024px){
    .g-nav{
        width: var(--cha-contents-width);
    }

    .footer-information a:hover{
        opacity: 0.6;
    }

}