@charset "shift_jis";

/* Main
----------------------------------------------------------- */
#main .inner-wrap{
	max-width:960px;
	margin:auto;
}

#main .bg-img {
	display: block;
	overflow: hidden;
	text-indent: 200%;
	white-space: nowrap;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: contain;
	height:0;
}

#main img{
	width:100%;
	height:auto;
}

#main button {
	display: block;
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	font-family : inherit;
}

#main .bold {
	font-weight:bold;
}

#main .small {
	font-size:0.8em;
}

#main .ib {
	display:inline-block;
}

#main .burasage, #main .burasage > span {
	display:block;
	overflow: hidden;
}
#main .burasage > span:first-child {
	float:left;
}

#main a.txt-link {
	color:#004ea9;
	text-decoration: underline;
}
body:not(.device-sp) #main a.txt-link:hover {
	text-decoration: none;
}

body:not(.device-sp) #main .op-hover {
	transition:opacity 0.3s;
}
body:not(.device-sp) #main .op-hover:hover {
	opacity:0.7;
}


/* MV
----------------------------------------------------------- */
#main .mv{
	background:url(../img/mv-img.jpg) no-repeat 50% 60%;
	background-size:cover;
}
.device-sp #main .mv{
	background-image:url(../img/mv-img-sp.jpg);
}

#main .mv .inner-wrap{
	text-align:center;
	padding-top:80px;
	height:400px;
	box-sizing: border-box;
}
.device-sp #main .mv .inner-wrap{
	height:66.666vw;
	padding-top:11%;
}

#main .mv .mv-lead{
	font-size:22px;
	line-height:1.4;
	font-weight:bold;
	color:#003063;
	margin-bottom:1em;
	margin-left:0.5em;
}
.device-sp #main .mv .mv-lead{
	font-size:4vw;
	margin-left:0;
}

#main .mv .mv-ttl{
	background-image:url(../img/mv-ttl.png);
	padding-top:15.625%;
}
.device-sp #main .mv .mv-ttl{
	background-image:url(../img/mv-ttl-sp.png);
	padding-top:19.2%;
}

#main .mv .ex-logo{
	width:200px;
	margin:30px auto 0;
}
.device-sp #main .mv .ex-logo{
	width:35%;
	margin-top:6%;
}



/* Points
----------------------------------------------------------- */
#main .points{
	background:url(../img/point-bg.png);
}

#main .points .points-ttl{
	position:relative;
	font-size:28px;
	line-height:1.4;
	font-weight:bold;
	text-align: center;
	color:#FFF;
	background-color:#e75512;
	padding:0.8em 0 0.7em 0;
	text-indent:-0.5em;
}
.device-sp #main .points .points-ttl{
	font-size:4.5vw;
}

#main .points .points-ttl::after{
	position: absolute;
	content:'';
	border: 25px solid transparent;
	border-top-color: #e75512;
	bottom:-48px;
	left:50%;
	margin-left:-25px;
}
.device-sp #main .points .points-ttl::after{
	bottom:-40px;
}

#main .points .inner-wrap{
	padding:50px 0;
}
.device-sp #main .points .inner-wrap{
	padding:7% 0;
}


/* point-sec
----------------------------------------------------------- */
#main .point-sec{
	background:#FFF;
	border:2px solid #bfbfbf;
	border-radius: 12px;
	box-sizing: border-box;
	overflow: hidden;
}
.device-sp #main .point-sec{
	border-width:2px 0;
	border-radius: 0;
}

#main .point-sec + .point-sec{
	margin-top:35px;
}
.device-sp #main .point-sec + .point-sec{
	margin-top:4%;
}

/* point-sec toggle-btn
----------------------------------------------------------- */
#main .point-sec .toggle-btn{
	width:100%;
	background:#FFF;
	text-align: left;
}

#main .point-sec .toggle-btn .btn-inner{
	display:block;
	position: relative;
	padding:24px 90px 24px 140px;
}
.device-sp #main .point-sec .toggle-btn .btn-inner{
	padding:4% 11% 4% 13.5%;
}

#main .point-sec .toggle-btn .btn-inner::after{
	position:absolute;
	content:'';
	top:0;
	right:0;
	bottom:0;
	width:90px;
	background:url(../img/point-ico-toggle.png) no-repeat 50% 50% #d1f0ff;
	background-size:30px auto;
}
#main .point-sec .toggle-btn.open .btn-inner::after{
	transform: scaleY(-1);
}
.device-sp #main .point-sec .toggle-btn .btn-inner::after{
	width:11%;
	background-size:50% auto;
}

#main .point-sec .toggle-btn .icon{
	position:absolute;
	width:90px;
	display:block;
	margin-left:25px;
	margin-top:-22px;
}
.device-sp #main .point-sec .toggle-btn .icon{
	width:12%;
	margin-left:1%;
	margin-top:-2%;
}

#main .point-sec .toggle-btn .txt{
	display:inline-block;
	white-space: nowrap;
	font-size:36px;
	line-height:1.2;
	font-weight:bold;
	color:#1f4c8c;
	background: linear-gradient(transparent 60%, #ffefbf 60%);
	padding:0 0.1em;
}
.device-sp #main .point-sec .toggle-btn .txt{
	font-size:4.8vw;
	letter-spacing: -0.01em;
}


/* point-sec .toggle-wrap
----------------------------------------------------------- */
#main .toggle-wrap{
	overflow: hidden;
	display:none;
}

#main .toggle-wrap::before, #main .toggle-wrap::after{
	content:'';
	display: block;
	height:0;
	padding-top:50px;
}
.device-sp #main .toggle-wrap::before, #main .toggle-wrap::after{
	padding-top:7%;
}

#main .toggle-wrap::before{
	border-top:1px solid #bfbfbf;
}


/* point-sec sub-sec
----------------------------------------------------------- */
#main .point-sec .sub-sec{
	margin:0 30px 0 25px;
	padding-left:120px;
	background:no-repeat 0 0;
	background-size:90px auto;
}
.device-sp #main .point-sec .sub-sec{
	margin:0 3% 0 2%;
	padding-left:15%;
	background:no-repeat 0 0;
	background-size:13% auto;
}

#main .point-sec .sub-sec + .sub-sec{
	margin-top:50px;
}
.device-sp #main .point-sec .sub-sec + .sub-sec{
	margin-top:7%;
}

#main .point-sec .sub-sec .sec-ttl-lv1{
	font-size:32px;
	font-weight:bold;
	line-height: 1.4;
	color:#ff6a00;
	margin-bottom:0.3em;
}
.device-sp #main .point-sec .sub-sec .sec-ttl-lv1{
	font-size:20px;
}

#main .point-sec .sub-sec .sec-ttl-lv2{
	font-size:18px;
	font-weight:normal;
	line-height: 1.4;
	background-color:#eee;
	padding:0.5em;
	margin:1.5em 0 0.8em;
}
.device-sp #main .point-sec .sub-sec .sec-ttl-lv2{
	font-size:15px;
}

#main .point-sec .sub-sec .sec-txt{
	font-size:16px;
	line-height:1.8;
	margin-bottom:0.5em;
}
.device-sp #main .point-sec .sub-sec .sec-txt{
	font-size:14px;
}

#main .point-sec .sub-sec .sec-txt + .sec-caption{
	margin-top:1em;
}

#main .point-sec .sub-sec .sec-caption{
	font-size:13px;
	line-height:1.5;
}
#main .point-sec .sub-sec .sec-caption li{
	margin-top:0.3em;
}
.device-sp #main .point-sec .sub-sec .sec-caption{
	font-size:10px;
}

/* #point-01
----------------------------------------------------------- */
#point-01 .sec-03 .inner-column{
	position:relative;
	padding-right:300px;
	min-height:350px;
}
.device-sp #point-01 .sec-03 .inner-column{
	padding-right:0;
	min-height:0;
}

#point-01 .sec-03 .inner-column .sec-img{
	position:absolute;
	top:0;
	right:0;
	width:250px;
}
.device-sp #point-01 .sec-03 .inner-column .sec-img{
	position:static;
	width:50%;
	margin:3% auto;
}

#point-01 .sec-03 .inner-column .sec-caption{
	margin-left:1.2em;
}

#point-01 .sec-05 .cancel-price{
	display:table;
	width:100%;
	margin:1em 0 0.5em 0;
}

#point-01 .sec-05 .cancel-price dt{
	display:table-cell;
	vertical-align: middle;
	font-size:18px;
	font-weight:bold;
	line-height:1.4;
	border-right:2px solid #FFF;
	background:#eee;
	text-align:center;
	width:250px;
	padding:0.6em 0 0.5em;
}
.device-sp #point-01 .sec-05 .cancel-price dt{
	font-size:11px;
	width:10em;
	white-space: nowrap;
}

#point-01 .sec-05 .cancel-price dd{
	display:table-cell;
	vertical-align: middle;
	font-size:16px;
	line-height:1.4;
	background:#f6f6f6;
	text-align:left;
	padding:0.7em 1em 0.6em;
}
.device-sp #point-01 .sec-05 .cancel-price dd{
	font-size:11px;
	padding:0.7em 0.5em 0.6em 1em;
}

#point-01 .sec-05 .cancel-price.ex{
	margin-top:2em;
}
#point-01 .sec-05 .cancel-price.ex dt{
	color:#1f4c8c;
	background-color:#d1f0ff;
}
#point-01 .sec-05 .cancel-price.ex dd{
	color:#ff6a00;
	background-color:#fff7df;
	font-size:22px;
	padding-top:0.3em;
	padding-bottom:0.2em;
}
.device-sp #point-01 .sec-05 .cancel-price.ex dd{
	font-size:14px;
}


/* #point-02
----------------------------------------------------------- */
#point-02 .inner-column{
	margin:30px 0 0 -120px;
}
.device-sp #point-02 .inner-column{
	margin:6% 0 0 0;
}

#point-02 .inner-column .sec-caption{
	margin-top:1em;
}


/* #point-04
----------------------------------------------------------- */
.device-sp #point-04 .inner-column{
	margin-left:-17%;
}

.device-sp #point-04 .table-wrap{
	overflow-x: auto;
}

#point-04 .price-table{
	width:100%;
	font-size:16px;
	line-height:1.4;
	border-collapse:collapse;
	border:2px solid #c9c9c9;
}
.device-sp #point-04 .price-table{
	font-size:10px;
	font-size:2.5vw;
	border-width: 1px;
}

#point-04 .price-table th,
#point-04 .price-table td{
	vertical-align: middle;
	padding:0.5em 0.5em 0.4em 0.5em;
	border:1px solid #c9c9c9;
}
.device-sp #point-04 .price-table th,
.device-sp #point-04 .price-table td{
	padding:0.5em 0.2em 0.4em 0.2em;
	letter-spacing: -0.05em;
}

#point-04 .price-table thead th{
	text-align:center;
	background:#eee;
	white-space: nowrap;
}

#point-04 .price-table tbody th{
	background:#f6f6f6;
	white-space: nowrap;
}

.device-sp #point-04 .price-table tbody th{
	white-space:normal;
	max-width:7em;
	min-width: 5em;
}

#point-04 .price-table td{
	text-align:right;
	line-height:1.2;
	white-space: nowrap;
}

#point-04 .price-table td.none{
	color:#999;
}

#point-04 .price-table td .small{
	color:#ff6a00;
}

#point-04 .price-table tr.ex th{
	background-color:#d1f0ff;
	font-weight:bold;
}

#point-04 .price-table tbody th a.txt-link{
	display: inline-block;
	font-weight:normal;
	padding-left:1em;
	font-size:0.8em;
	background:url(/common/img/pdf.png) no-repeat 0 0.25em;
	background-size:0.8em auto;
}

#point-04 .price-table tr.ex td{
	background-color:#fff7df;
}

#point-04 .table-wrap + .sec-caption{
	margin-top:1em;
}


/* Banner
----------------------------------------------------------- */
#main .top-ban{
	margin:50px auto;
}
.device-sp #main .top-ban{
	margin:10% 4%;
}

#main .top-ban .corp-ban{
	display:block;
	width:920px;
	margin:auto;
	padding:25px 0 25px 150px;
	box-sizing: border-box;
	border:4px solid #003064;
	background:url(../img/ban-corp-img.png) no-repeat #FFF;
	background-size:90px auto;
	background-position: 35px 50%;
}
.device-sp #main .top-ban .corp-ban{
	width:auto;
	padding:5.5% 4% 5%;
	background-size:13% auto;
	background-position: 4.5% 5.3vw;
}

#main .top-ban .corp-ban .ban-txt{
	display:block;
	font-size:28px;
	line-height:1.4;
	color:#003064;
}
.device-sp #main .top-ban .corp-ban .ban-txt{
	font-size:5vw;
	margin-left:16.5%;
	letter-spacing: -0.01em;
}

#main .top-ban .corp-ban .ban-txt em{
	display:inline-block;
	background: linear-gradient(transparent 60%, #ffefbf 60%);
	padding-left:0.1em;
	margin-right:-0.5em;
	font-weight:bold;
	white-space: nowrap;
}

#main .top-ban .corp-ban .ban-btn{
	display:block;
	font-size:20px;
	line-height:1.4;
	font-weight:bold;
	width:400px;
	margin:1em auto 0 6em;
	color:#FFF;
	background:url(../img/ico-arrow-next.png) no-repeat #003064;
	background-size:0.5em auto;
	background-position: calc(100% - 1em) 50%;
	padding:0.6em;
	text-align:center;
	border-radius: 3em;
}
.device-sp #main .top-ban .corp-ban .ban-btn{
	width:auto;
	margin:1em 0.5em 0;
	font-size:4.6vw;
}