@charset "UTF-8";
/* CSS Document */

/* ========================= [ base ] */

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
button,
textarea,
p,
blockquote,
th,
td {
    margin: 0 auto;
    padding: 0;
    overflow-x: hidden;
    overflow: visible;
}

ul,
ol,
dl {
    list-style: none;
}

img {
    vertical-align: top;
}

body {
    text-align: center;
    font-family: メイリオ, Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Verdana, sans-serif;
    -webkit-text-size-adjust: 100%;
    overflow-x: hidden;
}

a:hover, button:hover {
    filter: brightness(120%);
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;	
}
a:hover img, button:hover img {
    transform: scale(1.05,1.05);
    transition: 0.5s;
}

#sec04 a:hover img, #sec04 button:hover img {
    transform: scale(1.00,1.00);
    transition: 0.5s;
}

a,a:hover, a:visited{
    color: inherit;
	cursor: pointer;
	text-decoration: none;
}

button{
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
}

*,
::before,
::after {
    background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
    box-sizing: inherit;
}

::before,
::after {
    text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
    vertical-align: inherit;
}

* {
    padding: 0; /* Reset `padding` and `margin` of all elements */
    margin: 0;
}

body {
    opacity: 0; /* 最初は完全に透明 */
    animation: fadeIn 2s ease-in-out forwards; /* fadeInアニメーションを1秒かけて実行し、終了状態を維持 */
}
@keyframes fadeIn {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
}

#dmm_ntgnavi {
    /*
    position: relative;
    */
    position: fixed;
    z-index: 999;
    width: 100%;
    background: url(../images/bg_navimain.gif) center center repeat-x;
    border-bottom: 1px solid #ccc;
    border-top: 1px solid #ccc;
    font-size: 12px;
    font-family: 'メイリオ', 'Meiryo', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', 'ＭＳ Ｐゴシック', Verdana, sans-serif;
    display: flex;
    justify-content: space-between;
}

#dmm_ntgnavi ul {
    list-style: none;
    margin: 2px 0;
    padding: 0;
    display: flex;
    width: 50%;
}

#dmm_ntgnavi ul li {
    margin: 0 6px 0 0;
    line-height: 15px;
}

#dmm_ntgnavi .navi_left li > a {
    display: block;
    padding: 0 3px 0 8px;
    text-decoration: none;
    border: 1px solid #eee;
    border-radius: 3px;
}

#dmm_ntgnavi .navi_left li > a:hover {
    background: #eee;
    border: 1px solid #666;
    border-radius: 3px;
}

#dmm_ntgnavi .navi_left li > a span {
    display: block;
    padding: 9px 10px 7px 28px;
    color: #333;
    font-weight: bold;
}

#dmm_ntgnavi .navi_left li.dmm_top img {
    margin: 8px 5px 8px 0
}

#dmm_ntgnavi .navi_left li.ntg_top {
    margin-left: 10px;
}

#dmm_ntgnavi .navi_left li.ntg_top span {
    background: url(../images/bg_bt_olgtop.gif) 0 center no-repeat;
    font-size: min(2.9vw,12px);
}

#dmm_ntgnavi .navi_right {
    justify-content: flex-end;
    font-size: 10px;
}

#dmm_ntgnavi .navi_right li {
    margin: 0 10px 0 0;
    padding: 8px 5px;
}

#dmm_ntgnavi .arrow {
    padding-left: 14px;
    background: url(../images/arrow_common.gif) no-repeat left center;
}

#dmm_ntgnavi .tx-point {
    font-size: 16px;
    font-weight: bold;
    color: #ff4b4b !important;
}

#dmm_ntgnavi a {
  color: inherit;
  text-decoration: none;
}

#dmm_ntgnavi p {
    margin: 0;
    line-height: 2.6em;
}

#dmm_ntgnavi .clear {
    clear: both;
}

main {
    margin: 0;
    padding: 0;
    overflow: hidden;
}

@media (min-width: 1024px) {
    .invisible-pc {
        display: none;
    }
}


/*bgvideo*/
.bg_media {
    width: 100%;
    height: 100%;
    /*
    position: fixed;
    */
    position: absolute;
    top: 0;
    left: 0;
    z-index:-2;
    text-align: center;
    background-size: cover;
    object-fit: cover;
    overflow: hidden;
    /*
    opacity: 0.5;
    */
    background: #fff;
}
        
.bg_media video {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    -o-object-fit: cover;
    object-fit: cover;
}

.video-wrapper {
    position: relative;
    width: 100%;
    height: 100vh; /* 必要に応じて調整 */
    overflow: hidden;
}
  .video-wrapper video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
  .bg_dot {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0px;
    top: 0px;
    background: url('../images/bg_dot.webp');
    opacity: 0.5;
    z-index: 1;
}
  
  



#fv {
    width: 100%;
    height: 950px;
    top: 0px;
    position: relative;
    z-index: 100; /* z-index を 0 に変更 */
	overflow: hidden;
    border-bottom: 2px solid #000064;
}
#fv h1 {
    position: relative;
    z-index: 200;
    margin: 0px auto 0px auto;
    top: 50px;
}    
#fv h1 img {
    width: 300px;
}    
#fv h2 {
    position: relative;
    z-index: 200;
    margin: 0px auto 0px auto;
    top: 80px;
}    
#fv h2 img {
    width: 657px;
}    

[data-aos=rotate]{ transform: rotate(0deg); }
[data-aos=rotate].aos-animate{ transform: rotate(360deg); }
[data-aos=rotate]{ transform: rotate(0deg); }
[data-aos=rotate].aos-animate{ transform: rotate(360deg); }


#fv .idol001 {
    position: relative;
    z-index: 20;
    background: url(../images/fv_ob02.webp) repeat-x center center;
    /*
    background-size: cover;
    */
    background-size: auto 260px;
    margin: 0px auto;
    text-align: center;
    top: 80px;
    width : 100%;
    height: auto;
    max-height: 260px;
}    
[data-aos=HorizontalOpen]{ clip-path:inset(0 1000px); }
[data-aos=HorizontalOpen].aos-animate{ clip-path:inset(0 0); }
[data-aos=HorizontalOpenT]{ clip-path:inset(1000px 0); }
[data-aos=HorizontalOpenT].aos-animate{ clip-path:inset(0 0); }

#fv .idol001 .obmd {
    position: relative;
    z-index: 25;
    top: -140px;
    width: 500px;
}
#fv h3 {
    position: relative;
    z-index: 200;
    margin: 0px auto 0px auto;
    top: 180px;
}    
#fv h3 img {
    width: 457px;
}    
#fv .idol001 .obtxt {
    position: relative;
    z-index: 100;
    top: 70px;
    /*
    width: 500px;
    */
    height: 230px;
}
#fv .idol001 .obtxt p {
    color: #ffffff;
    font-size: 7.5em;
    line-height: 0.7em;
    letter-spacing: 0.1em;
    font-family: "kozuka-gothic-pr6n", sans-serif;
    font-weight: 900;
    font-style: normal;
    
    text-shadow: #000064 4px 4px;
    -webkit-text-stroke-width: 4px;
    -webkit-text-stroke-color: #000064;
}
#fv .aol {
    position: relative;
    z-index: 35;
    top: 60px;
    width: 839px;
}
#fv .aol img {
    width: 100%;
}
#fv .ohen {
    position: relative;
    z-index: 45;
    top: -185px;
    right: -415px;
    width: 139px;
}
#fv .ohen img {
    width: 100%;
}

@keyframes bounce {
    from,
    10%,
    26.5%,
    50%,
    to {
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
        transform: translate3d(0, 0, 0);
    }
    20%,
    21.5% {
        animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
        transform: translate3d(0, -30px, 0) scaleY(1.1);
    }
    35% {
        animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
        transform: translate3d(0, -15px, 0) scaleY(1.05);
    }
    40% {
        transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
        transform: translate3d(0, 0, 0) scaleY(0.95);
    }
    45% {
        transform: translate3d(0, -4px, 0) scaleY(1.02);
    }
}

.bounce {
    animation-name: bounce;
    transform-origin: center bottom;
    animation-fill-mode: both;
    animation-iteration-count: infinite;
    animation-duration: 2.5s;
}

#fv .title .idol002 {
    position: relative;
    z-index: 25;
    margin: 0px auto;
    top: 115px;
    right: 0;
    width : 100%;
}    
#fv .title .idol002 img {
    width: 1390px;
}    
#fv .title .capt01 {
    position: relative;
    z-index: 250;
    margin: 0px auto 0px auto;
    top: -490px;
    width: 530px;
}    
#fv .title .capt01 a {
    width: 530px;
    height: 122px;
}    
#fv .title .capt01 img {
    width: 530px;
    box-shadow: 5px 5px 5px -2px #333;
}    






@media (min-width: 391px) and (max-width:739px) {

#fv {
    width: 100%;
    height: 103vw;
    top: 0px;
    position: relative;
    z-index: 100; /* z-index を 0 に変更 */
	overflow: hidden;
    border-bottom: 2px solid #000064;
}
#fv h1 {
    position: relative;
    z-index: 200;
    margin: 0px auto 0px auto;
    top: 40px;
}    
#fv h1 img {
    width: 25%;
}    
#fv h2 {
    position: relative;
    z-index: 200;
    margin: 0px auto 0px auto;
    top: 8vw;
}    
#fv h2 img {
    width: 75%;
}    


#fv .idol001 {
    position: relative;
    z-index: 20;
    background: url(../images/fv_ob02.webp) no-repeat center center;
    background-size: cover;
    /*
    */
    margin: 0px auto;
    text-align: center;
    top: 8vw;
    width: 100%;
    height: 30vw;
    max-height: 440px;
    /*
    */
}    
[data-aos=HorizontalOpen]{ clip-path:inset(0 1000px); }
[data-aos=HorizontalOpen].aos-animate{ clip-path:inset(0 0); }
[data-aos=HorizontalOpenT]{ clip-path:inset(1000px 0); }
[data-aos=HorizontalOpenT].aos-animate{ clip-path:inset(0 0); }

#fv .idol001 .obmd {
    position: relative;
    z-index: 25;
    top: 3.7vw;
    width: 65vw;
}
#fv .idol001 .obmd img {
    width: 100%;
}
#fv h3 {
    position: relative;
    z-index: 200;
    top: 0;
    width: 65vw;
}    
#fv h3 img {
    width: 457px;
}    
#fv .idol001 .obtxt {
    position: relative;
    z-index: 100;
    top: 7.0vw;
    width: 97%;
    height: auto;
}
#fv .idol001 .obtxt p {
    width: 100%;
    color: #ffffff;
    font-size: 13.5vw;
    line-height: 0.8em;
    letter-spacing: 0.1em;
    font-family: "kozuka-gothic-pr6n", sans-serif;
    font-weight: 900;
    font-style: normal;
    
    text-shadow: #000064 3px 3px;
    -webkit-text-stroke-width: 2px;
    -webkit-text-stroke-color: #000064;
}
#fv .aol {
    position: relative;
    z-index: 35;
    top: 5.8vw;
    width: 97vw;
}
#fv .aol img {
    width: 100%;
}
#fv .ohen {
    position: relative;
    z-index: 45;
    top: -55vw;
    right: -41vw;
    width: 15vw;
}
#fv .ohen img {
    width: 100%;
}

@keyframes bounce {
    from,
    10%,
    26.5%,
    50%,
    to {
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
        transform: translate3d(0, 0, 0);
    }
    20%,
    21.5% {
        animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
        transform: translate3d(0, -30px, 0) scaleY(1.1);
    }
    35% {
        animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
        transform: translate3d(0, -15px, 0) scaleY(1.05);
    }
    40% {
        transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
        transform: translate3d(0, 0, 0) scaleY(0.95);
    }
    45% {
        transform: translate3d(0, -4px, 0) scaleY(1.02);
    }
}

.bounce {
    animation-name: bounce;
    transform-origin: center bottom;
    animation-fill-mode: both;
    animation-iteration-count: infinite;
    animation-duration: 2.5s;
}

#fv .title .idol002 {
    position: relative;
    z-index: 25;
    margin: 0px auto;
    top: 115px;
    right: 0;
    width : 100%;
}    
#fv .title .idol002 img {
    width: 1390px;
}    
#fv .title .capt01 {
    position: relative;
    z-index: 250;
    margin: 0px auto 0px auto;
    top: -490px;
    width: 530px;
}    
#fv .title .capt01 a {
    width: 530px;
    height: 122px;
}    
#fv .title .capt01 img {
    width: 530px;
    box-shadow: 5px 5px 5px -2px #333;
}    

}


@media screen and (max-width:1024px) {

#fv .ohen {
    position: relative;
    z-index: 45;
    top: -43vw;
    right: -41vw;
    width: 15vw;
}
#fv .ohen img {
    width: 100%;
}


}



#content {
    border-top: 4px solid #5af5d2;
}
    @keyframes pc-bg {
	    0% {
		    background-position: center 0
	    }
	    100% {
		    background-position: center -237.0833333333vw;
	    }
    }

.fvbg {
	position: relative;
	width: 100%;
	height: 103.078125vw;
	z-index: 50;
}
    @media print, screen and (min-width:739px) {
	    .fvbg {
		    height: 952px;
            border-bottom: 6px solid #5af5d2;
	    }
    }
.fvbg_Wrapper {
	width: 100%;
	height: 100%;
	position: relative;
	overflow: hidden
}
.fvbg_Inner {
	width: 100%;
	height: 100%;
	position: relative;
	overflow: hidden
}
.fvbg_Contents {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	display: none
}

.wrapper {
	position: relative;
    z-index: 0;
        background: url(../images/bg.webp) repeat;
        background-position:0%;
        background-size: auto;
        animation: pc-bg 400s linear infinite;
}
@media screen and (max-width:740px) {
.wrapper {
	position: relative;
    z-index: 200;
}
}
@media screen and (min-width:739px) {
	.content_wrapper {
		width: 780px;
		margin: 0 auto 0px auto;
		position: relative;

	}
	.content_wrapper::before {
		content: "";
		display: block;
		position: fixed;
        z-index: -5;
		width: 800px;
		top: 0px;
		left: 0;
		right: 0;
        bottom: 10px; 
		margin: 0 auto 10px auto;
	}
}

@media screen and (min-width:739px) {
	.content_right {
		width: calc((100% - 740px) * .5);
		height: 100dvh;
        background-position:0%;
        background-size: auto;
        animation: pc-bg 400s linear infinite;
		position: fixed;
		left: 0;
		top: 0px;
	}
}
@keyframes pc-bg {
	0% {
		background-position: center 0
	}
	100% {
		background-position: center -237.0833333333vw;
	}
}


@media screen and (max-width:739px) {
	.content_right {
		display: none
	}
}

@media print, screen and (min-width:739px) {
	.content_left {
		width: calc((100% - 740px) * .5);
		height: 100dvh;
        background-size: auto;
        animation: pc-bg 400s linear infinite;
        border-top: 4px solid #5af5d2;
		position: fixed;
		right: 0;
		top: 0px;
		display: -webkit-box;
		display: -webkit-flex;
		display: flex;
		-webkit-box-align: center;
		-webkit-align-items: center;
		align-items: center;
		padding-left: clamp(10px, 8.3333333333vw, 160px)
	}
}
@media screen and (max-width:1400px) {
	.content_left {
		padding-left: 5.2083333333vw
	}
}
@media screen and (max-width:739px) {
	.content_left {
		width: calc(100% - 520px - 100px);
		padding-left: 0
	}
}
@media screen and (max-width:739px) {
	.content_left {
		display: none
	}
}


.content_main {
	position: relative;
	z-index: 2;
	padding: 0.0677083333vw 0 0;
}
.content_main::before {
	content: "";
	display: block;
	position: absolute;
	height: 165.1041666667vw;
    margin-bottom: 10px;
    padding-bottom: 10px;
	width: 100%;
}
@media screen and (min-width:1025px) {
	.content_main::before {
		height: 858.436px;
	}
}
@media screen and (min-width:1025px) {
	.content_main {
        background: 0 0;
		padding: 0px 0 0;
	}
}

@media screen and (min-width:1025px) {
	.sectionbg {
        width: 740px;
        background-color: #fff;
		padding: 0px 0 0;
	}
}

#sec01 {
    position: relative;
    z-index: 100;
    background: url(../images/sec01_bg02.webp) no-repeat center -80px;
    background-size: 100%;
    margin: 0 auto 0 auto;
    top: 0px;
    width: 740px;
    /*height: 2740px;*/
    height: auto;
}
#sec01 h3 {
    margin: 0px auto 20px auto;
    padding-top: 70px;
}
#sec01 h3 img {
    width: 680px;
}

#sec01 .cont {
    /*display: flex;*/
    width: 800px;
    flex-wrap: wrap;
    margin-left: -33px;
}
#sec01 .frm01 {
    position: relative;
    z-index: 100;
    background: url(../images/sec01_frame01.webp) no-repeat center top;
    background-size: contain;
    width: 89%;
}
#sec01 .cont .txt {
    width: 740px;
    margin: 0px auto;
    padding-top: 0px;
}
#sec01 .cont .txt img {
    width: 740px;
}
#sec01 .cont .achieve {
    width: 800px;
    margin: 0px auto 25px auto;
}
#sec01 .cont .achieve img {
    width: 700px;
}
/*
#sec01 .cont .achieve03 {
    width: 800px;
    margin: 0px auto 35px -30px;
}
#sec01 .cont .achieve03 img {
    width: 700px;
}
*/
#sec01 .cont .achieve60 {
    width: 700px;
    margin: -30px auto 0px auto;
}
#sec01 .cont .achieve70 {
    width: 700px;
    margin: -30px auto 0px auto;
}
#sec01 .cont .achieve90 {
    width: 700px;
    margin: -30px auto 5px auto;
}
#sec01 .cont .achieve100 {
    width: 700px;
    margin: 0px auto 5px auto;
}
#sec01 .cont .achieve100fkds {
    position: relative;
    z-index: 100;
    top: -100px;
    width: 222px;
    margin: 0px 40px 5px auto;
}
#sec01 .cont .achieve100fkds img {
    width: 100%;
}
#sec01 .cont .achieve60 img, #sec01 .cont .achieve70 img, #sec01 .cont .achieve90 img, #sec01 .cont .achieve100 img #sec01 .cont .achieve90 img, #sec01 .cont .achieve100 img {
    width: 100%;
}



#sec01 .cont .deco01 {
    position: relative;
    z-index: 100;
    top: -1320px;
    width: 800px;
    margin: 0px auto -1320px auto;
}
#sec01 .cont .deco01 img {
    width: 100%;
}



#sec01 .cont .txt_add {
    position: relative;
    z-index: 110;
    top: -50px;
    /*
    left: 50%;
    transform: translateX(-50%);
    */
    width: 550px;
    padding-top: 70px;
    margin: 0 auto -50px auto;
}
#sec01 .cont .txt_add img {
    width: 100%;
}
#sec01 .cont .leftcha {
    position: relative;
    z-index: 100;
    top: -200px;
    left: -330px;
    width: 140px;
    margin: 0 auto -200px auto;
}
#sec01 .cont .leftcha img {
    width: 100%;
}
#sec01 .cont .rightcha {
    position: relative;
    z-index: 100;
    top: -260px;
    right: -330px;
    width: 170px;
    margin: 0 auto -200px auto;
}
#sec01 .cont .rightcha img {
    width: 100%;
}


#sec01 .frm02 {
    position: relative;
    z-index: 120;
    top: -120px;
    background: url(../images/sec01_frame02.webp) no-repeat top center;
    background-size: 100%;
    width: 89%;
    margin: 0px auto -90px auto;
    padding-bottom: 100px;
}

#sec01 .cont .achieve210 {
    width: 700px;
    margin: 30px auto 5px auto;
    padding-top: 50px;
}
#sec01 .cont .achieve220 {
    width: 700px;
    margin: 0px auto 5px auto;
    padding-top: 20px;
    padding-bottom: 30px;
}
#sec01 .cont .achieve210 img, #sec01 .cont .achieve220 img {
    width: 100%;
}


#sec01 .cont .deco02 {
    position: relative;
    z-index: 190;
    top: -1320px;
    width: 800px;
    margin: 0px auto -1320px auto;
}
#sec01 .cont .deco02 img {
    width: 100%;
}





#sec01 .cont .slide {
    width: 800px;
    margin: 125px auto 5px 5px;
}
#sec01 .cont .slide img {
    width: 740px;
}


#sec01 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: 10px;
    left: 3px;
}

.slider-container {
  width: 740px; /* 表示したい画像の幅の合計 (300px * 3枚 = 900px) */
  height: 204px; /* 画像の高さに合わせる */
  overflow: hidden; /* この範囲外の画像を非表示にする */
  /*
  border: 2px solid #ccc;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  border-radius: 0px;
  */
}

.slider-track_left {
  display: flex; /* 画像を横並びにする */
  width: calc(378px * 8); /* 画像1枚の幅 * 全ての画像枚数 (300px * (3+3) = 1800px) */
  animation: slide-left 45s linear infinite; /* アニメーションの設定 */
}
.slider-track_right {
  display: flex; /* 画像を横並びにする */
  width: calc(378px * 8); /* 画像1枚の幅 * 全ての画像枚数 (300px * (3+3) = 1800px) */
  animation: slide-right 45s linear infinite; /* アニメーションの設定 */
}

.slider-track img {
  width: 378px; /* 画像1枚の幅 */
  height: 204px; /* 画像1枚の高さ */
  object-fit: cover; /* 画像の縦横比を保ちつつコンテナに収める */
  display: block; /* img要素のデフォルト余白をなくす */
}

/* キーフレームアニメーション */
@keyframes slide-left {
  0% {
    transform: translateX(0); /* 開始位置 */
  }
  100% {
    /* (画像1枚の幅 * 元の画像の枚数) 分だけ左に移動 */
    /* 300px * 3 = 900px */
    transform: translateX(-3024px); /* 終了位置 */
  }
}

@keyframes slide-right {
  0% {
    transform: translateX(-3024px); /* 開始位置 */
  }
  100% {
    /* (画像1枚の幅 * 元の画像の枚数) 分だけ左に移動 */
    /* 300px * 3 = 900px */
    transform: translateX(0px); /* 終了位置 */
  }
}


#sec02 {
    position: relative;
    z-index: 100;
	background: url(../images/sec02_bg2.webp) no-repeat center 0px;
    background-size: 100%;
    margin: 0 auto 0 auto;
    top: 0px;
    width: 740px;
    height: 2082px;
}
#sec02 h3 {
    margin: 10px auto 20px auto;
    padding-top: 80px;
}
#sec02 h3 img {
    width: 680px;
}
#sec02 .cont {
    margin: 50px auto 20px auto;
    text-align: center;
}
#sec02 .cont .txt {
    width: 583px;
    margin: 0px auto;
    padding-top: 65px;
}
#sec02 .cont .txt img {
    width: 100%;
}

#sec02 ul {
    position: relative;
    display: flex;
    width: 740px;
    margin: 50px auto 30px auto;
    margin-left: 23px;
    flex-wrap: wrap;
}
#sec02 ul li {
    position: relative;
	background: url(../images/sec02_mbox.webp) no-repeat center 0px;
    background-size: 100%;
    width: 338px;
    height: 437px;
    margin: 10px 5px 0px 5px;
}
#sec02 ul li .thum {
    position: relative;
    z-index: 100;
    margin-top: 17px;
    top: -1px;
    width: 320px;
    height: 180px;
}
#sec02 ul li .thum img {
    position: relative;
    z-index: 100;
    width: 100%;
}

/*
#sec02 ul li .thum::after {
    position: relative;
    z-index: 200;
	content: url("../images/sec02_play178.webp") no-repeat center center;
    display: inline-block;
    width: 178px;
    height: 178px;
}
#sec02 ul li .thum::before {
    content: url(../images/sec02_play178.webp);
    display: block;
    position: relative;
    z-index: 200;
    top: 5px;
    left: 2px;
}
*/
#sec02 ul li .thumplay {
    position: relative;
    z-index: 200;
    top: -180px;
    left: 3px;
    width: 178px;
    height: 178px;
}
#sec02 ul li .thumplay img {
    width: 100%;
}
#sec02 ul li .thumcircle {
    position: relative;
    z-index: 200;
    top: -368px;
    width: 178px;
    height: 178px;
}
#sec02 ul li .thumcircle img {
    width: 100%;
}
#sec02 ul li .thumcircle button {
    position: relative;
    z-index: 300;
    top: 5px;
    left: -2px;
    display: inline-block;
    width: 100%;
    height: 178px;
}
#sec02 ul li .thumcircle button:hover {
    position: relative;
    opacity: 0.9;
    animation: 3s linear infinite rotation;
}
@keyframes rotation {
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}
#sec02 ul li .thumtitle {
    position: relative;
    z-index: 200;
    top: -323px;
    /*
    */
    font-family: "kozuka-gothic-pr6n", sans-serif;
    font-family: "fot-seurat-pron", sans-serif;
    font-style: normal;
    color: #000064;
}
#sec02 ul li .thumtitle p.unit {
    font-weight: 700;
    font-size: 27px;
    line-height: 40px;
}
#sec02 ul li .thumtitle p.title {
    padding-top: 0.2vw;
    font-weight: 500;
    font-size: 21px;
    line-height: 27px;
}
#sec02 ul li .btnx {
    position: relative;
    z-index: 200;
    top: -275px;
    width: 311px;
}
#sec02 .cont .btnx img {
    width: 100%;
}
#sec02 ul li button:hover {
    filter: brightness(200%);
    filter: hue-rotate(-10deg);
    filter: contrast(120%);
    transform: scale(1.01);
}
#sec02 .cont .slide {
    margin: 110px auto 5px auto;
}
#sec02 .cont .slide img {
    width: 740px;
}
#sec02 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: 55px;
}



#sec03 {
    position: relative;
    z-index: 100;
	background: url(../images/sec03_bg.webp) no-repeat center 0px;
    margin: 0 auto 0px auto;
    top: -10px;
    width: 740px;
    height: 1080px;
}
#sec03 h3 {
    margin: 10px auto 20px auto;
    padding-top: 50px;
}
#sec03 h3 img {
    width: 680px;
}


/* CTA /////////////////////////////////////// */

@media (min-width: 1024px) {
  .cta {
    padding-top: 0px;
  }
}
.cta img {
    width: 100%;
    height: auto;
}
.cta .cta__wrapper {
    position: relative;
    width: 714px;
    height: 320px;
    margin: 0 auto;
    background-image: url('../images/sec03_ctaspbg.webp');
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: center;
}
@media (min-width: 768px) {
  .cta .cta__wrapper {
    width: 714px;
    height: 250px;
    background-image: url('../images/sec03_ctabg.webp');
  }
}
.cta .cta__wrapper .cta__title {
  position: absolute;
  left: 50%;
  top: 5vw;
  width: 60%;
  height: auto;
  margin: 0 auto;
  transform: translate(-50%, -100%);
}
@media (min-width: 1024px) {
  .cta .cta__wrapper .cta__title {
    top: 40px;
    width: 60%;
  }
}
.cta .cta__deco_wrapper .cta__deco1 {
  position: absolute;
  left: 102%;
  top: 290px;
  width: 160px;
  height: auto;
  margin: 0 auto;
  transform: translate(-50%, -100%);
  z-index: 1;
  pointer-events: none;
}
.cta .cta__deco_wrapper .cta__deco2 {
  position: absolute;
  left: 2%;
  top: 300px;
  width: 200px;
  height: auto;
  margin: 0 auto;
  transform: translate(-50%, -100%);
  z-index: 1;
  pointer-events: none;
}
.cta .cta__deco_wrapper .cta__deco3 {
  position: absolute;
  left: 100%;
  top: 300px;
  width: 120px;
  height: auto;
  margin: 0 auto;
  transform: translate(-50%, -100%);
  z-index: 1;
  pointer-events: none;
}
.cta .cta__deco_wrapper {
  position: relative;
  width: 92vw;
  height: 41vw;
  margin: 0 auto;
}
@media (min-width: 1024px) {
  .cta .cta__deco_wrapper {
    width: 800px;
    height: auto;
  }
}
.cta .cta__wrapper .cta__button-wrapper--sp {
  width: 100%;
  height: 100%;
  text-align: center;
}
@media (min-width: 768px) {
  .cta .cta__wrapper .cta__button-wrapper--sp {
    display: none;
  }
}
.cta .cta__wrapper .cta__button-wrapper--sp .cta__content--sp .cta__button {
  display: block;
  width: 35vw;
  margin: 0 auto;
}
.cta
  .cta__wrapper
  .cta__button-wrapper--sp
  .cta__content--sp
  .cta__button
  > img {
  width: 100%;
}
.cta .cta__wrapper .cta__button-wrapper--sp .cta__content--sp .cta__taxt {
  display: block;
  width: 75vw;
  margin: 2vw auto;
  position: relative;
  z-index: 100;
}
.cta .cta__wrapper .cta__button-wrapper--pc {
  display: none;
}
@media (min-width: 768px) {
  .cta .cta__wrapper .cta__button-wrapper--pc {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    padding: 22px 14px 0;
  }
}
@media (min-width: 768px) {
  .cta .cta__wrapper .cta__button-wrapper--pc .cta__content {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    margin-top: 20px;
    gap: 0;
  }
  .cta .cta__wrapper .cta__button-wrapper--pc .cta__content:nth-of-type(n + 2) {
    margin-left: 18px;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-head {
    width: 98%;
    margin: 0 auto;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-head
    > img {
    width: auto;
    height: 20px;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__pc-button-wrapper {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-top: 35px;
    width: 486px;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__pc-button-wrapper
    .cta__device-pc
    .cta__pc-button {
    display: block;
    transition: filter 0.2s ease-in-out;
    cursor: pointer;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-qr {
    width: 77%;
    height: auto;
    margin: 0 auto;
    padding: 7px;
    margin-left: 70px;
    margin-top: 75px;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-qr
    > img {
    width: 100%;
    height: auto;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox {
    margin-top: 6px;
    color: #6e647d;
    
    font-family: "fot-seurat-pron", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-feature-settings: 'palt';
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-checkbox-text {
    display: flex;
    align-items: center;
    margin-top: 5px;
    font-size: 14px;
    letter-spacing: 0.05rem;
    text-indent: 0.05rem;
    line-height: 1;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-checkbox-text
    .cta__device-pc-checkmark {
    width: 16px;
    height: 16px;
    margin: 0 5px 0 0;
    accent-color: #ff73bc;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-checkbox-text
    > label {
    line-height: 1;
    cursor: pointer;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-checkbox-text
    > label:hover {
    text-decoration: underline;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-provider {
    margin-top: 5px;
    line-height: 1;
    font-size: 14px;
    text-align: left;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-provider
    .dealer_name {
    font-size: 120%;
  }
}



#sec03 .txt {
    margin: 0px auto;
    padding-top: 5px;
    width: 586px;
}
#sec03 .txt img {
    width: 100%;
}

#sec03 ul.sec04ul {
    position: relative;
    display: flex;
    width: 760px;
    margin: 20px auto 30px auto;
    margin-left: 23px;
    flex-wrap: wrap;
}
#sec03 ul.sec04ul li {
    position: relative;
    width: 340px;
    height: auto;
    margin: 10px 5px 0px 5px;
}
#sec03 ul.sec04ul li img {
    width: 335px;
    height: auto;
}

#sec03 .slide {
    margin: 48px auto 0px auto;
}
#sec03 .slide img {
    width: 740px;
}
#sec03 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: 0px;
}



#sec04 {
    position: relative;
    z-index: 100;
	background: #ffa6e7;
    margin: 0 auto 0px auto;
    top: 0px;
    width: 740px;
    height: 90px;
    box-shadow: 
    /* 右側の影 */
    10px 0 10px -5px rgba(0, 0, 0, 0.3), 
    /* 左側の影 */
    -10px 0 10px -5px rgba(0, 0, 0, 0.3);
}

#sec04 .footer__link-wrapper .footer__links {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0vw auto;

    position: relative;
    top: 25px;
    width: 740px;
    font-family: "fot-seurat-pron", sans-serif;
    font-style: normal;
    color: #ffffff;
}

#sec04 
  .footer__link-wrapper
  .footer__links:nth-of-type(n + 2) {
  margin-top: 2vw;
}

@media (min-width: 1024px) {
  #sec04 
    .footer__link-wrapper
    .footer__links:nth-of-type(n + 2) {
    margin-top: 12px;
  }
}

#sec04 
  .footer__link-wrapper
  .footer__links
  .footer__link-item {
  display: flex;
  align-items: center;
  padding: 10px 5px;
  line-height: 1;
}



.popup {
    display: none; /* 最初は非表示 */
    position: fixed; /* 画面全体に固定 */
    z-index: 900;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /*background-color: rgba(0, 0, 0, 0.5); /* 半透明の背景 */
    justify-content: center;
    align-items: center;
  }
  
  .popup-content {
    padding: 0px 0px;
    position: relative; /* closeボタンの配置基準 */
  }
  
  #close-popup {
    position: absolute;
    top: -40px;
    right: -40px;
    cursor: pointer;
    color: #ddd;
    font-size: 48px;
    font-weight: inherit;
  }
  
  #youtube-player {
    width: 960px; /* ポップアップの動画サイズ */
    height: 540px;
  }


@media screen and (max-width:768px){
   
    #sec02 {
        position: relative;
        height: auto;
    }
    #sec02 .bgleft {
        display: none;;
    }
    #sec02 .bgright {
        display: none;;
}    
    .popup {
        display: none; /* 最初は非表示 */
        position: fixed; /* 画面全体に固定 */
        z-index: 900;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        margin: 0 auto;
        background-color: rgba(0, 0, 0, 0.5); /* 半透明の背景 */
        justify-content: center;
        align-items: center;
    }
  
    .popup-content {
        padding: 0px 0px;
        position: relative; /* closeボタンの配置基準 */
        width: 90%;
        height: auto;
    }
    #sec04 .popup-content {
        padding: 0px 0px;
        position: relative; /* closeボタンの配置基準 */
        width: 90%;
        height: 90%;
    }
  
  
    #close-popup {
        position: absolute;
        top: -30px;
        right: -10px;
        cursor: pointer;
        color: #fff;
        font-size: 24px;
        font-weight: inherit;
    }
  
    #youtube-player {
        width: 100%; /* ポップアップの動画サイズ */
        height: auto;
        &::before {
        content: '';
        display: block;
        padding-top: 56.25%;
        }
    & > iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        }
    }
}
    


/*追従BTN*/
#page_btn {
    position: fixed;
    right: 20px;
    bottom: 0;
    z-index: 99;
}
    
#page_btn:hover{
    filter: brightness(120%);
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;	
}

.common-footer .copy{
    position: relative;
    top: 30px;
    color: #fff;
    font-size: 14px;
    z-index: 2;
}

footer{
    position: relative;
    z-index: 698;
    background: #ffa6e7;
    border-top: 1px solid #ffa6e7;
    height: 80px;
    }

    
@media screen and (max-width:768px){
    .common-footer{
        flex-direction: column;
        text-align: center;
    }
    .common-footer p{
        margin-top: 20px;
        font-size: 10px;
    }
}

    


/*:: ■■ SP ■■ ::*/

* {
    box-sizing: border-box; /* すべての要素にbox-sizingを適用 */
}

@media (max-width: 740px) {
    .invisible-sp {
        display: none;
    }


    /*bgvideo*/
    .bg_media {
	    max-width: 1024px;
        width: 100%;
        height: 100%;
        /*
        position: fixed;
        */
        top: 0;
        left: 0;
        z-index:-2;
	    overflow: hidden;
        opacity: 0.5;
	    background: #FFFFFF;
    }	

    .bg_media video {
        width: 100%;
        height: 103.5vw;
        position: absolute;
        top: 0;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        -o-object-fit: cover;
        object-fit: cover;
	    overflow: hidden;
    }
	
	
	
    @keyframes slideIn {
        from {
            transform: translateY(-100%);
        }
        to {
            transform: translateY(0);
        }
    }	
	
		
	


    #fv {
	    overflow: hidden;
        }


    #fv .title .idol001 {
        display: none;
    }    
    #fv .title .idol002 {
        display: none;
    }    
    #fv .title h1 {
        position: relative;
        z-index: 200;
        margin: 100% auto 0px auto;
        top: 0;
        right: 0;
    }    

    #fv .title h1 img {
        width: 50%;
    }    
    #fv .title .capt01 {
        position: relative;
        z-index: 100;
        top: 0;
        margin: 0% auto 0px auto;
        padding-bottom: 7%;
        width: 92%;
        box-shadow: none;
    }  
    #fv .title .capt01 img {
        width: 100%;
        box-shadow: 3px 3px 3px -2px #333;
    }    
    #fv .ohen {
        position: relative;
        z-index: 45;
        top: -47vw;
        right: -41vw;
        width: 15vw;
    }
    #fv .ohen img {
        width: 100%;
    }


    
	.sectionbg {
        background-color: #fff;
		padding: 0px 0 0;
	}
#sec01 {
    position: relative;
    z-index: 100;
	background: url(../images/sec01_bg02.webp) no-repeat center -5vw;
    background-size: 100%;
    margin: 0 auto -5vw auto;
    top: 0px;
    width: 100%;
    height: auto;
    box-shadow: 
    /* 右側の影 */
    10px 0 10px -5px rgba(0, 0, 0, 0.3), 
    /* 左側の影 */
    -10px 0 10px -5px rgba(0, 0, 0, 0.3);
    box-shadow: none;
}
#sec01 h3 {
    margin: 0px auto 20px auto;
    padding-top: 8vw;
    width: 90%;
}
#sec01 h3 img {
    width: 100%;
}

#sec01 .cont {
    display: flex;
    width: 100%;
    height: auto;
    flex-wrap: wrap;
    margin: 0px auto -0vw auto;
}
#sec01 .frm01 {
    position: relative;
    z-index: 100;
    background: url(../images/sec01_frame01.webp) no-repeat center top;
    background-size: contain;
    width: 95%;
}
#sec01 .cont .txt {
    width: 100%;
    margin: 0px auto;
    padding-top: 0.1vw;
}
#sec01 .cont .txt img {
    width: 100%;
}

#sec01 .cont .achieve60 {
    width: 95%;
    margin: -5vw auto 8vw auto;
}
#sec01 .cont .achieve60 img {
    width: 100%;
}
#sec01 .cont .achieve70 {
    width: 95%;
    margin: -8vw auto 8vw auto;
}
#sec01 .cont .achieve70 img {
    width: 100%;
}
#sec01 .cont .achieve90 {
    width: 95%;
    margin: -8vw auto 8vw auto;
}
#sec01 .cont .achieve90 img {
    width: 100%;
}
#sec01 .cont .achieve100 {
    width: 95%;
    margin: -8vw auto 5vw auto;
}
#sec01 .cont .achieve100 img {
    width: 100%;
}
#sec01 .cont .achieve100fkds {
    position: relative;
    z-index: 100;
    top: -10vw;
    width: 30%;
    margin: 0px 2vw 5px auto;
}
#sec01 .cont .achieve100fkds img {
    width: 100%;
}

#sec01 .cont .deco01 {
    position: relative;
    z-index: 100;
    top: -170vw;
    width: 100vw;
    margin: 0px auto -170vw auto;
}
#sec01 .cont .deco01 img {
    width: 100%;
}



#sec01 .cont .txt_add {
    position: relative;
    z-index: 110;
    top: -10vw;
    left: 50%;
    transform: translateX(-55%);
    /*
    */
    width: 60vw;
    padding-top: 10vw;
    margin: 0 auto -10vw auto;
}
#sec01 .cont .txt_add img {
    width: 100%;
}
#sec01 .cont .leftcha {
    position: relative;
    z-index: 100;
    top: -5vw;
    left: 0%;
    transform: translateX(-290%);
    width: 25vw;
    margin: 0 auto -5vw auto;
}
#sec01 .cont .leftcha img {
    width: 100%;
}
#sec01 .cont .rightcha {
    position: relative;
    z-index: 100;
    top: -44vw;
    right: 0%;
    transform: translateX(150%);
    width: 28vw;
    margin: 0 auto -10vw auto;
}
#sec01 .cont .rightcha img {
    width: 100%;
}


#sec01 .frm02 {
    position: relative;
    z-index: 120;
    top: -43vw;
    background: url(../images/sec01_frame02.webp) no-repeat top center;
    background-size: 100%;
    width: 95%;
    margin: 0px auto -43vw auto;
    padding-bottom: 12vw;
}

#sec01 .cont .achieve210 {
    width: 95%;
    margin: 2vw auto 5px auto;
    padding-top: 5vw;
}
#sec01 .cont .achieve220 {
    width: 95%;
    margin: 2vw auto 5px auto;
    padding-top: 0;
    padding-bottom: 4vw;
}
#sec01 .cont .achieve210 img, #sec01 .cont .achieve220 img {
    width: 100%;
}


#sec01 .cont .deco02 {
    position: relative;
    z-index: 190;
    top: -160vw;
    width: 95%;
    margin: 0px auto -160vw auto;
}
#sec01 .cont .deco02 img {
    width: 100%;
}






#sec01 .cont .slide {
    /*
    display: none;
    */
    width: 100%;
    margin: 8.2vw auto 0 auto;
    padding-top: 5vw;
}
#sec01 .cont .slide img {
    width: 100%;
}

#sec01 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: 1.5vw;
    left: 0px;
}

.slider-container {
  width: 100%; /* 表示したい画像の幅の合計 (300px * 3枚 = 900px) */
  height: auto; /* 画像の高さに合わせる */
  overflow: hidden; /* この範囲外の画像を非表示にする */
}

.slider-track_left {
  display: flex; /* 画像を横並びにする */
  width: calc(378px * 6); /* 画像1枚の幅 * 全ての画像枚数 (300px * (3+3) = 1800px) */
  animation: slide-left 20s linear infinite; /* アニメーションの設定 */
}
.slider-track_right {
  display: flex; /* 画像を横並びにする */
  width: calc(378px * 6); /* 画像1枚の幅 * 全ての画像枚数 (300px * (3+3) = 1800px) */
  animation: slide-right 20s linear infinite; /* アニメーションの設定 */
}

.slider-track img {
  width: 378px; /* 画像1枚の幅 */
  height: 204px; /* 画像1枚の高さ */
  object-fit: cover; /* 画像の縦横比を保ちつつコンテナに収める */
  display: block; /* img要素のデフォルト余白をなくす */
}

/* キーフレームアニメーション */
@keyframes slide-left {
  0% {
    transform: translateX(0); /* 開始位置 */
  }
  100% {
    /* (画像1枚の幅 * 元の画像の枚数) 分だけ左に移動 */
    /* 300px * 3 = 900px */
    transform: translateX(-1134px); /* 終了位置 */
  }
}

@keyframes slide-right {
  0% {
    transform: translateX(-1134px); /* 開始位置 */
  }
  100% {
    /* (画像1枚の幅 * 元の画像の枚数) 分だけ左に移動 */
    /* 300px * 3 = 900px */
    transform: translateX(0px); /* 終了位置 */
  }
}






#sec02 {
    position: relative;
    z-index: 90;
	background: url(../images/sec02_bg2.webp) no-repeat center 0px;
    background-size: 100%;
    margin: 0 auto 0 auto;
    top: 5vw;
    width: 100%;
    height: auto;
    box-shadow: 
    /* 右側の影 */
    10px 0 10px -5px rgba(0, 0, 0, 0.3), 
    /* 左側の影 */
    -10px 0 10px -5px rgba(0, 0, 0, 0.3);
}
#sec02 h3 {
    width: 90%;
    margin: 10px auto 20px auto;
    padding-top: 10vw;
}
#sec02 h3 img {
    width: 100%;
}
#sec02 .cont {
    margin: 9vw auto 0vw auto;
    text-align: center;
}
#sec02 .cont .txt {
    width: 85%;
    margin: 0px auto;
    padding-top: 8vw;
}
#sec02 .cont .txt img {
    width: 100%;
}

#sec02 ul {
    position: relative;
    display: flex;
    width: 94.5%;
    margin: 5vw auto 5vw auto;
    flex-wrap: wrap;
}
#sec02 ul li {
    position: relative;
	background: url(../images/sec02_mbox.webp) no-repeat center center;
    background-size: 96% 100%;
    width: 50%;
    height: 58vw;
    margin: 2vw 0.0vw -0vw 0.0vw;
    padding-bottom: 0vw;
}
#sec02 ul li .thum {
    position: relative;
    z-index: 100;
    width: 85%;
    height: 22vw;
    margin: 2.5vw auto 0.0vw auto;
}
#sec02 ul li .thum img {
    width: 100%;
}
/*
#sec02 ul li .thum::before {
    position: relative;
    z-index: 200;
    top: -0.6vw;
    left: 2px;
}
*/
#sec02 ul li .thumplay {
    position: relative;
    z-index: 200;
    top: -22.8vw;
    left: 0.3vw;
    width: 50%;
    height: 23vw;
    margin: 0 auto -22.5vw auto;
}
#sec02 ul li .thumplay img {
    width: 100%;
    height: auto;
}
#sec02 ul li .thumcircle {
    position: relative;
    z-index: 200;
    top: -24.9vw;
    width: 50%;
    height: 23vw;
    margin: 0 auto -24.1vw auto;
}
#sec02 ul li .thumcircle button {
    position: relative;
    z-index: 300;
    left: -2px;
    display:inline-block;
    width: 100%;
    height: auto;
}
#sec02 ul li .thumcircle button img {
    width: 100%;
    height: auto;
}
#sec02 ul li .thumcircle button:hover {
    position: relative;
    opacity: 0.9;
    animation: 3s linear infinite rotation;
}
@keyframes rotation {
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}
#sec02 ul li .thumtitle {
    position: relative;
    z-index: 200;
    top: 7.8vw;
    font-family: "kozuka-gothic-pr6n", sans-serif;
    font-family: "fot-seurat-pron", sans-serif;
    font-style: normal;
    color: #000064;
    margin: 0 auto -7.8vw auto;
}
#sec02 ul li .thumtitle p.unit {
    font-weight: 700;
    font-size: 3.3vw;
    line-height: 3.8vw;
    /*
    */
}
#sec02 ul li .thumtitle p.title {
    font-weight: 500;
    font-size: 2.3vw;
    line-height: 2.8vw;
    padding-top: 1.2vw;
    /*
    */
}
#sec02 ul li .btnx {
    position: relative;
    z-index: 200;
    top: 23.5vw;
    width: 77%;
}
#sec02 ul li .btnx img {
    width: 100%;
}
#sec02 ul li button:hover {
    filter: brightness(200%);
    filter: hue-rotate(-10deg);
    filter: contrast(120%);
    transform: scale(1.01);
}
#sec02 .cont .slide {
    margin: 20vw auto 5vw auto;
}
#sec02 .cont .slide img {
    width: 740px;
}
#sec02 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: 8.5vw;
}


#sec03 {
    position: relative;
    z-index: 80;
	background: url(../images/sec03_bg.webp) no-repeat center 0px;
    margin: 0 auto 5vw auto;
    top: 8vw;
    width: 100%;
    height: 100%;
    box-shadow: 
    /* 右側の影 */
    10px 0 10px -5px rgba(0, 0, 0, 0.3), 
    /* 左側の影 */
    -10px 0 10px -5px rgba(0, 0, 0, 0.3);
}
#sec03 h3 {
    width: 90%;
    margin: 10px auto 20px auto;
    padding-top: 8vw;
}
#sec03 h3 img {
    width: 100%;
}
}


/* CTA /////////////////////////////////////// */

@media (min-width: 1024px) {
  .cta {
    padding-top: 0px;
  }
}
.cta img {
    width: 100%;
    height: auto;
}
.cta .cta__wrapper {
    position: relative;
    width: 95%;
    margin: 0 auto;
}
@media (min-width: 768px) {
  .cta .cta__wrapper {
    width: 714px;
    height: 250px;
    background-image: url('../images/sec03_ctabg.webp');
  }
}
.cta .cta__wrapper .cta__title {
  position: absolute;
  left: 50%;
  top: 5vw;
  width: 60%;
  height: auto;
  margin: 0 auto;
  transform: translate(-50%, -100%);
}
@media (min-width: 1024px) {
  .cta .cta__wrapper .cta__title {
    top: 40px;
    width: 60%;
  }
}
@media (min-width: 1024px) {
  .cta .cta__deco_wrapper {
    width: 800px;
    height: auto;
  }
  .sectionbg {
    position: relative;
    width: 750px;
    background-color: #fff;
    border-width: 0 5px;
    border-style: solid;
    border-image-slice: 1;
    border-image-source: linear-gradient(
    to bottom,
    #00deff, 
    #66ffd9, 
    #fff667, 
    #ffa6e7  
  );
    box-shadow: 
    /* 右側の影 */
    10px 0 10px -5px rgba(0, 0, 0, 0.3), 
    /* 左側の影 */
    -10px 0 10px -5px rgba(0, 0, 0, 0.3);
  }
  .sectionbg::after {
    background-color: #fff;
    border-right: 3px solid;
    border-image: conic-gradient(#00deff,#66ffd9,#fff667,#ffa6e7) 1;
  }
}
.cta .cta__wrapper .cta__button-wrapper--sp {
  width: 100%;
  height: auto;
  text-align: center;
    background-image: url('../images/sec03_ctaspbg.webp');
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
}
@media (min-width: 768px) {
  .cta .cta__wrapper .cta__button-wrapper--sp {
    display: none;
  }
}
.cta .cta__wrapper .cta__button-wrapper--sp .cta__content--sp {
  margin: 4vw auto;
  padding-top: 9.5vw;
  /*
  */
}
.cta .cta__wrapper .cta__button-wrapper--sp .cta__content--sp .cta__button {
  display: block;
  width: 35vw;
  margin: 0 auto;
}
.cta
  .cta__wrapper
  .cta__button-wrapper--sp
  .cta__content--sp
  .cta__button
  > img {
  width: 100%;
}
.cta .cta__wrapper .cta__button-wrapper--sp .cta__content--sp .cta__taxt {
  display: block;
  width: 75vw;
  margin: 6vw auto 2vw auto;
  position: relative;
  z-index: 100;
}
.cta .cta__wrapper .cta__button-wrapper--pc {
  display: none;
}
@media (min-width: 768px) {
  .cta .cta__wrapper .cta__button-wrapper--pc {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    padding: 22px 14px 0;
  }
}
@media (min-width: 768px) {
  .cta .cta__wrapper .cta__button-wrapper--pc .cta__content {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    margin-top: 20px;
    gap: 0;
  }
  .cta .cta__wrapper .cta__button-wrapper--pc .cta__content:nth-of-type(n + 2) {
    margin-left: 18px;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-head {
    width: 98%;
    margin: 0 auto;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-head
    > img {
    width: auto;
    height: 20px;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__pc-button-wrapper {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-top: 35px;
    width: 486px;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__pc-button-wrapper
    .cta__device-pc
    .cta__pc-button {
    display: block;
    transition: filter 0.2s ease-in-out;
    cursor: pointer;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-qr {
    width: 77%;
    height: auto;
    margin: 0 auto;
    padding: 7px;
    margin-left: 70px;
    margin-top: 75px;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-qr
    > img {
    width: 100%;
    height: auto;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox {
    margin-top: 6px;
    color: #6e647d;
    
    font-family: "fot-seurat-pron", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-feature-settings: 'palt';
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-checkbox-text {
    display: flex;
    align-items: center;
    margin-top: 5px;
    font-size: 14px;
    letter-spacing: 0.05rem;
    text-indent: 0.05rem;
    line-height: 1;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-checkbox-text
    .cta__device-pc-checkmark {
    width: 16px;
    height: 16px;
    margin: 0 5px 0 0;
    accent-color: #ff73bc;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-checkbox-text
    > label {
    line-height: 1;
    cursor: pointer;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-checkbox-text
    > label:hover {
    text-decoration: underline;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-provider {
    margin-top: 5px;
    line-height: 1;
    font-size: 14px;
    text-align: left;
  }
  .cta
    .cta__wrapper
    .cta__button-wrapper--pc
    .cta__content
    .cta__device-wrapper
    .cta__device-pc-checkbox
    .cta__device-pc-provider
    .dealer_name {
    font-size: 120%;
  }
}

@media (max-width: 740px) {

#sec03 .txt {
    margin: 0px auto;
    padding-top: 2vw;
    width: 90%;
}
#sec03 .txt img {
    width: 100%;
}

#sec03 ul.sec04ul {
    position: relative;
    display: flex;
    width: 95%;
    margin: 20px auto 30px auto;
    margin-left: 2.5vw;
    flex-wrap: wrap;
}
#sec03 ul.sec04ul li {
    position: relative;
    width: 48%;
    height: auto;
    margin: 1vw 0.8vw 0vw 0.8vw;
}
#sec03 ul.sec04ul li img {
    width: 100%;
    height: auto;
}

#sec03 .slide {
    /*
    display: none;
    width: 800px;
    */
    margin: 5vw auto 0vw auto;
}
#sec03 .slide img {
    width: 100%;
}
#sec03 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: 0vw;
    /*
    height: 61.5vw;
    */
    height: auto;
    margin: 5vw auto 0vw auto;
}




#sec04 {
    position: relative;
    z-index: 200;
	background: #ffa6e7;
    margin: 0 auto 5vw auto;
    top: 5vw;
    width: 100%;
    height: 10vw;
    box-shadow: 
    /* 右側の影 */
    10px 0 10px -5px rgba(0, 0, 0, 0.3), 
    /* 左側の影 */
    -10px 0 10px -5px rgba(0, 0, 0, 0.3);
}

#sec04 .footer__link-wrapper .footer__links {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0vw auto;

    position: relative;
    top: 2.5vw;
    width: 90%;
    font-size: 2vw;
    font-family: "fot-seurat-pron", sans-serif;
    font-style: normal;
    color: #ffffff;
}

#sec04 
  .footer__link-wrapper
  .footer__links:nth-of-type(n + 2) {
  margin-top: 2vw;
}

#sec04 
  .footer__link-wrapper
  .footer__links
  .footer__link-item {
  display: flex;
  align-items: center;
  padding: 10px 5px;
  line-height: 1;
}

}
@media (min-width: 1024px) {
  #sec04 
    .footer__link-wrapper
    .footer__links:nth-of-type(n + 2) {
    margin-top: 12px;
  }
}



@media (max-width: 1024px) {
  .sectionbg {
    max-width: 750px;
    background-color: #fff;
    border-width: 0 5px;
    border-style: solid;
    border-image-slice: 1;
    border-image-source: linear-gradient(
    to bottom,
    #00deff, 
    #66ffd9, 
    #fff667, 
    #ffa6e7  
  );
    box-shadow: 
    /* 右側の影 */
    10px 0 10px -5px rgba(0, 0, 0, 0.3), 
    /* 左側の影 */
    -10px 0 10px -5px rgba(0, 0, 0, 0.3);
  }
}
.popup {
    display: none; /* 最初は非表示 */
    position: fixed; /* 画面全体に固定 */
    z-index: 900;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /*background-color: rgba(0, 0, 0, 0.5); /* 半透明の背景 */
    justify-content: center;
    align-items: center;
  }
  
  .popup-content {
    padding: 0px 0px;
    position: relative; /* closeボタンの配置基準 */
  }
  
  #close-popup {
    position: absolute;
    top: -40px;
    right: -40px;
    cursor: pointer;
    color: #ddd;
    font-size: 48px;
    font-weight: inherit;
  }
  
  #youtube-player {
    width: 960px; /* ポップアップの動画サイズ */
    height: 540px;
    margin-top: 100px;
  }



@media (max-width: 390px) {


#fv {
    width: 100%;
    height: 103vw;
    top: 0px;
    position: relative;
    z-index: 100; /* z-index を 0 に変更 */
	overflow: hidden;
    border-bottom: 2px solid #000064;
}
#fv h1 {
    position: relative;
    z-index: 200;
    margin: 0px auto 0px auto;
    top: 40px;
}    
#fv h1 img {
    width: 25%;
}    

#fv h2 {
    position: relative;
    z-index: 200;
    margin: 0px auto 0px auto;
    top: 10vw;
}    
#fv h2 img {
    width: 70%;
}    
#fv .idol001 {
    position: relative;
    z-index: 20;
    background: url(../images/fv_ob.webp) no-repeat center center;
    background-size: cover;
    margin: 0px auto;
    text-align: center;
    top: 18vw;
    width : 100%;
    height: 30vw;
    max-height: 440px;
}    
[data-aos=HorizontalOpen]{ clip-path:inset(0 1000px); }
[data-aos=HorizontalOpen].aos-animate{ clip-path:inset(0 0); }
[data-aos=HorizontalOpenT]{ clip-path:inset(1000px 0); }
[data-aos=HorizontalOpenT].aos-animate{ clip-path:inset(0 0); }

#fv h3 {
    position: relative;
    z-index: 200;
    top: 0;
    width: 65vw;
}    
#fv h3 img {
    width: 457px;
}    
#fv .idol001 {
    position: relative;
    z-index: 25;
    top: 9.0vw;
}
#fv .idol001 .obmd {
    position: relative;
    z-index: 25;
    top: 3.5vw;
    width: 65vw;
}
#fv .idol001 .obmd img {
    width: 100%;
}
#fv .idol001 .obtxt {
    position: relative;
    z-index: 100;
    top: 6.5vw;
    width: 97%;
    height: auto;
}
#fv .idol001 .obtxt p {
    width: 100%;
    color: #ffffff;
    font-size: 13.5vw;
    line-height: 0.7em;
    letter-spacing: 0.1em;
    /*
    font-family: "kozuka-gothic-pr6n", sans-serif;
    */
    font-family: "kozuka-gothic-pr6n", sans-serif;
    font-weight: 900;
    font-style: normal;
    
    text-shadow: #000064 3px 3px;
    -webkit-text-stroke-width: 2px;
    -webkit-text-stroke-color: #000064;
}
#fv .aol {
    position: relative;
    z-index: 35;
    top: 6.8vw;
    width: 97vw;
}
#fv .aol img {
    width: 100%;
}

#fv .ohen {
    position: relative;
    z-index: 45;
    top: -48vw;
    right: -41vw;
    width: 15vw;
}
#fv .ohen img {
    width: 100%;
}


#sec01 .cont .slide {
    width: 100%;
    margin: 6.2vw auto 0 auto;
    padding-top: 3vw;
}

#sec01 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: -1.5vw;
}
#sec01 .cont .deco {
    position: relative;
    z-index: 100;
    top: -222vw;
    width: 100%;
    margin: 0px auto -228vw auto;
}




#sec02 {
    position: relative;
    z-index: 90;
	background: url(../images/sec02_bg2.webp) no-repeat center 0px;
    background-size: 100%;
    margin: 0 auto 0 auto;
    top: -1.0vw;
    width: 100%;
    height: auto;
    box-shadow: none;
}
#sec02 ul li {
    position: relative;
	background: url(../images/sec02_mbox.webp) no-repeat center top;
    background-size: 94% 100%;
    width: 50%;
    height: auto;
    margin: 2vw 0.0vw 2vw 0.0vw;
    padding-bottom: 4vw;
}
#sec02 ul li .thum {
    position: relative;
    z-index: 100;
    width: 83%;
    height: 22vw;
    margin: 2.5vw auto 1.0vw auto;
}
#sec02 ul li .thum img {
    width: 100%;
    top: 0vw;
}
#sec02 ul li .thum::before {
    position: relative;
    z-index: 200;
    top: -11vw;
    left: -2vw;
    width: 100%;
    height: 12vw;
    margin: 2.5vw auto -11.0vw auto;
}
#sec02 ul li .thumplay {
    position: relative;
    z-index: 200;
    top: -27.3vw;
    left: 1.2vw;
    width: 65%;
    height: 25vw;
    margin: 0 auto -15.8vw auto;
}
#sec02 ul li .thumplay img {
    width: 100%;
    /*height: 25vw;*/
}
#sec02 ul li .thumcircle {
    position: relative;
    z-index: 200;
    top: -38.4vw;
    left: 1.2vw;
    width: 65%;
    height: 25vw;
}
#sec02 ul li .thumcircle button {
    position: relative;
    z-index: 300;
    top: 0.0vw;
    left: -2px;
    display:inline-block;
    width: 100%;
    height: 25vw;
}
#sec02 ul li .thumcircle button img {
    width: 100%;
    /*height: 25vw;*/
}
#sec02 ul li .thumcircle button:hover {
    position: relative;
    opacity: 0.9;
    animation: none;
}
@keyframes rotation {
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}
#sec02 ul li .thumtitle {
    position: relative;
    z-index: 200;
    top: -6.4vw;
    font-family: "kozuka-gothic-pr6n", sans-serif;
    font-family: "fot-seurat-pron", sans-serif;
    font-style: normal;
    color: #000064;
    margin: 0 auto -1.5vw auto;
}
#sec02 ul li .thumtitle p.unit {
    font-weight: 700;
    font-size: 3.3vw;
    line-height: 3.8vw;
    /*
    */
}
#sec02 ul li .thumtitle p.title {
    font-weight: 500;
    font-size: 2.3vw;
    line-height: 2.8vw;
    /*
    */
}
#sec02 ul li .btnx {
    position: relative;
    z-index: 200;
    top: 2.2vw;
    width: 77%;
}
#sec02 ul li .btnx img {
    width: 100%;
}

#sec02 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: 13.5vw;
}

#sec03 {
    position: relative;
    z-index: 80;
    top: 10vw;
    width: 100%;
    margin: 0 auto 0vw auto;
}
#sec03 .slider-wrapper {
    position: relative;
    z-index: 100;
    top: 2vw;
    height: auto;
    margin: 5vw auto 0vw auto;
}

.cta .cta__wrapper {
    position: relative;
    width: 95%;
    height: 100%;
    max-height: 300px;
    margin: 0 auto;
}
.cta .cta__wrapper .cta__button-wrapper--sp {
  width: 100%;
  height: auto;
  text-align: center;
    background-image: url('../images/sec03_ctaspbg.webp');
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
}
.cta .cta__wrapper .cta__button-wrapper--sp .cta__content--sp {
  margin: 4vw auto;
  padding-top: 8.5vw;
  padding-bottom: 3.5vw;
  /*
  */
}
.cta .cta__wrapper .cta__button-wrapper--sp .cta__content--sp .cta__button {
  display: block;
  width: 35vw;
  margin: 0 auto;
}
.cta
  .cta__wrapper
  .cta__button-wrapper--sp
  .cta__content--sp
  .cta__button
  > img {
  width: 100%;
}
.cta .cta__wrapper .cta__button-wrapper--sp .cta__content--sp .cta__taxt {
  display: block;
  width: 75vw;
  margin: 6vw auto 2vw auto;
  position: relative;
  z-index: 100;
}



}


    
@media screen and (min-width:740px) and (max-width:767px){ 
    #sec03 .slider-wrapper {
        position: relative;
        z-index: 100;
        top: 0vw;
        height: 50vw;
        margin: 5vw auto 12vw auto;
    }

    #sec04 {
        position: relative;
        z-index: 100;
	    background: #ffa6e7;
        margin: 0 auto 60px auto;
        top: 60px;
        width: 740px;
        height: 90px;
    }

}



@media screen and (min-width:391px) and (max-width:567px){ 


#sec01 .cont .deco {
    position: relative;
    z-index: 100;
    top: -215vw;
    width: 800px;
    margin: 0px auto -215vw auto;
}
#sec01 .cont .deco img {
    width: 100%;
}

}





@media screen and (max-width:739px) {
    
    .sectionbg {
      max-width: 750px;
      background-color: #fff;
      border: none;
    }

    .popup {
        display: none; /* 最初は非表示 */
        position: fixed; /* 画面全体に固定 */
        z-index: 900;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        margin: 0 auto;
        background-color: rgba(0, 0, 0, 0.5); /* 半透明の背景 */
        justify-content: center;
        align-items: center;
    }
  
    .popup-content {
        padding: 0px 0px;
        position: relative; /* closeボタンの配置基準 */
        width: 98%;
        height: auto;
        /*
        margin: 0 auto 30px auto;
        */
    }
    #sec04 .popup-content {
        padding: 0px 0px;
        position: relative; /* closeボタンの配置基準 */
        width: 90%;
        height: 90%;
    }
  
  
    #close-popup {
        position: absolute;
        top: -30px;
        right: -10px;
        cursor: pointer;
        color: #fff;
        font-size: 24px;
        font-weight: inherit;
    }
  
    #youtube-player {
        width: 100%; /* ポップアップの動画サイズ */
        height: auto;
    }
    #youtube-player {
        width: 100%; /* ポップアップの動画サイズ */
        height: auto;
    }
    #youtube-player::before {
        content: '';
        display: block;
        padding-top: 0.0%;
        margin: 0 auto 55vw auto;
        }
    #youtube-player iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        }
    }


/* popupのCSS /////////////////////////////////////// */

.popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgb(0 0 0 / 50%);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 99999;
}

.popup-content2 {
  position: relative;
  background: #fff;
  width: 80%;
  max-width: 600px;
  height: 70vh;
  border-radius: 8px;
  overflow: hidden;
}

.popup-content2 iframe {
  width: 100%;
  height: 100%;
  border: none;
}
/*
*/



