@charset "utf-8";
/* CSS Document */

@media all and (max-width: 1600px) {
/* 	.menu a{ padding: .2vw 0;} */
}

@media all and (max-width: 1199px) {
	.container{ max-width: 1240px; padding: 0 20px;}

	header, header:active{ height: 80px; padding: 0 70px;}

	.logo{ margin: 10px 0;}
	.logo a{ width: 242px; height: auto;}
	/* #header_index .menu{ width: 58px; height: 58px; margin: 0px 0 0 0; }
	#header_index .menu img{ width: 100%; } */
	.menu{ width: 58px; height: 58px; margin: 10px 0 0 0; }
	.menu img{ width: 100%; }
	.menu_close{ top: 10px; right: 46px; }
	.menu_close img{ width: 58px;}
	.menu_box{ margin: 200px auto; }
	.menu_box li a{ margin: 50px 0; font-size: 2em; }

	.music_wrap{ margin: 10px 30px 0 0; }
	.music_wrap button{ width: 58px; height: 58px;}

	main.bg_test1_intro, main.bg_test2_intro{ background-size: 45% auto, cover; }

	main .cnt_wrap h3{ padding: 30px 0; font-size: 2em; line-height: 1.5em;}
	main .cnt_wrap h3.intro{ padding: 100px 0;}
	main .cnt_wrap h3.rep{ padding: 73px 0 73px 0;}
	main .cnt_wrap h3.rep .cap_rep{ max-width: 800px; margin-top: 65px; margin-bottom: -50px; background-size: auto 25px, auto 25px; }
	main .cnt_wrap.h_01{ min-height: calc(100vh - 243px); }
	main .cnt_wrap .btn_wrap{ height: 50px; padding: 30px 0; }
	main .cnt_wrap .btn_wrap .btn_box{ margin: 11px 0 0 0; }
	main .cnt_wrap .btn_wrap .btn_box.h2{ margin-top: 5px !important; }
	main .cnt_wrap .btn_wrap .btn_box i, main .cnt_wrap .btn_wrap .btn_box button{ width: 450px; height: 75px;}
	main .cnt_wrap .btn_wrap .btn_box i{ left: calc(50% - 225px + 15px);}
	main .cnt_wrap .btn_wrap .btn_box button{ padding: 7px 0 9px 0; font-size: 1.625em; left: calc(50% - 225px); }
	main .cnt_wrap h3 span.subtitle{ font-size: .6em;}

	.main1 main .cnt_wrap .btn_wrap .btn_box{ margin-top: 0px;}
	.main2 main .cnt_wrap .btn_wrap .btn_box{ margin-top: 5px;}

	main .cnt_wrap .btn_wrap.intro{ bottom: 100px; }

	.progress_wrap{ max-width: 960px; padding: 125px 0 28px 0;}
	.progress_mark{ width: 54px; height: 54px; line-height: 52px; top: 105px;}
	.progress_mark p{ font-size: 1em;}
	.progress_mark span{ bottom: -3px; }
	.progress_bar, .progress_bar:active{ height: 14px; }
	.progress_line{ height: 14px; }

	.q_wrap .q_opt label{ font-size: 1.25em;}

	.q_wrap.type_01 li{ margin: 50px 0;}
	.q_wrap.type_01 li i{ width: 50px; height: 50px; margin: 11px 20px 0 0; font-size: 1em; line-height: 48px; }
	.q_wrap.type_01 li .q_opt_wrap{ width: calc(100% - 50px - 20px);}
	.q_wrap.type_01 .q_opt{ width: calc(50% - 2px); display: inline-block; }
	.q_wrap.type_01 .q_opt input[type="radio"] { width: auto; position: fixed; opacity: 0 !important;}
	.q_wrap.type_01 .q_opt input[type="radio"]:checked + label{ color: #fff; background: #87c440; border-color: #87c440;}
	.q_wrap.type_01 .q_opt label{ margin: 0 10px; padding: 20px 0; }
	.q_wrap.type_01 .q_opt label p{ font-size: 1.25em; }
	.q_wrap.type_01.t03 .q_opt label{ clip-path: polygon( 0 10px, 10px 0, calc(100% - 10px) 0, 100% 10px, 100% calc(100% - 10px), calc(100% - 10px) 100%, 10px 100%, 0% calc(100% - 10px), 0% 10px) }
	.q_wrap.type_01.t03 .q_opt label::before{ clip-path: polygon( 0 9px, 9px 0, calc(100% - 9px) 0, 100% 9px, 100% calc(100% - 9px), calc(100% - 9px) 100%, 9px 100%, 0% calc(100% - 9px), 0% 9px) }

	.q_wrap.type_02 li{ margin-bottom: 15px; }
	.q_wrap.type_02 li i{ width: 50px; height: 50px; margin-top: 10px; font-size: 1.5em; line-height: 48px; }
	.q_wrap.type_02 li .q_opt_wrap{ width: calc(100% - 50px); padding: 22px 0 1px 30px;}
	.q_wrap.type_02 li .q_opt_wrap span{ margin-bottom: 25px; font-size: 1.375em; line-height: 1.25em; }
	.q_wrap.type_02 li .q_opt_wrap .line_wrap{ height: 60px; top: 8px; }
	.q_wrap.type_02 li .q_opt_wrap .line{ width: calc(100% - 40px); height: 6px !important; margin-left: 10px; }

	.q_wrap.type_02 .q_opt{ top: -5px;}
	.q_wrap.type_02 .q_opt:nth-child(1){ left: calc(0% - 0px); }
	.q_wrap.type_02 .q_opt:nth-child(2){ left: calc((100% - 40px) / 4); }
	.q_wrap.type_02 .q_opt:nth-child(3){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4); }
	.q_wrap.type_02 .q_opt:nth-child(4){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4); }
	.q_wrap.type_02 .q_opt:nth-child(5){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4); }
	.q_wrap.type_02 .q_opt label{ width: 20px !important; height: 20px !important; margin: 0; padding: 0; border-radius: 50%; transition:0.2s all; }
	.q_wrap.type_02 .q_opt input[type="radio"] { width: 20px; height: 20px; position: absolute; top: -7px; left: 0px; opacity: 0 !important; z-index: 1;}
	.q_wrap.type_02 .q_opt input[type="radio"]:checked + label{ width: 36px !important; height: 36px !important; margin: -8px 0 0 -8px !important;}
	
	.q_wrap.type_02 .q_opt_name{ width: 100%; position: absolute; z-index: 3; }
	.q_wrap.type_02 .q_opt_name p{ width: 64px; margin: 30px 0 0 -22px; font-size: 1.125em; position: absolute; white-space: nowrap; text-align: center; }
	.q_wrap.type_02 .q_opt_name p:nth-child(1){ left: 0; }
	.q_wrap.type_02 .q_opt_name p:nth-child(2){ left: calc((100% - 40px) / 4); }
	.q_wrap.type_02 .q_opt_name p:nth-child(3){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4); }
	.q_wrap.type_02 .q_opt_name p:nth-child(4){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4); }
	.q_wrap.type_02 .q_opt_name p:nth-child(5){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4); }

	h3.ico-checked span.t01, h3.ico-checked span.t02, h3.ico-checked span.t03, h3.ico-checked span.t04{ padding: 6px 40px 2px 0; background-size: 40px auto;}

	.form_wrap{ max-width: 800px; margin: 0 auto; padding: 30px; background: #fff; border-radius: 5px; text-align: left; }
	.form_wrap b{ font-size: 1.25em; }
	.form_wrap .collist .column{ margin-bottom: 30px; overflow: hidden; }
	.form_wrap .s-3 .column{ width: calc((100% / 3) - 10px); display: inline-block; }
	.form_wrap .s-2 .column{ width: calc((100% / 2) - 3px); display: inline-block; }
	.form_wrap .s-4 .column{ width: calc((100% / 2) - 3px); margin-top: -40px; display: inline-block; }
	.form_wrap .s-4 .column:nth-child(-n+2){ margin-top: 0px; }
	.form_wrap .collist:last-child .column{ margin-bottom: 0; }
	.form_wrap span.error { font-size: 1em;}

	#header_index header, #header_index header:active{ height: 80px; padding: 0 10px; }
	#header_index .menu{ margin: 25px 0 0 0; }
	#header_index .menu a{ margin-left: 50px; font-size: 1.25em; }

	main.index{ background:#ffeecd; }
	main.index .cnt_wrap{ margin: 0 -12px; display: block; }
	main.index .cnt_wrap .cnt_col{ padding: 0 20px; display: block; }
	main.index .cnt_wrap .cnt_col:nth-child(1){ background: url('../../img/bg-index_m.webp') center top no-repeat; background-size: cover; }
	main.index .cnt_wrap .cnt_col .model{ max-width: 700px; margin: 0 auto; padding-top: 25%; }
	main.index .cnt_wrap .cnt_col .txt01{ width: 104px; position: absolute; top: 35%; left: 10%; }
	main.index .cnt_wrap .cnt_col .txt02{ width: 216px; position: absolute; top: 20%; left: 25%; }
	main.index .cnt_wrap .cnt_col .txt03{ width: 237px; position: absolute; top: 22%; right: 10%; }
	main.index .cnt_wrap .cnt_col .bg_wave{ width: calc(100% + 0px); height: 10px; margin-left: -20px; margin-bottom: -1px; background: url('../../img/bg-wave_m.webp') repeat-x; background-size: auto 9px; position: absolute; bottom: 0; }
	main.index .cnt_wrap .cnt_col:nth-child(2){ }
	main.index .cnt_wrap .cnt_col .title{ max-width: 650px; margin: 8% auto 0 auto; }
	main.index .cnt_wrap .cnt_col .txt{ max-width: 700px; margin: 4% auto 0 auto; text-align: left; }
	main.index .cnt_wrap .cnt_col .txt h3{ width: 100%; padding: 0; display: flex; }
	main.index .cnt_wrap .cnt_col .txt h3 i{ margin-right: 10px; padding: 0; flex-basis: 25px; }
	main.index .cnt_wrap .cnt_col .txt h3 i img{ padding-top: 7px; vertical-align: top; }
	main.index .cnt_wrap .cnt_col .txt h3 span{ color: #f05a49; font-size: 28px; flex-basis: calc(100% - 35px); text-align: left;}
	main.index .cnt_wrap .cnt_col .txt h3 span span{ padding-bottom: 8px; background: auto 3px; }
	main.index .cnt_wrap .cnt_col .txt p{ margin-top: 25px; font-size: 1.313em; }
	main.index .cnt_wrap .cnt_col .btn_wrap{ margin-top: 20px; padding-bottom: 150px; }

	.cookie_des{ padding: 20px 70px; font-size: 1em; }
	.cookie_des .cd_item:nth-child(1){ flex-basis: calc(100% - 500px); }
	.cookie_des .cd_item:nth-child(2){ flex-basis: 250px; }
	.cookie_des .cd_item:nth-child(3){ flex-basis: 250px; }
	.cookie_des .cd_item .btn{ max-width: 200px; padding: 7px 0 8px 0; }

	.nav-link, .nav-link:hover, .nav-link:focus{ padding-top: 15px; font-size: 1.75em; border-top-left-radius: 20px !important; border-top-right-radius: 20px !important; border-bottom-left-radius: 0 !important; border-bottom-right-radius: 0 !important; }
	.nav-item:first-child { padding-right: 5px; }
	.nav-item:last-child { padding-left: 5px; }
	.nav-item .nav-link i{ float: left; width: 30px; height: 30px; margin: 3px 15px 0 0; }
	.tab-content{ padding: 50px;}
	.tab-pane .tab_mainpic img{ max-width: 600px !important; }
	.tab_data{ max-width: 856px; margin: 30px auto 0 auto; }
	.tab_data li:first-child{ width: calc(100% - 316px); padding-right: 30px; font-size: 1.25em; }
	.tab_data li:last-child{ width: 254px; padding-left: 30px; border-left: 2px solid #fac373; }
	.tab_data li p:nth-child(1){ float: left; margin: 10px 0 0 0; color: #1c7f8c; font-size: 1.25em; }
	.tab_data li p:nth-child(2){ float: right; color: #f05a49; font-size: 2.188em; font-weight: 700; }
	.tab_data li p:nth-child(2) span{ font-size: 20px; }
	.tab_data li:last-child .star_rank .star{ width: 30px; height: 30px; margin: 0 0 0 15px;}

	.volunteer .nav-item{ padding: 0 4px; }
	.volunteer .nav-item:nth-child(1) { padding: 0 8px 0 0; }
	.volunteer .nav-item:nth-child(3) { padding: 0 0 0 8px; }
	.volunteer .nav-item button{ padding: 50px; }
	.volunteer .nav-item button p{ margin: 20px 0;}
	.volunteer .nav-item button li{ height: 55px; }
	.volunteer .nav-item button li .perc{ width: 56px; margin: 8px auto 0 auto;}
	.volunteer .nav-item button li .perc p{ width: 48px; font-size: 30px; }
	.volunteer .nav-item button li .perc span{ margin: 12px 0 0 5px; font-size: 16px; }
	.volunteer .nav-item button li .star_rank{ margin: 10px auto 0 auto; }
	.volunteer .nav-item button li .star_rank .star{ width: 30px; height: 30px; margin: 0 2px; }
	.volunteer .nav-item button li:first-child{ width: 92px; margin-right: 8px; border-top-right-radius: 0; border-bottom-right-radius: 0; }
	.volunteer .nav-item button li:last-child{ width: calc(100% - 100px); border-top-left-radius: 0; border-bottom-left-radius: 0; }
	.volunteer .nav-item .ico-triangle{ height: 59px; margin: 31px 0 0 0; }
	.volunteer .nav-link, .volunteer .nav-link:hover, .volunteer .nav-link:focus{ border-radius: 20px !important; }

	.volunteer .tab-content h3{ margin: 0 0 10px 0; }
	.volunteer .tab-content .collist:nth-child(1) p{ font-size: 1.25em; }
	.volunteer .tab-content .subcap{ padding-left: 20px; font-size: 1.125em; line-height: 1.875em; border-left: 10px solid #f05a49; }
	.volunteer .tab-content .param_wrap{ margin-top: 20px; padding: 30px; border: 1px solid #000; border-radius: 10px; }
	.volunteer .tab-content .param_wrap .param{ margin-bottom: 20px; }
	.volunteer .tab-content .param_wrap .param h3{ margin: 0 0 10px 0; padding: 0 0 0 50px; line-height: 1em; }
	.volunteer .tab-content .param_wrap .param.rep02_00{ height: 100px; }
	.volunteer .tab-content .param_wrap .param.rep02_01 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_02 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_03 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_04 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_05 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_06 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_07 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_08 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_09 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_10 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_11 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_12 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_13 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_14 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_15 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param h3 .star_rank .star{ width: 30px; height: 30px; margin: 0 0 0 15px; }
	.volunteer .tab-content .param_wrap .param p{ padding: 0 0 0 50px; font-size: 1.25em; line-height: 1.5em; }

	.item_wrap{ margin-top: 50px; padding: 30px; background: #fff; border-radius: 20px; }
	.item_share{ margin: 20px 0; padding: 0; border-radius: 20px; display: flex; overflow: hidden; }
	.item_share .item{ padding: 30px; background: #e3e3e3; display: flex; align-items: center; justify-content: center; }
	.item_share .item:nth-child(1){ flex-basis: calc(100% - 200px);  }
	.item_share .item:nth-child(1) .item_img{ flex-basis: 180px; }
	.item_share .item:nth-child(1) .item_txt{ margin-left: 40px; flex-basis: calc(100% - 140px); text-align: left; }
	.item_share .item:nth-child(1) .item_txt h3{ margin: 0 0 8px 0; padding: 0; font-family: 'Noto Sans TC', sans-serif; text-align: left; }
	.item_share .item:nth-child(1) .item_txt p{ margin: 0; padding: 0; font-size: 20px; line-height: 1.5em; }
	.item_share .item:nth-child(2){ margin-left: 20px; flex-basis: 180px; flex-wrap: wrap; align-content: center; }
	.item_share .item:nth-child(2) b{ width: 100%; margin-bottom: 0px; color: #1c7f8c; font-size: 20px; font-weight: 400; display: block; }
	.item_share .item:nth-child(2) .perc{ width: 100%; margin: 0; padding: 0; text-align: center;}
	.item_share .item:nth-child(2) .perc p{ margin: 0; padding: 0; color: #f05a49; font-size: 1.875em; font-weight: 700; display: inline-block; }
	.item_share .item:nth-child(2) .perc span{ margin: 19px 0 0 5px; color: #f05a49; font-size: 1em; display: inline-block; }
	.item_share .item:nth-child(2) .star_rank{ margin: 10px auto 0 auto; text-align: center; }
	.item_share .item:nth-child(2) .star_rank .star{ width: 25px; height: 25px; margin: 0 4px; background: url('../../img/ico-star.webp') center center no-repeat; background-size: cover; display: inline-block; }
	.item_share .item:nth-child(2) .star_rank .star.x{ background: url('../../img/ico-starx.webp') center center no-repeat; background-size: cover; }

	.concept_wrap{ padding: 30px; background: #fff; border: 1px solid #000; border-radius: 10px; display: flex; align-items: center; }
	.concept_wrap h3{ margin: 0 30px 0 0; padding: 0 0 0 40px !important; color: #1c7f8c; font-size: 1.75em; line-height: 1.125em !important; flex-basis: 170px; }
	.concept_wrap h3.rep03_01{ background: url('../../img/ico-rep03_01.webp') 0 5px no-repeat; background-size: 30px auto; }
	.concept_wrap h3.rep03_02{ background: url('../../img/ico-rep03_02.webp') 0 5px no-repeat; background-size: 30px auto; }
	.concept_wrap h3.rep03_03{ background: url('../../img/ico-rep03_03.webp') 0 5px no-repeat; background-size: 30px auto; }
	.concept_wrap p{ flex-basis: calc(100% - 330px); font-size: 1.25em; }
	.concept_wrap .star_rank{ flex-basis: 135px; margin-top: -3px; overflow: hidden; }
	.concept_wrap .star_rank .star{ float: left; width: 30px; height: 30px; margin: 0 0 0 10px; background: url('../../img/ico-star2.webp') center center no-repeat; background-size: cover; display: block; }
	.concept_wrap .star_rank .star.x{ background: url('../../img/ico-star2x.webp') center center no-repeat; background-size: cover; }

	.item_wrap.dl{ padding: 50px 30px;}
	.item_wrap.dl p{ font-size: 1.25em; line-height: 1.5em; text-align: left; }
	.item_wrap.dl button, .item_wrap.dl a { width: 100%; max-width: 450px; margin: 50px 0 0 0; padding: 26px 20px 28px 20px; color: #fff; font-size: 1.375em; line-height: 1em; }
	.item_wrap.dl button span, .item_wrap.dl a span{ padding: 0 0 0 45px; background:#5ac3d7 url('../../img/ico-dl.webp') 0 5px no-repeat; background-size: 30px auto; }

	.info{ padding: 50px 0; }
	.info li{ margin-bottom: 20px; }
	.info li i{ width: 25px; height: 25px; margin-right: 15px; }
	.info li p{ width: calc(100% - 40px); font-size: 1.25em; line-height: 1.5em; }

	main .cnt_wrap h3.rep_q{ padding: 150px 0 30px 0; font-size: 2em;}
	main .cnt_wrap h3.rep_q span{ margin-top: 10px; font-size: 16px; line-height: 1.188em; }
	main.bg_rep_q .btn_wrap{ padding-bottom: 150px; }

	.copyright{ padding: 10px 20px; font-size: .875em; border-top: 10px solid #5ac3d7; }

	.login_bg{ width: 100%; height: 100vh; background: #5ac3d7 url('../../img/bg-menu.webp') center bottom no-repeat; background-size: 100% auto; }
	.login_wrap{ padding: 100px 40px; }
	.login_box{ max-width: calc(480px - 40px); margin: 0 auto; }
	.login_box h2{ margin: 50px 0 20px 0; padding-bottom: 20px; color: #fff; font-size: 2em; border-bottom: 1px solid #fff; text-align: center; }
	.form_login p{ margin-top: 10px; color: #fff; font-size: 1.5em; line-height: 46px; text-align: left; }
	.form_login button{ color: #624147; font-weight: 700; background: #f3bf73; border: 2px solid #f3bf73; }
	.form_login button:hover{ background: #f3bf73; border-color: #624147; }
}

@media all and (max-width: 1024px) {
	main.bg_test1_intro, main.bg_test2_intro{ background-size: 80% auto, cover; }
	main .cnt_wrap.h_01{ min-height: 100%; padding-bottom: 120px; }

	.balloon{ left: 10%; }
	.balloon img{ width: 79px; }
	.cloud{ margin-top: 20%; }

	.progress_wrap{ margin: 0 50px;}

	.q_wrap.type_01 li{ margin-bottom: 20px;}
	.q_wrap.type_01 li i{ float: none; width: 50px; height: 50px; margin: 15px auto; font-size: 1em; line-height: 48px; display: inline-block; }
	.q_wrap.type_01 li .q_opt_wrap{ float: none; width: calc(100% - 20px);}
	.q_wrap.type_01 .q_opt{ width: calc(100% - 2px); margin-bottom: 20px; }
	.q_wrap.type_01 .q_opt label{ margin: 0 10px; padding: 20px 0 !important; }

	.q_wrap.type_02 li{ margin-bottom: 100px; }
	.q_wrap.type_02 li i{ width: 50px; height: 50px; margin-top: 10px; font-size: 1em; line-height: 48px; }
	.q_wrap.type_02 li .q_opt_wrap .line_wrap{ height: 55px; margin: 20px 0 0 0; }
	.q_wrap.type_02 li .q_opt_wrap .line{ width: calc(100% - 20px) !important; height: 5px !important; margin: 2px 0 0 -30px !important; }

	.q_wrap.type_02 .q_opt{ top: -5px;}
  .q_wrap.type_02 .q_opt:nth-child(1){ left: calc(0% - 40px); }
  .q_wrap.type_02 .q_opt:nth-child(2){ left: calc((100% - 40px) / 4 - 35px); }
  .q_wrap.type_02 .q_opt:nth-child(3){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 - 30px); }
  .q_wrap.type_02 .q_opt:nth-child(4){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4 - 25px); }
  .q_wrap.type_02 .q_opt:nth-child(5){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4 - 20px); }

  .q_wrap.type_02 .q_opt_name p{ margin: 25px 0 0 -22px; font-size: 1em}
  .q_wrap.type_02 .q_opt_name p:nth-child(1){ left: -40px; }
  .q_wrap.type_02 .q_opt_name p:nth-child(2){ left: calc((100% - 40px) / 4 - 35px); }
  .q_wrap.type_02 .q_opt_name p:nth-child(3){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 - 30px); }
  .q_wrap.type_02 .q_opt_name p:nth-child(4){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4 - 25px); }
  .q_wrap.type_02 .q_opt_name p:nth-child(5){ left: calc((100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4 + (100% - 40px) / 4 - 20px); }
}

@media all and (max-width: 991px) {
	main.bg_test1_intro, main.bg_test2_intro{ background-size: 50% auto, cover; }

	.balloon{ left: 5%; }
	.balloon img{ width: 79px; }
	.cloud{ margin-top: 0%; }

	.progress_wrap{ margin: 0 20px;}

	.q_wrap.type_02 li{ margin-bottom: 30px; }

	main .cnt_wrap h3.rep{ padding: 100px 0;}
	main .cnt_wrap h3.rep .cap_rep{ background: url('../../img/bg-cap_rep_l.webp') left -30px center no-repeat, url('../../img/bg-cap_rep_r.webp') right -30px center no-repeat; background-size: auto 25px, auto 25px; }

	main.index .cnt_wrap .cnt_col .model{ max-width: 60%; margin: 0 auto; padding-top: 30%; }
	main.index .cnt_wrap .cnt_col .txt01{ width: 104px; position: absolute; top: 35%; left: 10%; }
	main.index .cnt_wrap .cnt_col .txt02{ width: 216px; position: absolute; top: 20%; left: 25%; }
	main.index .cnt_wrap .cnt_col .txt03{ width: 237px; position: absolute; top: 22%; right: 10%; }
	main.index .cnt_wrap .cnt_col .bg_wave{ width: calc(100% + 24px); height: 9px; background: url('../../img/bg-wave_m.webp') 0 0 repeat-x; background-size: auto 9px; position: absolute; bottom: 0; }
	main.index .cnt_wrap .cnt_col:nth-child(2){ }
	main.index .cnt_wrap .cnt_col .title{ max-width: 650px; margin: 8% auto 0 auto; }
	main.index .cnt_wrap .cnt_col .txt{ max-width: 700px; margin: 4% auto 0 auto; text-align: left; }
	main.index .cnt_wrap .cnt_col .txt h3{ width: 100%; padding: 0; display: flex; }
	main.index .cnt_wrap .cnt_col .txt h3 i{ margin-right: 10px; padding: 0; flex-basis: 25px; }
	main.index .cnt_wrap .cnt_col .txt h3 i img{ padding-top: 7px; vertical-align: top; }
	main.index .cnt_wrap .cnt_col .txt h3 span{ color: #f05a49; font-size: 28px; flex-basis: calc(100% - 35px); text-align: left;}
	main.index .cnt_wrap .cnt_col .txt h3 span span{ padding-bottom: 8px; background: auto 3px; }
	main.index .cnt_wrap .cnt_col .txt p{ margin-top: 25px; }
	main.index .cnt_wrap .cnt_col .btn_wrap{ margin-top: 20px; padding-bottom: 150px; }

	.cookie_des .cd_item:nth-child(1){ margin-bottom: 30px; flex-basis: 100%; }
	.cookie_des .cd_item:nth-child(2){ flex-grow: 1; }
	.cookie_des .cd_item:nth-child(3){ flex-grow: 1; }

	.tab_data .clearfix{ display: none; }
	.tab_data li:first-child{ width: 100%; padding: 0; }
	.tab_data li:last-child{ width: 100%; margin-top: 20px; padding: 20px 0 0 0; border: 0; border-top: 2px solid #fac373; }
	.data_perc{ float: left; }
	.data_perc p:nth-child(2){ margin-left: 20px; }
	.star_rank{ margin-top: 2px; }

	.volunteer .nav-item button{ padding: 30px; }
	.volunteer .nav-item button li{ height: 45px; }
	.volunteer .nav-item button li .perc{ width: 48px; margin: 6px auto 0 auto;}
	.volunteer .nav-item button li .perc p{ font-size: 26px; }
	.volunteer .nav-item button li .perc span{ margin: 10px 0 0 3px; font-size: 15px; }
	.volunteer .nav-item button li .star_rank{ margin: 0px auto 0 auto; }
	.volunteer .nav-item button li .star_rank .star{ width: 20px; height: 20px; margin: 0 1px; }
	.volunteer .nav-item button li:first-child{ width: 70px; margin-right: 5px; border-top-right-radius: 0; border-bottom-right-radius: 0; }
	.volunteer .nav-item button li:last-child{ width: calc(100% - 75px); border-top-left-radius: 0; border-bottom-left-radius: 0; }
	.volunteer .nav-item .ico-triangle{ height: 30px; margin: 15px 0 0 0; }

	.volunteer .tab-content h3{ margin: 0 0 10px 0; }
	.volunteer .tab-content .collist:nth-child(1) p{ font-size: 1.25em; }
	.volunteer .tab-content .subcap{ padding-left: 20px; font-size: 1em; line-height: 1.875em; border-left: 10px solid #f05a49; }
	.volunteer .tab-content .param_wrap{ margin-top: 20px; padding: 30px; border: 1px solid #000; border-radius: 10px; }
	.volunteer .tab-content .param_wrap .param{ margin-bottom: 20px; }
	.volunteer .tab-content .param_wrap .param:last-child, .volunteer .tab-content .collist:last-child .param_wrap .param:nth-last-child(-n+2){ margin-bottom: 0px; }
	.volunteer .tab-content .param_wrap .param h3{ margin: 0 0 10px 0; padding: 0 0 0 50px; line-height: 1em; }
	.volunteer .tab-content .param_wrap .param.rep02_00{ display: none; }
	.volunteer .tab-content .param_wrap .param.rep02_01 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_02 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_03 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_04 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_05 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_06 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_07 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_08 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_09 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_10 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_11 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_12 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_13 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_14 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param.rep02_15 h3{ background-size: 30px auto; }
	.volunteer .tab-content .param_wrap .param h3 .star_rank .star{ width: 30px; height: 30px; margin: 0 0 0 15px; }
	.volunteer .tab-content .param_wrap .param p{ padding: 0 0 0 50px; font-size: 1.25em; line-height: 1.5em; }

	.concept_wrap{ flex-wrap: wrap; }
	.concept_wrap h3{ flex-basis: calc(100% - 165px); text-align: left !important; order: 1; }
	.concept_wrap p{ flex-basis: 100%; margin-top: 10px; order: 3; }
	.concept_wrap .star_rank{ margin-top: -3px; order: 2; }
}

@media all and (max-width: 768px) {
	main.bg_test1_intro, main.bg_test2_intro{ background-size: 70% auto, cover; }

	.tab-content{ padding: 30px 20px; background: url('../../img/bg-rep_01_m.webp') center center no-repeat; background-size: cover; background-color: rgba(255, 255, 255, .9);}
}

@media all and (max-width: 767px) {
	#index .menu a{ margin-left: 25px; font-size: 1.25em; }

	.balloon{ margin-top: -10%; left: 5%; }
	.balloon img{ width: 50px; }
	.cloud{ margin-top: 0%; }

	.q_wrap.type_01 .q_opt{ width: calc(100% - 2px); margin-bottom: 10px; display: block; }
	.q_wrap.type_01 .q_opt:last-child{ margin-bottom: 0; }

	main .cnt_wrap h3.rep{ padding: 80px 0 80px 0;}
	main .cnt_wrap h3.rep .cap_rep{ background: url('../../img/bg-cap_rep_l.webp') left -120px center no-repeat, url('../../img/bg-cap_rep_r.webp') right -120px center no-repeat; background-size: auto 25px, auto 25px; }

	.tab-pane .tab_mainpic img{ max-width: 100% !important; }

	.volunteer.dk{ display: none; }
	.volunteer.mb{ display: block; opacity: 0; transition: .5s all; }
	.volunteer.mb.show{ opacity: 1;}
	.volunteer.mb .nav-item{ width: 100%; padding: 0; }
	.volunteer.mb .nav-item button{ width: 260px; margin: 0 14px 0 14px; padding: 20px; border-radius: 20px !important; text-align: center; }
	.volunteer.mb .nav-item button p{ float: none; margin: 10px 0 15px 0; padding: 0; color: #333; font-size: 22px !important;}
	.volunteer.mb .nav-item button ul{ margin: 0; padding: 0; list-style: none; overflow: hidden; }
	.volunteer.mb .nav-item button li{ float: left; height: 45px; background: #fac373; border-radius: 45px; text-align: center; }
	.volunteer.mb .nav-item button li .perc{ width: 54px; margin: 6px auto 0 auto; overflow: hidden;}
	.volunteer.mb .nav-item button li .perc p{ float: left; width: 31px; margin: 0; padding: 0; color: #f05a49; font-size: 26px; font-weight: 700; }
	.volunteer.mb .nav-item button li .perc span{ float: left; width: 20px; margin: 10px 0 0 3px; color: #f05a49; font-size: 15px; }
	.volunteer.mb .nav-item button li .star_rank{ margin: 0px auto 0 auto; text-align: center; }
	.volunteer.mb .nav-item button li .star_rank .star{ width: 20px; height: 20px; margin: 0 1px; background: url('../../img/ico-star.webp') center center no-repeat; background-size: cover; display: inline-block; }
	.volunteer.mb .nav-item button li .star_rank .star.x{ background: url('../../img/ico-starx.webp') center center no-repeat; background-size: cover; }
	.volunteer.mb .nav-item button li:first-child{ width: 100px; margin-right: 5px; border-top-right-radius: 0; border-bottom-right-radius: 0; }
	.volunteer.mb .nav-item button li:last-child{ width: calc(100% - 105px); border-top-left-radius: 0; border-bottom-left-radius: 0; }
	.volunteer.mb .nav-item button .dtl{ margin: 0px 0 -5px 0; padding: 0 0 0 20px; color: #f05a49; font-size: .6em; line-height: 1em; background: url('../../img/ico-dtl.webp') 0 center no-repeat; background-size: 15px auto; display: inline-block; text-align: center; }
	.volunteer.mb .nav-item .ico-triangle{ width: 100%; height: 3.0729vw; margin: 1.6145vw 0 0 0; background: url('../../img/ico-triangle.webp') center 0 no-repeat; background-size: auto 100%; opacity: 0; transition:0.2s all; }
	.volunteer.mb .nav-item .nav-link.active ~ .ico-triangle{ opacity: 1; }
	.volunteer.mb .nav-link, .volunteer .nav-link:hover, .volunteer .nav-link:focus{ margin-bottom: 0px !important; background: #fff !important; border-radius: 1.0416vw !important; }

	.volunteer h3{ font-weight: 700; }
	.volunteer .tab-content .param_wrap .param h3{ background-position: 0 3px !important; background-size: 24px auto !important;}
	.volunteer .tab-content .param_wrap .param h3 .star_rank .star{ width: 26px; height: 26px; margin: 0 0 0 15px; }
	.volunteer .tab-content .param_wrap .param p{ padding: 0 0 0 50px; font-size: 1.25em; line-height: 1.5em; }

	.item_wrap{ margin-top: 50px; padding: 30px; background: #fff; border-radius: 20px; }
	.item_share{ flex-wrap: wrap; }
	.item_share .item{ padding: 30px; }
	.item_share .item:nth-child(1){ margin-bottom: 10px; flex-basis: 100%; flex-wrap: wrap; }
	.item_share .item:nth-child(1) .item_img{ margin-bottom: 20px; flex-basis: 100%; }
	.item_share .item:nth-child(1) .item_img img{ max-width: 180px !important; }
	.item_share .item:nth-child(1) .item_txt{ margin-left: 0px; flex-basis: 100%; }
	.item_share .item:nth-child(2){ margin-left: 0px; flex-basis: 100%; flex-wrap: wrap; }
}

@media all and (max-width: 600px) {
}

@media all and (max-width: 575px) {
	h2{ font-size: 1.875em; }
	h3{ font-size: 1.325em; }
	h4{ font-size: 1.25em; }
	h5{ font-size: 1.125em; }
	h6{ font-size: 1em; }

	.logo{ margin: 10px 0;}
	.logo a{ width: 160px; height: auto;}
	.menu{ width: 39px; height: 39px; }
	.menu img{ width: 100%; }
	.menu_close{ top: 10px; right: 30px; }
	.menu_close img{ width: 38px;}
	.menu_box{ margin: 200px auto; }
	.menu_box li a{ margin: 30px 0; font-size: 1.25em; }
	.menu_bg{ background: #5ac3d7 url('../../img/bg-menu_m.webp') center bottom no-repeat; background-size: 100% auto; }

	.music_wrap{ margin: 10px 15px 0 0; }
	.music_wrap button{ width: 39px; height: 39px;}

	main .cnt_wrap h3{ font-size: 1.375em; }
	main .cnt_wrap h3.rep{ padding: 50px 0; font-size: 1.375em; }
	main .cnt_wrap h3.rep:nth-child(3){ padding-top: 80px; }
	main .cnt_wrap h3.rep .cap_rep{ margin: 0; background: url('../../img/bg-cap_rep_l.webp') left -80px center no-repeat, url('../../img/bg-cap_rep_r.webp') right -80px center no-repeat; background-size: auto 20px, auto 20px; }
	main .cnt_wrap h3 span.subtitle{ font-size: .6em; line-height: 1.5em; }
	main .cnt_wrap .btn_wrap .btn_box{ margin: 0px 0 0 0; }
	main .cnt_wrap .btn_wrap .btn_box i, main .cnt_wrap .btn_wrap .btn_box button{ width: 260px; height: 50px;}
	main .cnt_wrap .btn_wrap .btn_box i{ top: -10px; left: calc(50% - 130px + 10px);}
	main .cnt_wrap .btn_wrap .btn_box button{ left: calc(50% - 130px); font-size: 1.25em;}
	main .cnt_wrap .btn_wrap.intro{ bottom: 70px; }

	/* .progress_wrap{ max-width: 960px; padding: 85px 0 18px 0;}
	.progress_mark{ width: 42px; height: 42px; font-size: .875em; line-height: 40px; top: 68px;}
	.progress_mark span{ font-size: .5em; }
	.progress_bar, .progress_bar:active{ height: 8px; }
	.progress_line{ height: 8px; } */

	main.bg_test_01.bg01{ background: url('../../img/bg-test_01-01_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-01.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg02{ background: url('../../img/bg-test_01-02_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-02.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg03{ background: url('../../img/bg-test_01-03_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-03.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg04{ background: url('../../img/bg-test_01-04_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-01.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg05{ background: url('../../img/bg-test_01-05_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-02.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg06{ background: url('../../img/bg-test_01-06_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-03.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg07{ background: url('../../img/bg-test_01-07_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-01.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg08{ background: url('../../img/bg-test_01-08_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-02.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg09{ background: url('../../img/bg-test_01-09_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-03.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_01.bg10{ background: url('../../img/bg-test_01-10_pic_m.webp') center bottom -10px no-repeat, url('../../img/bg-test_01-01.webp') center top; background-size: 80% auto, auto; }
	main.bg_test_02.bg01{ background: url('../../img/bg-test_02-01.webp') center top; background-size: auto; }
	main.bg_test_02.bg02{ background: url('../../img/bg-test_02-02.webp') center top; background-size: auto; }

	.q_wrap.type_01 li{ margin: 20px 0;}
	.q_wrap.type_01 li i{ width: 30px; height: 30px; margin: 15px auto; font-size: 1em; line-height: 28px; }
	.q_wrap.type_01 li .q_opt_wrap{ float: none; width: calc(100% - 0px);}
	.q_wrap.type_01 .q_opt{ width: calc(100% - 2px); margin-bottom: 10px; }
	.q_wrap.type_01 .q_opt label p{ font-size: .875em; }

	.q_wrap.type_02 li{ margin: 20px 0;}
	.q_wrap.type_02 li i{ width: 30px; height: 30px; margin-top: 10px; font-size: 1em; line-height: 28px; }
	.q_wrap.type_02 li .q_opt_wrap{ width: calc(100% - 50px); padding: 12px 0 0 15px;}
	.q_wrap.type_02 li .q_opt_wrap span{ margin-bottom: 25px; font-size: 1.125em; line-height: 1.125em; }
	.q_wrap.type_02 li .q_opt_wrap .line_wrap{ height: 53px; }
	.q_wrap.type_02 li .q_opt_wrap .line{ width: calc(100% + 34px) !important; margin: 2px 0 0 -30px !important; }
	.q_wrap.type_02 li .q_opt_wrap .line{ width: calc(100% - 6px) !important; height: 5px !important; margin: 2px 0 0 -10px !important; }

  .q_wrap.type_02 .q_opt:nth-child(1){ left: calc(0% - 20px); }
  .q_wrap.type_02 .q_opt:nth-child(2){ left: calc((100% - 20px) / 4 - 17px); }
  .q_wrap.type_02 .q_opt:nth-child(3){ left: calc((100% - 20px) / 4 + (100% - 20px) / 4 - 13px); }
  .q_wrap.type_02 .q_opt:nth-child(4){ left: calc((100% - 20px) / 4 + (100% - 20px) / 4 + (100% - 20px) / 4 - 10px); }
  .q_wrap.type_02 .q_opt:nth-child(5){ left: calc((100% - 20px) / 4 + (100% - 20px) / 4 + (100% - 20px) / 4 + (100% - 20px) / 4 - 6px); }
	.q_wrap.type_02 .q_opt input[type="radio"]:checked + label{ width: 30px !important; height: 30px !important; margin: -5px 0 0 -5px !important;}

  .q_wrap.type_02 .q_opt_name p:nth-child(1){ left: -20px; }
  .q_wrap.type_02 .q_opt_name p:nth-child(2){ left: calc((100% - 20px) / 4 - 17px); }
  .q_wrap.type_02 .q_opt_name p:nth-child(3){ left: calc((100% - 20px) / 4 + (100% - 20px) / 4 - 13px); }
  .q_wrap.type_02 .q_opt_name p:nth-child(4){ left: calc((100% - 20px) / 4 + (100% - 20px) / 4 + (100% - 20px) / 4 - 10px); }
  .q_wrap.type_02 .q_opt_name p:nth-child(5){ left: calc((100% - 20px) / 4 + (100% - 20px) / 4 + (100% - 20px) / 4 + (100% - 20px) / 4 - 6px); }

	.copyright{ font-size: .75em;}

	h3.ico-checked span.t01, h3.ico-checked span.t02, h3.ico-checked span.t03, h3.ico-checked span.t04{ padding: 5px 30px 3px 0; background-size: 28px auto;}

	#header_index header, #header_index header:active{ height: 59px; padding: 0 8px; }
	#header_index .menu a{ width: 39px; position: absolute; top: 10px; right: 30px;}
	#header_index .menu a:nth-child(-n+2){ display: none; }
	#header_index .menu_show{ display: block !important; }
	#header_index .menu_show img{ width: 38px !important; vertical-align: top; }

	main.index .cnt_wrap .cnt_col .txt01{ width: 74px; position: absolute; top: 35%; left: 10%; }
	main.index .cnt_wrap .cnt_col .txt02{ width: 156px; position: absolute; top: 20%; left: 25%; }
	main.index .cnt_wrap .cnt_col .txt03{ width: 177px; position: absolute; top: 22%; right: 10%; }
	main.index .cnt_wrap .cnt_col .txt{ max-width: 700px; margin: 8% auto 0 auto; }
	main.index .cnt_wrap .cnt_col .txt h3{ width: 100%; padding: 0; display: flex; }
	main.index .cnt_wrap .cnt_col .txt h3 i{ margin-right: 10px; padding: 0; flex-basis: 18px; }
	main.index .cnt_wrap .cnt_col .txt h3 i img{ padding-top: 5px; vertical-align: top; }
	main.index .cnt_wrap .cnt_col .txt h3 span{ color: #f05a49; font-size: 22px; flex-basis: calc(100% - 35px); text-align: left;}
	main.index .cnt_wrap .cnt_col .txt h3 span span{ padding-bottom: 8px; background: auto 3px; }
	main.index .cnt_wrap .cnt_col .txt p{ margin-top: 20px; font-size: 1.125em; line-height: 1.5em; }
	main.index .cnt_wrap .cnt_col .btn_wrap{ margin-top: 10px; padding-bottom: 100px; }

	.cookie_des{ padding: 20px; font-size: .813em; }
	.cookie_des .cd_item:nth-child(1){ margin-bottom: 15px; }
	.cookie_des .cd_item:nth-child(2){ margin-bottom: 15px; flex-basis: 100%; }
	.cookie_des .cd_item button{ font-size: .813em; }

	.form_wrap{ margin: 20px 0 0 0; padding: 30px 20px; }

	.nav-link, .nav-link:hover, .nav-link:focus{ font-size: 1.125em;}
	.nav-item .nav-link i{ width: 20px; height: 20px; margin: 2px 10px 0 0; }

/* 	main.bg_rep .nav{ margin-top: -50px; } */

	.nav-link, .nav-link:hover, .nav-link:focus{ padding-top: 10px;}
	.tab-content{ padding: 30px 20px;}
	.tab_data li:first-child{ font-size: 1em; }
	.tab_data li p:nth-child(1){ font-size: 1em; }
	.tab_data li p:nth-child(2){ font-size: 1.875em; }
	.tab_data li p:nth-child(2) span{ font-size: .75em; }
	.tab_data li:last-child .star_rank{ margin: 9px 0 0 0; }
	.tab_data li:last-child .star_rank .star{ width: 20px; height: 20px; margin: 0 0 0 10px;}

	.volunteer.mb .nav-item button{ width: 260px; margin: 0 -35px 0 -35px;}
	.volunteer.mb .nav-item button .dtl{ margin: 20px 0 0 0 !important; font-size: .875em;}
	.volunteer.mb .nav-item button li .star_rank{ margin: 10px auto 0 auto; }

	.volunteer .tab-content .collist:nth-child(1) p{ font-size: 1em; line-height: 1.5em; }
	.volunteer .tab-content .subcap{ padding-left: 15px; line-height: 1.5em; }
	.volunteer .tab-content .param_wrap{ padding: 20px; }
	.volunteer .tab-content .param_wrap .param h3{ padding: 0 0 0 30px; line-height: 1.325em; background-position: 0 5px !important; background-size: 20px auto !important; }
	.volunteer .tab-content .param_wrap .param h3 .star_rank .star{ width: 25px; height: 25px; margin: 0 0 0 10px; }
	.volunteer .tab-content .param_wrap .param p{ padding: 0 0 0 30px; font-size: 1em; line-height: 1.5em; }

	.item_wrap{ margin-top: 50px; padding: 20px; background: #fff; border-radius: 20px; }
	.item_wrap > h3{ margin-bottom: 20px;  }
	.item_share{ flex-wrap: wrap; }
	.item_share .item{ padding: 20px; }
	.item_share .item b{ font-size: 1em !important; }
	.item_share .item:nth-child(1) .item_txt h3{ font-size: 1.375em; }
	.item_share .item:nth-child(1) .item_txt p{ font-size: 1em; }

	.concept_wrap{ padding: 20px; }
	.concept_wrap h3{ flex-basis: calc(100% - 120px); padding: 0 0 0 30px !important; font-size: 1.375em !important; background-size: 20px auto !important; background-position: 0 3px !important; }
	.concept_wrap p{ flex-basis: 100%; margin-top: 10px; font-size: 1em; line-height: 1.5em; }
	.concept_wrap .star_rank{ flex-basis: 90px; margin-top: 3px !important; }
	.concept_wrap .star_rank .star{ width: 20px; height: 20px; }

	.info{ padding: 30px 0; }
	.info li{ margin-bottom: 20px; }
	.info li i{ width: 15px; height: 15px; margin: 5px 10px 0 0; }
	.info li p{ width: calc(100% - 25px); font-size: 1em; line-height: 1.5em; }

	main .cnt_wrap h3.rep_q{ padding: 100px 0 30px 0; font-size: 1.375em;}
	main .cnt_wrap h3.rep_q span{ margin-top: 5px; }
	main.bg_rep_q .btn_wrap{ padding: 20px 0 100px 0; }
	.btn{ font-size: 1.25em; }

	.item_wrap.dl{ background: url('../../img/bg-rep_01_m.webp') center center no-repeat; background-size: cover; background-color: rgba(255, 255, 255, .9);}
	.item_wrap.dl p{ font-size: 1.125em; }
	.item_wrap.dl button { margin: 40px 0 0 0; padding: 15px 15px 17px 15px; font-size: 20px; }
	.item_wrap.dl button span{ padding: 0 0 0 30px; background:#5ac3d7 url('../../img/ico-dl.webp') 0 5px no-repeat; background-size: 20px auto; }

	.login_box h2{ margin: 40px 0 20px 0; padding-bottom: 20px; font-size: 1.5em; }
	.form_login p{ font-size: 1.125em; line-height: 1.25em;}
}

@media all and (max-width: 480px) {
	main.bg_test1_intro, main.bg_test2_intro{ background-size: 90% auto, cover; }
	main .cnt_wrap h3.rep .cap_rep{ background: url('../../img/bg-cap_rep_l.webp') left -80px center no-repeat, url('../../img/bg-cap_rep_r.webp') right -80px center no-repeat; background-size: auto 15px, auto 15px; }

	/* main.index .cnt_wrap .cnt_col .model{ max-width: 100%; margin: 0 auto; padding-top: 38%; }
	main.index .cnt_wrap .cnt_col .txt01{ width: 54px; position: absolute; top: 35%; left: 5%; }
	main.index .cnt_wrap .cnt_col .txt02{ width: 116px; position: absolute; top: 18%; left: 20%; }
	main.index .cnt_wrap .cnt_col .txt03{ width: 137px; position: absolute; top: 20%; right: 5%; }
	 */


	main.index .cnt_wrap .cnt_col .txt01{ width: 54px; margin-top: 20px; position: absolute; top: 35%; left: 5%; }
	main.index .cnt_wrap .cnt_col .txt02{ width: 116px; margin-top: 20px; position: absolute; top: 20%; left: 25%; }
	main.index .cnt_wrap .cnt_col .txt03{ width: 137px; margin-top: 20px; position: absolute; top: 22%; right: 5%; }
	main.index .cnt_wrap .cnt_col .title{ margin: 12% auto 0 auto; }


	.balloon{ margin-top: -10%; left: 5%; }
	.balloon img{ width: 40px; }
	.cloud{ margin-top: 20%; }

	.data_perc p:nth-child(2){ margin-left: 10px; }

	.volunteer.mb .nav-item button li:first-child{ width: 80px; margin-right: 5px; border-top-right-radius: 0; border-bottom-right-radius: 0; }
	.volunteer.mb .nav-item button li:last-child{ width: calc(100% - 85px); border-top-left-radius: 0; border-bottom-left-radius: 0; }
	.volunteer.mb .nav-item button{ width: 220px; margin: 0 -39px 0 -39px; }
	.volunteer.mb .nav-item button .dtl{ margin: 20px 0 -5px 0 !important;}

	.volunteer .tab-content{ padding: 20px; }
}

@media all and (max-width: 414px) {
	.volunteer.mb .nav-item button{ width: 220px; margin: 0 -54px 0 -54px; }
	.volunteer.mb .nav-item button .dtl{ margin: 20px 0 -5px 0 !important;}
}

@media all and (max-width: 375px) {
	main.index .cnt_wrap .cnt_col .txt01{ width: 44px; position: absolute; top: 35%; left: 2%; }
	main.index .cnt_wrap .cnt_col .txt02{ width: 96px; position: absolute; top: 20%; left: 20%; }
	main.index .cnt_wrap .cnt_col .txt03{ width: 117px; position: absolute; top: 23%; right: 2%; }

	.balloon{ margin-top: -0%; left: 5%; }
	.balloon img{ width: 40px; }
	.cloud{ margin-top: 20%; }

	.volunteer.mb .nav-item button{ width: 220px; margin: 0 -65px 0 -65px; }
	.volunteer.mb .nav-item button .dtl{ margin: 20px 0 -5px 0 !important;}
}

@media all and (max-width: 374px) {
	.balloon{ margin-top: 5%; left: 5%; }
	.balloon img{ width: 40px; }
	.cloud{ margin-top: 20%; }

	main .cnt_wrap h3.rep .cap_rep{ background: url('../../img/bg-cap_rep_l.webp') left -30px center no-repeat, url('../../img/bg-cap_rep_r.webp') right -30px center no-repeat; background-size: auto 7px, auto 7px; }

	.tab_data .clearfix{ display: block; }
	.data_perc{ }
	.data_perc p:nth-child(2){ margin-left: 10px; }
	.star_rank{ float: none; width: 100%; margin: 0; }
	.star_rank .star{ margin: 0 10px 0 0 !important; }

	.q_wrap.type_02 .q_opt_name p{ font-size: .813em;}

	.volunteer.mb .nav-item button{ width: 200px; margin: 0 -68px 0 -68px; }
	.volunteer.mb .nav-item button .dtl{ margin: 20px 0 -5px 0 !important;}
	.volunteer.mb .nav-item button li{ height: 40px; }
	.volunteer.mb .nav-item button li .perc{ width: 40px; margin: 7px auto 0 auto;}
	.volunteer.mb .nav-item button li .perc p{ width: 23px; font-size: 20px; }
	.volunteer.mb .nav-item button li .perc span{ width: 13px; margin: 7px 0 0 3px; font-size: 12px; }
	.volunteer.mb .nav-item button li .star_rank{ margin: 7px auto 0 auto; }
	.volunteer.mb .nav-item button li .star_rank .star{ width: 15px; height: 15px; margin: 0 2px !important; }
	.volunteer.mb .nav-item button li:first-child{ width: 70px; margin-right: 5px; border-top-right-radius: 0; border-bottom-right-radius: 0; }
	.volunteer.mb .nav-item button li:last-child{ width: calc(100% - 75px); border-top-left-radius: 0; border-bottom-left-radius: 0; }

	.volunteer .tab-content .param_wrap .param h3 .star_rank{ width: auto; }
	.volunteer .tab-content .param_wrap .param h3 .star_rank .star{ width: 20px; height: 20px; margin: 4px 0 0 5px !important; }

	.concept_wrap h3{ flex-basis: calc(100% - 66px); margin-right: 0; }
	.concept_wrap .star_rank{ flex-basis: 66px;}
	.concept_wrap .star_rank .star{ margin: 0 0 0 2px !important; }
}

@media all and (max-width: 320px) {
}