@charset "utf-8";
/* CSS Document */
html {
	overflow-x : hidden;
	-webkit-overflow-scrolling: touch;
	-webkit-user-select:none;
	-moz-user-select:none;
	-ms-user-select:none;
	-o-user-select:none;
	user-select:none; 
	-webkit-user-drag:none; 
	-webkit-touch-callout:none;
	-webkit-user-select:none;
}
body {
    overflow-x : hidden;
    -webkit-overflow-scrolling: touch;
	font: 16px/1.6 "Hiragino Kaku Gothic Pro",Osaka,"メイリオ","ＭＳ Ｐゴシック","MS PGothic",Verdana,Arial,sans-serif;
	margin: 0;
	color: #313131;
	margin-bottom: 100px;
}
p {
    margin-block-start: 0 !important;
	margin-block-end: 0 !important;
}

/* ヘッダ ++++++++ */
#header {
    text-align: center;
}
.head_explain {
    font-size: 16px !important;
    color: red;
    margin-bottom: 20px;
}
.head_explain .tel {
    color:red;
    font-size: 10px;
    text-align: center;
}
.line_explain {
    color:red;
	width: 70%;
	max-width: 600px;
    font-size: 16px;
	margin: 20px auto 0 auto;
}

/* 性別 ++++++++ */
.sex {
    margin: 20px 0;
}
.sex_caption {
   font-size: 16px;
    color: black;
	line-height: 2;
}
.sex input {
    display: none;
}
.sex label{
    display: block;
    float: left;
    cursor: pointer;
    margin: 0;
    padding:8px;
    background: #ccc;
    color: #869198;
    font-size: 16px;
    text-align: center;
    line-height: 1;
    transition: .2s;
}
.sex label:first-of-type{
    border-radius: 3px 0 0 3px;
}
.sex label:last-of-type{
    border-radius: 0 3px 3px 0;
}
.sex input[type="radio"]:checked + .switch-on {
    /*background-color: #e67168;*/
    background-color: yellow;
    color: #000;
}
.sex input[type="radio"]:checked + .switch-off {
    background-color: yellow;
    color: #000;
}
/* 希望会場 +++++++++ */
.place {
	line-height: 2;
}
.place input {
    display: none;
}
.place label{
    display: block;
    float: left;
    cursor: pointer;
    margin: 0;
    padding: 8px;
    background: #ccc;
    color: #869198;
    font-size: 16px;
    text-align: center;
    line-height: 1;
    transition: .2s;
}
.place label:first-of-type{
    border-radius: 3px 0 0 3px;
}
.place label:last-of-type{
    border-radius: 0 3px 3px 0;
}
.place input[type="radio"]:checked + .switch2-on {
    background-color: yellow;
    color: #000;
}
.place input[type="radio"]:checked + .switch2-off {
    background-color: yellow;
    color: #000;
}

.spouse {
    margin: 20px 0;
}
.spouse_caption {
   font-size: 16px;
    color: black;
    line-height: 2;
}
.spouse input {
    display: none;
}
.spouse label{
    display: block;
    float: left;
    cursor: pointer;
    margin: 0;
    padding:8px;
    background: #ccc;
    color: #869198;
    font-size: 16px;
    text-align: center;
    line-height: 1;
    transition: .2s;
}
.spouse label:first-of-type{
    border-radius: 3px 0 0 3px;
}
.spouse label:last-of-type{
    border-radius: 0 3px 3px 0;
}
.spouse input[type="radio"]:checked + .switch3-on {
    /*background-color: #e67168;*/
    background-color: yellow;
    color: #000;
}
.spouse input[type="radio"]:checked + .switch3-off {
    background-color: yellow;
    color: #000;
}

/* 送信ボタン ++++++++ */
#submit_button {
    cursor: pointer;
    cursor: hand;
    margin:auto;
    margin-top: 60px;
    margin-bottom: 0px;
    text-align: center;
    border-radius: 4px;
	width: 300px;

}
#submit_button img:active {
		position:relative;
		top:10px;
}

#submit_label {
    line-height:60px;
    font-size:18px;
    vertical-align:center;
    display:table-cell;
    margin-left:20px;
    color:#000;
    float:left;
}

 /* floatを解除 */
.cb{
  clear: both;
}

.event_prevent {
  pointer-events: none;
  background-color:lightgrey !important;
}

/* フォーム大枠 ++++++ */
.content {
    background-color: white;
    margin: auto;
    padding:2px;
    width: 90%;
}

/*　画面サイズ 999pxまで適用　*/

	.line_explain_pc {
		display:none;
	}
	#header img {
		width: 90%;
	}
	.pc_item_title {
		display:none;
	}

	/* プレイスホルダ ++++++++ */
	input::-webkit-input-placeholder {
    	font-size: 14px;
		color:dimgray;
	}
	input:-moz-placeholder {
    	font-size: 14px;
		color:dimgray;
	}
	input::-moz-placeholder {
    	font-size: 14px;
		color:dimgray;
	}
	input:-ms-input-placeholder {
    	font-size: 14px;
		color:dimgray;
	}

	/* テキストボックス ++++++++ */
	.cp_iptxt {
	    position: relative;
	}
	.cp_iptxt input[type=text] {
	    font: 16px/24px sans-serif;
	    box-sizing: border-box;
	    width: 100%;
	/*  height: 46px;*/
	    margin: 2px 0;
	    padding: 0.3em;
	    transition: 0.3s;
	    border: 1px solid #1b2538;
	    border-radius: 4px;
	    outline: none;
	}
	.cp_iptxt input[type=text]:focus {
    	border-color: #da3c41;
	}
    .cp_iptxt input[type=tel] {
        font: 16px/24px sans-serif;
        box-sizing: border-box;
        width: 100%;
    /*  height: 46px;*/
        margin: 2px 0;
        padding: 0.3em;
        transition: 0.3s;
        border: 1px solid #1b2538;
        border-radius: 4px;
        outline: none;
    }
    .cp_iptxt input[type=tel]:focus {
        border-color: #da3c41;
    }

    .cp_iptxt input[type=email] {
        font: 16px/24px sans-serif;
        box-sizing: border-box;
        width: 100%;
        margin: 2px 0;
        padding: 0.3em;
        transition: 0.3s;
        border: 1px solid #1b2538;
        border-radius: 4px;
        outline: none;
    }
    .cp_iptxt input[type=email]:focus {
        border-color: #da3c41;
    }

	/* 年齢 ++++++++ */
	.cp_ipnum {
	    position: relative;
	}
	.cp_ipnum input[type=number] {
	    font: 16px/24px sans-serif;
	    box-sizing: border-box;
	    width: 100%;
	    margin: 2px 0;
	    padding: 0.3em;
	    transition: 0.3s;
	    border: 1px solid #1b2538;
	    border-radius: 4px;
	    outline: none;
		ime-mode: disabled;
	    padding-left: 8px;
	}
	.cp_ipnum input[type=number]:focus {
	    border-color: #da3c41;
	}

	/* 居住地 ++++++++ */
	.cp_ipselect {
	    overflow: hidden;
	    margin:2px auto;
	    text-align: center;
		background-color:#FFF;
	}
	.cp_ipselect select {
        font-size: 16px;
		font-weight:bold;
	    width: 100%;
	    padding-right: 1em; 
	    cursor: pointer;
	    text-indent: 0.01px;
	    text-overflow: ellipsis;
	    background: transparent;
	    background-image: none;
	    box-shadow: none;
	    -webkit-appearance: none;
	    appearance: none;
	    border: 1px solid #1b2538;
	    border-radius: 4px;
	    outline: none;
	}
	.cp_ipselect.pref {
	    position: relative;
	    border-radius: 2px;
	    /*background: #ffffff;*/
	}
	.cp_ipselect.pref::before {
	    position: absolute;
	    top: 1.0em;
	    right: 1.0em;
	    width: 0;
	    height: 0;
	    padding: 0;
	    content: '';
	    border-left: 6px solid transparent;
	    border-right: 6px solid transparent;
	    border-top: 6px solid #666666;
	    pointer-events: none;
	}
	.cp_ipselect.pref:after {
	    position: absolute;
	    top: 0;
	    right: 2.5em;
	    bottom: 0;
	    width: 1px;
	    content: '';
	    border-left: 1px solid #bbbbbb;
	}
	.cp_ipselect.pref select {
	    padding: 8px 26px 8px 4px;
	    color: #666666;
	}


	/* ラジオボタン領域幅 */
	.belt {
		float:right;
		width:70%;
	}
@media screen and (max-width:750px) {
.belt {
	float:none;
	width:90%;
	margin-bottom: 20px;
}
}

input[type=checkbox] {
    display: none;
}

.cb01 {
    box-sizing: border-box;
    cursor: pointer;
    display: inline-block;
    padding: 5px 30px;
    position: relative;
    width: auto;
    margin-top: 50px;
}
.cb01::before {
    background: #fff;
    border: 1px solid #231815;
    content: '';
    display: block;
    height: 16px;
    left: 5px;
    margin-top: -20px;
    position: absolute;
    top: 50%;
    width: 16px;
}
.cb01::after {
    border-right: 3px solid #ed7a9c;
    border-bottom: 3px solid #ed7a9c;
    content: '';
    display: block;
    height: 9px;
    left: 10px;
    margin-top: -19px;
    opacity: 0;
    position: absolute;
    top: 50%;
    transform: rotate(45deg);
    width: 5px;
}
input[type=checkbox]:checked + .cb01::after {
    opacity: 1;
}

/** チェックOFFなら非表示 */
.cookie { 
  display: none;
}
/** チェックONなら表示 */
input:checked ~ .cookie{
  display: block;
}
 
/** チェックボックス横にラベル表示 */
[type="checkbox"].toggle{
  position: relative;
}
[type="checkbox"].toggle:after{
  content: "";
  position: absolute;
  width: 100%; height: 20px;
  padding-left: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
}



.line {
	margin:auto;
	width:50%;
	margin-top: -30px;
	padding-bottom: 30px;
	text-align: center;
}
@media screen and (max-width:750px) {
	.line {
		width:100%;
	}
	}


/* フォーム改修 */
.head_explain {
    font-size: 13px !important;
    margin-bottom: 10px;
}

.cp_iptxt + .cp_iptxt {
    margin-top: 20px;
}
.cp_ipselect {
    margin-top: 20px;
}
.cp_ipnum {
    margin-top: 20px;
}
.cp_iptxt_ttl {
    padding-bottom: 5px;
    font-size: 15px;
    line-height: 1;
    font-weight: bold;
}
.cp_iptxt_ttl-required {
    display: inline-block;
    position: relative;
    top: -2px;
    left: 4px;
    padding: 3px 4px;
    color: #fff;
    background: #ff6565;
    font-size: 11px;
    border-radius: 3px;
}
.cp_ipselect {
    overflow: visible;
    text-align: left;
}

.cp_ipselect.pref::before {
    top: auto;
    bottom: 1em;
    border-top: 6px solid #8aadd0;
}
.cp_ipselect.pref:after {
    content: none;
}

.cp_iptxt input {
    border: 1px solid #c0ccd8 !important;
    background: #edf3f9 !important;
}
.cp_iptxt input:focus {
    border: 1px solid #2975c2 !important;
}
.cp_ipnum input {
    border: 1px solid #c0ccd8 !important;
    background: #edf3f9 !important;
}
.cp_ipnum input:focus {
    border: 1px solid #2975c2 !important;
}
.cp_ipselect select {
    border: 1px solid #c0ccd8 !important;
    background: #edf3f9 !important;
}

/* エラー */
.formError + input {
    border: 1px solid #d95e5e !important;
    background: #f9edee !important;
}
.formError + input:focus {
    border: 1px solid #fd2929 !important;
}
.formError + select {
    border: 1px solid #d95e5e !important;
    background: #f9edee !important;
}
.formError + select:focus {
    border: 1px solid #fd2929 !important;
}

/* 性別 */
/* .sex input {
    display: inline-block;
}
.sex label {
    display: inline-block;
    float: none;
    background: none;
    padding: 0;
}
.sex input[type="radio"]:checked + .switch-on {
    background: none;
}
.sex input[type="radio"]:checked + .switch-off {
    background: none;
} */

/* 希望活動拠点エリア */
/* .place input {
    display: inline-block;
}
.place label {
    display: inline-block;
    float: none;
    background: none;
    padding: 0;
}
.place input[type="radio"]:checked + .switch2-on {
    background: none;
}
.place input[type="radio"]:checked + .switch2-off {
    background: none;
} */

/* ラジオボタン */
.belt {
    display: block;
    margin-top: 5px;
    height: 30px;
    float: none;
    width: 100%;
}
/* .belt_in {
    display: inline-block;
}
.belt_in + .belt_in {
    margin-left: 10px;
} */

/* 応募ボタン */
.line_explain {
    margin-top: 40px;
    width: 100%;
    max-width: 650px;
    color: #01af48;
    font-weight: bold;
    text-align: center;
    line-height: 1.5;
}
.line_explain .sp {
    font-size: 14px;
}
#submit_button {
    margin: 20px auto;
    width: 100%;
    max-width: 300px;
}

.line {
    width: 40%;
    padding: 0 0 20px;
}

@media screen and (max-width:750px) {
    .line {
        width: 80%;
    }
    .line_explain {
        margin-top: 20px;
    }
}

@media screen and (max-width: 320px){
    .fv_form_wrap {
        top: -25px;
    }
    .cp_iptxt_ttl {
        font-size: 14px;
    }
    .belt {
        height: 60px;
    }
}
