@charset "UTF-8";
/*▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼
▼ BASE
▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼△▼*/
/*====================================================================================
エリア
====================================================================================*/
html, body {
  overflow-x: hidden;
  position: relative;
  background-color: #5c0f12;
}

/*====================================================================================
テキスト
====================================================================================*/
/*------------------------------------------
基本
------------------------------------------*/
h1, h2, h3, h4, h5, h6, p, a, blockquote, pre, abbr, address, cite, code, dt, dd, li, fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure {
  color: #000;
  font-family: "游ゴシック体", "YuGothic", "ヒラギノ角ゴシック", "Hiragino Sans", "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-size: 16px;
  line-height: 1.5em;
  font-weight: 300;
  letter-spacing: 0;
  list-style-type: none;
  word-wrap: break-word;
}


.questionnaire__container {
	width: 100%;
	margin: 0 auto;
	padding: 0;
  max-width: 640px;
  background-color: #ffffff;
}
.questionnaire__jacket img{
	width: 100%;
	margin: 0 auto;
}
.questionnaire__content {
	width: 100%;
	margin: auto;
	padding: 0 8px 16px;
}
.header__headline {
	font-size: 5.5vw;
	margin: 5% 0 2%;
}
.header__thanks {
	padding: 8vw 0;
}
.header__abstract{
  padding: 0 0 16px;
}
.header__notice{
  padding: 0 0 16px;
}
.header__notice li{
  list-style-type: none;
  padding: 0 1em 0 2em;
  text-indent: -1em;
  font-size: 14px;
}
.header__description {
	background: #fff;
	border-radius: 5px;
	padding: 3% 0;
}
.header__description table{
  margin: 0 auto;
  border-collapse: separate;
  border-spacing: 3px;
}
.header__description table caption,.header__description table td,.header__description table td a{
  font-weight: bold;
}
.header__description table caption{
  font-size: 18px;
}
.header__description table td{
  padding:5px;
}
.header__description table td:nth-child(odd){
  background-color: #f0f0f0;
}
.header__description table td:nth-child(even){
  background-color: #fafafa;
}
.description__text {
	margin-bottom: 5%;
}
.description__text--gift {
	color: #FF0000;
}
.content__title {
	color: #1F59BA;
	font-weight: bold;
	font-size: 18px;
	margin: 0 0 8px;
	text-indent: -3rem;
	margin-left: 4rem;
}
.content__title02 {
	text-indent: -4.5rem;
	margin-left: 5rem;
}
.content__title03 {
	text-indent: 0;
	margin-left: 0;
  border-bottom: 1px solid #1F59BA;
}
.questionnaire__caution {
	color: #ff0000;
	margin: 1.5% 0;
}
.questionnaire__caution:before {
	content: "※";
}
.questionnaire__caution03 {
	margin-left: 4%;
}
.questionnaire__form {
    flex-direction: column;
    display: inlin e-flex;
}
.questionnaire__form input:not([type="submit"]) {
	margin-left: 3%;
	width: 2rem;
	height: 1.8rem;
	position: relative;
	top: 4.5px;
}
.questionnaire__form textarea,.mail_box input {
	padding: 1.5%;
}
.content {
	margin-bottom: 3%;
}
.text_box {
	width: 93%;
	margin-left: 7%;
}
.text_box textarea,.text_box02 textarea,.mail_box input {
	width: 100%;
	border: 1px solid #3c3c3c;
	font-size: 18px;
}
.content label {
/*	font-size: 4.5vw;*/
}
.content--btn {
	text-align: center;
	color: #fff;
	font-weight: bold;
	background: #1F59BA;
	border: 1px solid #0C419A;
	box-shadow: 2px 2px 2px rgba(55,55,55,0.4);
	margin: 8% 0;
}
.content--btn input {
	width: 100%;
	padding: 5% 0;
  font-size: 18px;
}
.questionnaire__form input[type="email"],.questionnaire__form input[type="text"] {
	width: 100%;
	margin: 0;
	height:30px;
}
.content--mailaddress input {
	position: relative;
	top: 0!important;
}




/*ラジオボタン・チェックボックス*/
input[type="checkbox"],
input[type="radio"] {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.form__title {
  font-size: 20px;
  color: #f00;
}
.form__content {
  position: relative;
  margin: 0 auto 16px;
  width: auto;
  font-size: 16px;
}
.content_section_title {
  margin: 0 auto 45px;
  padding: 0;
  max-width: 900px;
  font-size: 24px;
  font-weight: normal;
  text-align: center;
}

.label_list {
  margin: auto;
  max-width: 600px;
  line-height: 1.3;
}
.label_list::after {
  display: block;
  content: '';
  clear: both;
}
.label_list_item {
  margin: 0 auto 16px;
}
.label_list_item label {
	position: relative;
	left: 13px;
	display: block;
	word-break: break-all;
}
.label_list_item label input[type="checkbox"] + span,
.label_list_item label input[type="radio"] + span {
  position: relative;
  padding: 0 30px 0;
}



/* CHECKBOX */

.content--checkbox label span {
  display: inline-block;
}
.content--checkbox label input[type="checkbox"] {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
.content--checkbox label input[type="checkbox"] + span::before, .content--checkbox label input[type="checkbox"] + span::after {
  position: absolute;
  top: 2px;
  left: 0;
  display: inline-block;
  content: '';
  box-sizing: border-box;
}
.content--checkbox label input[type="checkbox"] + span::before {
  z-index: 0;
  background-color: transparent;
  width: 22px;
  height: 22px;
  border: 2px #616161 solid;
  border-radius: 5px;
}
.content--checkbox label input[type="checkbox"] + span::after {
  z-index: 1;
  margin: 5px 8px;
  width: 6px;
  height: 9px;
}
.content--checkbox label input[type="checkbox"]:checked + span::before {
  background-color: #616161;
}
.content--checkbox label input[type="checkbox"]:checked + span::after {
  border: 2px solid #fff;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}



/* DEMO 02 RADIO BUTTON */
.content--radio{
  margin: 0 auto 32px;
}
.content--radio .label_list:nth-of-type(1) label input[type="radio"] + span::before {
  border-color: #333;
}
.content--radio label span {
  display: inline-block;
}
.content--radio label input[type="radio"] {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
.content--radio label input[type="radio"] + span::before {
  position: absolute;
  display: inline-block;
  content: '';
  box-sizing: border-box;
  border-radius: 22px;
}
.content--radio label input[type="radio"] + span::before {
  z-index: 0;
  top: 2px;
  left: 0;
  background-color: transparent;
  width: 22px;
  height: 22px;
  border: 2px #78909c solid;
}
.content--radio label input[type="radio"]:checked + span::before {
  border-width: 6px;
}



/*thanks.html*/
.thanks {
	padding: 10%;
}
.thanks__logo {
	text-align: center;
}
.thanks__logo img {
	width: 35%;
}
.thanks__text {
	font-weight: bold;
	margin: 15% 0;
	font-size: 5vw;
	text-align: center;
}

/* error message */
.err_content {
	position: relative;
	margin: 15px auto;
	width: auto;
	font-size: 16px;
    	border: 1px solid #f00;
    	padding: 10px 5px;
}

.err_txt {
	line-height: 200%;
	color: #f00;
	font-weight: bold;
}

/* hidde */
.hide {
  display: none;
  opacity: 0;
  transform: translateY(30px);
  transition: 1s ease-out;
}
