	/*----------------------------------------------------------------------------レスポンシブCSS-------------------------------------------------------------------------------------------------------------------------------------*/
	/*--------スマホ--------*/
	/*--------トップページ--------*/
	
	
	.width {
		max-width: 400px;
		margin: 0 auto;
	}
	.logo {
		font-size: 0;
		background: #ff86b0;
		text-align: center;
		padding: 15px 0;
	}
	.logo img {
		display: inline-block;
		width: 76px;
	}
	.fv_img {
		font-size: 0;
	}
	.co_bg {
		background-image: url(../img/bg.png);
	}
	.arrowbar {
		display: block;
		margin-bottom: 30px;
	}
	.qblock {
		text-align: center;
	}
	.q1_txt1 {
		font-weight: bold;
		font-size: 18.5px;
		margin-bottom: 5px;
	}
	.q1_txt2 {
		font-size: 21.5px;
		font-weight: bold;
	}
	.q1_txt2 span {
		background: linear-gradient(transparent 0%, #ffff99 0%);
	}
	.start {
		font-size: 0;
		margin: 30px 0 45px;
	}
	.start img {
		display: inline-block;
		width: 311px;
	}
	.qbox_wrap {
		padding: 0 20px;
		margin-bottom: 60px;
	}
	.qbox {
		position: relative;
	}
	.qbox_num {
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		top: -1em;
		font-size: 5vw;
	}
	.qbox_num span {
		font-size: 1.5em;
	}
	.qbox_qtxt {
		position: absolute;
		top: 2em;
		left: 0;
		width: 100%;
		font-size: 5.5vw;
		line-height: 1.34;
		font-weight: bold;
	}
	.line_yellow {
		background: linear-gradient(transparent 60%, #ffff70 60%);
	}
	.checkbox_wrap {
		position: absolute;
		left: 50%;
		top: 35%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		width: 100%;
	}
	.checkbox_list {
		padding: 0;
		display: inline-block;
		list-style: none;
		text-align: left;
	}
	.checkbox_list li {
		font-size: 5vw;
		margin: 0 0 .5em;
		font-weight: semibold;
	}
	.checkbox_list li input {
		margin: 0 1em 0 0;
	}
	.check_text {
	  cursor: pointer;
	}
	.check_text {
	  /* チェックボックスとテキストの上下を中央に */
	  align-items: center;
	  display: flex;
	}
	.checkbox_list input {
	  display: none; /* デフォルトのチェックボックスを非表示 */
	}
	.checkbox_list input + .check_text::before {
	  background-image: url("../img/check1.png");
	  background-position: center;
	  background-repeat: no-repeat;
	  background-size: contain;
	  content: "";
	  height: 1em;
	  position: relative;
	  width: 1em;
	  margin: 0 1em 0 0;
	}
	.checkbox_list input:checked + .check_text::before {
	  background-image: url("../img/check2.png");
	}
	.q1_img01 {
		font-size: 0;
		margin-bottom: 50px;
	}
	.q1_txt3 {
		padding: 0 30px;
		font-size: 0;
		margin-bottom: 20px;
	}
	.q1_txt4 {
		padding: 0 30px;
		font-size: 14px;
		line-height: 2.1;
		text-align: left;
		font-weight: semibold;
	}
	.q1_display {
		padding: 0 0 60px;
		display: none;
	}
	.q1_display.display {
		display: block;
	}
	.nextbtn_wrap {
		padding: 0 0 60px;
		position: relative;
	}
	.nextbtn {
		margin: 0 auto;
		width: 90%;
		max-width: 314px;
		background: #ccc;
		color: #FFF;
		padding: 15px 0;
		position: relative;
		cursor: not-allowed;
		font-style: italic;
	}
	.nextbtn.on {
		background: #ff86b0;
		cursor: pointer;
	}
	.nextbtn::after {
		content: "";
		position: absolute;
		top: 50%;
		right: 25px;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
		display: inline-block;
		width: 7px;
		height: 12px;
		background-image: url(../img/arrow.png);
		background-position: center;
		background-repeat: no-repeat;
		background-size: contain;
	}
	#q2 {
		padding: 60px 0 0;
		display: none;
	}
	#q2.q2_on {
		display: block;
	}
	.q2_txt1 {
		font-size: 0;
		margin-bottom: 25px;
	}
	.q2_txt2 {
		text-align: left;
		font-size: 14px;
		font-weight: semibold;
		padding: 0 20px;
		margin-bottom: 30px;
	}
	.q2_display {
		padding: 30px 0 30px;
		display: none;
	}
	.q2_display.display {
		display: block;
	}
	.q2_table_scroll {
		position: absolute;
		font-size: 0;
		width: 62px;
		top: 50%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
		left: calc(50% - 31px);
		opacity: 0;
		transition: 1s;
	}
	.q2_table_scroll.started {
		animation: q2_table_scroll_anime 3s;
	}
	@keyframes q2_table_scroll_anime {
		0% {
			opacity: 0;
			transform: translateX(-30px);
		}
		25% {
			opacity: 1;
			transform: translateX(30px);
		}
		50% {
			opacity: 1;
			transform: translateX(-30px);
		}
		75% {
			opacity: 1;
			transform: translateX(30px);
		}
		100% {
			opacity: 0;
			transform: translateX(-30px);
		}
	}
	.q2_table_wrap {
		position: relative;
		padding: 0 0 0 20px;
		margin: 0 0 45px;
	}
	.q2_table_in {
		position: relative;
		overflow-x: scroll;
		-ms-overflow-style: none;
	   scrollbar-width: none;
	}
	.q2_table_in::-webkit-scrollbar{
	   display: none;
	}
	.q2_table {
		font-size: 0;
		width: 886px;
		padding: 0 20px 0 0;
	}
	.q2_table:hover {
		cursor: grab;
	}
	.q2_table:active {
	  cursor: grabbing;
	}
	.q2_txt3 {
		font-size: 0;
	}
	.q2_txt3 img {
		display: inline-block;
		width: 266px;
	}
	#q3 {
		padding-top: 60px;
		display: none;
	}
	#q3.q3_on {
		display: block;
	}
	#nextbtn_q3 {
		padding-top: 50px;
	}
	.nextbtn_cover {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		-webkit-transform: translate(-50%, -50%);
		-ms-transform: translate(-50%, -50%);
		width: 100%;
		height: 100%;
		background: transparent;
		z-index: 5;
	}
	@media screen and (max-width: 399px) {
		#q3 .checkbox_list li {
			padding-left: 4vw;
			padding-right: 2.5vw;
			font-size: 4.5vw;
		}
	}
	
	
	
	/*--------タブレット--------*/
	@media screen and (min-width: 400px) {
	    /*--------トップページ--------*/
	    
	    .qbox_num {
	    	font-size: 24px;
	    }
	    .qbox_qtxt {
	    	font-size: 20.5px;
	    }
	    .checkbox_list li {
	    	font-size: 16px;
	    	margin: 0 0 1em;
	    }
	    
	}
	
	
	
	
	
	/*--------PC--------*/
	@media screen and (min-width: 1180px) {
	    /*--------トップページ--------*/
	}
	
	
