@charset "utf-8";

body#cpPage {
	font-family: 'Noto Sans JP', sans-serif ,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", Verdana;
	font-size: 16px;
	line-height: 1.5;
	text-align: center;
	color: #000;
	min-width: 320px;
}
a {
	color: #000;
	outline: none;
	text-decoration: none;
	transition: .1s;
}
input[type=radio], input[type=checkbox] {
	margin:0 5px 0 0;
	width: auto;
}
label {
	line-height: 1.8;
}
label:hover {
	background: #f1f1f1;
}
small {
	font-size: 80%;
}
.container {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto;
}
article > section {
	padding: 60px 0;
}
a.blank::after {
	content: "";
	display: inline-block;
	background: url("../img/ico_blank.png") center center no-repeat;
	background-size: contain;
	width: 11px;
	height: 10px;
	margin-left: 10px;
}
.fo-futura {
	font-family: futura-pt, sans-serif!important;
	font-weight: 500;
	font-style: normal;
	line-height: .8;
}
.fo-corp {
	font-family: corporate-logo-ver2, sans-serif;
	font-weight: 700;
	font-style: normal;
}
.clr-white {
	color: #fff!important;
}
.bg-pink {
	background: url("../img/bg_pink.jpg") top center no-repeat;
	background-size: cover;
}
.bg-blue {
	background: url("../img/bg_blue.jpg") top center no-repeat;
	background-size: cover;
}
.bg-green {
	background: url("../img/bg_green.jpg") top center no-repeat;
	background-size: cover;
}
.bg-red {
	background: url("../img/bg_red.jpg") top center no-repeat;
	background-size: cover;
}
.bg-yellow {
	background: url("../img/bg_yellow.jpg") top center no-repeat;
	background-size: cover;
}
.clr-white {
	color: #fff!important;
}
.bg01 {
	background: #f1f1f1;
}

/*header----------------------------*/
#header {
	background: #000;
	padding: 10px 15px
}
img[src*="/logo.png"] {
	max-height: 35px;
}
.mainVis {
	background: url("../img/main_end.jpg") center center no-repeat;
	background-size: cover;
	height: 722px;
}
.mainBtm {
	background: #000;
	padding: 12px 15px;
	color: #fff;
	font-size: 28px;
	font-weight: 600;
	line-height: 1.1;
}
.ttlBox {
	margin-bottom: 35px;
}
.ttlBox img {
	max-height: 97px;
}
#how {
	padding: 20px 0 100px;
}
#how .ttlBox {
	max-width: 860px;
	margin: 0 auto 35px;
	background: url("../img/ttl_img_left.png") left top no-repeat,url("../img/ttl_img_right.png") right 5% top no-repeat;
	padding-top: 50px;
}
#how .ttlBox + .txt {
	color: #fff;
	font-size: 25px;
	font-weight: 800;
	margin-bottom: 35px;
}
.stepWrap dl {
	width: 22%;
	font-size: 24px;
	font-weight: 800;
	background: #fff;
	border: 8px solid #000;
	line-height: 1.2;
	position: relative;
}
.stepWrap dl:not(:first-of-type)::before {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: -40px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 15px 0 15px 25px;
	border-color: transparent transparent transparent #000000;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}
.stepWrap dt {
	color: #fff;
	font-size: 21px;
	background: #2c68f6;
	padding: 5px;
	letter-spacing: .05em;
	text-indent: .05em;
}
.stepWrap dd {
	padding: 12px 5px;
}
.presentWrap {
	margin-top: 110px;
	background: #fff;
	border: 8px solid #000;
	position: relative;
	z-index: 1;
	padding: 30px 5%;
}
.presentWrap::before {
	content: "";
	display: block;
	width: 100%;
	position: absolute;
	left: 0;
	right: 0;
	top: -73px;
	background: url("../img/present_ttl_bg.png") top center no-repeat;
	background-size: contain;
	height: 65px;
	z-index: -1;
}
.presentWrap h3 {
	position: absolute;
	left: 0;
	right: 0;
	top: -45px;
	z-index: 5;
}
.presentWrap h3 img {
	max-height: 76px;
}
img[src*="logo_brubo"] {
	max-height: 56px;
}
.presentWrap dl {
	text-align: left;
	width: 50%;
}
.presentWrap dt {
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: 3px solid #000;
}
.presentWrap h4 {
	font-family: 'Noto Sans JP', sans-serif ,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", Verdana!important;
	font-size: 37px;
	font-weight: 800;
	letter-spacing: -.05em;
}
.presentImg {
	width: 42%;
	position: relative;
}
.presentImg small {
	display: block;
	text-align: left;
	padding-top: 10px;
}
.capa {
	width: 58%;
	position: absolute;
	right: -10%;
	bottom: -120px;
	z-index: 10;
}
.capa img {
	max-height: 170px;
}
.channelWrap {
	margin-bottom: 20px;
}
.channelWrap figure {
	width: 50%;
}
.channelWrap .box {
	text-align: left;
	width: 48%;
}
.channelWrap h3 img {
	max-height: 124px;
}
.channelWrap .txt {
	font-size: 20px;
	font-weight: 700;
	color: #fff;
	margin-top: 10px;
}
.channelBnr .bnr {
	margin-top: -100px;
	position: relative;
	z-index: 1;
}
.infoTxt {
	font-size: 36px;
	font-weight: 800;
	line-height: 1.2;
}
.infoArea {
	position: relative;
}
.infoWrap {
	border: 8px solid #000;
	background: #fff;
	position: relative;
	width: 32%;
	margin-top: 80px;
	padding: 50px 0 20px;
}
.infoWrap._01 {
	width: 100%;
	padding-top: 20px;
}
.infoTtl {
	position: absolute;
	left: 0;
	right: 0;
	top: -65px;
	background: url("../img/info_ttl_bg.png") top center no-repeat;
	padding-top: 25px;
	z-index: 5;
}
.infoTtl img {
	max-height: 62px;
}
.info01Box {
	width: 33%;
	padding: 10px;
}
.info01Box:not(:first-of-type) {
	border-left: 3px dotted #808080;
}
.sclIcon img {
	max-height: 90px;
}
.btn00 {
	margin-top: 20px;
}
.btn00 a {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #fff;
	border: 1px solid #000;
	border-radius: 30px;
	padding: 8px;
}
.infoWrap .btn00 a {
	font-size: 25px;
	font-weight: 600;
	max-width: 200px;
	margin: 0 auto;
}
.infoWrap h5 {
	position: absolute;
	left: 0;
	right: 0;
	top: -70px;
	margin: 0 auto;
	z-index: 5;
}
.infoWrap h5 img {
	max-height: 110px;
}
.infoImg {
	position: absolute;
	right: 0;
	bottom: 87%;
	bottom: calc(100% - 80px);
	width: 22%;
}
.questionBg {
	background: url("../img/question_bg_top.png") top center no-repeat,url("../img/question_bg_btm.png") bottom center no-repeat;
	padding-top: 50px;
}
.questionWrap {
	border: 8px solid #000;
	background: #fff000;
	position: relative;
	padding: 80px 3% 30px;
	margin-top: 60px;
}
.questionWrap h3 {
	position: absolute;
	left: 0;
	right: 0;
	top: -50px;
	z-index: 5;
}
.questionWrap h3 img {
	max-height: 113px;
}
.questionTxt {
	text-align: right;
	font-size: 30px;
	font-weight: 800;
	margin-bottom: 35px;
	padding-right: 30%;
}
.questionTxt > p {
	display: inline-block;
	text-align: left;
}
.questionTxt small {
	font-weight: 700;
	font-size: 60%;
	display: block;
}
.ansWrap {
	position: relative;
}
.ansBox {
	width: 23%;
	background: #fff;
	border: 5px solid #39b44a;
	padding: 30px 20px 20px;
}
.ansImg {
	position: absolute;
	right: 0;
	bottom: 100%;
	width: 28%;
}
.ansBox .btn00 a {
	border: none;
	color: #fff;
	background: #39b44a;
}
.num {
	font-size: 28px;
	width: 36px;
	height: 36px;
	line-height: 36px;
	background: #39b44a;
	margin: 0 auto 40px;
	color: #fff;
}
.ansBox h4 {
	font-size: 18px;
	color: #231815;
	margin-bottom: 10px;
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif ,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", Verdana !important;
}
.ansBox._02 {border-color: #ec1c24}
.ansBox._02 .num,
.ansBox._02 .btn00 a {background: #ec1c24}
.ansBox._03 {border-color: #29aae1}
.ansBox._03 .num,
.ansBox._03 .btn00 a {background: #29aae1}
.ansBox._04 {border-color: #0071bb}
.ansBox._04 .num,
.ansBox._04 .btn00 a {background: #0071bb}
.ansBox .btn00 a:hover {
	background: #000;
}
#hall {
	padding: 0;
}
.hallArea {
	padding: 80px 0;
}
.hallTopTxt {
	font-size: 27px;
	font-weight: 800;
	padding: 0 19%;
}
.hallWrap {
	border: 8px solid #000;
	background: #fff;
	padding: 60px 3% 40px;
	position: relative;
	margin-top: 100px;
}
.hallTtl {
	position: absolute;
	left: 0;
	right: 0;
	top: -65px;
	z-index: 5;
}
.hallTtl img {
	max-height: 118px;
}
.hallImg {
	width: 47%;
}
.hallCont {
	text-align: left;
	width: 50%;
}
.hallCont h4 {
	font-family: 'Noto Sans JP', sans-serif ,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", Verdana!important;
	font-size: 38px;
	font-weight: 800;
	margin-bottom: 20px;
}
.hallCont dt,.hallCont dd {
	border-bottom: 1px solid #000;
	padding: 8px 10px;
	font-weight: 600;
	font-size: 110%;
}
.hallCont dt {
	width: 23%;
	background: #000;
	color: #fff;
	border-color: #fff;
}
.hallCont dd {
	width: 77%;
}
.hallCont dt:last-of-type,.hallCont dd:last-of-type {
	border-bottom: none;
}
.hallCont .btn00 {
	margin-top: 5px;
	max-width: 200px;
}
.hallCont .btn00 a {
	padding: 5px 5px 7px;;
	line-height: 1;
}
.rate {
	margin-top: 15px;
}
.rate dt {
	font-size: 24px;
	font-weight: 600;
	padding-right: 5px;
}
.rate img {
	max-height: 65px;
	margin-left: 5px;
}
.rate dt:not(:first-of-type) {
	margin-left: 15px;
}
.person {
	position: absolute;
	bottom: 100%;
	bottom: calc(100% + 8px);
}
.person._01 {
	width: 19.6%;
	left: 0;
}
.person._02 {
	width: 22%;
	right: 5%;
}
.person._03 {
	width: 22%;
	left: 2%;
}
.fBnr {
	background: #fff;
	padding: 50px 0;
}
.fBnr li {
	width: 49%;
}
.fLogo {
	padding: 15px;
	background: #000;
}
.fLogo img {
	max-height: 40px;
}
.copyRights {
	background: #fff;
	padding: 5px;
}
.fix {
	position: fixed;
	right: 0;
	top: 10%;
	z-index: 999;
}

/*incorrect------------------------------------------*/
.subPage {
	padding: 0 0 30px;
}
.subBg {
	background: url(../img/cp_bg_top.png) top center no-repeat,url(../img/cp_bg_btm.png) bottom center no-repeat;
	padding: 50px 0;
}
.cpTtl {
	margin-bottom: 60px;
}
.ansDetail {
	background: #fff;
	padding: 60px 5%;
	border: 8px solid #000;
}
.ansDetail h2 {
	font-size: 24px;
	font-weight: 800;
	margin-bottom: 35px;
}
.ansDetail h2 span {
	display: inline-block;
	position: relative;
	padding: 0 40px;
}
.ansDetail h2 span::after,
.ansDetail h2 span::before {
	content: "";
	display: block;
	background: url("../img/ttl_slash.png") left bottom no-repeat;
	background-size: contain;
	width: 19px;
	height: 30px;
	position: absolute;
	left: 0;
	bottom: 0;
}
.ansDetail h2 span::after {
	left: inherit;
	right: 0;
  -webkit-transform: scale(-1, 1);
	-ms-transform: scale(-1, 1);
	transform: scale(-1, 1);
}
.ansDetImg {
	margin-bottom: 40px;
}
.ansDetImg + p {
	font-size: 30px;
	font-weight: 800;
	margin-bottom: 40px;
}
.ansDetImg + p span {
	font-size: 24px;
	display: block;
	line-height: 1.5;
}
.nextTxt {
	background: url("../img/arrow.png") bottom center no-repeat;
	background-size: auto 12px;
	padding-bottom: 35px;
	font-weight: 800;
}
.hintWrap {
	border: 5px solid #000;
	padding: 40px 5% 30px;
	max-width: 800px;
	margin: 0 auto;
	position: relative;
}
.hintWrap .person {
	bottom: 100%;
	right: 0;
	z-index: 5;
	width: 22%;
}
.hintWrap figure {
	width: 49%;
}
.hintWrap h3 {
	font-size: 18px;
	text-align: left;
	width: 48%;
}
.hintWrap h3 .txt {
	display: block;
	padding-top: 10px;
	line-height: 1.2;
	font-size: 36px;
	font-weight: 800;
}
.hintIco img {
	max-height: 92px;
}
.btn1 {
	margin-top: 50px;
}
.btn1 a {
	display: inline-block;
	color: #fff;
	font-size: 18px;
	background: #ec1c24;
	padding: 20px 20px 20px 35px;
	border-radius: 33px;
	min-width: 300px;
}
.btn1 a:hover {
	background: #333;
	color: #fff000!important;
}
.btn1 a::after,.btn-back a::before {
	content: "";
	display: inline-block;
	background: url("../img/btn_arrow.png") center center no-repeat;
	background-size: contain;
	width: 7.5px;
	height: 14px;
	margin-left: 20px;
}
.btn-back a {
	background: #666;
	padding: 20px 35px 20px 20px; 
}
.btn-back a::after {display: none;}
.btn-back a::before {
	margin: 0 20px 0 0;
  -webkit-transform: scale(-1, 1);
	-ms-transform: scale(-1, 1);
	transform: scale(-1, 1);
}
.ansDetail .btn-back a {
	background-color: #ec1c24;
}
/*correct----------------------------------*/
#correct .hintWrap .person {
	left: -5%;
	right: inherit;
	width: 30%;
}
#correct .nextTxt {
	font-size: 36px;
	margin-top: 30px;
}
.product02 {
	background: #fff;
	position: relative;
	padding-bottom: 30px;
	border-top: 30px solid transparent;
}
.product02::after {
	content: "";
	display: block;
	position: absolute;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 24px 25px 0 25px;
	border-color: #ffffff transparent transparent transparent;
	bottom: -23px;
	left: 0;
	right: 0;
	margin: 0 auto;
	z-index: 10;
}
.product02 figure {
	margin-top: -75px;
	margin-bottom: 15px;
}
.productName b {
	display: block;
	font-size: 37px;
	font-weight: 800;
	line-height: 1;
	margin-left: 15px;
}
.ouboTxt {
	font-size: 26px;
	font-weight: 800;
	color: #fff;
	margin-bottom: 50px;
}
#outline .container {
	max-width: 840px;
}
.outLine {
	background: #fff;
	padding: 50px 5% 35px;
	margin-bottom: 50px;
}
.outLine dt {
	color: #fff;
	background: #000;
	font-size: 18px;
	width: 15%;
	padding: 15px 10px;
	margin-bottom: 12px;
}
.outLine dd {
	width: 85%;
	text-align: left;
	padding-left: 5%;
	margin-bottom: 12px;
	display: flex;
	align-items: center;
}
.kikan {
	font-size: 22px;
	font-weight: 800;
	letter-spacing: .05em;
}
.kikan strong {
	font-size: 42px;
	font-weight: 600;
	vertical-align: 5px;
	display: inline-block;
	margin-top: -.3em;
}
.cpDetail h3 {
	background: #000;
	color: #fff;
	line-height: 1;
	letter-spacing: .3em;
	text-indent: .3em;
	font-size: 22px;
	padding: 15px 10px;
	margin-bottom: 40px;
}
.cpDetail ol {
	padding-left: 0;
	list-style: none;
	text-align: left;
}
.cpDetail li {
	text-indent: -.8em;
	padding-left: .8em;
	margin-bottom: 5px;
}
.privacyWrap {
	background: #dfe7e6;
	padding: 50px 9%;
}
.privacyBox {
	background: #fff;
	padding: 50px 10px;
	font-weight: 600;
}
.privacyBox a {
	display: inline-block;
	margin-top: 40px;
}
.entryBtn {
	margin-top: 30px;
}
.entryBtn img {
	max-height: 66px;
}
.formWrap {
	background: #fff;
	border: none;
}
/*form------------------------------*/
.entryTtl {
	background: #000;
	color: #fff;
	padding: 20px 5px 15px;
	font-size: 24px;
	font-weight: 700;
}
.entryTtl h2 {
	font-size: 60px;
	font-weight: 700;
}
.formTopTxt {
	font-size: 28px;
	font-weight: 800;
	letter-spacing: .05em;
}
.formWrap {
	margin-top: 40px;
	border: 8px solid #000;
	padding: 60px 5%;
	text-align: left;
	font-size: 18px;
}
.formWrap dt.req::after {
	content: "*";
	color: #ff0000;
	position: absolute;
	right: -0.7em;
	top: 0;
}
.formWrap dt,.formWrap dd {
	margin-bottom: 30px;
}
.formWrap dt {
	width: 30%;
	text-align: right;
	position: relative;
}
.formWrap dd {
	width: 70%;
	padding-left: 5%;
}
.formWrap input[type="text"], .formWrap input[type="email"], .formWrap input[type="tel"], .formWrap select {
	padding: 5px;
	max-width: 100%;
	border: 1px solid #333;
}
.formWrap input[name="address"] {
	max-width: 518px;;
}
.formName {
	display: flex;
}
.formName input[type="text"] {
	max-width: 150px;
	margin-right: 10px
}
.formZip {
	margin-bottom: 10px;
}
.formZip input[type="text"] {
	width: 150px;
	margin-left: 5px;
}
.mailBtn {
	padding-left: 72px;
	text-align: center;
	margin-top: 30px;
}
.mailBtn input[type='submit'] {
	display: inline-block;
	color: #fff;
	background: #ec1c24 url("../img/btn_arrow.png") right 15px center no-repeat;
	background-size: auto 17px;
	padding: 15px 100px;
	border: 2px solid #ec1c24;
	border-radius: 30px;
	cursor: pointer;
	font-size: 16px;
	transition: .1s;
	white-space: normal;
	width: auto;
}
.mailBtn input.formBack {
	background: #f1f1f1;
	color: #000;
}
.mailBtn input:hover {
	background-color: #666;
}
.mailBtn.-blue input[type="submit"] {
	background-color: #007fff;
	border-color: #007fff;
}
/*form*/
#entryForm {
	padding-top: 0;
}
.formTxt {
	text-align: center;
	margin-bottom: 40px;
}
.formWrap .formTxt  .clrRed {
	display: inline-block;
}
.formTxt 
.contTtl {
	background: url(../img/head_bg.png) repeat-x left top;
	background-size: auto 100%;
	width: 100%;
	margin: 0 auto 50px;
	color: #fff;
	text-align: center;
	padding: 11px 0 18px;
	font-size: 22px;
	font-weight: normal;
}
#entryForm .contTtl + p {
	font-size: 20px;
	line-height: 2;
}
.clrRed {
	color: #ff0000;
}
.wpcf7-form-control-wrap.month {
	margin-right: 10px;
	display: inline-block;
}
.formNote {
	font-size: 85%;
}
.wpcf7c-elm-step2 {
	font-weight: 600;
	text-align: center;
	margin-bottom: 15px;
}
.thxBox {
	text-align: center;
}
.thxBox a {
	display: block;
	margin-top: 15px;
}
.formWrap form .clrRed {
	display: block;
	padding-top: 5px;
}
.formWrap small {
	display: block;
}

.formWrap input[type="tel"] {
    width: 12em;
}


/*ieハック*/
@media screen\0  {
}

/*********************************/
/* タブレット用のスタイル記述 */
/*********************************/
@media screen and (max-width: 1020px) {
}
/*********************************/
/* スマートフォン用のスタイル記述 */
/*********************************/
@media screen and (max-width: 620px) {
/*全体レイアウト
------------------------------------------------*/
	body#cpPage {
		padding-top: 0!important;
		font-size: 14px;
	}
	body.active {
		overflow: hidden;
	}
	article > section {
		padding: 40px 0;
	}
	/*header-------------------------------------*/
	.mainVis {
		height: auto;
		background: none;
	}
	.mainBtm {
		font-size: 5vw;
	}
	#how {
		padding: 40px 0;
	}
	#how .ttlBox {
		background-position: left bottom 5px,right bottom;
		background-size:30% auto,35% auto;
		padding: 0 0 8vw;
		margin-bottom: 10px;
	}
	.ttlBox img {
		max-height: 75px;
	}
	#how .ttlBox + .txt {
		font-size: 16px;
		font-weight: 700;
		margin-bottom: 20px;
	}
	.stepWrap dl {
		width: 100%;
		font-size: 16px;
		margin: 15px 0;
		border-width: 5px;
	}
	.stepWrap dt {
		font-size: 20px;
	}
	.stepWrap dl:not(:first-of-type)::before {
		left: 0;
		right: 0;
		margin: 0 auto;
		top: -38px;
		transform: rotate(90deg);
		border-width: 15px 0 15px 15px;
	}
	.presentWrap::before {
		height: 35px;
		top: -42px;
	}
	.presentWrap {
		display: block;
		margin-top: 60px;
	}
	.presentWrap h3 {
		top: -31px;
	}
	.presentWrap h3 img {
		max-height: 45px;
	}

	.presentImg {
		width: 100%;
		padding-top: 10%;
		margin-bottom: 20px;
    margin-left: 10px;
	}
	.capa {
		left: -13%;
		right: inherit;
		bottom: inherit;
		top: -7%;
		width: 45%;
	}
.capa img {
	max-height: 170px;
  margin-left: 30px;
}
	.presentWrap dl {
		width: 100%;
	}
  .presentWrap dl img{
		width: 50%;
	}
/*	.presentWrap dt {
		display: flex;
		align-items: center;
	}*/
	.presentWrap h4 {
		font-size: 24px;
	}
	img[src*="logo_brubo"] {
    max-height: 30px;
	}
	.channelWrap {
		display: block;
	}
	.channelWrap figure {
		width: 100%;
		margin-bottom: 20px;
	}
	.channelWrap .box {
		width: 100%;
	}
	.channelWrap h3 img {
		max-height: 74px;
	}
	.channelWrap .txt {
		font-size: 16px;
		font-weight: 700;
	}
	.channelBnr .bnr {
		margin-top: -12vw;
	}
	.infoTxt {
		font-size:5.5vw;
		padding-bottom: 40px;
	}
	.infoTtl img {
    max-height: 36px;
	}
	.infoTtl {
		background-size: auto 30px;
		top: -34px;
		padding-top: 5px;
	}
	.sclIcon img {
    max-height: 42px;
	}
	.infoWrap {
		border-width: 5px;
		margin-top: 35px;
		padding: 30px 10px 10px;
	}
	.infoImg  {
		width: 25%;
		bottom: 87%;
    bottom: calc(100% - 35px);
	}
	.info01Box {
		padding: 10px 5px;
	}
	.infoWrap .btn00 {
		margin-top: 10px;
	}
	.infoWrap .btn00 a {
    font-size: 11px;
		padding: 5px 0;
	}
	.infoWrap h5 {
		top: -30px;
	}
	.infoWrap._01 {
		padding: 10px 0;
	}
	.infoWrap h5 img {
    max-height: 55px;
	}
	.questionBg {
		background-position: left top,top 15% center;
		background-size: 92% auto,95% auto;
	}
	.questionTxt {
		font-size: 16px;
		padding-right: 0;
	}
	.questionTxt small {
		font-size: 80%;
		padding-top: 10px;
		margin-bottom: 10px;
		padding-right: 35%;
	}
	.ansBox {
		width: 99%;
		margin: 4px auto 0;
		padding: 10px;
	}
	.ansBox h4 {
		font-size: 20px;
		margin-bottom: 0;
	}
	.num {
		margin-bottom: 15px;
	}
	.ansImg {
		width: 36%;
		bottom: 100%;
		bottom: calc(100% - 4px);
	}
	.hallArea {
		padding: 40px 0;
	}
	.hallTopTxt {
		padding: 0 0 10vw;
		font-size: 4.5vw;
	}
	.hallTtl {
		top: -37px;
	}
	.hallTtl img {
    max-height: 60px;
	}
	.hallWrap {
		padding: 40px 5% 20px;
		margin-top: 55px;
	}
	.hallBox {
		display: block;
	}
	.hallImg {
		width: 100%;
		margin-bottom: 15px;
	}
	.rate dt {
		font-size: 18px;
	}
	.rate img {
    max-height: 30px;
	}
	.hallCont {
		width: 100%;
	}
	.hallCont h4 {
		font-size: 18px;
		padding-right: 0;
		margin-bottom: 10px;
	}
	.hallCont dt, .hallCont dd {
		font-size: 90%;
	}
	.hallCont dt {
		width: 30%;
	}
	.hallCont dd {
		width: 70%;
	}
	.hallCont .btn a {
		white-space: nowrap;
	}
	.person._01 {
		width: 34%;
		left: -8%;
	}
	.person._02 {
		width: 43%;
		right: 2%;
	}
	.person._03 {
		width: 43%;
		left: 0;
	}
	.fBnr {
		padding: 30px 0;
	}
	#footer {
		padding-bottom: 16vw;
	}
	.fix {
		left: 0;
		bottom: 0;
		top: inherit;
	}
	/*incorrect---------------------------------*/
	.cpTtl {
		padding: 0 10%;
		margin-bottom: 20px;
	}
	.ansTtl {
		margin-bottom: 30px;
	}
	.ansDetail {
		padding: 40px 5%;
	}
	.ansDetail h2 {
		font-size: 20px;
		margin-bottom: 20px;
		white-space: nowrap;
	}
	.ansDetail h2 span {
		padding: 0 20px;
	}
	.ansDetail h2 span::after, .ansDetail h2 span::before {
		width: 12px;
		height: 23px;
	}
	.ansDetImg {
		padding: 0 5%;
		margin-bottom: 30px;
	}
	.ansDetImg + p {
		font-size: 5vw;
		letter-spacing: normal;
		padding-right: 20%;
		margin-bottom: 20px;
	}
	.ansDetImg + p span {
	font-size: 70%;
	}
	.nextTxt {
		background-size: auto 8px;
		padding-bottom: 25px;
		background-position: left 33% bottom;
	}
	.hintWrap {
		display: block;
		padding: 20px 5%;
	}
	.hintWrap figure:not(.person) {
		width: 100%;
		margin-bottom: 15px;
	}
	.hintWrap h3 {
		width: 100%;
		text-align: center;
	}
	.hintWrap h3 span {
		display: block;
		width: 100%;
	}
	.hintWrap h3 .txt {
		font-size: 22px;
	}
	.hintIco img {
		max-height: 75px;
	}
	.hintWrap .person {
		width: 28%;
	}
	.btn1 {
		margin-top: 30px;
	}
	.btn1 a {
		font-size: 14px;
		min-width: inherit;
		width: 100%;
		padding: 15px 5px;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	/*correct-----------------------------*/
	.subBg {
    background-position: center top,top 22% center;
    background-size: 92% auto,95% auto;
}
	#correct .ansDetImg + p {
		padding: 0 0 0 20%;
	}
	
	#correct .hintWrap .person {
		width: 30%;
	}
	#correct .nextTxt {
		font-size: 20px;
		background-position: bottom center;
	}
	.product02 figure {
		width: 60%;
		margin: -75px auto 15px;;
	}
	.productName b {
		text-align: left;
		font-size: 16px;
		margin-left: 5px;
	}
	.ouboTxt {
		font-size: 18px;
		margin-bottom: 40px;
	}
	.outLine {
		padding: 30px 5%;
	}
	.outLine .d-flex {
		display: block;
	}
	.outLine dt,.outLine dd {
		width: 100%;
	}
	.outLine dt {
		font-size: 14px;
		padding: 5px;
	}
	.outLine dd {
		padding: 0 5%;
	}
	.kikan {
		font-size: 14px;
	}
	.kikan strong {
		font-size: 26px;
	}
	.cpDetail h3 {
		padding: 10px;
		font-size: 16px;
		margin-bottom: 15px;
	}
	.cpDetail li {
		font-size: 90%;
	}
	.privacyWrap {
		padding: 30px 5%;
	}
	.privacyBox {
		padding: 30px 5%;
		text-align: left;
	}
	.privacyBox a {
		width: 70%;
		display: block;
		margin: 20px auto 0;
	}
	.entryBtn {
		width: 70%;
		margin: 20px auto 0;
	}
/*entry----------------*/
	.entryTtl {
		font-size: 16px;
	}
	.entryTtl h2 {
    font-size: 30px;
}
	.formTopTxt {
		font-size: 16px;
	}
#entryForm {
	padding-top: 0;
}
#entryForm .contTtl {
	padding: 10px 5px 15px;
	margin-bottom: 20px;
}
#entryForm .contTtl + p {
	line-height: 1.6;
	font-size: 12px;
}
.contTtl h1 {
	font-size: 17px;
}
.formWrap {
	padding: 40px 5%;
	margin-top: 30px;
	font-size: 14px;
}
.formWrap dl {
	display: block;
}
.formWrap dt {
	background: #f1f1f1;
	padding: 5px 15px 5px 10px;
	text-align: left;
	display: inline-block;
	width: auto;
	margin-bottom: 15px;
}
.formWrap dt.req::after {
	right: 3px;
}
.formWrap dd {
	width: 100%;
	padding-left: 0;
	border-bottom: 1px solid #666;
	padding-bottom: 20px;
	margin-bottom: 20px;
}
.fTel input + small {
	margin-left: 0;
}
.formTxt {
	display: block;
}
.flwTxt {
	width: 100%;
	margin-top: 5px;
}
.follow label {
	display: inline-block;
	margin-bottom: 8px;
}
.account {
	display: block;
	margin-top: 5px;
	font-size: 12px;
}
input[type=radio], input[type=checkbox] {
	vertical-align: -1px;
}
.zip input {
	width: 35%;
}
.fTel input[type="text"],
input[type="email"],
input[name="address"] {
	width: 100%;
}
.formName > span{
	width: 39%;
	margin-right: 10px;
}
.formName input[type="text"]{
	max-width: 100%;
	width: 100%;
}
.mailBtn input {
	font-size: 15px;
	padding: 10px 50px;
	width: 100%;
}
.formWrap small {
	display: block;
	padding-top: 3px;
}
#confirm .mailBtn {
	display: block;
}
#confirm .mailBtn input {
	width: 100%!important;
}
.mailBtn .button02 {
	margin-right: 0;
	margin-bottom: 20px;
}
.btn1 {
	margin-top: 30px;
}
.btn1 a {
	font-size: 14px;
	min-width: inherit;
	width: 100%;
	padding: 15px 5px;
	display: flex;
	justify-content: center;
	align-items: center;
}
	
	.mailBtn {
		padding-left: 0;
	}
	
	
	
	
	#go-to-top {
		right: 3px!important;
		bottom: 13vw!important;
	}
	
}

