﻿@charset "UTF-8";

.border-bg{
	padding:5em 0 ;
	background-color: #efefef;
	background-image: repeating-linear-gradient(
    -45deg,     /* 角度（45度） */
    transparent,       /* 開始色 */
    transparent 10px,  /* 10pxまで透明（背景色が見える） */
    #f5f5f5 10px,      /* ここから白線 */
    #f5f5f5 12px       /* 12pxまで白線（つまり線の太さは2px） */
  );
}
@media screen and (min-width:768px){
.border-bg{
	padding:10em 0 ;
	}
}

.link{
	color:#058FD1;
	background:url(../cmn/images/arrow_blank_blue.png) no-repeat 100% 50%;
	padding-right:15px;
	background-size:10px;
	font-size:clamp(13px,3vw,14px);
	letter-spacing:1px;
}
.gold-lbl{
	background-image: linear-gradient(90deg, #a17600 60%, #cda700);
	font-size:clamp(16px,3vw,19px);
	font-weight:700;
	color:var(--color-white);
	padding:.3em .5em ;
	text-align:center;
	width:min(70%, 280px);
	margin: -65px auto 30px;
	transform: skewX(-15deg);
}

.lbl_service{
	margin: -40px auto 30px!important;
}
.lbl_point{
	margin: -30px auto 10px!important;
	font-size:clamp(12px,3vw,20px);
	width:min(95%, 280px);
}


@media screen and (min-width:768px){
.gold-lbl{
	margin: -70px auto 30px;
	}
}

.gold-lbl span{
    transform: skewX(15deg);
    display: inline-block;
}
.gold-lbl .lbl-number{
	font-size:clamp(22px,3vw,28px);
	transform: skewX(0deg);
}
/*----------------------------------------------------------------------

メインビジュアル

/*--------------------------------------------------------------------*/

.mv .mv-logo img{
	max-width:50px;
}
@media screen and (min-width:768px){
.mv .mv-logo img{
	max-width:80px;
	}
}

.mv .mv-logo{
	padding:15px 0 0;
	margin:0 0 -30px;
}
@media screen and (min-width:768px){
.mv .mv-logo{
	margin:0 0 -50px;
	}
}

.mv{
	background:url(../images/mv/sp_title_bg.jpg) no-repeat 0 7% ;
	position:relative;
	margin:0 0 60px;
}
@media screen and (min-width:768px){
.mv{
	background:url(../images/mv/pc_title_bg.jpg) no-repeat;
	margin:0 0 40px;
	}
}

.mv-inner img{
	max-width:100%;
}
@media screen and (min-width:768px){
.mv-inner{
	text-align:center;
	margin:-80px 0 0;
	}
}

.mv ul{
	display:flex;
	justify-content:center;
	gap:0 0px;
	margin: 0 auto;
	width:min(80%, 950px);
	position:absolute;
   left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	bottom:-75px;
}
@media screen and (min-width:768px){
.mv ul{
	display:flex;
	justify-content:flex-end;
	position:static;
	left: 0%;
	gap:0 0px;
	transform: translateX(0%);
	-webkit-transform: translateX(0%);
	-ms-transform: translateX(0%);
	bottom:0px;
	margin:-120px auto 0;
	}
}
.mv ul img{
	max-width:100%;
}
.mv ul li{
	text-align:center;
}
/*----------------------------------------------------------------------

期間限定キャンペーン

/*--------------------------------------------------------------------*/

.campaign-title{
	font-size:clamp(15px,3vw,18px);
	font-weight:700;
	padding:40px 0 0;
	text-align:center;
	margin:0 0 -40px;
}
@media screen and (min-width:768px){
.campaign-title{
	margin:0 0 0px;
	}

}

@media screen and (min-width:768px){
.campaign-inner{
	display:grid;
	grid-template-columns:1fr;
	align-items:center;
	gap:0 25px;
	}
}
.campaign-inner figure img{
	max-width:100%;
}
.campaign-inner figure{
	text-align:center;
	max-width:100%;
	margin: 0 auto 30px;
}
.campaign-inner dl{
	margin:0 0 25px;
}
@media screen and (min-width:768px){
.campaign-inner dl{
	width:min(100%, 600px);
	margin: 0px auto 30px;
	}
}

.campaign-inner dt{
	font-size:clamp(15px,3vw,19px);
	font-weight:700;
	margin:0 0 10px;
}
.campaign-inner dd{
	font-size:clamp(15px,3vw,20px);
	text-indent:-1em;
	padding-left:1em;
	text-align:center;
	font-weight:700;
}
.head-border {
    display: flex;
    align-items: center;
}

.head-border:before,
.head-border:after {
    content: "";
    height: 2px;
    flex-grow: 1;
    background-color: #666;
}

.head-border:before {
    margin-right: 1rem;
}

.head-border:after {
    margin-left: 1rem;
}

.campaign-btn{
	text-align:center;
	width:min(80%, 450px);
	margin: 0px auto;
}

.campaign-btn a{
	color:#E5001F;
	text-decoration:none;
	font-size:clamp(14px,2vw,18px);
	font-weight:var(--w700);
	border:2px solid #E5001F;
	border-radius:10px;
	display:block;
	background:#fff;
	padding:.6em 0 ;
}
.campaign-btn span{
	background:url(../cmn/images/arrow_blank_red.png) no-repeat 100% 50%;
	padding-right:20px;
	background-size:15px;
}

.campaign-notice{
	margin:20px 0 0;
	letter-spacing:1px;
}
@media screen and (min-width:768px){
.campaign-notice{
	width:min(100%, 600px);
	margin: 20px auto 25px;
	}
}

.campaign-notice dd{
	font-size:clamp(12px,2vw,13px);
	margin:3px 0;
}
.campaign-notice dd{
	text-indent:-1em;
	padding-left:1em;
}
.campaign-notice dd:before{
	content:"※";
}

.or-icon{
	text-align:center;
	max-width:80px;
	margin: 40px auto;
}

.benefits-body_in{
	padding:5em 3em 3em;
	margin:5em 0 5em;
	position:relative;
	background-color: #efefef;
	background-image: repeating-linear-gradient(
    -45deg,     /* 角度（45度） */
    transparent,       /* 開始色 */
    transparent 10px,  /* 10pxまで透明（背景色が見える） */
    #f5f5f5 10px,      /* ここから白線 */
    #f5f5f5 12px       /* 12pxまで白線（つまり線の太さは2px） */
  );
}
@media screen and (min-width:768px){
.benefits-body_in{
	margin:5em 0 10em;
	}
}
.tour-inner{
	display:flex;
	justify-content:center;
	gap:15px 15px;
	flex-wrap:wrap;
}
@media screen and (min-width:768px){
.tour-inner{
	gap:0 30px;
	flex-wrap:nowrap;
	max-width:900px;
	margin: 0 auto;
	}
}

.tour-inner div{
	background:#fff;
	padding:1em 1em;
	text-align:center;
	flex:1;

}
@media screen and (min-width:768px){
.tour-inner div{
	padding:2em 3em;
	width:calc(100% / 3);
	}
}

.tour-inner div dt img{
	max-width:130px;
}
@media screen and (min-width:768px){
.tour-inner div dt img{
	max-width:170px;
	}
}

.tour-inner div dd{
	font-size:clamp(13px,3vw,16px);
	font-weight:700;
	padding:20px 0 ;
	height:70px;
}



.tour-inner div .rampage-only{
	font-size:clamp(13px,3vw,16px);
	font-weight:700;
	padding:0px 0 20px;
	height:auto;
}

@media screen and (min-width:768px){
.tour-inner div .rampage-only{
	height:70px;
	}
}

.campaign-btn_sub{
	text-align:center;
	width:min(100%, 350px);
	margin: 0px auto 15px;
}
@media screen and (max-width:768px){
.sp_btn-only{
	width:min(50%, 350px);
	}
}



.campaign-btn_sub a{
	color:#E5001F;
	text-decoration:none;
	font-size:clamp(13px,2vw,25px);
	font-weight:var(--w700);
	border:2px solid #E5001F;
	border-radius:5px;
	display:block;
	background:#fff;
	padding:.5em 0 ;
	position: relative;
}

.campaign-btn_sub a:hover{
	opacity:.6;
	}

@media screen and (min-width:768px){
.campaign-btn_sub a{
	font-size:clamp(16px,2vw,17px);
	padding:.5em 0 ;
	}
}

.campaign-btn_sub a::after{
    content: '';
    /*絶対配置で矢印の位置を決める*/
	position: absolute;
    top:40%;
    right: 13px;
    /*矢印の形状*/
    width: 6px;
    height: 6px;
    border-top: 2px solid #E5001F;
    border-right: 2px solid #E5001F;
    transform: rotate(45deg);
    /*アニメーションの指定*/
    transition: all .3s;
}
@media screen and (min-width:768px){
.campaign-btn_sub a::after{
	top:40%;
	width: 8px;
	height: 8px;

	}

}

/*----------------------------------------------------------------------

新規入会特典

/*--------------------------------------------------------------------*/
.white-bg{
	padding:5em 0 0em;
}
@media screen and (min-width:768px){
.white-bg{
	padding:2em 0 10em;
	}
}

.benefits-body{
	padding:5em 1.5em 3em;
	margin:4em 0 4em;
	position:relative;
	background-color: #efefef;
	background-image: repeating-linear-gradient(
    -45deg,     /* 角度（45度） */
    transparent,       /* 開始色 */
    transparent 10px,  /* 10pxまで透明（背景色が見える） */
    #f5f5f5 10px,      /* ここから白線 */
    #f5f5f5 12px       /* 12pxまで白線（つまり線の太さは2px） */
  );
}
@media screen and (min-width:768px){
.benefits-body{
	padding:5em 1.5em 3em;
	margin:8em 0 4em;
	}
}



.benefits-title{
	font-size:clamp(22px,3vw,30px);
	font-weight:700;
	text-align:center;
	color:#E5001F;
	padding:0em 0 1em;
	line-height:1.2;
}
.benefits-title span{
	font-size:clamp(18px,3vw,20px);
}

.benefits-inner{
	letter-spacing:1px;
}
@media screen and (min-width:768px){
.benefits-inner{
	display:grid;
	grid-template-columns:1fr 2fr;
	align-items:center;
	gap:0 25px;
	}
}
.benefits-inner figure img{
	max-width:100%;
}
.benefits-inner figure{
	text-align:center;
	max-width:250px;
	margin: 0 auto 30px;
}
.benefits-inner dt{
	font-size:clamp(18px,3vw,21px);
	font-weight:700;
	margin:0 0 10px;
}
.benefits-inner dd{
	font-size:clamp(13px,3vw,14px);
	text-indent:-.7em;
	padding-left:.7em;
}
@media screen and (min-width:768px){
.benefits-inner dd{
	text-indent:-1em;
	padding-left:1em;
	}
}

.benefits-notice{
	padding:0 0 60px;
}

@media screen and (min-width:768px){

.benefits-notice dd a{
	margin:3px 0 0 7px;
	display:inline-block;
	}
}
@media screen and (min-width:768px){
.benefits-notice{
	padding:0 0 0px;
	}
}
/*----------------------------------------------------------------------

カードの魅力

/*--------------------------------------------------------------------*/
.charm_body{
	margin:3em 0 6em;
}
.charm_body img{
	max-width:100%;
}

.charm_body figure{
	text-align:center;
}

.charm_inner{
	display:flex;
	flex-direction: column;
	gap:20px 0 ;
}
@media screen and (min-width:850px){
.charm_inner{
	flex-direction: row;
	gap:20px 20px ;
	}
}

.charm_inner div{
	background:#fff;
	padding:0 0 20px;
}
@media screen and (min-width:768px){
.charm_inner div{
	flex:1;
	padding:0 0 20px;
	}
}
.charm_inner_one{
	margin:20px 0 0;
	background:#fff;
	padding:0 0 30px;
	text-align:center;
}
@media screen and (min-width:768px){
.charm_inner_one{
	margin:20px 0 100px;
	}
}


@media screen and (min-width:768px){
.charm-style_one{
	justify-content:center;
	}
.charm_inner_one figure{
	margin:30px 0 30px;
	}
}


.charm-text{
	font-size:clamp(15px,3vw,16px);
	font-weight:700;
	letter-spacing:.5px;
	line-height:1.5;
	padding:0px 25px 10px;
	text-align:center;
}
.charm-text span{
	color:#cc0000;
}

.charm-text_end{
	font-size:clamp(12px,3vw,13px);
	font-weight:700;
	letter-spacing:1px;
	line-height:1.2;
	padding:0px 25px;
	color:#cc0000;
	text-align:center;
}
.charm_body .page-list{
	font-size:clamp(12px,3vw,13px);
	font-weight:500;
	letter-spacing:1px;
	line-height:1.2;
	width:min(90%,500px);
	margin: 20px auto 10px;
}
.charm_body .page-list li{
	text-indent:-1em;
	padding-left:1em;
	margin:3px 0;
}
.charm_body .page-list li:before{
	content:"※";
}

.charm-link{
	width:min(90%,500px);
	margin:0 auto;
}
.charm-link a{
	color:#058FD1;
	background:url(../cmn/images/arrow_blank_blue.png) no-repeat 100% 50%;
	padding-right:15px;
	background-size:10px;
	font-size:clamp(13px,3vw,13px);
}

.charm_body .charm3-only{
	margin:10px auto 0;
}

@media screen and (min-width:768px){
.charm_body .charm3-only{
	margin:100px auto 0;
	}
}


/* 全体のスタイリング */
.accordion-container {
	width:min(90%, 900px);
	margin: 20px auto;

}

.accordion-container .or{
	text-align:center;
	font-size:clamp(14px,3vw,15px);
	font-weight:500;
	letter-spacing:1px;
	padding:20px 0;
	margin:0px 20px 0;
	white-space: nowrap;
}
@media screen and (min-width:768px){
.accordion-container .or{
	margin:10px 20px 0;
	}
}


.accordion-003 summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 1em 1em ;
    color: #cc0000;
    font-weight: 500;
    cursor: pointer;
    border:1px solid #cc0000;
    background:#fff;
    border-radius:10px;
	font-size:clamp(12px,3vw,15px);
	text-align:left;
	
}
@media screen and (min-width:768px){
.accordion-003 summary {
	max-width:430px;
	padding: 1em 1em 1em 1.5em;
  border:2px solid #cc0000;
	}
}


.accordion-003 summary::-webkit-details-marker {
    display: none;
}

.accordion-003 summary::after {
    transform: none; 
    width: 16px;  
    height: 16px; 
    margin-left: 10px;
    content: '';
    transition: transform .5s;
    background: 
        linear-gradient(#cc0000, #cc0000) no-repeat center/2px 100%, 
        linear-gradient(#cc0000, #cc0000) no-repeat center/100% 2px; 
}

.accordion-003[open] summary::after {
    background: 
        linear-gradient(#cc0000, #cc0000) no-repeat center/0% 100%, 
        linear-gradient(#cc0000, #cc0000) no-repeat center/100% 2px; 
   
}

@media screen and (min-width:768px){
.accordion-003 summary::after {
    width: 22px;  
    height: 22px; 
    background: 
        linear-gradient(#cc0000, #cc0000) no-repeat center/4px 100%, 
        linear-gradient(#cc0000, #cc0000) no-repeat center/100% 4px; 
}

.accordion-003[open] summary::after {
    background: 
        linear-gradient(#cc0000, #cc0000) no-repeat center/0% 100%, 
        linear-gradient(#cc0000, #cc0000) no-repeat center/100% 4px; 
	}

}

.accordion-003 section.acc {
transform: translateY(-20px); 
overflow: hidden;
    height: 0; /* 最初は高さを0にする */
    opacity: 0;
    transform: translateY(-10px);
    margin: 0;
    padding: 0; /* 閉じている時はパディングも0 */
    color: #333333;
    /* ぬるっと動かす設定（allにすると高さも透明度も一緒に動きます） */
    transition: all 0.5s ease-out;
}
/* 開いた状態の指定（JSで制御するため、[open]とは別にクラスを作ります） */
.accordion-003.is-animated section.acc {
    opacity: 1;
    transform: translateY(0);
    padding: .3em 0em 1.5em;
    /* heightはJSで中身に合わせて動的に設定されます */
}
.accordion-003[open] section.acc {
transform: translateY(0);
    opacity: 1;
    visibility: visible;
}



.accordion-container .circle-list{
	font-size:clamp(11px,3vw,12px);
	letter-spacing:1px;
	line-height:1.2;
	width:min(93%,500px);
	margin: 20px auto ;
	text-align:left;
}
@media screen and (min-width:768px){
.accordion-container{
	display:grid;
	grid-template-columns:2fr .3fr 2fr;
	}
}


.accordion-container .circle-list li{
	text-indent:-1em;
	padding-left:1em;
	margin:8px 0;
	font-weight:700;
	line-height:1.4;
	
}
.accordion-container .circle-list li:before{
	content:"●";
	font-family: sans-serif;
}
.accordion-container .page-list02{
	font-size:clamp(11px,3vw,12px);
	font-weight:500;
	letter-spacing:1px;
	line-height:1.4;
	width:min(93%,500px);
	margin: 20px auto -20px;
}
@media screen and (min-width:768px){
.accordion-container .page-list02{
	margin: 20px auto ;
	}
}

.accordion-container .page-list02 li{
	text-indent:-1em;
	padding-left:1em;
	margin:5px 0;
	text-align:left;

}
.accordion-container .page-list02 li:before{
	content:"※";
	font-family: sans-serif;
}

.accordion-container .text-list{
	font-size:clamp(11px,3vw,12px);
	letter-spacing:1px;
	line-height:1.2;
	width:min(93%,500px);
	margin: 20px auto 0;
	text-align:left;
}
.accordion-container .text-list li{
	text-indent:-1em;
	padding-left:1em;
	margin:6px 0;
	font-weight:700;
}
.accordion-container .text-list li a{
	color:#058FD1;
	background:url(../cmn/images/arrow_blank_blue.png) no-repeat 100% 50%;
	padding-right:15px;
	background-size:10px;
	font-size:clamp(12px,3vw,12px);
	font-weight:300;
}


/*----------------------------------------------------------------------

JCBならではのサービス

/*--------------------------------------------------------------------*/
.service-body{
	margin:6em 0 0em;
	background:#fff;
	padding:2em;
	position:relative;
}

.service_headline{
    display: flex;
    align-items: center;
	font-size:clamp(20px,3vw,33px);
	font-weight:900;
	letter-spacing:0px;
	margin:0px auto 10px;
	width:min(100%,600px);
	font-family: sans-serif;
	font-style: italic;
	
}
@media screen and (min-width:768px){
.service_headline{
	margin:30px auto 20px;
	}
}

.service_headline:before,
.service_headline:after {
    content: "";
    height: 2px;
    flex-grow: 1;
    background-color: #666;
}

.service_headline:before {
    margin-right: 1rem;
}

.service_headline:after {
    margin-left: 1rem;
}
.service_title {
	margin:0 0 30px;
}
.service_title dt{
	font-size:clamp(16px,3vw,22px);
	font-weight:700;
	letter-spacing:1px;
	text-align:center;
}
.service_title dt span,
.service-inner_border_text span{
	color:#E5001F;
}
.service_title dd{
	margin:20px 0 0px;
	text-align:center;
	font-size:clamp(13px,3vw,14px);
}
.service-inner_border{
	border:2px solid #000;
	padding:2em;
	position:relative;
	margin:60px auto 20px;
	width:min(95%,850px);
}
@media screen and (min-width:768px){
.service-inner_border{
	border:3px solid #000;

	}

}


.service-inner_border .more img{
	max-width:80px;
}

.service-inner_border .more{
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);	
}
.service-inner_border_text{
	font-size:clamp(16px,3vw,22px);
	font-weight:700;
	letter-spacing:1px;
	text-align:center;
	margin:40px 0 20px;
}
.service-inner_border_text span{
	font-size:clamp(20px,3vw,22px);
}
.service-inner_border .list-title{
	text-align:center;
	font-size:clamp(14px,3vw,14px);
	font-weight:700;
	border-top:1px solid #000;
	border-bottom:1px solid #000;
	padding:5px 0 ;
	width:min(50%,100px);
	margin: 0 auto;
}
@media screen and (min-width:768px){
.service-inner_border .list-title{
	margin: 30px auto 0;
	}
}

.service-inner_border ul{
	margin:20px auto  ;
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:30px;
	width:min(90%,280px);
}
@media screen and (min-width:768px){
.service-inner_border ul{
	grid-template-columns:1fr 1fr 1fr 1fr;
	gap:40px;
	width:min(90%,600px);
	align-items:center;
	}
}

.service-inner_border ul img{
	max-width:100%;
}
.service_border dt{
	font-weight:500;
}
.service_border dd{
	font-size:clamp(12px,2vw,13px);
}

/*----------------------------------------------------------------------

ポイントのため方・使い方（例）

/*--------------------------------------------------------------------*/
.point-body{
 background:#D8E0E6;
 padding:3em 0 ;
 margin:0 0 40px;
}


@media screen and (max-width:768px){
.point-body img{
	max-width:90%;
	}

}

.point-title{
	text-align:center;
	letter-spacing:var(--spacing);
	font-size:clamp(15px,3vw,23px);
	font-weight:900;
	padding:0em 0 0em;
	display: flex;
	justify-content: center;
	align-items: flex-end;
	position:relative;
	font-family: sans-serif;
}
@media screen and (min-width:768px){
.point-title{
	align-items: center;
	padding:0em 0 1em;
	}
}

.point-title::before,
.point-title::after {
	width: 1px;
	height: 25px;
	content: "";
	background-color: #000;
}
.point-title::before {
	margin-right:.7em;
	transform: rotate(-45deg);
}

.point-title::after {
	margin-left: .7em;
	transform: rotate(45deg);
}
@media screen and (min-width:768px){
.point-title::before,
.point-title::after {
	width: 2px;
	height: 30px;
	}
.point-title::before {
	margin-right:.7em;
	}
.point-title::after {
	margin-left: .7em;
	}

}

.point-inner{
	display:flex;
	justify-content:center;
	gap:10px;
	width:min(90%, 900px);
	margin: 30px auto 0;
}
@media screen and (min-width:768px){
.point-inner{
	gap:20px;
	}
}

.point-inner div{
	background:#fff;
	padding:15px 0px 0;
	position:relative;
	flex:1;
	text-align:center;
}

.point-notice{
	font-size:clamp(12px,2vw,14px);
	width:min(90%, 400px);
	margin: 10px auto 20px;
	text-indent:-1em;
	padding-left:1em;
}
@media screen and (min-width:768px){
.point-notice{
	width:min(90%, 580px);
	text-align:right;
	}
}

.point-center{
	text-align:center;
	width:min(60%, 300px);
	margin: 0 auto;
}
@media screen and (min-width:768px){
.point-center{
	margin: 0 auto 20px;
	}
}

.point-list_notice{
	padding:25px 0 0;
	width:min(90%, 750px);
	margin: 0 auto;
}

.point-list_notice dt{
	text-align:center;
	letter-spacing:var(--spacing);
	font-size:clamp(16px,3vw,20px);
	font-weight:700;
	margin:0 0 20px;
}
.point-list_notice dd{
	letter-spacing:var(--spacing);
	font-size:clamp(11px,2vw,14px);
	margin:3px 0;
	text-indent:-1em;
	padding-left:1em;
	text-align:center;
}
.point-list_notice dd:before{
content:"※";
}


.slider-title{
	font-size:clamp(18px,3vw,20px);
	font-weight:700;
	color:var(--color-white);
	background:#000;
	padding:.5em 0 ;
	letter-spacing:.5px;
}


.slider-wrapper {
  position: relative;
	width:min(90%, 880px);
  margin: auto;

}

.custom-slider-content {
  display: flex;
  gap: 16px;
 
}
.custom-slider-content .point-notice_slider{
	font-size:clamp(14px,2vw,14px);
	width:min(90%, 300px);
	margin: 0 auto 20px;
	text-indent:-1em;
	padding-left:1em;
}

.item_s figure{
	padding: 20px;
}
/* --- スマホ向け（スライダー有効） --- */
@media (max-width: 767px) {
.custom-slider-content {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -ms-overflow-style: none; /* IE, Edge */
    scrollbar-width: none; /* Firefox */
  }
  .custom-slider-content::-webkit-scrollbar { display: none; } /* Chrome, Safari */

  .item_s {
    flex: 0 0 100%;
    
    scroll-snap-align: start;
  }

.nav-btn {
    position: absolute;
    top: 50%;
    /* transformを1箇所にまとめます */
    background: #e60012;
    border: none;
    width: 30px;
    height: 80px;
    border-radius: 8px;
    cursor: pointer;
    z-index: 10;
    transition: opacity 0.3s;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0; /* 余計な余白をカット */
  }
/* 左矢印の配置調整 */
  .prev-btn {
    left: 0;
    transform: translate(-50%, -50%);
  }

  /* 右矢印の配置調整 */
  .next-btn {
    right: 0;
    transform: translate(50%, -50%);
  }

/* 矢印（白）のデザイン：太さとサイズを微調整 */
  .nav-btn::after {
    content: '';
    display: block;
    width: 10px; /* 少しシャープに */
    height: 10px;
    border-top: 2px solid #fff; /* 白いライン */
    border-right: 2px solid #fff;
    /* 矢印自体の位置を微調整 */
  }

  /* 左向きにする */
  .prev-btn::after {
    transform: rotate(-135deg);
    margin-left: 5px; /* ボタンが半分隠れるので少し右に寄せる */
  }

  /* 右向きにする */
  .next-btn::after {
    transform: rotate(45deg);
    margin-right: 5px; /* ボタンが半分隠れるので少し左に寄せる */
  }
  .is-hidden {
    opacity: 0;
    pointer-events: none; /* クリック不可にする */
  }

  .dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 15px;
  }
}

/* --- PC向け（シンプルな横並び） --- */
@media (min-width: 768px) {
.custom-slider-content .item_s {
    flex: 1; /* 均等に並べる */
  }
  .nav-btn, .dots {
    display: none; /* ボタンとドットを消す */
  }
.item_s img{
	max-width:100%;
	}
}

/* 見た目の調整 */
.item_s { background: #fff; padding: 0px ; border-radius: 0px; text-align: center;}
.dot { width: 8px; height: 8px; background: #ccc; border-radius: 50%; }
.dot.active { background: #333; }

/*----------------------------------------------------------------------

JCBトラベルで遠征

/*--------------------------------------------------------------------*/
.travel-body{
	background:#fff;
	position:relative;
	padding:25px;
	margin:70px 0;
}
@media screen and (min-width:768px){
.travel-body{
	background:#fff;
	position:relative;
	padding:25px;
	margin:70px 0 100px;
	}
}

@media screen and (min-width:768px){
.travel-inner{
	display:grid;
	grid-template-columns:1fr 2fr;
	gap:0 20px;

	}

}

.travel-body img{
	max-width:100%;
}

.travel-inner dl{
	padding:20px 0 0;
}

.travel-inner dt{
	text-align:center;
	font-size:clamp(13px,3vw,20px);
	font-weight:700;
	margin:0 0 20px;
}


.travel-inner dd{
	letter-spacing:var(--spacing);
	font-size:clamp(11px,2vw,16px);
	margin:3px 0;
	text-indent:-1em;
	padding-left:1em;
	text-align:center;
}
@media screen and (min-width:768px){
.travel-inner dt,
.travel-inner dd{
	text-align:left;
	}
}
/*----------------------------------------------------------------------

安全・安心のセキュリティ

/*--------------------------------------------------------------------*/
.security_body{
	margin:30px 0 ;
}
@media screen and (min-width:768px){
.security_body{
	margin:60px 0 ;
	}
}

.security-lbl{
	width:min(55%,330px);
	margin: 0 auto 20px;
	background:#000;
	padding:3px 0 ;
	border-radius:100px;
	color:var(--color-white);
	text-align:center;
	letter-spacing:var(--spacing);
	font-size:clamp(15px,3vw,26px);
	font-weight:700;
}
@media screen and (min-width:768px){
.security-lbl{
	padding:4px 0 ;
	}
}

.lbl-space{
	margin: 50px auto 20px;
}
@media screen and (min-width:768px){
.lbl-space{
	margin: 70px auto 20px;
	}
}
.security_inner{
	display:flex;
	flex-direction: column;
	gap:20px 0 ;
}
@media screen and (min-width:768px){
.security_inner{
	flex-direction: row;
	gap:20px;
	}
}

.last-space{
	margin:0 0 80px;
}
@media screen and (min-width:768px){
.last-space{
	margin:0 0 120px;
	}
}


.security_inner div{
	background:#fff;
	padding:25px 20px;
}
@media screen and (min-width:768px){
.security_inner div{
	padding:30px 25px;
	flex:1;
	}
}

.security_inner div figure img{
	max-width:100%;
}

.security_inner div dt{
	text-align:center;
	letter-spacing:.5px;
	font-size:clamp(17px,3vw,24px);
	font-weight:700;
	white-space: nowrap;
}
.security_inner div dd{
	text-align:left;
	letter-spacing:var(--spacing);
	font-size:clamp(14px,3vw,17px);
	font-weight:500;
}
.security_inner div dd span{
	font-family: sans-serif;
	font-weight:700;
}

.security_notice {
    display: block; /* 追記：ブロック要素にすることでインデントを有効化 */
    letter-spacing: var(--spacing);
    font-size: clamp(11px, 2vw, 14px);
    margin: 6px 0 0 0;
    padding-left: 1em;   /* 左側に1文字分の余白を作る */
    text-indent: -1em;    /* 1行目だけを左に1文字分戻す */
}

.security_notice:before {
    content: "※";
}

/*----------------------------------------------------------------------

申し込みの流れ

/*--------------------------------------------------------------------*/

/* 全体のコンテナ（背景グレーのシマシマを模倣） */
.tab-container {
  max-width: 850px;
  margin: 20px auto 40px;
  padding: 20px 0;
  background-color: #f0f0f0;
}
@media screen and (min-width:768px){
.tab-container {
  margin: 20px auto 80px;
	}
}

/* タブメニューの並び */
.tab-menu {
  display: flex;
  gap: 7px; 
  border-bottom: 4px solid #E5001F;
}
@media screen and (min-width:768px){
.tab-menu {
  gap: 10px; 
  border-bottom: 8px solid #E5001F;
	}
}

/* 各タブの基本スタイル */
.tab-item {
  flex: 1;
  padding: 12px 10px 5px;
  border: none;
  cursor: pointer;
  border-radius: 10px 10px 0 0; /* 上だけ丸く */
  display: flex;
  flex-direction: column;
  align-items: center;
  transition: 0.3s;
  
  /* 非アクティブ時の色（グレー） */
  background-color: #c0bcbc;
  color: #ffffff;
}

/* アクティブ時の色（赤） */
.tab-item.active {
  background-color: #E5001F;
  color: #ffffff;
}

/* テキストのスタイル */
.sub-text {
	font-size:clamp(11px,2vw,13px);
	font-weight:var(--w700);
}
.main-text {
	font-size:clamp(18px,2vw,21px);
	font-weight:var(--w700);
}

/* コンテンツエリア */
.tab-content {
  display: none;
  background: #fff;
  padding: 20px 20px;
  text-align: center;
  margin-top: 15px; 
}
@media screen and (min-width:768px){
.tab-content {
	padding: 40px 20px 20px;
	}
}

.tab-content .lbl{
	width:min(100%,500px);
	margin: 0 auto 0px;
}

@media screen and (min-width:768px){
.tab-content .lbl{
	margin: 0 auto 40px;
	}
}

.tab-content .lbl dt{
	font-size:clamp(13px,2vw,20px);
	font-weight:var(--w500);
	letter-spacing:.5px;

}
.tab-content .lbl dd{
	font-size:clamp(18px,2vw,33px);
	font-weight:900;
	color:#E5001F;
	border-top:1px solid #E5001F;
	border-bottom:1px solid #E5001F;
	padding:8px 0 ;
	margin:10px 0 0;
}
@media screen and (min-width:768px){
.tab-content .lbl dd{
	border-top:2px solid #E5001F;
	border-bottom:2px solid #E5001F;
	}
}


.tab-content.active {
  display: block;
}

.step-container {
    padding: 30px 0px 30px;
    max-width: 100%;
    margin: 0 auto; /* 左寄せを確実にするため */
    width:min(95%,700px);
}
@media screen and (min-width:768px){
.step-container {
    padding: 30px 0px 50px;
	}
}


.step-item {
    display: flex;
    position: relative;
    padding-bottom: 30px;
    align-items: flex-start; /* 上揃え */
    justify-content: flex-start; /* 左寄せ */
}
@media screen and (min-width:768px){
.step-item {
    padding-bottom: 60px;
	}
}

/* 最後の項目は線を出さない */
.step-item:last-child {
    padding-bottom: 0;
}

/* 垂直ライン */
.step-item::before {
    content: "";
    position: absolute;
    left: 7px; 
    top: 25px;
    bottom: -20px;
    width: 4px;
    background-color: #E5001F;
}
@media screen and (min-width:768px){
.step-item::before {
    left: 7px; 
    top: 25px;
    bottom: -30px;
    width: 4px;
	}
}


.step-item:last-child::before {
    display: none;
}

/* 赤いドット */
.step-dot {
    position: absolute;
    left: 3px;
    top: 15px;
    width: 12px;
    height: 12px;
    background-color: #E5001F;
    border-radius: 50%;
    z-index: 2;
}

@media screen and (min-width:768px){
.step-dot {
    left: 1px;
    top: 15px;
    width: 16px;
    height: 16px;
	}

}

/* 数字：幅を固定してテキスト開始位置を統一 */
.step-num {
    font-size: 40px;
    font-weight: 700;
    line-height: 0.8;
    margin-left: 25px; 
    margin-top:5px;
    min-width: 45px;
    text-align: left;
}

@media screen and (min-width:768px){
.step-num {
    margin-left: 40px; 
    min-width: 50px;
    font-size: 55px;
    margin-top:0px;
	}
}

.step-content {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	text-align: left;
	padding-top: 5px;
}

.step-title {
	font-size:clamp(15px,2vw,23px);
	font-weight: 700;
	margin: 0 0 5px 0;
	line-height: 1.2;
}
.step-title span{
	color:#e60012;
	margin:0 10px;
}

.step-description {
	font-size:clamp(12px,2vw,16px);
	color: #333;
	line-height: 1.6;
	margin: 0;
}

.tab-notice{
	margin:0px auto 0px;
	letter-spacing:1px;
	text-align:left;
	max-width:710px;
}
@media screen and (min-width:768px){
.tab-notice{
	margin:0px auto 40px;
	}
}


.tab-notice dt{
	font-size:clamp(13px,2vw,17px);
	font-weight:var(--w700);
	margin:0 0 5px;
	color:#e60012;
}
.tab-notice dd{
	font-size:clamp(12px,2vw,13px);
	margin:3px 0;
}
.tab-notice dd{
	text-indent:-.7em;
	padding-left:.7em;
}
.tab-notice dd:before{
	content:"●";
}

.tab-comeent{
	font-size:clamp(14px,2vw,17px);
	font-weight:var(--w700);
	border:1px solid #000;
	border-radius:10px;
	padding:10px 0 ;
	width:min(90%,650px);
	margin: 25px auto;
}
@media screen and (min-width:768px){
.tab-comeent{
	border:2px solid #000;
	}
}
/*----------------------------------------------------------------------

カードの基本情報

/*--------------------------------------------------------------------*/

.detail_figure{
	text-align:center;
	margin:60px 0;
}

.table-details{
	background:#fff;
	width:100%;
	letter-spacing:1px;
}
.table-details caption{
	caption-side:bottom;
	margin:20px 0 0;
	font-size:clamp(12px,2vw,13px);
}
.table-details caption:before{
	content:"※";
}
.table-details th,
.table-details td{
	padding:25px;
	border:2px solid #f5f5f5;
}
@media screen and (max-width:768px){
.table-details th,
.table-details td{
	padding:25px;
	width:100%;
	display:block;
	border:none;
	border:1px solid #f5f5f5;
	}
}

.table-details th{
	background:#D8E0E6;
	vertical-align:top;
	font-size:clamp(14px,2vw,14px);
	width:230px;
	font-weight:var(--w700);
}
@media screen and (max-width:768px){
.table-details th{
	width:100%;
	padding:15px 25px;
	}
.table-details td{
	padding:10px 25px 40px;
	}
}
.table-details td{
	font-size:clamp(14px,2vw,15px);
}
.table-details dt{
	font-weight:var(--w700);
}
.table-in_notice,
.table-in_service{
	font-size:clamp(12px,2vw,13px);
	margin:10px 0 20px;
}
.table-in_notice li,
.table-in_service li{
	text-indent:-1em;
	padding-left:1em;
}
.table-in_notice li:before{
	content:"※";
}
.table-in_service li:before{
	content:"・";
}
.table-in_service li{
	margin:10px 0 0;
}

.table-in_service li span{
	display:block;
}
.table-in_service li a{
	color:#058FD1;
	background:url(../cmn/images/arrow_blank_blue.png) no-repeat 100% 50%;
	padding-right:15px;
	background-size:10px;
}
.last-style{
	margin:10px 0 0px;
}
/*----------------------------------------------------------------------

注意事項

/*--------------------------------------------------------------------*/
.main-notice{
	margin:40px 0 0;
	letter-spacing:1px;
}
.main-notice dt{
	font-size:clamp(15px,2vw,17px);
	font-weight:var(--w700);
	margin:0 0 10px;
}
.main-notice dd{
	font-size:clamp(13px,2vw,14px);
	margin:3px 0;
}
.main-notice dd{
	text-indent:-1em;
	padding-left:1em;
}
.main-notice dd:before{
	content:"●";
}

/*----------------------------------------------------------------------

モーダルウィンドウ

/*--------------------------------------------------------------------*/
/* 基本スタイル */
        .modal-overlay {
            display: none; /* 初期状態は非表示 */
            position: fixed;
            top: 0; left: 0;
            width: 100%; height: 100%;
            background: rgba(0, 0, 0, 0.8);
            z-index: 9999;
            justify-content: center;
            align-items: center;
        }

        .modal-content-insentive {
            background: #fff;
            padding: 20px 20px;
            width: 90%;
            max-width: 830px;
            border-radius: 0px;
            position: relative;
            animation: modalIn 0.3s;
        }
        .modal-content-cta {
            background: #fff;
            padding: 20px 20px 30px;
            width: 90%;
            max-width: 830px;
            min-height: 520px;
            border-radius: 0px;
            position: relative;
            animation: modalIn 0.3s;
        }
@media screen and (min-width:768px){
        .modal-content {
            padding: 30px 20px;
            max-width: 830px;
        }

}


        .close-btn {
            position: absolute;
            top: -50px; right: -10px;
            font-size: 35px;
            cursor: pointer;
            font-weight:300;
            color: #fff;
            font-family: sans-serif;
        }
     
@media screen and (min-width:768px){
        .close-btn {
            top: -75px; right: -10px;
            font-size: 60px;
            /*
            position: absolute;
            top: -50px; right: -10px;
            font-size: 35px;
            */
        }
}
        .close-btn:hover {
            color: #f00;
        }
        @keyframes modalIn {
            from { opacity: 0; transform: scale(0.9); }
            to { opacity: 1; transform: scale(1); }
        }
        
@media screen and (min-width: 769px) {
    .modal-overlay {
        display: none;
        position: fixed;
        top: 0; left: 0;
        width: 100%; height: 100%;
        background: rgba(0, 0, 0, 0.8);
        z-index: 9999;
        /* 中央配置を担保 */
        justify-content: center;
        align-items: center;
    }

    .close-btn_fixed {
        /* HTML構造が変わったため、配置基準を画面全体に固定 */
        position: fixed !important; 
        /* PC版の白枠（max-width: 830px）の右上に合わせる計算 */
        top: 50px; 
        right: calc(50% - 415px - 40px); /* 中央から白枠の半分+余白分右へ */
        font-size: 60px;
        color: #fff;
        z-index: 10000;
        cursor: pointer;
    }
}

.modal-title{
	color:#E5001F;
	font-size:clamp(18px,3vw,28px);
	font-weight:var(--w700);
	text-align:center;
	line-height:1.3;
	margin: 20px 0 0px;
}
.iwata-only{
	margin: 0px 0 0px;
}

@media screen and (min-width:768px){
.iwata-only{
	margin: 20px 0 30px;
	}
}

@media screen and (min-width:768px){
.modal-img img{
	max-width:100%;
	}
}

.iwata-only img{
	max-width:100%;
}

.modal-img {
	text-align:center;
}
.modal-content dd{
	font-size:clamp(14px,3vw,23px);
	font-weight:700;
	letter-spacing:1px;
	text-align:center;
	margin: 10px auto;
	font-family: sans-serif;
}

.modal-notice {
	font-size:clamp(12px,2vw,14px);
	margin:20px auto 0;
	width:min(100%,600px);
}
@media screen and (min-width:768px){
.modal-notice {
	margin:40px auto 0;

	}
}

.modal-notice li{
	text-indent:-1em;
	padding-left:1em;
	margin:3px 0;
}
.modal-notice li:before{
	content:"※";
}

.modal_headline{
    display: flex;
    align-items: center;
	font-size:clamp(14px,3vw,18px);
	font-weight:500;
	letter-spacing:1px;
	margin:10px auto 0;
	width:min(100%,600px);
	
}
@media screen and (min-width:768px){
.modal_headline{
	margin:30px auto 20px;
	}
}

.modal_headline:before,
.modal_headline:after {
    content: "";
    height: 2px;
    flex-grow: 1;
    background-color: #666;
}

.modal_headline:before {
    margin-right: 1rem;
}

.modal_headline:after {
    margin-left: 1rem;
}

/*--------------------------------------------------

	申し込むボタンの中身

----------------------------------------------------*/
:root {
--primary-red: #e60012;
--selected-bg: #fff5e6;
--border-color: #e60012;
}

.modal-card_title{
	text-align:center;
	margin:10px auto 15px;
	font-size:clamp(12px,3vw,20px);
	font-weight:500;
}

/* 選択リスト（ラジオボタン） */
.option-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 0px;
}
.option-item {
	display: flex;
	align-items: center;
	border: 2px solid var(--border-color);
	border-radius: 8px;
	padding: 10px 30px 10px;
	cursor: pointer;
}
@media screen and (max-width:769px){
.option-item {
	padding: 5px 10px 10px;
	border: 1px solid var(--border-color);
	}
}

.option-item:has(input:checked) {
	border-color: var(--primary-red);
	background-color: var(--selected-bg);
}

.option-item input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    /* サイズ設定（ここをお好みで調整してください） */
    width: 20px;
    height: 20px;
    /* 枠線の設定 */
    border: 2px solid #e60012; /* 最初から赤色に設定 */
    border-radius: 50%;
    background-color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin-right: 30px; /* 右側のテキストとの距離 */
    flex-shrink: 0;    /* 親要素のフレックスで潰れないように固定 */
}
@media screen and (max-width:769px){
.option-item input[type="radio"] {
	margin-right: 15px; /* 右側のテキストとの距離 */
    width: 15px;
    height: 15px;
    /* 枠線の設定 */
    border: 1px solid #e60012; /* 最初から赤色に設定 */
	}
}


/* 選択された時の「中の点」をデザイン */
.option-item input[type="radio"]::after {
    content: "";
    width: 10px; /* 中の丸のサイズ */
    height: 10px;
    background-color: #e60012;
    border-radius: 50%;
    
    /* 初期状態は透明にして、チェック時だけ出す */
    opacity: 0;
    transition: opacity 0.2s ease;
}
@media screen and (max-width:769px){
.option-item input[type="radio"]::after {
    width: 9px; /* 中の丸のサイズ */
    height: 9px;

	}
}

/* チェックが入った時の挙動 */
.option-item input[type="radio"]:checked::after {
    opacity: 1;
}
.option-content {
	display:flex;
	gap:0 30px;
	justify-content:flex-start;
	align-items:center;
}
@media screen and (max-width:769px){
.option-content {
	gap:0 15px;
	}
}

.option-content dl{
	line-height:1.1;
	margin:10px 0 0;
}
@media screen and (max-width:769px){
.option-content dl{
	line-height:1.3;
	}
}

.option-content dt {
	font-size:clamp(12px,3vw,17px);
	font-weight:500;
	color: #e60012;
	letter-spacing:1px;
	

}
.option-content dd {
	font-size:clamp(11px,2vw,14px);
	text-align:left;
	font-weight:300;
}
@media screen and (max-width:769px){
.option-content dd {
	margin:5px 0 0;
	}
}


/* STEP 2 見出し */
	.step-header{
	text-align: center;
	display:flex;
	justify-content:center;
	align-items:center;
	margin:20px 0 15px;
	font-size:clamp(14px,3vw,25px);
	font-weight:700;
}
.step-badge {
	background: #000;
	color: #fff;
	padding: 4px 20px;
	border-radius: 100px;
}
@media screen and (max-width:769px){
.step-badge {
	padding: 2px 10px;
	}
}

.step-title_modal {
	margin-left: 10px;
	font-size:clamp(18px,3vw,33px);
	font-weight:900;
	font-family: sans-serif;
}

.step-two{
	margin:60px 0 30px ;
}
@media screen and (max-width:769px){
.step-two{
	margin:40px 0 20px ;
	}
}

/* --- ボタンエリア共通スタイル --- */
.btn-wrapper {
	display: none;
	gap: 15px;
	justify-content: center;
}
.btn-wrapper.active {
	display: flex;
} /* activeクラスがついた方だけ表示 */

@media screen and (max-width:769px){
.btn-wrapper.active {
	display: flex;
	flex-direction: column;
	gap:30px 0;
	}
}

.action-box {
	flex: 1;
	text-align: center;
}
.action-guide {
	font-size:clamp(13px,3vw,16px);
	font-weight: 500;
	margin-bottom: 10px;
	min-height: 2.5em;
}
.action-guide::after {
	content: "▼";
	display: block;
	font-size: 0.9rem;
	margin-top: 3px;
}
.action-box{

}

.action-box p{
	width:min(90%,350px);
	margin: 0 auto;
}



/* 1枚ボタン用の幅調整 */
.single-btn-layout .action-box {
	max-width: 350px;
	margin: 0 auto;
}
@media screen and (max-width:769px){
.single-btn-layout .action-box {
	max-width: 100%;
	width: 100%;
	margin: 0 auto;
	}
}
.btn-tag { 
	background: #fff;
	color: var(--primary-red);
	padding: 1px 10px;
	margin-right: 12px;
	font-size:clamp(16px,3vw,20px);

}
.btn07{
	position: relative;
	text-decoration: none;
	display: block;
	background:#E5001F;
	color:#fff;
	padding: 10px 40px 10px 30px;
	border-radius:7px;
	text-align: center;
	outline: none;
	transition: ease .2s;
	font-size:clamp(16px,2vw,23px);
	font-weight:var(--w700);

}
@media screen and (min-width:768px){
.btn07{
	padding: 15px 40px 15px 30px;
	}
}

.btn07:hover{
	background:rgba(229,0,31,.8);
}
.btnarrow2::after{
	content: '';
	position: absolute;
	top:40%;
	right: 20px;
	width: 8px;
	height: 8px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transform: rotate(45deg);
	transition: all .3s;
}
@media screen and (min-width:768px){
.btnarrow2::after{
	right: 20px;
	width: 10px;
	height: 10px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;

}

}
.btnarrow2:hover::after{
	right: 15px;
}

@media screen and (max-width:769px){
.fixed-modal{
	box-sizing: border-box;
    /* ↓ここが重要：はみ出た分をスクロールさせる */
    max-height: 65vh; /* 画面の高さの90%を上限にする */
    overflow-y: auto;  /* 縦方向にスクロールを出す */
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch; /* iOSのスクロールを滑らかに */
	position: relative;
	}
.close-btn_fixed {
        position: fixed;     /* スクロールしても動かさない */
        display: block;
        /* 位置調整：白枠の右上に重なるように配置 */
        top: calc(4vh + 10px); /* 白枠の出現位置に合わせて微調整してください */
        right: 2%;           /* 画面端からの距離 */
        
        /* サイズと見た目 */
        width: 40px;         /* クリックエリアの幅 */
        height: 40px;        /* クリックエリアの高さ */
        font-size: 40px;     /* ×印自体の大きさ */
        font-weight: 300;    /* 線を少し細くしてスタイリッシュに（画像に近い質感） */
        line-height: 40px;   /* 上下の位置合わせ */
        color: #ffffff;      /* 真っ白 */
        text-align: center;
        z-index: 1100;       /* 白枠(1000)よりも必ず上に */
        cursor: pointer;
        font-family: sans-serif; /* フォントによって×の形が変わるのを防ぐ */
    }
}

/* フェードインのアニメーション定義 */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px); /* 少し下から浮き上がる演出 */
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 表示された時に適用するクラス */
.js-step2-area.is-visible {
  display: block !important; /* JSのstyle.displayを上書き */
  animation: fadeIn 0.8s ease forwards;
}