@charset "UTF-8";

@media only screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}

@media print, screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
input,
select,
textarea {
  border: solid 1px #ccc;
}

figure {
  padding: 0;
  margin: 0;
}
figure img {
  width: 100%;
}
textarea {
  width: 100%;
  height: 100px;
  margin: 5px;
}
.notes {
  display: block;
  margin-top: 2em;
  line-height: 1.4;
  font-size: 1.5rem;
}

/*====================================
�w�b�_�[�t�b�^�[
====================================*/

.head01_bg01{
	width: 100%;
	/*background-image: url(../xxxx-p/xxxxxx_bg.jpg);*/
	margin: 0 auto;
	overflow: hidden;
	/* background-color: #005B9C; */
  background-color: #fff;
}
/*.head01_bg02{
	width: 100%;
	background-image: url(../xxxx-p/xxxxxx_bg02.jpg);
	margin: 0 auto;
	overflow: hidden;
	background-repeat:no-repeat;
	background-position: top center;
}*/
.head01_tit {
	font-size:34px;
	font-size:3.4rem;
	text-align: center;
	color: #c99f45;
	font-weight: bold;
}
.head01_tit img {
vertical-align: middle;
padding: 5px 12px 5px 0;
width: 200px;
}
.head01_tit span {
display: inline-block;
vertical-align: middle;
	padding: 10px 0 8px;
}



.head02_bg01{
	width: 100%;
	/*background-image: url(../xxxx-p/xxxxxx_bg.jpg);*/
	margin: 0 auto;
	overflow: hidden;
	/* background-color: #0084DB; */
  background-color: #343330;
}
.head02_tit {
	font-size:24px;
	font-size:2.4rem;
	text-align: center;
	color: #FFF;
	font-weight: bold;
	padding: 8px 0;
}
@media only screen and (max-width: 820px) {
.head02_tit {
	font-size:20px;
	font-size:2.0rem;
	letter-spacing: -0.03em;
	}
}


.foot01_bg{
	width:100%;
	margin: 0 auto;
	/* background-color: #005B9C; */
  background-color: #529535;
	padding: 35px 0 30px;
}
@media only screen and (max-width: 820px) {
.foot01_bg{
	padding: 35px 0 80px;
}
}

.foot_nav_ul {
	font-size:16px;
	font-size:1.6rem;
text-align: center;
}

.foot_nav_ul a {
color: #FFF;
text-decoration: none;
}
.foot_nav_ul a:hover {
text-decoration: underline;
}

.foot_nav_ul li {
display: inline-block;
padding: 0 1.2em;
}

.foot_copy {
	font-size:14px;
	font-size:1.4rem;
	padding-top: 85px;
	text-align: center;
	color: #FFF;
}
@media only screen and (max-width: 820px) {
.foot_copy {
	padding-top: 145px;
}
}



.pointer {
cursor: pointer;
}


/*====================================
�T�C�g��������
====================================*/
.top_c01_bg01{
	width: 100%;
	margin: 0 auto;
	overflow: hidden;
  /* background-color: #E3F7C4; */
  background: url(../images/itop-body-bg.jpg) repeat top left;
}
.top_c01_bg02{
	width: 100%;
	/*background-image: url(../xxxx-p/xxxxxx_bg02.jpg);*/
	margin: 0 auto;
	overflow: hidden;
	background-repeat:no-repeat;
	background-position: top center;
	padding: 35px 0 160px;	
}

@media only screen and (max-width: 820px) {
.top_c01_bg02{
	padding: 35px 0 620px;	
}
}



.top_c01a_box {
/*width: 100%;*/
background-color: #FFF;
padding: 10px 25px 15px;
border-radius: 8px;
}
@media only screen and (max-width: 820px) {

}

.top_c01a_tx01 {
	font-size:16px;
	font-size:1.6rem;
	font-weight: bold;
}
.top_c01a_tx01 .q_icon {
background-color: #FF8000;
border-radius: 4px;
padding: 0.2em;
color: #FFF;
margin-right: 0.4em;
}
@media only screen and (max-width: 820px) {
.top_c01a_tx01 {
	font-size:18px;
	font-size:1.8rem;
	padding-top: 6px;
}
}



.top_c01b_box {
/*width: 100%;*/
background-color: #FFF;
margin-top: 15px;
padding: 35px 25px 65px;
border-radius: 8px;
}
@media only screen and (max-width: 820px) {

}

.thanks_c01b_box {
/*width: 100%;*/
background-color: #FFF;
margin-top: 15px;
padding: 35px 25px 35px;
border-radius: 8px;
}



/*====================================
�t�H�[��
====================================*/

/*�y�[�W���[�i���Ɓ��j*/
#space_count {
  background: #fff;
  border-radius: 5px 5px 0 0;
  height: 30px;
  left: 0;
  margin: auto auto auto 0;
  overflow: hidden;
  padding: 0;
  position: absolute;
  top: -10px;/*
  width: 70px;*/
  z-index: 2;
}

#space_count ul {
 /* width: 210px;*/
}

#space_count li {
  color: #111;
  float: left;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.25;
  padding: 4px 1.2em 5px;
  text-align: center;
  /*white-space: nowrap;*/
  /*width: 70px;*/
}

#space_count .space_count_inner {
  color: #111;
  font-weight: 700;
}

#space_count .space_count_inner .tx {
  color: #FF8000;
  font-size: 20px;
  font-size: 2.0rem;
}
@media only screen and (max-width: 820px) {
#space_count {
  height: auto;
  }
}
/* --------------------
���╶
-------------------- */
/*.title {
  background: #fff;
  border-radius: 0 5px 5px 5px;
  font-size: 1.6rem;
  margin: 0;
  overflow: hidden;
  padding: 0 8px;
  position: relative;
  z-index: 1;
}

.title ul li {
  float: left;
  font-weight: bold;
  height: 100%;
  overflow: hidden;
}

.title ul li .icon_q {
  display: inline-block;
  line-height: 1.5;
  text-align: left;
  padding: 13px 15px 13px 40px;
  position: relative;
}

.title ul li .icon_q:before {
  background: url(../img/icon_q.png) top center/contain no-repeat;
  content: '';
  height: 32px;
  overflow: hidden;
  vertical-align: text-bottom;
  width: 24px;
  margin: 0 5px 0 3px;
  position: absolute;
  left: 0;
}

#spece_contents {
  background: #fff;
  border-radius: 5px;
  margin: 10px 0 0 0;
  padding: 0 5px;
  height: 320px;
}
*/

/* --------------------
�`�F�b�N�{�b�N�X
-------------------- */

.top_c01b_box .check_box {
  	font-size:20px;
	font-size:2.0rem;
}
.top_c01b_box .check_box label {
  display: block;
  font-weight: bold;
  /* margin: 30px 32px; */
}
.top_c01b_box .check_box label span{
  /* padding: 6px 0; */
}

.Radio-Input {
  appearance: none;
  position: absolute;
}
@media only screen and (max-width: 820px) {
.top_c01b_box .check_box label span{
  /* padding: 10px 0; */
}
}



/* Hide Default Checkbox */
/* form input[type="checkbox"] {
  opacity:0;
  -webkit-appearance: none;
  appearance: none;
  position: absolute;
} */

/* Create a Box */
/* input[type="checkbox"] + span::before {
  display: inline-block;
  content: '';
  width: 1.4rem;
  height: 1.4rem;
  border: 2px solid #ccc;
  border-radius: 5px;
  margin-right: .8rem;
} */

/* Checked Style */
/* input[type="checkbox"]:checked + span::before {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpolyline fill='none' stroke='%230bd' stroke-width='3' points='2,7.3 7.3,12.7 18,2 '/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 0 2px;
} */

/* Focused Style */
/* input[type="checkbox"]:focus + span::before {
  border-color: #0bd;
} */



/* --------------------
���փ{�^��
-------------------- */

form button {
  /*background: -moz-linear-gradient(top, #f39f01, #e85000);
  background: -webkit-linear-gradient(top, #f39f01, #e85000);
  background: linear-gradient(to bottom, #f39f01, #e85000);*/
  background-color: #FF3900;
  border: none;
 /* border-bottom: solid 4px #D7000A;*/
  border-radius: 6px;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  padding: 0.8em 4.6em;
  /*position: relative;*/
  text-align: center;
  transition: 0.3s;
  /*width: 100%;*/
  /*width: 165px;
  height: 50px;*/
  margin: 120px auto 0;
  /*position: absolute;
  bottom: 25px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);*/
  letter-spacing: 0.4em;
}

/*button:focus {
  outline-width: 0;
}

p.button {
  margin: 16px auto 0;
  width: 165px;
}*/


form button:focus,
form button:active,
form button:hover {
  /*background: linear-gradient(#fed6e3 0%, #ffaaaa 100%);*/
  	filter:alpha(opacity=80);
    -moz-opacity: 0.8;
    opacity: 0.8;
  color: #fff;
  transition: 0s;
}

@media only screen and (max-width: 820px) {
form button {
  padding: 1.2em 0em;
  width: 100%;
  border-radius: 8px;
  font-size: 18px;
  font-size: 1.8rem;
}
}



.thanks_tx01 {
	font-size:20px;
	font-size:2.0rem;
	text-align: center;
	font-weight: bold;
	border-bottom: 1px #DDD solid;
	padding-bottom: 12px;
	margin-bottom: 15px;
}
.thanks_tx02 {
	font-size:18px;
	font-size:1.8rem;
	line-height: 2.0;
	text-align: center;
	font-weight: bold;
	color: #EF0000;
}
.thanks_tx02 span {
background: linear-gradient(transparent 70%, yellow 70%);
}

.thanks_tx03 {
	font-size:42px;
	font-size:4.2rem;
	text-align: center;
	font-weight: bold;
	margin-top: 15px;
	}

.thanks_tx04 {
	font-size:20px;
	font-size:2.0rem;
	text-align: center;
	font-weight: bold;
	margin: 5px 0;
	}
	
.thanks_tx05 {
	font-size:42px;
	font-size:4.2rem;
	text-align: center;
	font-weight: bold;
	}
	
.thanks_tx06 {
	font-size:18px;
	font-size:1.8rem;
	text-align: center;
	font-weight: bold;
	margin-top: 15px;
	}

li {
  display: none;
}

li.active {
  display: block;
}

dt.item_name {
  font-size: 2rem;
  font-weight: bold;
}

dd.item_input {
  display: flex;
}

.item_input_answer {
  display: flex;
  width: 70%;
  font-size: 2rem;
  margin: 10px;
}

input#form_age {
  width: 50%;
  font-size: 2rem;
  padding: 2px;
  margin-right: 15px;
}

div#form_con3 {
  line-height: 2;
  font-size: 2rem;
}

input#form_area {
  width: 50%;
  font-size: 2rem;
  padding: 2px;
  margin-right: 15px;
}

div#form_con4 {
  line-height: 2;
  font-size: 2rem;
}

select#form__prefectures-select {
  line-height: 2;
  padding: 10px;
  width: 100%;
  font-size: 2rem;
  margin: 10px;
}

select#form__city-select {
  line-height: 2;
  padding: 10px;
  width: 100%;
  font-size: 2rem;
  margin: 10px;
}

input#address {
  width: 100%;
  font-size: 2rem;
  line-height: 2;
  margin: 5px;
}

input#name {
  width: 100%;
  font-size: 2rem;
  line-height: 2;
  margin: 5px;
}

input#form__item_email {
  width: 100%;
  font-size: 2rem;
  line-height: 2;
  margin: 5px;
}

input#phone1, input#phone2, input#phone3 {
  font-size: 2rem;
  margin-left: 5px;
  line-height: 2;
  width: 27%;
}

span.haihun {
  font-size: 2rem;
  line-height: 2;
  margin: 0 15px;
}

span.ninni {
  font-size: 1.5rem;
  padding-left: 5px;
}

#back_btn_2, #back_btn_3, #back_btn_4, #back_btn_5, #back_btn_6 {
  width: 100px;
  padding: 8px 0;
  cursor: pointer;
}
@media only screen and (max-width: 820px) {
#back_btn_2, #back_btn_3, #back_btn_4, #back_btn_5, #back_btn_6 {
  font-size: 1.6rem;
  width: 100px;
  margin-top: 4px;
  padding: 16px 0.3em 20px;
}
}

/* 2025.04.25 */
.mv {
  position: relative;
}
.mv .button__modal {
  position: absolute;
  width: 33.33%;
  left: 8.66%;
  top: 43%;
}
.mv .button__modal img {
  width: 100%;
}
@media only screen and (max-width: 820px) {
  .mv .button__modal {
    position: absolute;
    width: 600px;
    top: unset;
    bottom: 7.6%;
    left: 50%;
    transform: translateX(-50%);
  }
}
.report {
  width: 70%;
  margin-inline: auto;
}
.list {
  width: 80%;
  margin-inline: auto;
}
.list .list__inner:not(:last-of-type) {
  margin-bottom: 30px;;
}
.half {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
label {
  width: 100%;
  position: relative;
  display: block;
}
label.agree {
  margin: 30px auto;
}
label.checkbox {
  height: 70px;
  line-height: 70px;
  border-radius: 35px;
  border: solid 3px #000;
  text-align: center;
  font-weight: 500;
  color: #000;
}
input[type=checkbox] ~ span {
  position: relative;
  padding-left: 30px;
}
input[type=checkbox] ~ span::before {
  position: absolute;
  content: "";
  width: 20px;
  height: 20px;
  border: solid 1px #000;
  background: #fff;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
input[type=checkbox]:checked ~ span::after {
  position: absolute;
  content: "";
  width: 15px;
  height: 10px;
  border-left: solid 3px #000;
  border-bottom: solid 3px #000;
  rotate: -45deg;
  left: 2px;
  top: 8px;
}
input[type=checkbox] {
  display: none;
}
input[type=checkbox]:checked + label {
  background: #000;
  color: #fff;
}
.privacy {
  height: 300px;
  overflow: auto;
  padding: 10px;
  border: solid 1px #ccc;
}
.privacy h2 {
  font-weight: bold;
  font-size: 120%;
}
.privacy h3 {
  font-weight: bold;
  margin-top: 1em;
}
.privacy p {
  margin-top: 1em;
  font-size: 80%;
  line-height: 1.4;
}
.privacy ul {
  margin-top: 1em;
}
.privacy ul li {
  display: block;
  font-size: 80%;
  line-height: 1.4;
  padding-left: 1em;
  text-indent: -1em;
}
.privacy ul li:not(:last-child) {
  margin-bottom: .5em;
}
.privacy ul li::before {
  content: "・";
}
.privacy ol {
  counter-reset: privacy;
  margin-top: 1em;
}
.privacy ol li {
  display: block;
  font-size: 80%;
  line-height: 1.4;
  padding-left: 2.5em;
  text-indent: -2.5em;
  counter-increment: privacy;
}
.privacy ol li::before {
  content: "（"counter(privacy)"）";
}
.privacy ol li:not(:last-child) {
  margin-bottom: .5em;
}
#modal {
	display: none;
}
.modaal-container {
	max-width: 800px;
}
.modaal-content-container {
  padding: 30px;
	height: 80vh;
	overflow-y: scroll;
}
@media only screen and (max-width: 820px) {
  .modaal-content-container {
    height: unset;
  }
}
.modaal-content-container h2 {
  font-size: 190%;
  color: #c99f45;
  font-weight: bold;
  text-align: center;
  margin-bottom: 1em;
}
.modaal-content-container h2:last-of-type {
  margin-top: 1em;
}
.modaal-content-container .box {
  background: rgba(82, 149, 53, .1);
  padding: 2em;
  margin-top: 2em;
}
.modaal-content-container .box h2 {
  color: #006837;
  margin-top: 0;
}
.modaal-content-container h3 {
  font-size: 120%;
  text-align: center;
  font-weight: bold;
  margin: 2em 0 1em;
}
.modaal-content-container .medal {
  width: 70%;
  margin: 0 auto 30px;
}