@charset "utf-8";
@import url(common.css);

/* ------------------------------------------------
  #main
------------------------------------------------ */

/* ----------------------------
  common
---------------------------- */

.lato {
	font-family: 'Lato', sans-serif;
}
sup {
	font-size: 50%;
}
.asterisk {
	font-size: 10px;
	font-weight: 200;
	text-align: right;
}
.asterisk + .asterisk {
	margin-top: .5em;
}


/*----- .blue_box -----*/

.blue_box {
	border: 2px solid #0047c0;
	border-radius: 20px;
	overflow: hidden;
	margin-top: 50px;
}
.blue_box h4 {
	font-size: 30px;
	font-weight: 400;
	color: #fff;
	background-color: #0047c0;
	line-height: 1;
	letter-spacing: 0.15em;
	padding: 25px 0;
}


#main {
	padding-top: 80px;
}
#main h3 {
	font-size: 36px;
	font-weight: 400;
	color: #0047c0;
	line-height: 1;
	letter-spacing: 0.1em;
}
#main .lead {
	font-size: 22px;
	font-weight: 300;
	text-align: center;
	letter-spacing: 0.1em;
	line-height: 2;
	margin: 35px 0 20px 0;
}
#main .lead.off80 {
	border-top: 4px solid rgba(0,71,192,.15);
	border-bottom: 4px solid rgba(0,71,192,.15);
	margin: 35px 0 0;
	padding: 28px 0;
}
#main .lead.off80 + .asterisk {
	margin-top: 10px;
}
#main ul.asterisk {
	text-align: left;
	margin-top: 18px;
}
#main ul.asterisk li {
	line-height: 2;
	letter-spacing: 0.1em;
}

/* ----------------------------
  .privilege
---------------------------- */

#main .privilege {
	margin-top: 40px;
}
#main .privilege .box1 {
	border: 13px solid #d9e4f6;
	border-radius: 20px;
	padding: 37px 48px 15px;
}
#main .privilege .box1 h4 {
	font-size: 30px;
	font-weight: 400;
	color: #ffff00;
	background-color: #0047c0;
	line-height: 1;
	letter-spacing: 0.15em;
	padding: 16px 0 14px;
	position: relative;
}
#main .privilege .box1 h4::before,
#main .privilege .box1 h4::after {
	content: '';
	margin-top: -30px;
	position: absolute;
	top: 50%;
}
#main .privilege .box1 h4::before {
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 0 30px 20px;
	border-color: transparent transparent transparent #ffffff;
	left: 0;
}
#main .privilege .box1 h4::after {
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 20px 30px 0;
	border-color: transparent #ffffff transparent transparent;
	right: 0;
}
#main .privilege .box1 > ol {
	width: 770px;
	margin-top: 40px;
}
#main .privilege .box1 > ol li {
	width: 33.3333%;
	height: 300px;
	box-sizing: border-box;
	float: left;
}
#main .privilege .box1 > ol li + li {
	border-left: 2px solid #eaf0fa;
}
#main .privilege .box1 > ol li > p {
	line-height: 1;
	letter-spacing: 0.15em;
}
#main .privilege .box1 > ol li .num {
	font-size: 18px;
	font-weight: 300;
	color: #0047c0;
	border: 3px solid #0047c0;
	border-radius: 24px;
	padding: 7px 13px 6px 17px;
	display: inline-block;
}
#main .privilege .box1 > ol li .num > span {
	vertical-align: middle;
}
#main .privilege .box1 > ol li .num > span.large {
	font-size: 30px;
	font-weight: bold;
	line-height: 1;
}
#main .privilege .box1 > ol li .note {
	font-size: 18px;
	font-weight: 300;
	line-height: 1.5;
	margin-top: 20px;
}
#main .privilege .box1 > ol li .red {
	font-size: 26px;
	font-weight: 300;
	letter-spacing: 0.05em;
	margin-top: 10px;
}
#main .privilege .box1 > ol li .red .small {
	font-size: 18px;
	line-height: 1;
}
#main .privilege .box1 > ol li .red.lato {
	font-size: 24px;
	font-weight: bold;
}
#main .privilege .box1 > ol li .red.lato .large {
	font-size: 32px;
	line-height: 1;
}
#main .privilege .box1 > ol li .img {
	margin-top: 15px;
}
#main .privilege .box1 .asterisk {
	letter-spacing: 0.1em;
	margin: 15px -30px 0;
}
#main .privilege .list {
	margin-top: 15px;
}
#main .privilege .list li {
	font-size: 10px;
	font-weight: 200;
	line-height: 2;
	text-align: left;
	letter-spacing: 0.1em;
}
#main .privilege .tri {
	font-size: 24px;
	font-weight: 400;
	background-color: #fff;
	line-height: 1;
	letter-spacing: 0.1em;
	padding: 0 20px;
	margin-top: 45px;
	display: inline-block;
	position: relative;
	bottom: -16px;
	z-index: 10;
}
#main .privilege .tri::before {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 110px 176px 0 176px;
	border-color: #ffe7ef transparent transparent transparent;
	margin-left: -176px;
	position: absolute;
	z-index: -1;
	top: -17px;
	left: 50%;
}
#main .privilege .tri .large {
	font-size: 30px;
	color: #e72240;
	line-height: 1;
	letter-spacing: 0.15em;
	margin-top: 13px;
	display: block;
}
#main .privilege .box2 {
	border: 2px solid #e5022b;
	border-radius: 20px;
	padding: 42px 50px 34px 60px;
}
#main .privilege .box2 > ul li {
	float: left;
	letter-spacing: -.4em;
}
#main .privilege .box2 > ul li + li {
	margin-left: 15px;
}
#main .privilege .box2 > ul li > p {
	font-size: 22px;
	letter-spacing: 0.15em;
	vertical-align: middle;
	display: inline-block;
}
#main .privilege .box2 > ul li > p.icon {
	color: #fff;
	font-weight: 400;
	background-color: #e5022b;
	border-radius: 40px;
	line-height: 1;
	padding: 29px 17px 30px 18px;
	margin-right: 10px;
}
#main .privilege .box2 > ul li > p.note {
	font-weight: 300;
	text-align: left;
	line-height: 1.5;
	letter-spacing: 0.1em;
}

/* ----------------------------
  .deals
---------------------------- */

#main .deals .column {
	background: rgb(244,239,188);
	background: -moz-linear-gradient(left, rgba(244,239,188,1) 0%, rgba(251,249,227,1) 50%, rgba(244,239,189,1) 100%);
	background: -webkit-linear-gradient(left, rgba(244,239,188,1) 0%,rgba(251,249,227,1) 50%,rgba(244,239,189,1) 100%);
	background: linear-gradient(to right, rgba(244,239,188,1) 0%,rgba(251,249,227,1) 50%,rgba(244,239,189,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f4efbc', endColorstr='#f4efbd',GradientType=1 );
	padding: 45px 83px 15px;
}
#main .deals .column .item {
	letter-spacing: -.4em;
}
#main .deals .column .item + .item {
	margin-top: 45px;
}
#main .deals .column .item .title {
	font-size: 22px;
	font-weight: 400;
	color: #0047c0;
	border-top: 2px solid #0047c0;
	border-bottom: 2px solid #0047c0;
	line-height: 1;
	letter-spacing: 0.1em;
	padding: 16px 0;
	position: relative;
}
#main .deals .column .item .title.bottom {
	border-top: none;
}
#main .deals .column .item .title > span {
	line-height: 1;
}
#main .deals .column .item .title > span.lato {
	font-weight: bold;
}
#main .deals .column .item .title > span.large {
	font-size: 40px;
	font-weight: bold;
	letter-spacing: 0.1em;
	margin-right: 3px;
}
#main .deals .column .item .title > span.banzai {
	line-height: 1;
	display: block;
	margin-bottom: 10px;
}
#main .deals .column .item .title > span.banzai::before,
#main .deals .column .item .title > span.banzai::after {
	content: '';
	height: 2px;
	width: 195px;
	background-color: #0047c0;
	margin-top: -1px;
	position: absolute;
	top: 30%;
}
#main .deals .column .item .title > span.banzai::before {
	left: 0;
}
#main .deals .column .item .title > span.banzai::after {
	right: 0;
}
#main .deals .column .item > div {
	letter-spacing: normal;
	vertical-align: middle;
	display: inline-block;
	margin-top: 30px;
}
#main .deals .column .item > div.txt {
	width: 330px;
	margin: 0 85px 0 65px;
}
#main .deals .column .item > div.txt > p {
	line-height: 1;
}
#main .deals .column .item > div.txt > p.off {
	font-size: 22px;
	font-weight: 200;
	letter-spacing: 0.1em;
}
#main .deals .column .item > div.txt > p.off .lato {
	font-size: 30px;
	font-weight: bold;
}
#main .deals .column .item > div.txt > p.off .large {
	font-size: 45px;
	line-height: 1;
}
#main .deals .column .item > div.txt > p.bg_red {
	font-size: 18px;
	font-weight: 300;
	color: #fff;
	background-color: #e5022b;
	border-radius: 19px;
	letter-spacing: 0.15em;
	line-height: 1;
	padding: 5px 0 7px;
	margin-top: 20px;
	position: relative;
}
#main .deals .column .item > div.txt > p.bg_red::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 8px 5px 0 5px;
	border-color: #e5022b transparent transparent transparent;
	margin-left: -5px;
	position: absolute;
	left: 50%;
	bottom: -7px;
}
#main .deals .column .item > div.txt > p.bg_red .lato {
	font-size: 28px;
	font-weight: bold;
	letter-spacing: 0.1em;
	margin: 0 3px;
}
#main .deals .column .item > div.txt > p.price {
	font-size: 30px;
	font-weight: 400;
	line-height: 1;
	letter-spacing: 0.05em;
	margin-top: 25px;
}
#main .deals .column .item > div.txt > p.price .lato {
	font-size: 82px;
	font-weight: 800;
	color: #e5022a;
	letter-spacing: 0.05em;
	margin-right: 3px;
}
#main .deals .column .item > div.txt > p.circle {
	margin-top: 15px;
	display: block;
}
#main .deals .column .item > div.txt > p.circle a {
	font-size: 26px;
	border-radius: 32px;
	padding: 15px 0 17px;
}
#main .deals .column .asterisk {
	/*margin: 25px -65px 0 0;*/
	text-align: left;
	margin: 30px -30px 20px;
}
#main .deals .column .asterisk li {
	line-height: 1.4;
	text-indent: -2em;
	padding-left: 2em;
}



/* ----------------------------
  .once
---------------------------- */

#main .once {
	letter-spacing: -.4em;
}
#main .once > div {
	width: 315px;
	letter-spacing: normal;
	margin-top: 38px;
	display: inline-block;
}
#main .once > div.left {
	margin-left: 75px;
}
#main .once > div.right {
	border-left: 2px solid #0047c0;
	padding-left: 50px;
	margin: 0 75px 0 50px;
}
#main .once > div > p {
	line-height: 1;
	text-align: left;
}
#main .once > div > p.note {
	font-size: 20px;
	font-weight: 200;
	letter-spacing: 0.15em;
}
#main .once > div > p.price {
	font-size: 26px;
	font-weight: 400;
	letter-spacing: 0.05em;
	margin-top: 5px;
}
#main .once > div > p.price .lato {
	font-size: 66px;
	font-weight: 800;
	margin-right: 3px;
}
#main .once > div > p.criterion {
	font-size: 16px;
	font-weight: 200;
	letter-spacing: 0.05em;
	margin-top: 8px;
}
#main .once > div > p.criterion .lato {
	font-size: 24px;
	font-weight: 500;
	margin-right: 3px;
}
#main .once > div > p.circle {
	text-align: center;
	margin-top: 15px;
	display: block;
}
#main .once > div > p.circle a {
	font-size: 22px;
	border-radius: 25px;
	padding: 10px 0 13px;
}
#main .once .asterisk {
	letter-spacing: 0.1em;
	margin: 17px 15px 15px 0;
}

/* ----------------------------
  .intro
---------------------------- */

#main .intro {
	border: 2px solid #d6dadb;
	text-align: left;
	margin-top: 50px;
}
#main .intro h5 {
	font-size: 24px;
	font-weight: 300;
	border-bottom: 2px solid #d6dadb;
	line-height: 1;
	text-align: center;
	letter-spacing: 0.15em;
	padding: 27px 0 28px;
}
#main .intro .box {
	padding: 40px 45px;
}
#main .intro .box + .box {
	border-top: 2px solid #d6dadb;
}
#main .intro .box > ul li > p {
	font-size: 16px;
	font-weight: 200;
	line-height: 1.8;
	letter-spacing: 0.1em;
}
#main .intro .box > ul li > p.title {
	font-weight: 300;
	color: #0047c0;
	line-height: 1;
	margin-top: 15px;
}
#main .intro .box > ul li > p.note {	
	margin-top: 5px;
}
#main .intro .box > ul li > p.asterisk {
	font-size: 10px;
	text-align: left;
	margin-top: 1em;
}
#main .intro .box > ul li > p.list {
	text-indent: -22px;
	margin-left: 22px;
	margin-top: 13px;
}
#main .intro .box > ul li > p.list > span {
	vertical-align: middle;
}
#main .intro .box > ul li > p.list > span.dot {
	width: 14px;
	height: 14px;
	background-color: #0047c0;
	border-radius: 7px;
	margin-right: 3px;
	display: inline-block;
}



#main .aside {
	margin-top: 50px;
}
#main .aside .note {
	font-size: 10px;
	font-weight: 300;
	text-align: left;
	border: 1px solid #000;
	padding: .5em 1em;
	margin-bottom: 10px;
}
#main .aside .asterisk {
	margin-bottom: 10px;
}
#main .aside .asterisk li {
	font-size: 10px;
	font-weight: 300;
	line-height: 1.2;
	text-align: left;
	letter-spacing: 0.1em;
	text-indent: -1em;
	padding-left: 1em;
}
#main .aside .asterisk li + li {
	margin-top: .4em;
}