@charset "UTF-8";

/*************************
font_import
*************************/

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap');


/*************************
reset
*************************/

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,main,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section{display:block}*[hidden]{display:none}body{line-height:1}menu,ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}table{border-collapse:collapse;border-spacing:0}body.noscroll{overflow:hidden}.iframe{width:100%;height:100%}.overlay{position:fixed;top:0;left:0;height:100vh;width:100%}.overlay.hidden{top:-100vh}#header.fixed{top:0;height:48px;position:sticky;box-shadow:0 2px 10px #2121211a}#header,#footer{overflow:hidden}@media screen and (min-width: 768px){#header.fixed{height:64px}}

*, *::before, *::after { box-sizing: border-box; }

#header {
	position: relative;
	z-index: 100;
}

#drawer.overlay,
#search-modal.overlay { z-index: 101; }

#drawer.overlay.hidden,
#search-modal.overlay.hidden {
	opacity: 0;
	z-index: 0;
}

/* 以下へページ固有のスタイル記述していく */

/*************************
custom properties
*************************/

#LP.pointup {
	--lp-color_black: #333;
	--lp-color_white: #fff;

	--lp-color_red: #C92222;
	--lp-color_sky-blue: #2882FF;
	--lp-color_orange: #FF9600;
}

#LP.pointup .bgcl_black {
	background-color: var(--lp-color_black);
}
#LP.pointup .bgcl_sky-blue {
	background-color: var(--lp-color_sky-blue);
}
#LP.pointup .bgcl_orange {
	background-color: var(--lp-color_orange);
}

/*************************
spacer
*************************/
#LP.pointup .mb_none { margin-bottom: 0 !important; }
#LP.pointup .mb_xs { margin-bottom: 3% !important; }
#LP.pointup .mb_sm { margin-bottom: 5% !important; }
#LP.pointup .mb_md { margin-bottom: 8% !important; }
#LP.pointup .mb_lg { margin-bottom: 15% !important; }

#LP.pointup .mt_none { margin-top: 0 !important; }
#LP.pointup .mt_xs { margin-top: 3% !important; }
#LP.pointup .mt_sm { margin-top: 5% !important; }
#LP.pointup .mt_md { margin-top: 8% !important; }
#LP.pointup .mt_lg { margin-top: 15% !important; }

/* SP限定 */
@media screen and (max-width: 980px) {
#LP.pointup .mb_xs_sp { margin-bottom: 3% !important; }
#LP.pointup .mb_sm_sp { margin-bottom: 5% !important; }
#LP.pointup .mb_md_sp { margin-bottom: 8% !important; }
#LP.pointup .mb_lg_sp { margin-bottom: 15% !important; }

#LP.pointup .mt_xs_sp { margin-top: 3% !important; }
#LP.pointup .mt_sm_sp { margin-top: 5% !important; }
#LP.pointup .mt_md_sp { margin-top: 8% !important; }
#LP.pointup .mt_lg_sp { margin-top: 15% !important; }
}

/*************************
main
SP_layout（980px未満）
*************************/

#LP.pointup {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	line-height: 1.5;
	color: var(--lp-color_black);
	margin: 0 auto;
	width: 100%;
}

#LP.pointup .txtFont_serif {
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
}

#LP.pointup.is_end { pointer-events: none; }

#LP.pointup img {
	user-select: none;
	vertical-align: bottom;
	width: 100%;
	height: auto;
}

#LP.pointup a {
	display: block;
	text-decoration: none;
	transition: filter .4s;
}
#LP.pointup a:hover { filter: brightness(.7); }

#LP.pointup a.inlineLink {
	display: inline;
}

#LP.pointup time,
#LP.pointup span {
	color: inherit;
	font-size: inherit;
	font-weight: inherit;
	letter-spacing: inherit;
}

#LP.pointup .device_sp { display: block; }
#LP.pointup .device_pc { display: none; }

/* キービジュアル */
#LP.pointup .kvArea,
#LP.pointup .kvArea__text {
	margin: 0 auto;
	width: 100%;
}

/* メインコンテンツ */
#LP.pointup .mainArea.bg_main {
	background-image: url('../images/sp/wh_main_bg.jpg'),  linear-gradient(to right, #CBB47A 0%, #F5EDBF 50%, #CBB47A 100%);
	background-repeat: no-repeat, no-repeat;
	background-size: contain, cover;
	background-position: center top, center;
}

#LP.pointup .mainArea__inner {
	width: 92%;
	margin: 0 auto;
	padding: 6% 0 10%;
}

#LP.pointup .mainArea__contents .main_header-h1 {
	margin-bottom: 5%;
	text-align: center;
	font-size: 3.9vw;
	font-weight: 800;
	line-height: 1.8;
}

/* 注意事項・有効期限 */
#LP.pointup .cp_notes_round {
	text-align: center;
	margin: 0 auto;
	width: 100%;
	padding: 0.4rem 0;
	border-radius: 100px;
	color: var(--lp-color_white);
	background-color: var(--lp-color_red);
}

#LP.pointup .cp_notes_round.icn_warning {
	background-image: url(../images/common/wh_main_icon_warning.png);
	background-repeat: no-repeat;
    background-size: 7vw;
    background-position-x: 3.5vw;
    background-position-y: 3.3vw;
	margin: 5% auto 8%;
}

#LP.pointup .cp_notes_round p {
	padding-left: 1rem;
	font-size: 2.1vw;
	font-weight: 700;
	letter-spacing: 0.01em;
	line-height: 1.5;
}

#LP.pointup .cp_notes_round p span {
	display: inline-block;
	padding-top: 1%;
	font-size: 2.6vw;
	font-weight: 900;
	line-height: 1.5;
}

#LP.pointup .cp_notes_txt {
	margin-top: 2%;
	margin-bottom: 8%;
	text-align: center;
	font-size: 2.6vw;
}

/* ボタン各種 */
#LP.pointup .btns_container {
	width: 100%;
	margin: 0 auto;
}

#LP.pointup .btn_round a {
	position: relative;
	display: block;
	margin: 0 auto;
	text-align: center;
	user-select: none;
	min-height: 3.3em;
	padding: 1.1em 0;
	font-size: 4vw;
	font-weight: 700;
	letter-spacing: 0.01em;
	line-height: 1;
	border-radius: 100px;
	transition: .4s;
	color: var(--lp-color_white);
}

#LP.pointup .btn_round a::after {
	content: "";
    display: block;
    position: absolute;
    top: 42%;
    right: 5%;
    transform: rotate(45deg);
    transition: all 0.2s ease-in-out;
    width: 10px;
    height: 10px;
	border-top: solid 2px var(--lp-color_white);
    border-right: solid 2px var(--lp-color_white);
}

#LP.pointup .btn_round.short a {
	width: 77vw;
}

#LP.pointup .btn_round.wide a {
	width: 100%;
}

#LP.pointup .btn_round.twoLines a {
	padding: 0.7em 0;
    font-size: 3.4vw;
    line-height: 1.3;
}

#LP.pointup .btn_round.buyNow a {
	font-size: 3.8vw;
}

#LP.pointup .btn_header_txt {
	margin-bottom: 3%;
    text-align: center;
    font-size: 4.5vw;
    font-weight: 900;
}

/* ポイントアップ購入例 */
#LP.pointup .mainArea__ex_pointUp {
	margin-bottom: 8%;
	padding: 4% 2% 6%;
	background-color: #FDFAED;
}

/* 注意事項 */
#LP.pointup .mainArea__notes {
	margin-bottom: 8%;
	padding: 5% 3%;
	background-color: var(--lp-color_white);
}

#LP.pointup .mainArea__notes .notes_header {
	margin-bottom: 0.6em;
    text-align: center;
    font-size: 4.5vw;
    font-weight: 900;
}

#LP.pointup .mainArea__notes .notes_list li {
	margin-bottom: 0.4em;
	font-size: 2.6vw;
	font-weight: 500;
	text-align: left;
	padding-left: 1.1em;
	letter-spacing: 0.01em;
	line-height: 1.5;
}
#LP.pointup .mainArea__notes .notes_list li::before {
	content: '※';
	display: inline-block;
	margin-left: -1em;
	width: 1.1em;
}

#LP.pointup .textLink { color: var(--lp-color_sky-blue); border-bottom: 1px solid var(--lp-color_sky-blue); font-weight: 500;}

/* 他施策バナー */
#LP.pointup .promotion__banners {
    margin: 0 auto;
}

/* APIスライダー */
#LP.pointup .API__slider {
	width: 92%;
	margin: 0 auto;
}
	
#LP.pointup .slider__container {
    margin: 0 auto;
    padding: 6% 4%;
    background-color: var(--lp-color_white);
}

#LP.pointup .main_area__header02 {
    position: relative;
	margin: 0 auto 5%;
}

#LP.pointup .main_area__header02 p {
    position: absolute;
    width: 100%;
	top: 10%;
    left: 50%;
	transform: translateX(-50%);
    text-align: center;
    font-size: 5vw;
    font-weight: 900;
    letter-spacing: 0.05em;
    color: var(--lp-color_white);
}

#LP.pointup .main_area__header02 p.header_mop {
	top: 5%;
    font-size: 3.8vw;
    line-height: 1.3;
}

/* もっと見るボタン */
#LP.pointup .sliderDynamic .btn_andmore {
	display: none;
    position: absolute;
    right: 2vw;
    top: 2vw;
    align-items: center;
    gap: 0.4em;
    text-decoration: none;
    font-size: 4vw;
    font-weight: 700;
    color: #252525;
    border-bottom: 2px solid #8f8f8f;
    line-height: 1;
	padding-bottom: 0.2em;
}

#LP.pointup .sliderDynamic .btn_andmore:hover {
	 filter: opacity(.7) 
}

#LP.pointup .sliderWrapper:has(.is_show) .btn_andmore {
    display: inline-flex;
}

#LP.pointup .sliderDynamic .btn_andmore.arrow_right {
	padding-right: 0.1em;
}

#LP.pointup .sliderDynamic .btn_andmore.arrow_right::after {
	content: '';
    width: 0.5em;
    height: 0.5em;
    border-top: solid 2px #252525;
    border-right: solid 2px #252525;
    transform: rotate(45deg);
    display: inline-block;
    flex-shrink: 0;
    margin-top: 0.1em;
}

/* 期間終了後表示 */
#LP.pointup .mainArea__campaignEnd {
	background-color: var(--lp-color_white);
	border-radius: 5px;
	color: var(--lp-color_black);
	display: none;
	font-size: 4.3vw;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
	margin: 0 auto;
	margin-bottom: 6%;
	padding: 3% 0;
	width: 100%;
}
#LP.pointup .mainArea__campaignEnd span { font-size: 70%; font-weight: 500;}

/*************************
main
PC_layout（980px以上）
*************************/

@media screen and (min-width: 980px) {

	#LP.pointup img {
		margin: 0 auto;
		width: fit-content;
	}

	/*************************
	spacer
	*************************/
	#LP.pointup .mb_xs { margin-bottom: 16px !important; }
	#LP.pointup .mb_sm { margin-bottom: 30px !important; }
	#LP.pointup .mb_md { margin-bottom: 60px !important; }
	#LP.pointup .mb_lg { margin-bottom: 80px !important; }

	#LP.pointup .mt_xs { margin-top: 16px !important; }
	#LP.pointup .mt_sm { margin-top: 30px !important; }
	#LP.pointup .mt_md { margin-top: 60px !important; }
	#LP.pointup .mt_lg { margin-top: 80px !important; }

	#LP.pointup .device_sp { display: none; }
	#LP.pointup .device_pc { display: block; }

	/* キービジュアル */
	#LP.pointup .kvArea__inner {
		background-image: url(../images/pc/wh_kv_bg.jpg);
		background-size: cover;
		background-position: center top;
		background-repeat: no-repeat;
	}

	#LP.pointup .kvArea__bottom {
		background-image: url(../images/pc/wh_kv_bottom_band.jpg);
		background-size: cover;
		background-position: center top;
		background-repeat: no-repeat;
		min-height: 50px;
		padding: 10px;
	}

	#LP.pointup .kvArea__bottom .promotion_term {
		display: block;
		width: fit-content;
		margin: 0 auto;
	}

	#LP.pointup .kvArea__text {
		padding: 34px 0;
		width: fit-content;
	}

	/* メインコンテンツ */
	#LP.pointup .mainArea {
		position: relative;
	}

	#LP.pointup .mainArea.bg_main {
		background-image: url('../images/pc/wh_main_bg.jpg');
		background-size: cover;
	}

	#LP.pointup .mainArea__inner {
		width: 980px;
		padding: 60px 0 80px;
	}

	#LP.pointup .mainArea__contents-block:not(:last-of-type) { margin-bottom: 36px; }

	#LP.pointup .mainArea__contents .main_header-h1 {
		margin-bottom: 30px;
		font-size: 24px;
		letter-spacing: .05em;
	}

	/* 注意事項・有効期限 */
	#LP.pointup .cp_notes_round {
		padding: 12px 0;
        min-height: 75px;
	}

	#LP.pointup .cp_notes_round.icn_warning {
		background-size: auto;
		background-position-x: 24px;
        background-position-y: 17px;
		margin: 40px auto 60px;
	}

	#LP.pointup .cp_notes_round p {
		padding-left: 1.5rem;
		font-size: 16px;
	}

	#LP.pointup .cp_notes_round p span {
		padding-top: 0;
		font-size: 18px;
	}

	#LP.pointup .cp_notes_txt {
		margin-top: 16px;
		margin-bottom: 60px;
		font-size: 14px;
	}

	/* ボタン各種 */
	#LP.pointup .btn_header_txt {
		margin-bottom: 16px;
		font-size: 26px;
	}

	#LP.pointup .btn_round.short a {
		width: 450px;
	}

	#LP.pointup .btn_round a {
        margin: 0 auto;
        min-height: 82px;
        padding: 27px 0;
        font-size: 24px;
    }

	#LP.pointup .btn_round.twoLines a {
		font-size: 20px;
	}

	#LP.pointup .btn_round a::after {
		top: 33px;
		right: 24px;
		width: 16px;
		height: 16px;
		border-top: solid 3px var(--lp-color_white);
		border-right: solid 3px var(--lp-color_white);
	}

	#LP.pointup .btn_flexBox {
		display: flex;
		justify-content: space-between;
	}


	/* ポイントアップ購入例 */
	#LP.pointup .mainArea__ex_pointUp {
		margin-bottom: 60px;
		padding: 20px;
	}

	/* 注意事項 */
	#LP.pointup .mainArea__notes {
		margin-bottom: 60px;
		padding: 30px 35px;
	}

	#LP.pointup .mainArea__notes .notes_header {
		font-size: 20px;
	}

	#LP.pointup .mainArea__notes .notes_list li {
		font-size: 14px;
	}
	

	/* APIスライダー */
	#LP.pointup .API__slider {
		width: 1200px;
	}

	#LP.pointup .main_area__header02 {
		width: fit-content;
		margin: 0 auto 20px;
	}

	#LP.pointup .main_area__header02 p {
		top: 20px;
		font-size: 32px;
	}

	#LP.pointup .main_area__header02 p.header_mop {
		top: 7px;
        font-size: 28px;
	}

	#LP.pointup .slider__container {
		padding: 40px;
	}

	/* もっと見るボタン */
	#LP.pointup .sliderDynamic .btn_andmore {
		font-size: 20px;
		right: 10px;
        top: 10px;
	}

	#LP.pointup .sliderDynamic .btn_andmore.arrow_right::after {
		width: 11px;
        height: 11px;
        bottom: 9px;
	}

	/* 期間終了後表示 */
	#LP.pointup .mainArea__campaignEnd {
		width: 980px;
		font-size: 32px;
		margin-bottom: 40px;
		padding: 24px 0;
	}
}