@charset "UTF-8";

/* 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,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

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;
}

html {
	color: #333;
	line-height: 1.4;
	word-spacing: 0;
	font-size: 1.33vw;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ",
		"MS Pゴシック", "MS PGothic", sans-serif;
	overflow-x: hidden;
}

body {
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
}

* {
	margin: 0;
	padding: 0;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: 100%;
}

ol,
ul {
	list-style: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

th {
	text-align: left;
	font-weight: normal;
}

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

img {
	vertical-align: bottom;
	max-width: 100%;
}

input,
textarea,
select,
option,
optgroup,
button {
	border-radius: 0;
	outline: none;
}

body {
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1.4rem;
}

.flex-between {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.container {
	width: 100%;
	max-width: 750px;
	margin: 0 auto;
	padding: 0 5.33vw;
}

.text-center {
	text-align: center;
}

.text-left {
	text-align: left;
}

.text-bold {
	font-weight: bold;
}

.text-medi {
	font-weight: 500;
}

.bg-db {
	background-color: #dbdbdb;
}

.bg-yl {
	background-color: #fff94c;
}

.lh1 {
	line-height: 1;
}

.fs20 {
	font-size: 2rem;
}

.fs22 {
	font-size: 2.2rem;
}

.fs26 {
	font-size: 2.6rem;
}

.fs28 {
	font-size: 2.8rem;
}

.fs30 {
	font-size: 3rem;
}

.fs32 {
	font-size: 3.2rem;
}

.fs34 {
	font-size: 3.4rem;
}

.fs36 {
	font-size: 3.6rem;
}

.fs38 {
	font-size: 3.8rem;
}

.fs40 {
	font-size: 4rem;
}

.fs54 {
	font-size: 5.4rem;
}

.fs58 {
	font-size: 5.8rem;
}

.fs86 {
	font-size: 8.6rem;
}

.mb-0 {
	margin-bottom: 0 !important;
}

.mb-15 {
	margin-bottom: 1.5rem;
}

.mb-2 {
	margin-bottom: 2rem;
}

.mb-3 {
	margin-bottom: 3rem;
}

.mb-4 {
	margin-bottom: 4rem;
}

.mb-5 {
	margin-bottom: 5rem;
}

.mb-8 {
	margin-bottom: 8rem;
}

.mb-10 {
	margin-bottom: 10rem;
}

.mb-15 {
	margin-bottom: 15rem;
}

.mb-20 {
	margin-bottom: 20rem;
}

.mb-35 {
	margin-bottom: 3.5rem !important;
}

.mt-15 {
	margin-top: 1.5rem;
}

.mt-2 {
	margin-top: 2rem;
}

.mt-3 {
	margin-top: 3rem;
}

.mt-4 {
	margin-top: 4rem;
}

.mt-35 {
	margin-top: 3.5rem;
}

.pd15 {
	padding: 1.5rem;
}

.pdt8 {
	padding-top: 8rem;
}

.color {
	color: #d80c18;
}

.color2 {
	color: #009abd;
}

.link {
	color: #009abd;
	text-decoration: underline;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

.link:hover {
	opacity: 0.7;
	text-decoration: none;
}

.img-1 {
	width: 33.7rem;
	height: 22.4rem;
}

.img-2 {
	/*width: 58.7rem; height: 26.9rem;*/
	width: 58rem;
	height: 48.3rem;
}

.img-3 {
	width: 57.2rem;
	height: 29.3rem;
}

.img-4 {
	width: 54.6rem;
	height: auto;
}

.img-5 {
	width: 55rem;
	height: 33.2rem;
}

.img-6 {
	width: 33.7rem;
	height: 16.4rem;
}

.img-7 {
	width: 61rem;
	height: 44.7rem;
}

.img-8 {
	width: 25.4rem;
	height: 21.7rem;
}
.img-14 {
	width: 19.8rem;
	height: 19.8rem;
}

header {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 100%;
	height: 8.5rem;
	color: #fff;
	background-color: #00779b;
}

header .txt {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: baseline;
	-ms-flex-align: baseline;
	align-items: baseline;
	width: 100%;
}

header .txt>span:first-child {
	font-size: 4rem;
	font-weight: 900;
}

header .txt>span:last-child {
	font-size: 2.4rem;
	font-weight: 700;
}

.mv {
	background-image: url(../imgs/bg-mv.png);
	background-size: cover;
	background-position: center;
	text-align: center;
}

.bg-blue {
	background-color: #009abd;
	padding: 6.5rem 0 8rem;
}

.bg-blue .s_title {
	color: #fff;
	font-size: 3.8rem;
	font-weight: bold;
	text-align: center;
	padding-bottom: 2rem;
}

.bg-blue .s_title>span {
	font-size: 2.8rem;
}

.box-1 {
	background-color: #fff;
	border-radius: 1rem;
	overflow: hidden;
	padding: 0 3rem;
}

.box-1>.title {
	font-size: 6rem;
	font-weight: bold;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	color: #009abd;
	background-color: #fffca5;
	padding: 1.3rem 0;
	margin: 0 -3rem 4rem;
}
.box-1>.title.fix {
	font-size: 5.5rem;
}

.box-1>.title [class*="icon"] {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin-right: 1.5rem;
}

.box-1>.title .icon-1 {
	width: 9.5rem;
}

.box-1>.title .icon-2 {
	width: 8.8rem;
}

.box-1>.title .icon-3 {
	width: 4.3rem;
}

.box-2 {
	background-color: #f4f4f4;
	border-radius: 1rem;
	overflow: hidden;
	padding: 0 3rem;
	margin-bottom: 3rem;
}

.box-2>.title {
	font-size: 3.2rem;
	font-weight: bold;
	text-align: center;
	color: #fff;
	background-color: #d80c18;
	padding: 1.3rem 0;
	margin: 0 -3rem 4rem;
}

.box-2>.title>span {
	font-size: 2.6rem;
	color: #d80c18;
	background-color: #fff;
	padding: 0 2.5rem 0.3rem;
	border-radius: 3rem;
	margin: 0 0 0.3rem 0.3rem;
}

.box-3 {
	border: solid 0.2rem #d80c18;
	border-radius: 1rem;
	padding: 3rem;
}

/* 通常時お申込み部分css */
.bnr {
	text-align: center;
	margin: 4rem 0 4rem;
	position: relative;
}

.bnr .txtPoints .txtBox:before,
.bnr .txtPoints .txtBox:after {
	content: '';
	position: absolute;
	top: 13.5rem;
	height: 2rem;
	width: 2rem;
	border: 2rem solid #FEFCA4;
	border-color: #FEFCA4 transparent transparent transparent;
	box-sizing: border-box;
}

.bnr.col2 .txtPoints .txtBox:before {
	left: 11rem;
}

.bnr.col2 .txtPoints .txtBox:after {
	right: 11rem;
}

.bnr.col1 .txtPoints .txtBox:before {
	left: calc(50% - 1rem);
}

.bnr.col1 .txtPoints .txtBox:after {
	content: none;
}

.bnr .txtPoints {
	position: absolute;
	left: 6rem;
	right: 6rem;
	top: 33.5rem;
	z-index: 99;
	color: #d80c18;
	text-align: center;
}

.bnr .txtPoints * {
	line-height: 1em;
}

.bnr .txtPoints .txtBox {
	position: relative;
}

.bnr .txtPoints .txtBox p {
	font-size: 10rem;
	font-family: 'Oswald', sans-serif;
	font-weight: 400;
}

.bnr .txtPoints span {
	font-size: 6.5rem;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	position: relative;
}

.bnr .txtPoints sup {
	font-size: 1.5rem;
	position: absolute;
	top: 0;
	right: 0;
}

@media only screen and (max-width: 760px) {
	.bnr .txtPoints {
		top: 31.7rem;
	}
}

@media only screen and (max-width: 375px) {
	.bnr .txtPoints {
		top: 33.5rem;
	}
}



.bnr.col2 .col1Btn,
.bnr.col1 .col2Btn,
.bnr.col1:not(.jcb) li:nth-child(2) {
	display: none !important;
}

.bnr.col2 .col1Btn,
.bnr.col1 .col2Btn,
.bnr.col1.jcb li:first-child {
	display: none !important;
}

.bnr:not(.row1, .row2)>img.row1,
.bnr:not(.row1, .row2)>img.row3 {
	display: none;
}

.bnr.row1>img:not(.row1) {
	display: none;
}

.bnr.row2>img:not(.row3) {
	display: none;
}


.bnr.row1 .txtBtm,
.bnr.row1 .txtBtm01,
.bnr.row1 .txtComment {
	display: none;
}


.bnr .btnBox {
	display: block;
	/*width: 26.5rem; height: 13.1rem;*/
	position: absolute;
	left: 6rem;
	right: 6rem;
	bottom: 20rem;
	z-index: 99;
}

.bnr.col2 .btnBox ul {
	display: flex;
	justify-content: space-between;
}

.bnr.col2 .btnBox li {
	flex-basis: calc((100% - 3rem)/2)
}

.bnr.col1 .btnBox {
	bottom: 22rem;
	padding: 0 6rem;
}

.bnr .btnBox li a:hover {
	opacity: 0.9;
}


/*
.bnr .btn-visa { left: 6rem; }
.bnr .btn-jcb { right: 6rem; }
.bnr .visa_btn { width: 100%; }
*/

.bnr_cap {
	margin: 0 0 4rem;
	padding: 2rem;
	border: 1px solid #ccc;
	font-size: 2.4rem;
}

.bnr_cap .btnRd {
	margin-top: 1rem;
}

.bnr_cap .btnRd a {
	display: block;
	border: 1px solid #d80c18;
	color: #d80c18;
	border-radius: 5px;
	line-height: 1em;
	padding: 1rem;
	font-size: 1.8rem;
	text-align: center;
	position: relative;
	transition: all .3s;
	-webkit-transition: all .3s;
}

.bnr_cap .btnRd a::after {
	content: '';
	width: 5px;
	height: 5px;
	border-bottom: 1px solid #d80c18;
	border-right: 1px solid #d80c18;
	position: absolute;
	right: 1.5rem;
	top: 40%;
	transform: rotate(45deg);
}

.bnr_cap .btnRd a:hover {
	background: #d80c18;
	color: #fff;
}

.bnr_cap .btnRd a:hover::after {
	border-color: #fff;
}


.btnBsc {
	/* margin-top: 1rem; */
	text-align: center;
}
.btnBsc a + a{
	margin-top: 3rem;
}
.btnBsc a {
    display: inline-block;
    width: min(75%, 470px);
	background: #f4f4f4;
	border: 1px solid #333;
	color: #333;
	border-radius: 5px;
	line-height: 1em;
	padding: 2rem;
	font-size: min(5vw,3.5rem);
	text-align: center;
	position: relative;
	transition: all .3s;
	-webkit-transition: all .3s;
	font-weight: 700;
}

.btnBsc a::after {
	content: '';
	width: 5px;
	height: 5px;
	border-bottom: 1px solid #333;
	border-right: 1px solid #333;
	position: absolute;
	right: 3rem;
	top: calc(50% - 3px);
	transform: rotate(-45deg);
}

.btnBsc.prev a::after {
	right: auto;
	left: 3rem;
	transform: rotate(135deg);
}

.btnBsc a:hover {
	background: #333;
	color: #fff;
}

.btnBsc.rd a {
	background: #fff;
	border: 1px solid #d80c18;
	color: #d80c18;
}

.btnBsc.rd a::after {
	border-bottom: 1px solid #d80c18;
	border-right: 1px solid #d80c18;
}

.btnBsc.rd a:hover {
	background: #d80c18;
	color: #fff;
}

.container.cp_box{
	padding-top: 3rem;
	margin-bottom: 15rem;
}
.cp_box p{
	line-height: 1.8em;
}
.rd{
	color: #d80c18;
}

.thanks .cp_box{ text-align: center;}
.cp_box .tit_bar{
	font-size: min(5vw,3.5rem);
	background: #009abd;
	color: #fff;
	line-height: 1em;
	text-align: center;
	padding: 0.5em;
	margin-bottom: 0.5em;
}
.cp_box .cap{
	font-size: min(5vw,2.4rem);
}
.cp_box form .cap{
	margin-top: 0.5em;
	text-align: center;
}
.cp_box .txt{
	font-size: min(5vw,2.8rem);
}
.cp_box .txt a{
	text-decoration: underline;
}
.cp_box .txtQ{
	font-size: min(5vw,3.5rem);
	font-weight: 700;
	text-align: center;
}
.cp_box select,
.cp_box input{
	display: block;
	width: 100%;
	border: 1px solid #ccc;
	color: #333;
	border-radius: 5px;
	line-height: 1em;
	padding: 2rem;
	font-size: min(5vw,2.8rem);
}
.cp_box .btn_box{
	display: flex;
	gap: 20px;
}
.cp_box .btn_box button{
	cursor: pointer;
}
.cp_box .btn_box input{
	padding: 0;
	border: none;
}


@media only screen and (max-width: 480px) {
	.btnBsc a {
		padding: 3rem;
	}
	.cp_box select{
		height: 50px;
		padding: 0 2rem;
	}

}

#pointup_cap {
	padding: 0 0 3rem;
	display: block;
}

#yutai .bg-gray {
	padding: 1.2rem 1.2rem 0 1.2rem;
	border-radius: 10px;
}

#yutai .bg-gray .txt01 {
	font-size: 2.5rem;
	font-weight: 700;
	line-height: 2em;
}

#yutai .bg-gray .txt02 {
	font-size: 2.1rem;
	line-height: 1.5em;
}

#yutai .bg-gray .txt03 {
	color: #d80c18;
	font-size: 4.5rem;
	font-weight: 700;
	line-height: 2em;
}

#yutai .bg-gray .txt03 em {
	font-size: 8rem;
	line-height: 1em;
	display: inline-block;
	padding: 0 0.5rem;
	font-family: 'Oswald', sans-serif;
	font-weight: 400;
}


/* ポイントアップキャンペーン時お申込み部分css */
/*.bnr{border: 0.5rem solid #009abd; border-radius: 1.5rem; max-width: 670px; margin: 4rem auto; overflow: hidden;}
.bnr-top{position: relative;margin-bottom: 2.5rem;}
.bnr-top .btn-visa, 
.bnr-top .btn-jcb{display: block; width: 26.5rem; height: 13.1rem; position: absolute; bottom: 17.7rem; z-index: 99;}
.bnr-top .btn-visa:hover, 
.bnr-top .btn-jcb:hover{opacity: 0.9;}
.bnr-top .btn-visa{left: 5.5rem;}
.bnr-top .btn-jcb{right: 5.5rem;}
.bnr-top .visa_btn{width: 100%;}
.bnr-bot .inner{padding: 5% 4% 2%;}
.bnr-bot .tit{font-size: 2.8rem; font-weight: bold; text-align: center; margin-bottom: 2rem;}
.bnr-bot .tit2{font-size: 3.2rem; font-weight: bold; text-align: center; color: #009abd;}
.bnr-frame{margin-bottom: 2rem; padding: 2rem 2rem 1.5rem; background: #e5f5f8; border-radius: 1rem;}
.bnr-list li{position: relative; padding: 1.5rem 0 1.5rem 4.7rem; border-bottom: 1px solid #c1ced1; font-size: 2.5rem;}
.bnr-list li span{font-size: 2.4rem; line-height: 1; font-weight: bold; width: 3.2rem; height: 3.2rem; background: #333; color: #fff; text-align: center; display: inline-block; padding-top: 0.25rem;}
.bnr-list li:last-of-type{border-bottom: none;}
.bnr-list li span.first{display: block; position: absolute; top: 1.9rem; left: 0;}
.bnr-cap span{font-size: 1.5rem; line-height: 1; font-weight: bold; width: 2.1rem; height: 2.1rem; background: #333; color: #fff; text-align: center; display: inline-block; padding-top: 0.2rem;}

.btn_top {position: relative;margin:4rem auto 0;max-width:750px;width:100%;}
.btn_top .btn-top-cont {padding: 0 5.33vw;}
.btn_top .btn-visa,
.btn_top .btn-jcb{display: block; width: 29rem; height: 13.1rem; position: absolute; bottom: 8.7rem; z-index: 99;border-radius: 4px;}
.btn_top .btn-visa:hover, 
.btn_top .btn-jcb:hover{opacity: 0.9;}
.btn_top .btn-visa{left: 3.5rem;}
.btn_top .btn-jcb{right: 3.5rem;}
.btn_top .visa_btn{width: 100%;}*/

.imgs-1 {
	display: flex;
	justify-content: center;
}

.imgs-1>img {
	width: 29.5rem;
	height: 19.6rem;
	border-radius: 10px;
}

.imgs-1>img:nth-child(2) {
	margin-left: 2.5rem
}

.bg-gray {
	background-color: #f4f4f4;
}

.ft {
	text-align: center;
	margin-top: 8rem;
}

.ft .container {
	position: relative;
}

.ft-title {
	font-size: 3.2rem;
	background-color: #ddd;
	font-weight: 500;
	padding: 1.5rem 0 1.3rem;
}

.ft-call {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 100%;
	height: 8.8rem;
	font-size: 5rem;
	font-weight: 500;
	border-radius: 0.5rem;
	border: 0.2rem solid #c7c7c7;
	padding-left: 8.8rem;
	margin-bottom: 1.5rem;
	overflow: hidden;
	position: relative;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

.ft-call:hover {
	opacity: 0.7;
}

.ft-call::before {
	content: "";
	display: block;
	width: 8.8rem;
	height: 100%;
	background-color: #333;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 9;
}

.ft-call.phone::after {
	content: "";
	display: block;
	width: 3.6rem;
	height: 4.7rem;
	background-image: url(../imgs/icon-phone.jpg);
	background-size: cover;
	position: absolute;
	left: 4.4rem;
	top: 50%;
	z-index: 9;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.ft-call>span {
	font-size: 2rem;
	margin-right: 2rem;
	font-weight: normal;
}

.ft-call.mobile::after {
	content: "";
	display: block;
	width: 2.8rem;
	height: 5.2rem;
	background-image: url(../imgs/icon-mobile.jpg);
	background-size: cover;
	position: absolute;
	left: 4.4rem;
	top: 50%;
	z-index: 9;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.ft-call>span {
	font-size: 2rem;
	margin-right: 2rem;
	font-weight: normal;
}

.ft-hr {
	height: 1px;
	background-color: #c7c7c7;
	margin: 3rem 0 2rem;
}

.ft-logo {
	display: block;
	margin: 7rem auto;
	width: 40rem;
	height: 10.6rem;
}

.ft-logo:hover {
	opacity: 0.7;
}

.ft-logo img {
	max-width: 40rem;
}

.ft-copyright {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	height: 7rem;
	width: 100%;
	font-size: 2rem;
	color: #fff;
	background-color: #d80c18;
}

.ft-btns {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	position: fixed;
	left: 0;
	bottom: 0;
	z-index: 999;
	height: 9rem;
	width: 100%;
	font-size: 2rem;
}

.ft-btns>a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 25%;
	color: #d80c18;
	background-color: #fff;
	border-right: 0.2rem solid #d4d4d4;
	position: relative;
}

.ft-btns>a .sm {
	font-size: 1rem;
}

.ft-btns>a img {
	height: 3.4rem;
}

.ft-btns>a:last-child {
	color: #fff;
	background-color: #d80c18;
	border-right: none;
}

.ft-btns>a:hover::after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 9;
	background-color: rgba(0, 0, 0, 0.1);
}

.ft-backtop {
	display: block;
	width: 8.8rem;
	height: 8.8rem;
	background-image: url(../imgs/btn-backtop.png);
	background-size: cover;
	position: fixed;
	right: 5.33vw;
	bottom: 10vw;
	z-index: 99;
	-webkit-transition: all 0.2s;
	transition: all 0.2s;
}

.ft-backtop:hover {
	opacity: 0.8;
}

.ft .bg-gray {
	padding: 8rem 0 6.5rem;
}

.cap_tit {
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	padding: 1rem;
	font-size: 2.5rem;
	text-align: left;
	margin-bottom: 2rem;
	font-weight: bold;
}

/* add 22.03.03 */
.bdBu {
	border: 4px solid #009BBD;
	box-sizing: border-box;
	border-radius: 12px;
	overflow: hidden;
}

.txtRd {
	color: #d80c18;
}

.bgLbu {
	background: #E5F5F9;
	border-radius: 10px;
	padding: 15px;
	margin: 0 2rem 2rem;
}

.bnr_cap.bd0 {
	border: none;
	padding-top: 0;
	padding-bottom: 0;
}

/*
.tokuten01,
.tokuten02{ margin: 8rem auto;}
*/
input.visa_btn {
	max-width: 100%;
}

input.visa_btn:hover {
	opacity: 0.8;
}

/* tokuten02 */
.tokuten02 .bdBu .bnr {
	margin:
		/*0*/
		0 0 3.5rem;
}

.tokuten02 .bnr .txtPoints .txtBox:before,
.tokuten02 .bnr .txtPoints .txtBox:after {
	top: 24.5rem;
}
.tokuten02 .bnr .text-bold .cap {
  line-height: 1.6em;
  text-align:left;
  padding:0 10rem;
}
.txtRd.sup,
.sup{
  font-size: medium;
  vertical-align: text-top;
}
.tokuten02 .bnr .btnBox {
	bottom: 16.5rem;
}

.tokuten02 .bnr.col1 .btnBox {
	bottom: 18.5rem;
}

.tokuten02 .bnr .txtPoints {
	top: 31rem;
}

.tokuten02 .bnr .txtPoints .txtBox {
	flex-direction: column;
	height: 22.7rem;
}

.tokuten02 .bnr .txtPoints .txtBox .txtTop p {
	font-size: 14rem;
	padding-right: 1rem;
}

.tokuten02 .bnr .txtPoints .txtBox .txtBtm {
	padding: 0 7.6rem 0 3.8rem;
}

.tokuten02 .bnr .txtPoints .txtBox .txtBtm p {
	font-size: 5rem;
}

.tokuten02 .bnr .txtPoints .txtBox .txtBtm01,
.tokuten02 .bnr .txtPoints .txtBox .txtComment {
	display: none;
}

.tokuten02 .bnr .num {
	display: inline-flex;
	color: #fff;
	background: #333;
	justify-content: center;
	align-items: center;
}

.tokuten02 .bnr .bgLbu li {
	position: relative;
	padding-left: 4rem;
	text-align: left;
	font-size: 2.5rem;
}

.tokuten02 .bnr .bgLbu li .num {
	font-size: 2rem;
	line-height: 1em;
	width: 3rem;
	height: 3rem;
}

.tokuten02 .bnr .bgLbu li>.num {
	position: absolute;
	top: 2rem;
	left: 0;
}

.tokuten02 .bnr .bgLbu li .txt .num {
	margin-right: 0.3rem;
	transform: translateY(-0.3rem);
}

.tokuten02 .bnr .bgLbu li {
	padding-top: 2rem;
}

.tokuten02 .bnr .bgLbu li:nth-of-type(n+2) {
	border-top: 1px solid #C1CDD0;
	margin-top: 2rem;
}

.tokuten02 .bnr .bnr_cap p {
	text-align: left;
}

.tokuten02 .bnr .bnr_cap p .num {
	font-size: 1.2rem;
	width: 2rem;
	height: 2rem;
	transform: translateY(-0.2rem)
}

.tokuten02 .bnr.row1 {}

.tokuten02 .bnr.row1 .txtPoints .txtBox:before,
.tokuten02 .bnr.row1 .txtPoints .txtBox:after {
	top: 100%;
}

#nonTxt .tokuten02 .bnr.row1 .txtPoints .txtBox:before,
#nonTxt .tokuten02 .bnr.row1 .txtPoints .txtBox:after {
	top: 108%;
}

#nonTxt .tokuten01 .bdBu {
	padding-bottom: 3rem;
}

#nonTxt .tokuten01 .bnr .txtPoints {
	top: 33rem;
}

#nonTxt .tokuten01 .bnr .btnBox {
	bottom: 20rem;
}


/*.tokuten02 .bnr.row1 .txtPoints {	top: 29rem;}*/
.tokuten02 .bnr.row1 .txtPoints .txtBox {
	height: 12.2rem;
}

#closed .tokuten02 .bnr.row1 .txtPoints .txtBox {
	height: 12rem;
}

.tokuten02 .bnr.row1 .txtPoints .txtBox .txtTop p {
	font-size: 10rem;
	padding-right: 7rem;
}

.tokuten02 .bnr.row1 .txtPoints {
	top: 32.1rem;
}

.tokuten02 .bnr .txtPoints .txtBox:before,
.tokuten02 .bnr .txtPoints .txtBox:after {
	top: 24.3rem;
}

#closed {}

#closed .tokuten02 .bnr .txtPoints {
	top: 35rem;
}

#closed .tokuten02 .bnr.row1 .txtPoints {
	top: 36.2rem;
}

/* tokuten03 */
.tokuten03 .bdBu .bnr {
	margin:
		/*0*/
		0 0 3.5rem;
}

.tokuten03 .bnr .txtPoints .txtBox:before,
.tokuten03 .bnr .txtPoints .txtBox:after {
	top: 24.3rem;
}

.tokuten03 .bnr .btnBox {
	bottom: 16.5rem;
}

.tokuten03 .bnr.col1 .btnBox {
	bottom: 18.5rem;
}

.tokuten03 .bnr .txtPoints {
	top: 31.5rem;
}

.tokuten03 .bnr .txtPoints .txtBox {
	flex-direction: column;
	height: 35.7rem;
}

.tokuten03 .bnr .txtPoints .txtBox .txtTop p {
	font-size: 14rem;
	padding-left: 2rem;
}

.tokuten03 .bnr .txtPoints .txtBox .txtBtm {
	padding: 1rem 7.6rem 0 3.8rem;
}

.tokuten03 .bnr .txtPoints .txtBox .txtBtm p {
	font-size: 5rem;
}

.tokuten03 .bnr .txtPoints .txtBox .txtBtm01 {
	padding: 0 7.6rem 0 19.8rem;
}

.tokuten03 .bnr .txtPoints .txtBox .txtBtm01 p {
	font-size: 5rem;
}

.tokuten03 .bnr .txtPoints .txtBox .txtComment {
	padding: 0 2.5rem;
}

.tokuten03 .bnr .txtPoints .txtBox .txtComment p {
	font-size: 2.2rem;
}

.tokuten03 .bnr .num {
	display: inline-flex;
	color: #fff;
	background: #333;
	justify-content: center;
	align-items: center;
}

.tokuten03 .bnr .bgLbu li {
	position: relative;
	padding-left: 4rem;
	text-align: left;
	font-size: 2.5rem;
}

.tokuten03 .bnr .bgLbu li .num {
	font-size: 2rem;
	line-height: 1em;
	width: 3rem;
	height: 3rem;
}

.tokuten03 .bnr .bgLbu li>.num {
	position: absolute;
	top: 2rem;
	left: 0;
}

.tokuten03 .bnr .bgLbu li .txt .num {
	margin-right: 0.3rem;
	transform: translateY(-0.3rem);
}

.tokuten03 .bnr .bgLbu li {
	padding-top: 2rem;
}

.tokuten03 .bnr .bgLbu li:nth-of-type(n+2) {
	border-top: 1px solid #C1CDD0;
	margin-top: 2rem;
}

.tokuten03 .bnr .bnr_cap p {
	text-align: left;
}

.tokuten03 .bnr .bnr_cap p .num {
	font-size: 1.2rem;
	width: 2rem;
	height: 2rem;
	transform: translateY(-0.2rem)
}

.tokuten03 .bnr.row1 {}

.tokuten03 .bnr.row1 .txtPoints .txtBox:before,
.tokuten03 .bnr.row1 .txtPoints .txtBox:after {
	top: 100%;
}

/*.tokuten03 .bnr.row1 .txtPoints {	top: 29rem;}*/
.tokuten03 .bnr.row1 .txtPoints .txtBox {
	height: 12.2rem;
}

#closed .tokuten03 .bnr.row1 .txtPoints .txtBox {
	height: 12rem;
}

.tokuten03 .bnr.row1 .txtPoints .txtBox .txtTop p {
	font-size: 10rem;
	padding-right: 7rem;
}

.tokuten03 .bnr.row1 .txtPoints {
	top: 32.1rem;
}

.tokuten03 .bnr .txtPoints .txtBox:before,
.tokuten03 .bnr .txtPoints .txtBox:after {
	top: 37.6rem;
}

#closed {}

#closed .tokuten03 .bnr .txtPoints {
	top: 34.8rem;
}

#closed .tokuten03 .bnr.row1 .txtPoints {
	top: 36.2rem;
}


.fukidashiWrap {
	position: relative;
}

.fukidashiWrap p {
	line-height: 1.3em;
}

.fukidashiWrap .fukidashi {
	position: absolute;
	max-width: 107px;
	width: 12rem;
	top: -6.5rem;
	left: 1rem;
}

.btnWrap .bnr {
	margin-bottom: 2rem;
}

.btnWrap .bnr .btnBox {
	bottom: 9rem;
}

.btnWrap .bnr.col1 .btnBox {
	bottom: 10rem;
}

#nonTxt .bnr .txtPoints .txtBox::before,
#nonTxt .bnr .txtPoints .txtBox::after {
	content: none !important;
}

/* #normal #nonTxt .tokuten01 .bnr .txtPoints {
	top: 32rem;
}

#during #nonTxt .tokuten02 .bnr.row1 .txtPoints {
	top: 35rem;
}

#closed #nonTxt .tokuten02 .bnr.row1 .txtPoints {
	top: 38.6rem;
} */

@media only screen and (min-width: 751px) {
	html {
		font-size: 0.625rem;
	}

	.container {
		padding: 0 4rem;
	}

	.ft-backtop {
		right: 4rem;
		bottom: 4rem;
	}

	@-moz-document url-prefix() {
		html {
			font-size: 10px;
		}

		/* #normal #nonTxt .tokuten01 .bnr .txtPoints {
			top: 33.4rem;
		}

		#during #nonTxt .tokuten02 .bnr.row1 .txtPoints {
			top: 36.1rem;
		}

		#closed #nonTxt .tokuten02 .bnr.row1 .txtPoints {
			top: 40.4rem;
		} */

		/*
		#normal .bnr .txtPoints { top: 40.2rem;}
		#normal .bnr .btnBox{ bottom: 23rem;}
		#normal .bnr.col1 .btnBox { bottom: 25rem;}
*/
	}

	/*	.tokuten02 .bnr.row1 .txtPoints { top: 32.1rem;}*/
}


@media only screen and (max-width: 480px) {
	.tokuten02 .bnr.row1 .txtPoints {
		/* top: 31.9rem; */
		top: 33.4rem;
	}

	/* #normal #nonTxt .tokuten01 .bnr .txtPoints {
		top: 36.4rem;
	}

	#during #nonTxt .tokuten02 .bnr.row1 .txtPoints {
		top: 35.6rem;
	}

	#closed #nonTxt .tokuten02 .bnr.row1 .txtPoints {
		top: 39.8rem;
	} */
}


.modaal-container {
	padding: 0;
	max-width: 670px;
}

.modaal-content-container {
	padding: 0;
	position: relative;
	background: white;
	text-align: center;
}

.modaal-content-container .inner {
	padding: min(5.5vw, 60px) min(4.5vw, 40px);
}

.modaal-content-container .inner .btnClose {
	position: absolute;
	bottom: calc(100% + 10px);
	right: 0;
	color: white;
	pointer-events: none;
	line-height: 1em;
	font-size: min(4vw, 20px);
	font-weight: bold;
}

.modaal-content-container .inner p {
	font-size: min(3.8vw, 26px);
	line-height: 1.8em;
	margin-bottom: min(4vw, 20px);
}

.modaal-content-container .inner p sup {
	font-size: 0.7em;
}

.modaal-content-container .inner p b {
	font-weight: bold;
}

.modaal-content-container .inner p em {
	font-size: 1.4em;
	font-weight: bold;
	color: #d80c18;
}

.modaal-content-container .inner p.txtRd {
	font-size: min(3.4vw, 24px);
	color: #d80c18;
	font-weight: bold;
}

.modaal-content-container .inner p a {
	color: #00baff;
	text-decoration: underline;
}

.modaal-content-container .btnRd a,
.modaal-content-container .btnRd p {
	display: block;
	line-height: 1em;
	padding: min(3.5vw, 20px);
	margin-top: 15px;
	font-size: min(3.5vw, 28px);
	font-weight: bold;
	border-radius: 12px;
}

.modaal-content-container .btnRd a:hover,
.modaal-content-container .btnRd p:hover,
.modaal-content-container .btnWh a:hover,
.modaal-content-container .btnWh a.modaal-close:hover,
.modaal-content-container .btnWh .visa_btn:hover {
	opacity: 0.8;
}

.modaal-content-container .btnRd a,
.modaal-content-container .btnRd p {
	position: relative;
	background: #d80c18;
	color: white;
}

.modaal-content-container .btnRd a::after,
.modaal-content-container .btnRd p::after {
	content: '';
	width: 4px;
	height: 4px;
	border: solid white;
	border-width: 1px 1px 0 0;
	position: absolute;
	right: 10px;
	top: calc(50% - 2px);
	transform: rotate(45deg);
}

.modaal-content-container .btnWh ul {
	display: flex;
	justify-content: space-between;
}

.modaal-content-container .btnWh ul li {
	flex-basis: calc((100% - 10px)/ 2);
}

/* .modaal-content-container .btnWh a,
.modaal-content-container .btnWh a.modaal-close,
.modaal-content-container .btnWh .visa_btn{ position: static; border: 2px solid #b4b4b4; padding: min(3.5vw, 20px); box-shadow: 0 5px 0 #E5E4E5; background: white; width: 100%; margin-top: 0; border-radius: 10px; font-size: 2.8rem; line-height: 1em; height: auto; color: #000;} */
.modaal-content-container .btnWh a.modaal-close {
	position: static;
	width: 100%;
	padding: 0;
	margin-top: 0;
}

.modaal-content-container .btnWh a.modaal-close::after,
.modaal-content-container .btnWh a.modaal-close::before {
	content: none;
}

/* Chrome, Safari, Edge, Opera 対応 */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox 対応 */
input[type=number] {
  -moz-appearance: textfield;
}
