@charset "UTF-8";

*{
    margin: 0;
    padding: 0;
    font-family: "Zen Maru Gothic", serif;
    box-sizing:border-box;
}
*,*:before,*:after{
    box-sizing:inherit;
}

img{
    width: 100%;
    vertical-align:top;
    pointer-events: none;
    -webkit-touch-callout:none;
    -webkit-user-select:none;
    -moz-touch-callout:none;
    -moz-user-select:none;
    user-select:none;
    box-sizing:border-box
}
a{
    text-decoration: none;
    color: inherit;
}
a:hover{
    cursor: pointer;
}

ul,li{
    list-style: none;
    font-weight: 500;
}
p,a{
    line-height: 1.6;
    font-size: clamp(14px, 10.400px + 0.96vw, 20px);
    font-weight: 500;
}
h1{
    margin: 1em auto;
    width: 80%;
    margin: 4em auto 1em;
    max-width: 600px;
}
h2{
    color: #c5221e;
    font-size: clamp(24px, 10.667px + 3.556vw, 32px);
    font-weight: bold;
}
h3{
    font-size: clamp(20px, 13.333px + 1.778vw, 24px);
    font-weight: bold;
}
.highlight_main{
    color: #866B6C;
    text-align: center;
}

.highlight_main section{
    width: 100%;
    margin-bottom: 4em;
}

.highlight_main h2{
    font-weight: bold;
    margin: 1em auto;
}

.highlight_main .section-wrapper{
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
}


.highlight_main .flex-sp-column{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.fadeUp{
    animation-name:fadeUpAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    }

    @keyframes fadeUpAnime{
      from {
        opacity: 0;
        transform: translateY(100px);
      }

      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

.fadeUpTrigger{
        opacity: 0;
    }


.blur{
    animation-name:blurAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
}

@keyframes blurAnime{
  from {
    filter: blur(10px);
    transform: scale(1.02);
    opacity: 0;
  }

  to {
    filter: blur(0);
    transform: scale(1);
    opacity: 1;
  }
}

.blurTrigger{
    opacity: 0;
}

.highlight_main .pc_only{
    display: none;
}

@media(min-width:500px){
    .highlight_main .br_500{
        display: none;
    }
    .highlight_main .sp_only{
        display: none;
    }
}

@media(min-width:769px){
    .highlight_main .br_768{
        display: none;
    }
    .highlight_main .pc_only{
        display: block;
    }
}

/* ====================== menu ====================== */


.menu_bg {
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url(https://www.2wayworld.jp/wp-content/uploads/mamicosme/gummihighlight/gummihighlight_menu.png);
    width: 50px;
    height: 50px;
    position: fixed;
    top: 2px;
    right: 2px;
    z-index: 1;
    opacity: 0.8;
    display: block;
}

#menu{
    position:fixed;
    top: 0;
    right: 0;
    z-index: 100;
}
#menu-toggle{
    display:block;
    width:32px;
    height:32px;
    cursor:pointer;
    transform:rotate(0deg);
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 10000;
}
#menu-toggle span{
    width:100%;
    height:4px;
    border-radius:1px;
    display:block;
    position:absolute;
    left:0;
    content:"";
    transition:.5s ease-in-out;
}
#menu-toggle span:nth-child(1){
    top:4px;
    transform-origin:left center
}
#menu-toggle span:nth-child(2){
    top:14px;
    transform-origin:left center
}
#menu-toggle span:nth-child(3){
    top:24px;
    transform-origin:left center
}
#menu-toggle.open span:nth-child(1){
    transform:rotate(45deg);
    top:3px;
    left:4px
}
#menu-toggle.open span:nth-child(2){
    width:0%;
    opacity:0
}
#menu-toggle.open span:nth-child(3){
    transform:rotate(-45deg);
    top:25px;
    left:4px
}
#menu-overlay{
    position:absolute;
    top:16px;
    left:16px;
    z-index:-1;
    background-image: linear-gradient(#fcc3ea 10%, #f0fefff5 90%);
    border-radius:50%;
    transition:1s;
    transform:scale3d(0, 0, 0)
}
#menu-overlay.open{
    transform:scale3d(1, 1, 1)
}
#gnav{
    width:100%;
    position:fixed;
    left:0;
    top:0;
    transition:ease-in-out .25s;
    transition-delay:0s;
    display: none;
    opacity:0;
    z-index: 100;
}
#gnav ul{
    list-style:none;
}
#gnav a{
    color:#fff;
    text-decoration:none;
    color: #c5221e;
    text-shadow: 0px 0px 4px #fff;
    font-weight: bold;
    vertical-align: super;
}
#gnav.open{
    display: block;
    opacity:1;
    transition:ease-in-out .5s;
    transition-delay:.25s
}

#menu-toggle span{
    background: #c5221e;
    border-radius: 5px;
}
#gnav .gnav_wrap{
    display:none;
    align-items:center;
    justify-content:center;
    font-family:sans-serif;
    font-size:8vh;
    flex-direction: column;
    height: 100%;
    opacity:0;
    transition: opacity 0.5s ease-in-out; /* 透明度の変化 */
    transition-delay: 0.5s; /* 遅延を設定 */
}
#gnav .gnav_wrap ul li a,#gnav .gnav_wrap ul li .sns_wrapper a i{
    font-size: clamp(24px, 20.757px + 0.865vw, 32px);
    padding: 0 8px;

}

/* メニューが開いたときに表示する */
#gnav.open .gnav_wrap {
    display: flex;
    opacity: 1;
}

/* ====================== 背景 ====================== */

.highlight_main .bg{
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-image: url(https://www.2wayworld.jp/wp-content/uploads/mamicosme/gummihighlight/gummihighlight_bg.jpg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: -100;
}

.highlight_main .prism{
    overflow: hidden;
    position: relative;
}
.highlight_main .prism::before{
    position: fixed;
    content: "";
    top: 0;
    left: -200%;
    width: 100%;
    height: 100%;
    z-index: -50;
    transform: skewX(-40deg);
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.5) 100%);
    animation: prism 8s infinite;
    opacity: 0.4;

}
@keyframes prism {
    0% {
        left: -200%;
    }
    15%, 100% {
        left: 200%;
    }
  }

/* ====================== キービジュアル ====================== */
.highlight_main .key {
    width: 100%;
    height: auto;
}
.highlight_main .key img{
    width: 100%;
    height: auto;
    max-height: 100vh;
    object-fit: contain;
}
/* ====================== top ====================== */

.highlight_main #top p{
    margin: 1em auto ;
}
.highlight_main #top .item_box{
    display: flex;
    gap: 2em;
    max-width: 1300px;
    margin-top: 4em;
    margin-left: auto;
    margin-right: auto;
}
.highlight_main #top .item{
    flex: 1;
    display: flex;
    flex-direction: column;
}
.highlight_main #top .item .img_box img{
    border: 1px solid #cdcdcd;
    box-shadow: 1px 1px 4px #afafaf;
    border-radius: 4%;
    transition: transform .6s ease;
}
.highlight_main #top .item .img_box:hover img{
    transform: scale(1.1);
}

@media(min-width:500px){
    .highlight_main #top p{
        margin: 0.4em auto ;
    }
}

@media(max-width:768px){
    .highlight_main #top .item_box{
        flex-direction: column;
        width: 80%;
    }
    .highlight_main #top .item{
        width: 80%;
        max-width: 250px;
        margin: 5% auto;
    }
}

/* ==================   products   =================== */

.highlight_main #products .section-wrapper{
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: column;
}
.highlight_main #products .item{
    display: flex;
    flex-direction: row;
}
.highlight_main #products .item.reverse{
    flex-direction: row-reverse;
}
.highlight_main #products .item_Tx_box{
    text-align: center;
    flex-basis: 60%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: auto;
}
.highlight_main #products .left{
    text-align: left;
    margin: 5% 0;
}
.highlight_main #products .item_img{
    flex-basis: 35%;
    align-self: center;
}

.highlight_main #products .btn{
    text-decoration: none;
    color: inherit;
    display: inline-block;
    padding: 0.5em 2em;
    border: 1px solid #866B6C;
    background: #f8d1ce;
    color: #866B6C;
}

.highlight_main #products .btn:hover{
    color: inherit;
    background-image: linear-gradient(to left, #f0d6ff, #fdefde 50%, #ccfffa);
    background-size: 150% auto;
    transition: all 1s ease-out;
    background-position: 100% 50%;
}

.punipuni {
	animation: punipuni 0.8s infinite;
    border-radius: 25px;
}
@keyframes punipuni {
	0% {
		transform: scale(1, 1);
	}
	50% {
		transform: scale(0.98, 1.15)
	}
}

.highlight_main #products .item_Tx_box h3{
    font-size: clamp(24px, 22.378px + 0.432vw, 28px);
    font-weight: bold;
}
.highlight_main #products .item_Tx_box{
    padding: 60px 0;
}
.highlight_main #products .item_title{
    font-weight: bold;
}
.highlight_main #products .left{
    font-weight: 500;
}

@media(max-width:768px){
    .highlight_main #products .item{
        flex-direction: column;
    }
    .highlight_main #products .item.reverse{
        flex-direction: column;
    }
    .highlight_main #products .item .item_img{
        max-width: 350px;
        margin-right: auto;
        margin-left: auto;
    }
    .highlight_main #products .item_Tx_box{
        padding: 0 0 60px;
    }
}

@media(max-width:500px){
    .highlight_main #products .item .item_img{
        max-width: 250px;
    }
}

/* ====================== point ====================== */

.highlight_main #point h2{
    width: 40%;
    max-width: 250px;
    margin: 2em auto 1em;
}

.highlight_main #point .sp-grid-column{
    display: grid;
    grid-auto-columns: 1fr;
    width: 100%;
    height: auto;
    margin: auto;
}

.highlight_main #point .sp-grid-column .item{
    width: 90%;
    margin: 1em auto;
    position: relative;
}
.highlight_main #point .sp-grid-column .item img{
    width: 100%;
    max-width: 280px;
    filter: drop-shadow(2px 2px 4px #e0e0e0);
}
.highlight_main #point .sp-grid-column .item .text{
    position: absolute;
    z-index: 10;
    top: 50%;
    left: 50%;
    width: 100%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    text-shadow: 2px 2px 2px#fff;
}
.highlight_main #point .sp-grid-column .item .text h3 {
    color: #c5221e;
    text-shadow: 2px 2px 0 #fff;
}
.highlight_main #point .sp-grid-column .item .text p span{
    font-size: 0.8em;
}
.highlight_main #point .sp-grid-column .item{
    animation: Shake 6s infinite;
}
@keyframes Shake {
    0% {transform: skew(0deg,0deg);}
    1% {transform: skew(1deg, 1deg);}
    2% {transform: skew(-1deg, -1deg);}
    3% {transform: skew(0deg,0deg);}

    4% {transform: skew(1deg, 1deg);}
    5% {transform: skew(-1deg, -1deg);}
    6% {transform: skew(0deg,0deg);}

    7% {transform: skew(1deg, 1deg);}
    8% {transform: skew(-1deg, -1deg);}
    9% {transform: skew(0deg,0deg);}

    100% {transform: skew(0deg,0deg);}
  }

.highlight_main #point .sp-grid-column .item:hover{
    animation: hoverShake 0.15s linear 3;
}
@keyframes hoverShake {
    0% {transform: skew(0deg,0deg);}
    25% {transform: skew(1deg, 1deg);}
    75% {transform: skew(-1deg, -1deg);}
    100% {transform: skew(0deg,0deg);}
}
@media(min-width:800px){
    .highlight_main #point .sp-grid-column{
        display: flex;
    }
}


.highlight_main #point .container{
    display: flex;
    flex-direction: column;
    gap: 5%;
    max-width: 1000px;
    margin-top: 4em;
    margin-left: auto;
    margin-right: auto;
    background-color: #f9fffe40;
    padding: 50px 4%;
    border-radius: 50px;
}

.highlight_main #point .container .text_box{
    flex: 1;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 1.5em auto;
}
.highlight_main #point .container .text_box h3{
    font-weight: bold;
    font-size: 1.3em;
    margin-bottom: 1em;
    color: #fff;

   /* ribbon shape */
    --r: .8em;
    padding-inline: calc(var(--r) + .3em);
    line-height: 1.8;
    clip-path: polygon(0 0,100% 0,calc(100% - var(--r)) 50%,100% 100%,0 100%, var(--r) 50%);
    background: #c5221e;
    width: fit-content;
}

.highlight_main #point .container .text_box p{
    margin-top: 0.8em;
}

.highlight_main #point .container .text_box p span{
    font-weight: 600;
    font-size: 1.1em;
    display: inline-block;
    color: #f799ad;
    text-shadow: 2px 4px 1px #fff6d0;
}

@media(max-width:768px){

    .highlight_main #point .container .text_box{
        margin-right: auto;
        margin-left: auto;
    }
    .highlight_main #point .container .text_box h3{
        font-size: 1.2em;
    }
    .highlight_main #point .sp-grid-column .item img{
        width: 75%;
        max-width: 250px;
    }
}

/* ====================== how to use ====================== */

.highlight_main #how h2{
    width: 50%;
    max-width: 300px;
    margin: 2em auto 1em;
}

.highlight_main #how ul{
    display: flex;
    margin: 1em auto;
    max-width: 800px;
}

.highlight_main #how ul li{
    flex: 1;
    border: #f8d1ce 1px solid;
    background: #ffe8e6;
    border-radius: 20px;
    margin: 2px;
}
.highlight_main #how #illust_box{
    width: 80%;
    min-width: 200px;
    margin: auto;
    max-width: 400px;
}

/* ボタンのスタイル（デザイン調整） */
.highlight_main #how ul li {
    cursor: pointer;
    transition: background 0.3s;
}

.highlight_main #how ul li:hover {
    background: #fff;
}

@media(min-width:800px){
    .highlight_main #how ul li{
        font-size: 1.4em;
    }
}

/* ====================== precautions ====================== */

.highlight_main #precautions h2{
    position: relative;
    display: inline-block;
    font-weight: bold;
}

.highlight_main #precautions h2::before{
    content: '';
    position: absolute;
    display: inline-block;
    top: 0;
    left: -1.6em;
    background-image: url(https://www.2wayworld.jp/wp-content/uploads/mamicosme/gummihighlight/caution_icon.png);
    background-size: contain;
    background-repeat: no-repeat;
    height: 100%;
    width: 100%;
    max-width: 1.5em;
}
.highlight_main #precautions h2::after{
    content: '';
    position: absolute;
    display: inline-block;
    top: 0;
    right: -1.8em;
    background-image: url(https://www.2wayworld.jp/wp-content/uploads/mamicosme/gummihighlight/caution_icon.png);
    background-size: contain;
    background-repeat: no-repeat;
    height: 100%;
    width: 100%;
    max-width: 1.5em;
}

.highlight_main #precautions{
    margin-bottom: 0px;
    padding-bottom: 4em;
}
.highlight_main #precautions p{
    text-align: left;
}
.highlight_main #precautions ul{
    text-align: left;
    margin-left: 1em;
    font-size: clamp(14px, 11.568px + 0.649vw, 20px);
}
.highlight_main #precautions ul li{
    list-style: disc;
}

/* ====================== campaign ====================== */
.highlight_main #campaign{
    background: #faebfa73;
    padding: 4em 0px;
}
.highlight_main #campaign h2{
    width: 40%;
    max-width: 250px;
    margin: 1em auto;
}
.highlight_main #campaign .section-wrapper h3{
    color: #ff8f8f;
    text-shadow: 1px 1px 1px #6d5151;
    line-height: 1.6;
    margin-bottom: 0.5em;
}

.highlight_main #campaign .section-wrapper div{
    margin: 2em auto;
}

.highlight_main #campaign a.btn{
    text-decoration: none;
    color: inherit;
    display: inline-block;
    padding: 0.2em 2em;
    border: 1px solid #866B6C;
    background: #f8d1ce;
    color: #866B6C;
    margin-top: 1em;
}

.highlight_main #campaign .btn:hover{
    color: inherit;
    background-image: linear-gradient(to left, #f0d6ff, #fdefde 50%, #ccfffa);
    background-size: 150% auto;
    transition: all 1s ease-out;
    background-position: 100% 50%;
}

.highlight_main #campaign .section-wrapper .SNS_box{
    display: flex;
    flex-direction: column;
}

.highlight_main #campaign .section-wrapper .SNS_box a{
    display: inline-block;
    margin: 0.5em;
    background-color: #fff;
}

.highlight_main #campaign .section-wrapper .SNS_box a:hover{
    background-image: linear-gradient(to left, #f0d6ff, #fdefde 50%, #ccfffa);
    background-size: 150% auto;
    transition: all 1s ease-out;
    background-position: 100% 50%;
}

.highlight_main #campaign .section-wrapper .SNS_box a i{
    padding: 0.5em;
}

@media (min-width:500px){
    .highlight_main #campaign .section-wrapper h3{
        line-height: 2.5;
    }
}

/* ====================== official SNS ====================== */

#sns {
    text-align: center;
}

#sns h2{
    width: 50%;
    max-width: 350px;
    margin: 1em auto 2em;
}

#sns p {
    width: 0;
    animation: typing 6s steps(18) 4s infinite, blink 0.5s step-end infinite alternate;
    white-space: nowrap;
    overflow: hidden;
    border-right: 3px solid;
    font-size: clamp(16px, 12.757px + 0.865vw, 24px);
    text-align: center;
    display: inline-block;
    background-color: #fefce6;

  }

  @keyframes typing {
    0% {
      width: 0;
    }
    25% {
      width: 22ch; /* タイプ完了 */
    }
    90% {
      width: 22ch; /* 少し表示状態でキープ */
    }
    100% {
      width: 0; /* 消える */
    }
  }

  @keyframes blink {
    50% {
      border-color: transparent;
    }
  }



/* ====================== 固定ボタン ====================== */
#instagram{
    width: 40px;
    height: 40px;
    position: fixed;
    right: 4px;
    bottom: 210px;
    background: rgb(255 139 158 / 50%);
    border-radius: 50%;
    z-index: 10;
}
#tiktok{
    width: 40px;
    height: 40px;
    position: fixed;
    right: 4px;
    bottom: 150px;
    background: rgb(255 139 158 / 50%);
    border-radius: 50%;
    z-index: 10;
}
#campaign_fixed{
    width: 40px;
    height: 40px;
    position: fixed;
    right: 4px;
    bottom: 90px;
    background: rgb(255 139 158 / 80%);
    border-radius: 50%;
    z-index: 10;
}
#onlinestore{
    width: 40px;
    height: 40px;
    position: fixed;
    right: 4px;
    bottom: 30px;
    background: rgb(255 139 158 / 80%);
    border-radius: 50%;
    z-index: 10;
}
#instagram a,#tiktok a,#campaign_fixed a,#onlinestore a{
    position: relative;
    display: block;
    width: 40px;
    height: 40px;
    text-decoration: none;
}

#instagram a::before{
    font-family: 'Font Awesome 6 Brands';
    font-weight: 900;
    content: '\f16d';
    font-size: 28px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -18px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}

#tiktok a::before{
    font-family: 'Font Awesome 6 Brands';
    font-weight: 900;
    content: '\e07b';
    font-size: 25px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -16px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}

#campaign_fixed a::before{
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    content: '\f06b';
    font-size: 24px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -12px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}

#onlinestore a::before{
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    content: '\f07a';
    font-size: 20px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -2px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}

@media screen and (max-width: 768px) {
    #instagram,
    #tiktok,
    #campaign_fixed,
    #onlinestore {
      display: none !important;
    }
  }