/* CSS Document */
* {
	box-sizing: border-box;
}
h1.campaign{
	background: #f59d21;
	color: #fff;
	margin: 20px;
	padding: 20px;
	line-height: 1.3;
	font-weight: bold;
	text-align: center;
	font-size: 16px;
	position: relative;
	overflow:hidden;
}

h1.campaign:before{
	position: absolute;
	display:block;
	top: -20px;
	left: 5px;
	content:"";
	-moz-transform:rotate(45deg);
	-webkit-transform:rotate(45deg);
	-ms-transform:rotate(45deg);
	transform:rotate(45deg);
	width: 3px;
	height: 50px;
	background: #fff;
}
h1.campaign:after{
	position: absolute;
	display:block;
	bottom: -20px;
	right: 5px;
	content:"";
	-moz-transform:rotate(45deg);
	-webkit-transform:rotate(45deg);
	-ms-transform:rotate(45deg);
	transform:rotate(45deg);
	width: 3px;
	height: 50px;
	background: #fff;
}

h2 {
	font-weight: normal;
	font-size: 13px;
	line-height: 1.3;
	padding: 10px 20px;
	background:#f6efef;
	margin: 0 0 -10px 0;
}

h3 {
	font-weight: normal;
	margin: 22px 0 5px 0;
}

h4{
	margin: 15px 0;
}

.text-S{
	font-size: 13px;
}

em{
	font-style: normal;
	color:red;
}

.contentArea{
	padding: 20px;
}

.contentArea+.contentArea{
	padding-top: 0;
}
.contentArea.gray+.contentArea{
	padding-top: 20px;
}

.contentArea.gray{
	background:#eff2f6;
}

.contentArea.gray > h2{
	font-weight: bold;
	font-size: 16px;
	text-align: center;
	margin: 0 0 20px 0;
	padding: 0;
}

table{
	width: 100%;
}

table.noBorder td{
	width: 90%;
	padding: 0;
	padding-bottom: 5px;
}
table.noBorder th{
	white-space: nowrap;
	padding: 0 10px 5px 0;
	text-align: left;
}

table.noBorder tr:last-child th,
table.noBorder tr:last-child td{
	padding-bottom: 0;
}
button[type=button] {
	padding: 0;
}
input[type=text],select{
	width: 100%;
	font-size: 14px;
	box-sizing: border-box;
	padding: 12px;
	border: 1px solid #b0b0b0;
	-moz-border-radius: 2px;
	-webkit-border-radius: 2px;
	-ms-border-radius: 2px;
	border-radius: 2px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
button[type=button].text {
	border: none;
	background: none;
	text-decoration: underline;
	color: #585858;
	font-size: 14px;
}

:placeholder-shown {
		color: #c9c9c9; }
::-webkit-input-placeholder {
		color: #c9c9c9; }
:-moz-placeholder {
		color: #c9c9c9; opacity: 1; }
::-moz-placeholder {
		color: #c9c9c9; opacity: 1; }
:-ms-input-placeholder {
		color: #c9c9c9; }

.img-block img{
	width: 80%;
	height: auto;
	margin:0 auto;
	display:block;
}

.iframe-content {
	position: relative;
	width: 100%;
	padding: 56.25% 0 0 0;
}
.iframe-content iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

form > div.form{
	margin-top: 25px;
}
.form-item .form-column {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}
.form-item .form-column > * {
    -webkit-flex: 1 1 auto;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    display: block;
    margin: 0;
}
.form-item .form-column>*+* {
    margin-left: 10px;
}

.form .form-item .form-inline {
	width: 100%;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
}
.form .form-inline>* {
	flex: 1 1 auto;
}
.form .form-inline>span {
	flex: 1 0 auto;
}
.form .form-inline>*+*{
	margin-left: 10px;
}
.form .form-item .error {
	margin-bottom: 10px;
}
.form .form-item-submit, 
.form-conf .form-item-submit {
	margin: 20px -20px -20px;
	padding: 20px;
	background: #f9fafb;
}
.form-item + .form-item {
	margin-top: 22px;
}
.form-select {
	position: relative;
}
.form-select:after {
	content: "";
	position: absolute;
	right: 20px;
	top: -6px;
	bottom: 0;
	z-index: 1;
	display: block;
	margin: auto;
	pointer-events: none;
	width: 12px;
	height: 12px;
	border-bottom: 1px solid #666;
	border-right: 1px solid #666;
	transform: rotate(45deg);
}

.form-conf dt, 
.form-conf dd {
	line-height: 1.2;
}
.form-conf dt {
	font-size: 12px;
	margin-top: 10px;
	padding-bottom: 6px;
	color: #8c8c8c;
}
.form-conf dd {
	padding-bottom: 10px;
	font-size: 14px;
	border-bottom: 1px solid #e3e3e3;
	color: #585858;
}
.point {
	color: #33a863;
	font-size: 16px;
	font-weight: bold;
}
.bold {
	font-weight: bold !important;
}
.mt10 {
	margin-top: 10px !important;
}
.mt20 {
	margin-top: 20px;
}
.pd20 {		padding: 20px !important;				}
.pt20 {		padding-top: 20px !important;			}
.pb20 {		padding-bottom: 20px !important;		}
.pl20 {		padding-left: 20px !important;			}
.pr20 {		padding-right: 20px !important;			}
.center {
	text-align: center;
}
.error {
	color:red;
	font-weight: bold;
}
.bt {
	display: block;
	width: 80%;
	height: 45px;
	border: none;
	margin: 0 auto;
	color: #fff;
	font-size: 16px;
	text-align: center;
	background: #33a863;
	border-radius: 22.5px;
}
.bt > span {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}
a.link, 
button.link {
	width: 100%;
	min-height: 45px;
	padding: 5px 20px;
	border: 1px solid #b0b0b0;
	border-radius: 22.5px;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	background: transparent;
}
.link span {
	flex: 1 1 auto;
	text-align: center;
	margin-right: 5px;
}
.link:after {
	content: '';
	width: 10px;
	height: 10px;
	margin-top: -8px;
	border-left: 1px solid #666;
	border-bottom: 1px solid #666;
	transform: rotate(-45deg);
	flex: 0 0 10px;
}
.bt.sub {
	border: 1px solid #33a863;
	color: #33a863;
	background: #fff;
}
.bt:disabled {
	color: #fff;
	background: #bababa;
}
.w100 {
	width: 100%;
}
.w50 {
	width: 50%;
}
.w50c {
	width: 50%;
	margin-right: auto;
	margin-left: auto;
}
.rules {
	margin-top: 22px;
}
.rules li {
	margin-top: 20px;
}

input[type=checkbox] {
	display: none;
}
input[type=checkbox] + label {
	position: relative;
	display: inline-block;
	padding-left: 30px;
}
input[type=checkbox] + label:before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	width: 16px;
	height: 16px;
	border: #bdbebf solid 1px;
	border-radius: 2px;
}
input[type=checkbox] + label:after {
}

input[type="checkbox"]:checked + label:after {
	content: "";
	width: 10px;
	height: 5px;
	border-left: 2px solid #33a863;
	border-bottom: 2px solid #33a863;
	position: absolute;
	top: 3px;
	left: 3px;
	transform: rotate(-45deg);
}

#modalContent {
	display: none;
}

.modal-button-list li button {
	width: 100%;
	padding: 20px;
	border: none;
	background: #fff;
	font-size: 14px;
	line-height: 1.3;
	text-align: left;
}
.modal-button-list li + li button {
	border-top: 1px solid #ccc;
}

.qa dt, 
.qa dd {
	min-height: 20px;
	padding-left: 30px;
	position: relative;
	color: #33a863;
	font-weight: bold;
	line-height: 1.3;
}
.qa {
	margin: 20px 0;
}
.qa dd + dt {
	margin-top: 20px;
}
.qa dd {
	margin-top: 10px;
	color: #585858;
	font-weight: normal;
}
.qa dt:before, 
.qa dd:before {
	width: 20px;
	height: 20px;
	background: #33a863;
	color: #fff;
	position: absolute;
	top: 0;
	left: 0;
	line-height: 20px;
	font-weight: bold;
	text-align: center;
}
.qa dt:before {
	content: 'Q';
	background: #33a863;
	color: #fff;
}
.qa dd:before {
	content: 'A';
	background: #eff8f3;
	color: #33a863;
}

.qa ul {
	list-style-type: '・';
	padding-left:1em;
}

.qa li {
	list-style-type: '・';
}

.qa ol {
	list-style-type: decimal;
	padding-left:2em;
}

.qa ol li {
	list-style-type: decimal;
}

.qa-ui-icon{
	margin: 0 0.2em;
	height: 1.5em;
	vertical-align: bottom;
}

.qa-icon-menu{
	margin: 0 0.2em;
	width: 1.5em;
	vertical-align: bottom;
}

.lineup li {
	padding: 20px 0;
	text-align: center;
}
.lineup li + li {
	border-top: 1px solid #e3e3e3;
	
}
.lineup li .title {
	font-weight: bold;
}
.lineup li .text, 
.lineup li .present {
	margin-top: 10px;
}
.lineup li .present {
	color: #33a863;
	font-weight: bold;
}
.lineup li .image {
	width: 100%;
	margin: 20px auto 0;
}
.lineup li .image img {
	width: 100%;
	display: block;
}
.lineup li .fee {
	width: auto;
	margin-top: 20px;
	padding: 10px 30px;
	border-radius: 5px;
	display: inline-block;
	background: #33a863;
	font-weight: bold;
	color: #fff;
}

dl.list-text dt {
	font-weight: bold;
}
dl.list-text dd + dt, 
dl.list-text dd {
	margin-top: 10px;
}

ul.colum2{
	display: -webkit-flex;
	display: flex;
}
ul.colum2 li{
	text-align: center;
}
ul.colum2 li .image img {
	width: 100%;
}

.js-accordion:not(.open) .js-accordion-content {
	display: none;
}
.js-accordion.open .js-accordion-bt:after {
	margin-top: 4px;
	-moz-transform:rotate(45deg);
	-webkit-transform:rotate(45deg);
	-ms-transform:rotate(45deg);
	transform: rotate(135deg)
}