@charset "utf-8";

html {
    touch-action: manipulation;
}
body {
    -ms-content-zooming: none;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    color: #000;
    line-height: 1.6;
    font-family: 'Noto Sans JP', sans-serif;
    /* font-feature-settings: "palt"; */
}

.en{
    font-family: 'IBM Plex Sans', sans-serif;
}
a{
    text-decoration: none;
    -webkit-transition: 0.2s;
	-o-transition: 0.2s;
	transition: 0.2s;
}
a:hover {
    color: #000;
    -webkit-transition: 0.2s;
	-o-transition: 0.2s;
	transition: 0.2s;
    opacity: 0.7;
}
img {
    vertical-align: bottom;
}
a img {
    transition: opacity 0.3s ease-out;
}

.sp {
    display: none;
}
.pc {
    display: block;
}
@media (max-width: 750px) {
    .sp {
        display: block;
    }
    .pc {
        display: none;
    }
}
.mb-5 {margin-bottom: 5px;}
.mb-10 {margin-bottom: 10px;}
.mb-20 {margin-bottom: 20px;}
.mb-30 {margin-bottom: 30px;}
.mb-40 {margin-bottom: 40px;}
.mb-50 {margin-bottom: 50px;}
.mb-60 {margin-bottom: 60px;}
.mb-70 {margin-bottom: 70px;}
.mb-80 {margin-bottom: 80px;}
.mb-90 {margin-bottom: 90px;}
.mb-100 {margin-bottom: 100px;}
.mb-110 {margin-bottom: 110px;}
.mb-120 {margin-bottom: 120px;}
.mb-130 {margin-bottom: 130px;}
.mb-140 {margin-bottom: 140px;}
.mb-150 {margin-bottom: 150px;}
.mb-160 {margin-bottom: 160px;}
.mb-170 {margin-bottom: 170px;}
.mb-180 {margin-bottom: 180px;}
.mb-190 {margin-bottom: 190px;}
.mb-200 {margin-bottom: 200px;}
@media (max-width: 640px) {
    .mb-5 {margin-bottom:0.666666667vw;}
    .mb-10 {margin-bottom:1.333333333vw;}
    .mb-20 {margin-bottom:2.666666667vw;}
    .mb-30 {margin-bottom:4vw;}
    .mb-40 {margin-bottom:5.333333333vw;}
    .mb-50 {margin-bottom:6.666666667vw;}
    .mb-60 {margin-bottom:8vw;}
    .mb-70 {margin-bottom:9.333333333vw;}
    .mb-80 {margin-bottom:10.66666667vw;}
    .mb-90 {margin-bottom:12vw;}
    .mb-100 {margin-bottom:13.33333333vw;}
    .mb-110 {margin-bottom:14.66666667vw;}
    .mb-120 {margin-bottom:16vw;}
    .mb-130 {margin-bottom:17.33333333vw;}
    .mb-140 {margin-bottom:18.66666667vw;}
    .mb-150 {margin-bottom:20vw;}
    .mb-160 {margin-bottom:21.33333333vw;}
    .mb-170 {margin-bottom:22.66666667vw;}
    .mb-180 {margin-bottom:24vw;}
    .mb-190 {margin-bottom:25.33333333vw;}
    .mb-200 {margin-bottom:26.66666667vw;}
}

/* -----------------------------------------
wrapper
-----------------------------------------*/
#wrapper {
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
    max-width: 750px;
    min-height: 100vh;
    margin: auto;
    /* padding-bottom: 60px; */
}
#contents {
    margin: 0 auto;
    line-height: 1.6;
    font-size: 26px;
    max-width: 750px;
    font-family: 'Noto Sans JP', sans-serif;
    font-style: normal;
}
@media (max-width: 750px) {
    #contents {
        font-size: 3.2vw;
    }
}

#contents img {
    width: 100%;
}
#contents .w-750 {
    max-width: 750px;
    margin: auto;
}

li {
    list-style-type: none;
}
.fw-b {
    font-weight: 600;
}
.ta-c {
    text-align: center;
}
.small{
	font-size: 78%;
}
.s-min{
	font-family: 'Shippori Mincho', serif;
    font-weight: 600;
}

.set-m{
	margin: 0 30px;
}
.hr_gold01{
	height: 30px;
	background-image: url(../img/221226/hr_gold.webp);
    background-size: cover;
}
.hr_gold02{
	height: 15px;
	background-image: url(../img/221226/hr_gold.webp);
    background-size: cover;
}
@media (max-width: 750px) {
	.set-m{
		margin: 0 4vw;
	}
	.hr_gold01{
		height: 4vw;
	}
	.hr_gold02{
		height: 2vw;
	}
}

.txt-copy{
	font-size: 160%;
	line-height: 2;
	/* letter-spacing: -0.05em; */
}


.page_nav a{
    display: block;
    position: relative;
}

.page_nav .icon_up a:after{
    content: '';
    position: absolute;
    background: url(../img/230131/icon_up.webp) no-repeat;
    background-size: 100% auto;
    width: 45px;
    height: 29px;
    bottom: 16%;
    right: 5%;
}

.page_nav .icon_next a:after{
    content: '';
    position: absolute;
    background: url(../img/230131/icon_next.webp) no-repeat;
    background-size: 100% auto;
    width: 29px;
    height: 45px;
    bottom: 16%;
    right: 6%;
}
@media (max-width: 750px) {
    .page_nav .icon_up a:after{
        width: 23px;
        height: 15px;
    }
    
    .page_nav .icon_next a:after{
        width: 15px;
        height: 23px;
    }
}

.itembox{
    display: flex;
    justify-content: space-between;
}
.itemimgbox,
.itemtxtbox{
    width: 47.826%;
}
.itemimgbox{
    padding-top: 10px;
}
.itemttl{
    font-size: 110%;
    font-weight: 600;
}

@media (max-width: 750px) {
    .itemimgbox{
        padding-top: 1.333vw;
    }
}
.itemcopy{
    font-size: 110%;
	/* letter-spacing: -0.02em; */
}

.hr_ribon01{
    width: 98.8%;
    height: 180px;
    margin-left: auto;
    margin-right: auto;
	background-image: url(../img/221226/hr_ribon_t.webp);
    background-size: contain;
    background-repeat: no-repeat;
}
.hr_ribon02{
    height: 110px;
    margin-left: auto;
    margin-right: auto;
	background-image: url(../img/221226/hr_ribon_b.webp);
    background-size: contain;
    background-repeat: no-repeat;
}
@media (max-width: 750px) {
    .hr_ribon01{
        height: 24vw;
    }
    .hr_ribon02{
        height: 14.666vw;
    }
}

.txt-copy2{
	font-size: 200%;
	letter-spacing: 0.05em;
    color: #C49443;
    margin-bottom: 0.3em;
}
.txt-copy3{
	font-size: 130%;
	line-height: 2;
}

.beauty_box{
    background-color: #FFE7F2;
    padding: 15px;
}
.beauty_innerbox{
    border: #fff 5px solid;
    padding: 22px;
}
@media (max-width: 750px) {
    .beauty_box{
        padding: 2vw;
    }
    .beauty_innerbox{
        border: #fff 0.6667vw solid;
        padding: 2.6667vw;
    }
}

.beauty_innerbox .txt-copy2{
    margin-top: 0.5em;
}

.item02_11 .itemimgbox{
    width: 28%;
    padding-top: 0;
}
.item02_11 .itemtxtbox{
    width: 72.652%;
}

.bg_kashiyama{
    height: 1312px;
	background-image: url(../img/221226/item02_12.webp);
    background-size: contain;
    background-repeat: no-repeat;
}
.bg_kashiyama .txt-copy3{
    margin-top: 1.5em;
}
@media (max-width: 750px) {
    .bg_kashiyama{
        height: 174.9333vw;
    }
    .bg_kashiyama .txt-copy3{
        margin-top: 1.8em;
    }
}

.itembox.item02_14{
    align-items: flex-end;
}
.item02_14 .itemimgbox{
    width: 56%;
    padding-top: 0;
}
.item02_14 .itemtxtbox{
    width: 39.652%;
    text-align: right;
}

.photo_m01{
    cursor: pointer;
    height: 1000px;
	background-image: url(../img/230131/item01_01.webp);
    background-size: contain;
    background-repeat: no-repeat;
    position: relative;
}
.photo_m02{
    cursor: pointer;
    height: 990px;
	background-image: url(../img/230131/item01_04.webp);
    background-size: contain;
    background-repeat: no-repeat;
    position: relative;
}
.modal-open {
    cursor: pointer;
    background: transparent;
    border: none;
    width: 60px;
    height: 60px;
    background-size: contain;
    position: absolute;
    right: 25px;
}
.photo_m01 .modal-open{
	background-image: url(../img/221226/btn_open.webp);
    bottom: 87px;
}
.photo_m02 .modal-open{
	background-image: url(../img/221226/btn_open.webp);
    bottom: 94px;
}

@media (max-width: 750px) {
    .photo_m01{
        height: 133.333vw;
    }
    .photo_m02{
        height: 132vw;
    }
    .modal-open {
        width: 8vw;
        height: 8vw;
        right: 3.333vw;
    }
    .photo_m01 .modal-open{
        bottom: 11.6vw;
    }
    .photo_m02 .modal-open{
        bottom: 12.533vw;
    }
}

.hr_line_l{
	height: 26px;
	background-image: url(../img/221226/hr_ladies.webp);
    background-size: contain;
    background-repeat: no-repeat;
    margin-top: 3.5em;
}
.hr_line_m{
	height: 26px;
	background-image: url(../img/221226/hr_mens.webp);
    background-size: contain;
    background-repeat: no-repeat;
    margin-top: 3.5em;
}
.hr_line_k{
	height: 26px;
	background-image: url(../img/221226/hr_kids.webp);
    background-size: contain;
    background-repeat: no-repeat;
    margin-top: 3.5em;
}
@media (max-width: 750px) {
    .hr_line_l,
    .hr_line_m,
    .hr_line_k{
        height: 3.4666vw;
    }
}


.overlay {
    position: fixed;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: .6;
    display: none;
    z-index: 0;
    top: 0;
    left: 0;
    right: 0;
}

.modal {
    width: 750px;
    border: 3px solid #997735;
    background: #fff;
    margin: 1em auto;
}
.modal_wrap{
    width: 690px;
    margin: 2em auto;
}
@media (max-width: 750px) {
    .modal {
        width: 94%;
    }
    .modal_wrap{
        width: 92%;
    }
}

.modal_wrap .itemcopy{
    font-size: 110%;
}

.modal_wrap p{
    text-align: left;
}

/* .modal-close__wrap {
    position: absolute;
    right: 40px;
    top: 20px;
} */

.modal-close {
    display: block;
    margin: 0 auto;
    width: 65px;
    height: 89px;
	background-image: url(../img/221226/btn_close.webp);
    background-size: contain;
    background-repeat: no-repeat;
    background-color: transparent;
    border: none;
    cursor: pointer;
}
@media (max-width: 750px) {
    .modal-close {
        width: 8.666vw;
        height: 11.866vw;
    }
}
  
/* .modal-close span {
    position: relative;
    width: 100%;
    height: 1px;
    background: black;
    display: block;
}

.modal-close span:nth-child(1) {
    transform: rotate(45deg);
}

.modal-close span:nth-child(2) {
    transform: rotate(-45deg);
} */

.overlay.open {
    display: block;
}

.modal.open {
    display: block;
}


/* common */

.btn{
    width: 100%;
    margin: 0 auto;
}
.btn a{
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 100%;
    height: 85px;
    border: solid 1px #333333;
    border-radius: 50px;
    background-color: #fff;
    box-shadow: 6px 6px #333333;
}
.btn a span{
    margin-left: -32px;
    font-size: 32px;
    font-weight: 700;
    transform: scale(0.93, 1);
    font-feature-settings: "palt";
}
.btn a::before{
    display: block;
    content: "";
    background-image: url(../img/250715/common/btn_arrow.webp);
    background-size: 100%;
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    width: 46px;
    height: 46px;
}
#page-top {
    width: 50px;
    height: 50px;
    z-index: 1000;
}
#page-top img{
    width: 100%;
    height: auto;
}
@media (max-width: 750px) {
    .btn{
        width: 100%;
        margin: 0 auto;
    }
    .btn a{
        display: flex;
        align-items: center;
        justify-content: center;
        position: relative;
        width: 100%;
        height: 11.333vw;
        border: solid 1px #333333;
        border-radius: 6.667vw;
        background-color: #fff;
        box-shadow: 0.8vw 0.8vw #333333;
    }
    .btn a span{
        margin-left: -4.267vw;
        font-size: 4.267vw;
        font-weight: 700;
        transform: scale(0.93, 1);
        font-feature-settings: "palt";
    }
    .btn a::before{
        display: block;
        content: "";
        background-image: url(../img/250715/common/btn_arrow.webp);
        background-size: 100%;
        position: absolute;
        top: 50%;
        right: 1.334vw;
        transform: translateY(-50%);
        width: 6.133vw;
        height: 6.133vw;
    }
    #page-top {
        bottom: 2.667vw;
        right: 2.667vw;
        width: 10.133vw;
        height: 10.133vw;
    }
}

/* top */

.l-top .info .lead-text{
    width: 590px;
    margin: 32px auto 0;
    font-size: 32px;
    font-weight: 700;
}
.l-top .info .info_wrap{
    position: relative;
    z-index: 10;
    padding-top: 160px;
}
.l-top .info .info_wrap .regist_block,
.l-top .info .info_wrap .line_block{
    width: 590px;
    margin: 0 auto;
    padding: 40px 40px 60px;
}
.l-top .info .info_wrap .regist_block{
    border-top-left-radius: 40px;
    border-top-right-radius: 40px;
    background-color: #FF862E;
    color: #333333;
}
.l-top .info .info_wrap .line_block{
    border-bottom-left-radius: 40px;
    border-bottom-right-radius: 40px;
    background-color: #00B900;
    color: #fff;
}
.l-top .info .info_wrap .title{
    width: 111%;
    font-size: 41px;
    line-height: 1.5;
    text-align: center;
    font-weight: 900;
    transform: scale(0.9, 1);
    transform-origin: top left;
    white-space: nowrap;
}
.l-top .info .info_wrap .text{
    margin-top: 28px;
    font-size: 32px;
    font-weight: 500;
}
.l-top .info .info_wrap .btn{
    margin-top: 40px;
}
.l-top .icon-star{
    display: block;
    content: "";
    background-image: url(../img/250715/common/icon_light-02.webp);
    background-size: 100%;
    position: absolute;
}
.l-top .info_wrap .icon-star-01{
    background-image: url(../img/250715/common/icon_light-01.webp);
    top: 3%;
    left: 36%;
    width: 72px;
    height: 90px;
}
.l-top .info .info_wrap .icon-star-02{
    top: 1.5%;
    right: 21%;
    width: 34px;
    height: 34px;
}
.l-top .info .info_wrap .icon-star-03{
    top: 29%;
    right: 4%;
    width: 34px;
    height: 34px;
}
.l-top .info .info_wrap .icon-star-04{
    top: 64.5%;
    left: 3%;
    width: 34px;
    height: 34px;
}
.l-top .info .info_wrap .icon-star-05{
    background-image: url(../img/250715/common/icon_light-03.webp);
    bottom: 12%;
    right: 5%;
    width: 64px;
    height: 64px;
}
.l-top .info .info_wrap .icon-star-06{
    bottom: -5%;
    left: 26%;
    width: 34px;
    height: 34px;
}
.l-top .info .back{
    position: relative;
    background-color: #FFFF00;
    height: 1100px;
    margin-top: -980px;
    padding-top: 219px;
}
.l-top .info .back::before{
    display: block;
    content: "";
    background-image: url(../img/250715/top/back_img-01.webp);
    background-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 219px;
}
.l-top .swiper-contents{
    position: relative;
    padding-bottom: 98px;
    background-color: #FFFF00;
}
.swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: unset;
    bottom: 44px;
    left: 0;
    width: 100%;
}
.swiper-pagination-bullet {
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 18px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 18px));
    background: var(--swiper-pagination-bullet-inactive-color, #FFFFFF);
    border: solid 1px #333333;
    border-radius: 50%;
    opacity: 1;
}
.swiper-pagination-bullet-active {
    background: #333333;
}
.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 6px);
}
.swiper-button-next, .swiper-button-prev{
    top: 274px;
    cursor: pointer;
}
.swiper-button-prev, .swiper-rtl .swiper-button-next {
    left: var(--swiper-navigation-sides-offset, 74px);
    right: auto;
}
.swiper-button-next, .swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset, 74px);
    left: auto;
}
.swiper-button-prev::after,
.swiper-button-next::after {
    bottom: 0;
    content: "";
    height: 0;
    margin: auto;
    position: absolute;
    top: 0;
    width: 0;
}
/* 前への矢印カスタマイズ */
.swiper-button-prev::after {
    background-image: url(../img/250715/top/btn_swiper.webp);
    background-size: 100%;
    width: 56px;
    height: 56px;
    transform: rotate(180deg);
}
/* 次への矢印カスタマイズ */
.swiper-button-next::after {
    background-image: url(../img/250715/top/btn_swiper.webp);
    background-size: 100%;
    width: 56px;
    height: 56px;
}
.l-top .g-nav{
    position: relative;
    padding-bottom: 302px;
    background-color: #FFFF00;
}
.l-top .g-nav .nav_wrap li{
    position: absolute;
    left: 23px;
    width: 651px;
}
.l-top .g-nav .nav_wrap li:first-of-type{
    top: 299px;
}
.l-top .g-nav .nav_wrap li:nth-of-type(2){
    top: 465px;
}
.l-top .g-nav .nav_wrap li:nth-of-type(3){
    top: 632px;
}
.l-top .g-nav .icon-star-01{
    top: -1.8%;
    left: 53%;
    width: 34px;
    height: 34px;
}
.l-top .g-nav .icon-star-02{
    background-image: url(../img/250715/common/icon_light-03.webp);
    top: 27%;
    right: 21%;
    width: 64px;
    height: 64px;
}
.l-top .g-nav .icon-star-03{
    background-image: url(../img/250715/common/icon_light-03.webp);
    bottom: 2%;
    left: 5%;
    width: 64px;
    height: 64px;
}
.l-top .g-nav .icon-star-04{
    bottom: -0.5%;
    left: 15.8%;
    width: 34px;
    height: 34px;
}
.l-top .event .event_wrap{
    width: 670px;
    margin: 0 auto;
    background-color: #FF7BC7;
}
.l-top .event .event_block{
    width: 590px;
    margin: 0 auto;
    padding-top: 180px;
}
.l-top .event .event_block:first-of-type{
    padding-top: 104px;
}
.l-top .event .event_block .title{
    margin-top: 26px;
    font-size: 38px;
    font-weight: 900;
    line-height: 1.5;
    color: #fff;
}
.l-top .event .event_block .text{
    margin-top: 36px;
    font-size: 32px;
    font-weight: 700;
    line-height: 1.6;
    color: #333;
}
.l-top .event .event_block .label{
    display: flex;
    column-gap: 16px;
    margin-top: 44px;
}
.l-top .event .event_block .label li{
    padding: 2px 21px;
    font-size: 26px;
    font-weight: 700;
    color: #333;
    background-color: #fff;
    border-radius: 20px;
}
.l-top .event .event_block .date{
    position: relative;
    margin-top: 38px;
    padding: 26px 0;
    font-size: 32px;
    font-weight: 900;
    text-align: center;
    color: #fff;
}
.l-top .event .event_block .date::before,
.l-top .event .event_block .date::after{
    display: block;
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    height: 6px;
    background-color: #fff;
    border-radius: 10px;
}
.l-top .event .event_block .date::before{
    top: 0;
}
.l-top .event .event_block .date::after{
    bottom: 0;
}
.l-top .event .event_block .detail{
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    font-size: 28px;
    color: #fff;
}
.l-top .event .event_block .detail dt{
    width: 110px;
    padding: 26px 0;
    font-weight: 900;
    border-bottom: solid 1px #fff;
}
.l-top .event .event_block .detail dd{
    width: 480px;
    padding: 26px 0;
    font-weight: 500;
    border-bottom: solid 1px #fff;
}
.l-top .event .event_block .detail dt:last-of-type{
    border-bottom: none;
}
.l-top .event .event_block .detail dd:last-of-type{
    border-bottom: none;
}
.l-top .event .event_block .btn{
    margin-top: 30px;
}
.l-top .event .event_wrap .btn_detail{
    width: 598px;
    margin: 178px auto 0;
    padding-bottom: 67px;
}
.l-top .btn_check {
    width: 620px;
    margin: 82px auto 0;
}
.l-top .g-nav-bottom{
    position: relative;
    margin-top: 271px;
    padding-bottom: 440px;
}
.l-top .g-nav-bottom::before {
    display: block;
    content: "";
    background-image: url(../img/250715/top/g-nav-bottom_back.webp);
    background-size: 100%;
    position: absolute;
    bottom: 100%;
    left: 0;
    width: 100%;
    height: 245px;
}
.l-top .g-nav-bottom .nav_wrap li:nth-of-type(4) {
    top: 825px;
    left: 75px;
    width: 607px;
}
.l-top .page_attention {
    padding: 105px 0 18px;
    background-color: #FFFF00;
}
.l-top .page_attention ul{
    width: 548px;
    margin: 0 auto;
    font-size: 24px;
}
.l-top .page_attention ul li{
    padding-left: 1em;
    text-indent: -1em;
    line-height: 1.25;
}
.l-top .event_block-01 .artwork{
    margin-top: 4px;
    font-size: 28px;
    font-weight: 500;
    color: #fff;
    text-indent: -0.5em;
}
.l-top .event_block-01 .img-02{
    width: 280px;
    margin: 25px auto 0;
}
.l-top .title-center{
    text-align: center;
}
.l-top .event_block-07 .attention{
    width: 280px;
    margin: 25px auto 0;
    font-size: 28px;
    text-align: center;
    color: #fff;
}
.l-top .text-center{
    text-align: center;
}
.l-top .text-center .text-left{
    display: block;
    text-align: left;
}

@media (max-width: 750px) {
    .l-top .info .lead-text{
        width: 78.667vw;
        margin: 4.2667vw auto 0;
        font-size: 4.267vw;
        font-weight: 700;
    }
    .l-top .info .info_wrap{
        position: relative;
        z-index: 10;
        padding-top: 21.333vw;
    }
    .l-top .info .info_wrap .regist_block,
    .l-top .info .info_wrap .line_block{
        width: 78.667vw;
        margin: 0 auto;
        padding: 5.333vw 5.333vw 8vw;
    }
    .l-top .info .info_wrap .regist_block{
        border-top-left-radius: 5.333vw;
        border-top-right-radius: 5.333vw;
        background-color: #FF862E;
        color: #333333;
    }
    .l-top .info .info_wrap .line_block{
        border-bottom-left-radius: 5.333vw;
        border-bottom-right-radius: 5.333vw;
        background-color: #00B900;
        color: #fff;
    }
    .l-top .info .info_wrap .title{
        width: 111%;
        font-size: 5.467vw;
        line-height: 1.5;
        text-align: center;
        font-weight: 900;
        transform: scale(0.9, 1);
        transform-origin: top left;
        white-space: nowrap;
    }
    .l-top .info .info_wrap .text{
        margin-top: 3.733vw;
        font-size: 4.267vw;
        font-weight: 500;
    }
    .l-top .info .info_wrap .btn{
        margin-top: 5.333vw;
    }
    .l-top .icon-star{
        display: block;
        content: "";
        background-image: url(../img/250715/common/icon_light-02.webp);
        background-size: 100%;
        position: absolute;
    }
    .l-top .info_wrap .icon-star-01{
        background-image: url(../img/250715/common/icon_light-01.webp);
        top: 3%;
        left: 36%;
        width: 9.6vw;
        height: 12vw;
    }
    .l-top .info .info_wrap .icon-star-02{
        top: 1.5%;
        right: 21%;
        width: 4.533vw;
        height: 4.533vw;
    }
    .l-top .info .info_wrap .icon-star-03{
        top: 29%;
        right: 4%;
        width: 4.533vw;
        height: 4.533vw;
    }
    .l-top .info .info_wrap .icon-star-04{
        top: 64.5%;
        left: 3%;
        width: 4.533vw;
        height: 4.533vw;
    }
    .l-top .info .info_wrap .icon-star-05{
        background-image: url(../img/250715/common/icon_light-03.webp);
        bottom: 12%;
        right: 5%;
        width: 8.533vw;
        height: 8.533vw;
    }
    .l-top .info .info_wrap .icon-star-06{
        bottom: -5%;
        left: 26%;
        width: 4.533vw;
        height: 4.533vw;
    }
    .l-top .info .back{
        position: relative;
        background-color: #FFFF00;
        height: 146.667vw;
        margin-top: -130.667vw;
        padding-top: 29.2vw;
    }
    .l-top .info .back::before{
        display: block;
        content: "";
        background-image: url(../img/250715/top/back_img-01.webp);
        background-size: 100%;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 29.2vw;
    }
    .l-top .swiper-contents{
        position: relative;
        padding-bottom: 13.067vw;
        background-color: #FFFF00;
    }
    .swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
        bottom: unset;
        bottom: 5.867vw;
        left: 0;
        width: 100%;
    }
    .swiper-pagination-bullet {
        width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 2.4vw));
        height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 2.4vw));
        background: var(--swiper-pagination-bullet-inactive-color, #FFFFFF);
        border: solid 1px #333333;
        border-radius: 50%;
        opacity: 1;
    }
    .swiper-pagination-bullet-active {
        background: #333333;
    }
    .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
        margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 0.8vw);
    }
    .swiper-button-next, .swiper-button-prev{
        top: 36.533vw;
        cursor: pointer;
    }
    .swiper-button-prev, .swiper-rtl .swiper-button-next {
        left: var(--swiper-navigation-sides-offset, 9.8667vw);
        right: auto;
    }
    .swiper-button-next, .swiper-rtl .swiper-button-prev {
        right: var(--swiper-navigation-sides-offset, 9.8667vw);
        left: auto;
    }
    .swiper-button-prev::after,
    .swiper-button-next::after {
        bottom: 0;
        content: "";
        height: 0;
        margin: auto;
        position: absolute;
        top: 0;
        width: 0;
    }
    /* 前への矢印カスタマイズ */
    .swiper-button-prev::after {
        background-image: url(../img/250715/top/btn_swiper.webp);
        background-size: 100%;
        width: 7.467vw;
        height: 7.467vw;
        transform: rotate(180deg);
    }
    /* 次への矢印カスタマイズ */
    .swiper-button-next::after {
        background-image: url(../img/250715/top/btn_swiper.webp);
        background-size: 100%;
        width: 7.467vw;
        height: 7.467vw;
    }
    .l-top .g-nav{
        position: relative;
        padding-bottom: 40.267vw;
        background-color: #FFFF00;
    }
    .l-top .g-nav .nav_wrap li{
        position: absolute;
        left: 3.067vw;
        width: 86.8vw;
    }
    .l-top .g-nav .nav_wrap li:first-of-type{
        top: 39.867vw;
    }
    .l-top .g-nav .nav_wrap li:nth-of-type(2){
        top: 62vw;
    }
    .l-top .g-nav .nav_wrap li:nth-of-type(3){
        top: 84.267vw;
    }
    .l-top .g-nav .icon-star-01{
        top: -1.8%;
        left: 53%;
        width: 4.533vw;
        height: 4.533vw;
    }
    .l-top .g-nav .icon-star-02{
        background-image: url(../img/250715/common/icon_light-03.webp);
        top: 27%;
        right: 21%;
        width: 8.533vw;
        height: 8.533vw;
    }
    .l-top .g-nav .icon-star-03{
        background-image: url(../img/250715/common/icon_light-03.webp);
        bottom: 2%;
        left: 5%;
        width: 8.533vw;
        height: 8.533vw;
    }
    .l-top .g-nav .icon-star-04{
        bottom: -0.5%;
        left: 15.8%;
        width: 4.533vw;
        height: 4.533vw;
    }
    .l-top .event .event_wrap{
        width: 89.333vw;
        margin: 0 auto;
        background-color: #FF7BC7;
    }
    .l-top .event .event_block{
        width: 78.667vw;
        margin: 0 auto;
        padding-top: 24vw;
    }
    .l-top .event .event_block:first-of-type{
        padding-top: 13.867vw;
    }
    .l-top .event .event_block .title{
        margin-top: 3.467vw;
        font-size: 5.067vw;
        font-weight: 900;
        line-height: 1.5;
        color: #fff;
    }
    .l-top .event .event_block .text{
        margin-top: 4.8vw;
        font-size: 4.267vw;
        font-weight: 700;
        line-height: 1.6;
        color: #333;
    }
    .l-top .event .event_block .label{
        display: flex;
        column-gap: 2.133vw;
        margin-top: 5.867vw;
    }
    .l-top .event .event_block .label li{
        padding: 0.267vw 2.8vw;
        font-size: 3.467vw;
        font-weight: 700;
        color: #333;
        background-color: #fff;
        border-radius: 2.667vw;
    }
    .l-top .event .event_block .date{
        position: relative;
        margin-top: 5.067vw;
        padding: 3.467vw 0;
        font-size: 4.267vw;
        font-weight: 900;
        text-align: center;
        color: #fff;
    }
    .l-top .event .event_block .date::before,
    .l-top .event .event_block .date::after{
        display: block;
        content: "";
        position: absolute;
        left: 0;
        width: 100%;
        height: 0.8vw;
        background-color: #fff;
        border-radius: 1.333vw;
    }
    .l-top .event .event_block .date::before{
        top: 0;
    }
    .l-top .event .event_block .date::after{
        bottom: 0;
    }
    .l-top .event .event_block .detail{
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        font-size: 3.733vw;
        color: #fff;
    }
    .l-top .event .event_block .detail dt{
        width: 14.667vw;
        padding: 3.467vw 0;
        font-weight: 900;
        border-bottom: solid 1px #fff;
    }
    .l-top .event .event_block .detail dd{
        width: 64vw;
        padding: 3.467vw 0;
        font-weight: 500;
        border-bottom: solid 1px #fff;
    }
    .l-top .event .event_block .detail dt:last-of-type{
        border-bottom: none;
    }
    .l-top .event .event_block .detail dd:last-of-type{
        border-bottom: none;
    }
    .l-top .event .event_block .btn{
        margin-top: 4vw;
    }
    .l-top .event .event_wrap .btn_detail{
        width: 79.733vw;
        margin: 23.7334vw auto 0;
        padding-bottom: 8.93334vw;
    }
    .l-top .btn_check {
        width: 82.667vw;
        margin: 10.9334vw auto 0;
    }
    .l-top .g-nav-bottom{
        position: relative;
        margin-top: 36.133vw;
        padding-bottom: 58.667vw;
    }
    .l-top .g-nav-bottom::before {
        display: block;
        content: "";
        background-image: url(../img/250715/top/g-nav-bottom_back.webp);
        background-size: 100%;
        position: absolute;
        bottom: 100%;
        left: 0;
        width: 100%;
        height: 32.667vw;
    }
    .l-top .g-nav-bottom .nav_wrap li:nth-of-type(4) {
        top: 110vw;
        left: 10vw;
        width: 80.933vw;
    }
    .l-top .page_attention {
        padding: 14vw 0 2.4vw;
        background-color: #FFFF00;
    }
    .l-top .page_attention ul{
        width: 73.067vw;
        margin: 0 auto;
        font-size: 3.2vw;
    }
    .l-top .page_attention ul li{
        padding-left: 1em;
        text-indent: -1em;
        line-height: 1.25;
    }
    .l-top .event_block-01 .artwork{
        margin-top: 0.533vw;
        font-size: 3.733vw;
        font-weight: 500;
        color: #fff;
        text-indent: -0.5em;
    }
    .l-top .event_block-01 .img-02{
        width: 37.333vw;
        margin: 3.3333vw auto 0;
    }
    .l-top .title-center{
        text-align: center;
    }
    .l-top .event_block-07 .attention{
        width: 37.333vw;
        margin: 3.3333vw auto 0;
        font-size: 3.733vw;
        text-align: center;
        color: #fff;
    }
    .l-top .text-center{
        text-align: center;
    }
    .l-top .text-center .text-left{
        display: block;
        text-align: left;
    }
}


/* page */

.l-page .main_wrap{
    position: relative;
}
.l-page .main_wrap h1{
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    width: 410px;
}
.l-page .main_wrap .lead{
    padding-top: 4px;
    background-color: #FFFF00;
}
.l-page .main_wrap .lead .lead-inner{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 670px;
    height: 102px;
    margin: 0 auto;
    background-color: #fff;
    border-radius: 50px;
}
.l-page .main_wrap .lead p:first-of-type{
    width: 146px;
}
.l-page .main_wrap .lead p:nth-of-type(2){
    width: 36px;
    margin: 0 10px 0 8px;
    line-height: 0;
}
.l-page .main_wrap .lead p:nth-of-type(3){
    font-size: 22px;
    letter-spacing: 0.02em;
}
.l-page .event{
    padding: 58px 0 166px;
    background-color: #FFFF00;
}
.l-page .event .event_block{
    width: 670px;
    margin: 180px auto 0;
    background-color: #fff;
    border-radius: 40px;
    overflow: hidden;
}
.l-page .event .event_block:first-of-type{
    margin-top: 0;
}
.l-page .event .event_block .event_inner{
    padding: 40px 40px 50px;
}
.l-page .event .event_block .title{
    margin-top: 26px;
    font-size: 38px;
    font-weight: 900;
    line-height: 1.5;
}
.l-page .event .event_block .text{
    margin-top: 36px;
    font-size: 32px;
    font-weight: 700;
    line-height: 1.6;
    color: #333;
}
.l-page .event .event_block .name{
    display: flex;
    justify-content: space-between;
    margin-top: 6px;
}
.l-page .event .event_block .name p{
    width: 48%;
    font-size: 28px;
    font-weight: 500;
    text-align: center;
}
.l-page .event .event_block .event_inner-color{
    padding: 44px 40px 58px;
}
.l-page .event .event_block .label{
    display: flex;
    align-items: flex-end;
    column-gap: 16px;
}
.l-page .event .event_block .label li{
    padding: 2px 21px;
    font-size: 26px;
    font-weight: 700;
    color: #333;
    background-color: #fff;
    border-radius: 20px;
}
.l-page .event .event_block .label .icon-proof{
    width: 146px;
    padding: 0;
    background-color: transparent;
}
.l-page .event .event_block .date{
    position: relative;
    margin-top: 38px;
    padding: 26px 0;
    font-size: 32px;
    font-weight: 900;
    text-align: center;
    color: #fff;
}
.l-page .event .event_block .date::before,
.l-page .event .event_block .date::after{
    display: block;
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    height: 6px;
    background-color: #fff;
    border-radius: 10px;
}
.l-page .event .event_block .date::before{
    top: 0;
}
.l-page .event .event_block .date::after{
    bottom: 0;
}
.l-page .event .event_block .detail{
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    font-size: 28px;
    color: #fff;
}
.l-page .event .event_block .detail dt{
    width: 110px;
    padding: 26px 0;
    font-weight: 900;
    border-bottom: solid 1px #fff;
}
.l-page .event .event_block .detail dd{
    width: 480px;
    padding: 26px 0;
    font-weight: 500;
    border-bottom: solid 1px #fff;
}
.l-page .event .event_block .detail dt:last-of-type{
    border-bottom: none;
}
.l-page .event .event_block .detail dd:last-of-type{
    border-bottom: none;
}
.l-page .event .event_block .detail dd .text-color{
    color: #FF0000;
    font-weight: 700;
}
.l-page .event .event_block .btn{
    margin-top: 30px;
}

.l-page .g-nav-bottom{
    position: relative;
    padding-bottom: 345px;
    background-color: #FFFF00;
}
.l-page .g-nav-bottom .nav_wrap li {
    position: absolute;
    left: 23px;
    width: 651px;
}
.l-page .g-nav-bottom .nav_wrap li:first-of-type{
    top: 350px;
}
.l-page .g-nav-bottom  .nav_wrap li:nth-of-type(2){
    top: 514px;
}
.l-page .g-nav-bottom .nav_wrap li:nth-of-type(3){
    top: 702px;
    left: 75px;
    width: 607px;
}
.l-page .page_attention {
    padding: 105px 0 18px;
    background-color: #FFFF00;
}
.l-page .page_attention ul{
    width: 548px;
    margin: 0 auto;
    font-size: 24px;
}
.l-page .page_attention ul li{
    padding-left: 1em;
    text-indent: -1em;
    line-height: 1.25;
}
@media (max-width: 750px) {
    .l-page .main_wrap h1{
        position: absolute;
        top: 2.667vw;
        left: 50%;
        transform: translateX(-50%);
        width: 54.667vw;
    }
    .l-page .main_wrap .lead{
        padding-top: 0.533vw;
        background-color: #FFFF00;
    }
    .l-page .main_wrap .lead .lead-inner{
        display: flex;
        align-items: center;
        justify-content: center;
        width: 89.333vw;
        height: 13.6vw;
        margin: 0 auto;
        background-color: #fff;
        border-radius: 6.667vw;
    }
    .l-page .main_wrap .lead p:first-of-type{
        width: 19.467vw;
    }
    .l-page .main_wrap .lead p:nth-of-type(2){
        width: 4.8vw;
        margin: 0 1.333vw 0 1.067vw;
        line-height: 0;
    }
    .l-page .main_wrap .lead p:nth-of-type(3){
        font-size: 2.933vw;
        letter-spacing: 0.02em;
    }
    .l-page .event{
        padding: 7.733vw 0 22.133vw;
        background-color: #FFFF00;
    }
    .l-page .event .event_block{
        width: 89.333vw;
        margin: 24vw auto 0;
        background-color: #fff;
        border-radius: 5.333vw;
        overflow: hidden;
    }
    .l-page .event .event_block:first-of-type{
        margin-top: 0;
    }
    .l-page .event .event_block .event_inner{
        padding: 5.333vw 5.333vw 6.667vw;
    }
    .l-page .event .event_block .title{
        margin-top: 3.467vw;
        font-size: 5.067vw;
        font-weight: 900;
        line-height: 1.5;
    }
    .l-page .event .event_block .text{
        margin-top: 4.8vw;
        font-size: 4.267vw;
        font-weight: 700;
        line-height: 1.6;
        color: #333;
    }
    .l-page .event .event_block .name{
        display: flex;
        justify-content: space-between;
        margin-top: 0.8vw;
    }
    .l-page .event .event_block .name p{
        width: 48%;
        font-size: 3.733vw;
        font-weight: 500;
        text-align: center;
    }
    .l-page .event .event_block .event_inner-color{
        padding: 5.867vw 5.333vw 7.733vw;
    }
    .l-page .event .event_block .label{
        display: flex;
        align-items: flex-end;
        column-gap: 2.133vw;
    }
    .l-page .event .event_block .label li{
        padding: 0.267vw 2.8vw;
        font-size: 3.467vw;
        font-weight: 700;
        color: #333;
        background-color: #fff;
        border-radius: 2.667vw;
    }
    .l-page .event .event_block .label .icon-proof{
        width: 19.467vw;
        padding: 0;
        background-color: transparent;
    }
    .l-page .event .event_block .date{
        position: relative;
        margin-top: 5.067vw;
        padding: 3.467vw 0;
        font-size: 4.267vw;
        font-weight: 900;
        text-align: center;
        color: #fff;
    }
    .l-page .event .event_block .date::before,
    .l-page .event .event_block .date::after{
        display: block;
        content: "";
        position: absolute;
        left: 0;
        width: 100%;
        height: 0.8vw;
        background-color: #fff;
        border-radius: 1.333vw;
    }
    .l-page .event .event_block .date::before{
        top: 0;
    }
    .l-page .event .event_block .date::after{
        bottom: 0;
    }
    .l-page .event .event_block .detail{
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        font-size: 3.733vw;
        color: #fff;
    }
    .l-page .event .event_block .detail dt{
        width: 14.667vw;
        padding: 3.467vw 0;
        font-weight: 900;
        border-bottom: solid 1px #fff;
    }
    .l-page .event .event_block .detail dd{
        width: 64vw;
        padding: 3.467vw 0;
        font-weight: 500;
        border-bottom: solid 1px #fff;
    }
    .l-page .event .event_block .detail dt:last-of-type{
        border-bottom: none;
    }
    .l-page .event .event_block .detail dd:last-of-type{
        border-bottom: none;
    }
    .l-page .event .event_block .detail dd .text-color{
        color: #FF0000;
        font-weight: 700;
    }
    .l-page .event .event_block .btn{
        margin-top: 4vw;
    }
    
    .l-page .g-nav-bottom{
        position: relative;
        padding-bottom: 46vw;
        background-color: #FFFF00;
    }
    .l-page .g-nav-bottom .nav_wrap li {
        position: absolute;
        left: 3.067vw;
        width: 86.8vw;
    }
    .l-page .g-nav-bottom .nav_wrap li:first-of-type{
        top: 46.667vw;
    }
    .l-page .g-nav-bottom  .nav_wrap li:nth-of-type(2){
        top: 68.533vw;
    }
    .l-page .g-nav-bottom .nav_wrap li:nth-of-type(3){
        top: 93.6vw;
        left: 10vw;
        width: 80.933vw;
    }
    .l-page .page_attention {
        padding: 14vw 0 2.4vw;
        background-color: #FFFF00;
    }
    .l-page .page_attention ul{
        width: 73.067vw;
        margin: 0 auto;
        font-size: 3.2vw;
    }
    .l-page .page_attention ul li{
        padding-left: 1em;
        text-indent: -1em;
        line-height: 1.25;
    }
}

/* make */

.l-make .event .event_block .title{
    color: #0073CA;
}
.l-make .event .event_block .event_inner-color{
    background-color: #0073CA;
}

/* learn */

.l-learn .event .event_block .title{
    color: #08BF79;
}
.l-learn .event .event_block .event_inner-color{
    background-color: #08BF79;
}

/* experience */

.l-experience .event .event_block .title{
    color: #FF6E49;
}
.l-experience .event .event_block .event_inner-color{
    background-color: #FF6E49;
}