@charset "UTF-8";
/* CSS Document */
/* hr */
.cp_headline10 {
	position: relative;
	height: 0.5em;
	color: #424242;
	background-color: #ffffff;/*背景色と合わせる*/
	background-image:
		-webkit-linear-gradient(135deg,
		#9e9e9e 25%, transparent 25%,
		transparent 50%, #9e9e9e 50%,
		#9e9e9e 75%, transparent 75%,
		transparent);
	background-image:
		linear-gradient(-45deg,
		#9e9e9e 25%, transparent 25%,
		transparent 50%, #9e9e9e 50%,
		#9e9e9e 75%, transparent 75%,
		transparent);
	background-size: 10px 10px;
}
.cp_headline10 span {
	position: absolute;
	display: inline-block;
	margin-top: -0.5em;
	margin-left: 0.8em;
	padding: 0em 0.5em 0em 0.5em;
	background: #ffffff;/*背景色と合わせる*/
}
/* hr */
/* checkbox */
.cp_checkbox {
	width: 90%;
	margin: 2em auto;
	text-align: left;
}
.cp_checkbox input[type='checkbox'] {
	position: absolute;
	z-index: -1;
	opacity: 0;
}
.cp_checkbox label {
	position: relative;
	display: inline-block;
	margin-right: 30px;
	padding-right: 10px;
	padding-left: 35px;
	cursor: pointer;
}
.cp_checkbox label::before {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	display: block;
	width: 24px;
	height: 24px;
	content: ' ';
	border: 2px solid #da3c41;
	border-radius: 4px;
}
.cp_checkbox input[type='checkbox'] + label::before {
	border-radius: 18px;
}
.cp_checkbox input[type='checkbox']:checked + label {
	padding-left: 10px;
	color: #ffffff;
}
.cp_checkbox input[type='checkbox']:checked + label::before {
	top: 0;
	width: 100%;
	height: 100%;
	background: #da3c41;
}
/* Transition */
.cp_checkbox label, .cp_checkbox label::before {
	-webkit-transition: 0.25s all ease;
	        transition: 0.25s all ease;
}
/* checkbox */

.form-mp {
	padding:1rem;
	font-size:2rem;
	
}


.cp_form {
	position: relative;
	width: 600px;
	margin: 40px auto;
	padding: 1em 2em;
	box-shadow:0px 0px 3px 2px #ededed;
}
.cp_form .cp_radio, .cp_group {
	position: relative;
	margin-top: 2.25rem;
	margin-bottom: 2.25rem;
}
.cp_form .cp_group input[type=button],
.cp_form .cp_group input[type=submit],
.cp_form .cp_group input[type=checkbox],
.cp_form .cp_group input[type=radio],
.cp_form .cp_group input[type=text],
.cp_form .cp_group input[type=tel],
.cp_form .cp_group input[type=password],
.cp_form .cp_group input[type=email],
.cp_form .cp_group input[type=url],
.cp_form .cp_group input[type=date],
.cp_form .cp_group input[type=number],
.cp_form .cp_group textarea,
.cp_form .cp_group .cp_file .file_text,
.cp_form .cp_group select {
	font-family: inherit;
}
.cp_form .cp_group input {
	height: 1.9rem;
}
.cp_form .cp_group textarea {
	resize: vertical;
}
.cp_form .cp_group select::-ms-expand {
	display: none;
}
.cp_form .cp_ipselect {
	position: relative;
	width: 100%;
	margin: 2em auto;
}
.cp_form .cp_sl {
	position: relative;
	font-size: 1rem;
	font-family: inherit;
	background-color: transparent;
	width: 100%;
	padding: 10px 10px 10px 0;
	border-radius: 0;
	border: none;
}
.cp_form .cp_sl:focus {
	outline: none;
	border-bottom: 1px solid rgba(0,0,0, 0);
}
.cp_form .cp_ipselect .cp_sl {
	-webkit-appearance: none;
	        appearance: none;
}
.cp_form .cp_ipselect:after {
	position: absolute;
	top: 18px;
	right: 10px;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid rgba(0, 0, 0, 0.3);
	pointer-events: none;
}
.cp_form .cp_sl_selectlabel {
	position: absolute;
	pointer-events: none;
	left: 0;
	top: 10px;
	transition: 0.2s ease all;
}
.cp_form .cp_sl:focus ~ .cp_sl_selectlabel,
.cp_form .cp_sl:valid ~ .cp_sl_selectlabel {
	font-size: 1.1rem;
	color: #da3c41;
	top: -20px;
	transition: 0.2s ease all;
}
.cp_form .cp_sl_selectbar {
	position: relative;
	display: block;
	width: 100%;
}
.cp_form .cp_sl_selectbar:before,
.cp_form .cp_sl_selectbar:after {
	content: '';
	height: 2px;
	width: 0;
	bottom: 1px;
	position: absolute;
	background: #da3c41;
	transition: 0.2s ease all;
}
.cp_form .cp_sl_selectbar:before {
	left: 50%;
}
.cp_form .cp_sl_selectbar:after {
	right: 50%;
}
.cp_form .cp_sl:focus ~ .cp_sl_selectbar:before,
.cp_form .cp_sl:focus ~ .cp_sl_selectbar:after {
	width: 50%;
}
.cp_form .cp_sl_highlight {
	position: absolute;
	top: 25%;
	left: 0;
	pointer-events: none;
	opacity: 0.5;
}
.cp_form .cp_group .cp_label {
	position: absolute;
	top: 0.25rem;
	pointer-events: none;
	padding-left: 0.125rem;
	z-index: 1;
	font-size: 1rem;
	font-weight: normal;
	-webkit-transition: all 0.28s ease;
	        transition: all 0.28s ease;
}
.cp_form .cp_group .bar {
	position: relative;
	border-bottom: 0.0625rem solid #999999;
	display: block;
}
.cp_form .cp_group .bar::before {
	content: '';
	height: 0.125rem;
	width: 0;
	left: 50%;
	bottom: -0.0625rem;
	position: absolute;
	background: #da3c41;
	-webkit-transition: left 0.28s ease, width 0.28s ease;
	        transition: left 0.28s ease, width 0.28s ease;
	z-index: 2;
}
.cp_form .cp_group input[type=button],
.cp_form .cp_group input[type=submit],
.cp_form .cp_group input[type=checkbox],
.cp_form .cp_group input[type=radio],
.cp_form .cp_group input[type=text],
.cp_form .cp_group input[type=tel],
.cp_form .cp_group input[type=password],
.cp_form .cp_group input[type=email],
.cp_form .cp_group input[type=url],
.cp_form .cp_group input[type=date],
.cp_form .cp_group input[type=number],
.cp_form .cp_group textarea {
	display: block;
	background: none;
	padding: 0.125rem 0.125rem 0.0625rem;
	font-size: 1rem;
	border-width: 0;
	border-color: transparent;
	line-height: 1.9;
	width: 100%;
	color: transparent;
	-webkit-transition: all 0.28s ease;
	        transition: all 0.28s ease;
	-webkit-box-shadow: none;
	        box-shadow: none;
	padding:2.5rem;
	margin-top:1.1rem;
}
.cp_form .cp_group select,
.cp_form .cp_group input:focus,
.cp_form .cp_group input:valid,
.cp_form .cp_group textarea:focus,
.cp_form .cp_group textarea:valid {
	color: #333333;
}
.cp_form .cp_group select ~ .cp_label,
.cp_form .cp_group input:focus ~ .cp_label,
.cp_form .cp_group input:valid ~ .cp_label,
.cp_form .cp_group textarea:focus ~ .cp_label,
.cp_form .cp_group textarea:valid ~ .cp_label {
	font-size: 1.1rem;
	color: #da3c41;
	top: -1rem;
	left: 0;
	font-weight: bold;
}
.cp_form .cp_group select:hover,
.cp_form .cp_group input:focus,
.cp_form .cp_group textarea:focus {
	outline: none;
}
.cp_form .cp_group select:hover ~ .cp_label,
.cp_form .cp_group input:focus ~ .cp_label,
.cp_form .cp_group textarea:focus ~ .cp_label {
	color: #da3c41;
}
.cp_form .cp_group select:hover ~ .bar::before,
.cp_form .cp_group input:focus ~ .bar::before,
.cp_form .cp_group textarea:focus ~ .bar::before {
	width: 100%;
	left: 0;
}
.cp_form .checkbox label,
.cp_form .cp_radio label {
	position: relative;
	cursor: pointer;
	padding-left: 2rem;
	text-align: left;
	color: #333333;
	display: block;
}
.cp_form .checkbox input,
.cp_form .cp_radio input {
	width: auto;
	opacity: 0.00000001;
	position: absolute;
	left: 0;
}
.cp_form .radio {
	margin-bottom: 1rem;
}
.cp_form .radio .ch_bar {
	position: absolute;
	top: -0.25rem;
	left: -0.25rem;
	cursor: pointer;
	display: block;
	font-size: 1rem;
	-webkit-user-select: none;
	        user-select: none;
	color: #999999;
}
.cp_form .radio .ch_bar::before,
.cp_form .radio .ch_bar::after {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	margin: 0.25rem;
	width: 1rem;
	height: 1rem;
	-webkit-transition: -webkit-transform 0.28s ease;
	        transition:         transform 0.28s ease;
	border-radius: 50%;
	border: 0.125rem solid currentColor;
}
.cp_form .radio .ch_bar::after {
	-webkit-transform: scale(0);
	        transform: scale(0);
	background-color: #da3c41;
	border-color: #da3c41;
}
.cp_form .radio label:hover .ch_bar {
	color: #da3c41;
}
.cp_form .radio input:checked ~ .ch_bar::after {
	-webkit-transform: scale(0.5);
	        transform: scale(0.5);
}
.cp_form .radio input:checked ~ .ch_bar::before {
	color: #da3c41;
}
.cp_form .checkbox {
	margin-top: 3rem;
	margin-bottom: 1rem;
}
.cp_form .checkbox .ch_bar {
	color: #999999;
	position: absolute;
	top: 0;
	left: 0;
	width: 1rem;
	height: 1rem;
	z-index: 0;
	border: 0.125rem solid currentColor;
	border-radius: 0.0625rem;
	-webkit-transition: border-color 0.28s ease;
	        transition: border-color 0.28s ease;
}
.cp_form .checkbox .ch_bar::before,
.cp_form .checkbox .ch_bar::after {
	position: absolute;
	height: 0;
	width: 0.2rem;
	background-color: #da3c41;
	display: block;
	-webkit-transform-origin: left top;
	        transform-origin: left top;
	border-radius: 0.25rem;
	content: '';
	-webkit-transition: opacity 0.28s ease, height 0s linear 0.28s;
	        transition: opacity 0.28s ease, height 0s linear 0.28s;
	opacity: 0;
}
.cp_form .checkbox .ch_bar::before {
	top: 0.65rem;
	left: 0.38rem;
	-webkit-transform: rotate(-135deg);
	        transform: rotate(-135deg);
	-webkit-box-shadow: 0 0 0 0.0625rem #ffffff;
	        box-shadow: 0 0 0 0.0625rem #ffffff;
}
.cp_form .checkbox .ch_bar::after {
	top: 0.3rem;
	left: 0;
	-webkit-transform: rotate(-45deg);
	        transform: rotate(-45deg);
}
.cp_form .checkbox label:hover .ch_bar {
	color: #da3c41;
}
.cp_form .checkbox input:checked ~ .ch_bar {
	color: #da3c41;
}
.cp_form .checkbox input:checked ~ .ch_bar::after,
.cp_form .checkbox input:checked ~ .ch_bar::before {
	opacity: 1;
	-webkit-transition: height 0.28s ease;
	        transition: height 0.28s ease;
}
.cp_form .checkbox input:checked ~ .ch_bar::after {
	height: 0.5rem;
}
.cp_form .checkbox input:checked ~ .ch_bar::before {
	height: 1.2rem;
	-webkit-transition-delay: 0.28s;
	        transition-delay: 0.28s;
}
.cp_form .radio + .radio,
.cp_form .checkbox + .checkbox {
	margin-top: 1rem;
}
/* File input */
.cp_form .cp_group .cp_file {
	position: relative;
}
.cp_form .cp_group .cp_file .title {
	position: static;
}
.cp_form .cp_group .cp_file .button {
	font-size: 1em;
	position: absolute;
	z-index: 1;
	top: 0;
	right: 0;
	bottom: 0;
	padding: .5rem 1.2em 0 1.2em;
	cursor: pointer;
	-webkit-transition: background-color 0.25s;
	        transition: background-color 0.25s;
	color: #ffffff;
	border-radius: 0;
	background-color: #999999;
}
.cp_form .cp_group .cp_file .file_input {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	padding: 0;
	cursor: pointer;
	opacity: 0;
	filter: alpha(opacity=0);
	-webkit-appearance: none;
					appearance: none;
}
.cp_form .cp_group .cp_file .file_text {
	position: relative;
	box-sizing: border-box;
	padding: 6px 10px;
	-webkit-transition: border-color 0.6s;
	        transition: border-color 0.6s;
	border-bottom: 0.0625rem solid #999999;
	outline: none;
}
.cp_form .cp_group .cp_file .file_text::before {
	content: '';
	height: 2px;
	width: 0;
	left: 50%;
	bottom: -1px;
	position: absolute;
	background: #da3c41;
	-webkit-transition: left 0.28s ease, width 0.28s ease;
	        transition: left 0.28s ease, width 0.28s ease;
	z-index: 2;
}
.cp_form .cp_group .cp_file .file_input:hover ~ .file_text::before {
	width: 100%;
	left: 0;
}
.cp_form .cp_group .cp_file label:hover .button {
	background-color: #da3c3c;
}
.cp_form .cp_group .cp_file label:active .button {
	background-color: #b02f2f;
}
.cp_form .btn_cont {
	text-align: center;
}
.cp_form .btn {
	position: relative;
	background: currentColor;
	border: 1px solid currentColor;
	font-size: 1.1rem;
	color: #da3c41;
	margin: 3rem 0;
	padding: 0.75rem 3rem;
	cursor: pointer;
	-webkit-transition: background-color 0.28s ease, color 0.28s ease, -webkit-box-shadow 0.28s ease;
	        transition: background-color 0.28s ease, color 0.28s ease, box-shadow 0.28s ease;
	overflow: hidden;
	-webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.3);
	        box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.3);
}
.cp_form .btn span {
	color: #ffffff;
	position: relative;
	z-index: 1;
}
.cp_form .btn::before {
	content: '';
	position: absolute;
	background: #071017;
	border: 50vh solid #1d4567;
	width: 30vh;
	height: 30vh;
	border-radius: 50%;
	display: block;
	top: 50%;
	left: 50%;
	z-index: 0;
	opacity: 1;
	-webkit-transform: translate(-50%, -50%) scale(0);
	        transform: translate(-50%, -50%) scale(0);
}
.cp_form .btn:hover {
	color: #3f51b5;
	-webkit-box-shadow: 0 6px 10px 0 rgba(0, 0, 0, 0.3);
	        box-shadow: 0 6px 10px 0 rgba(0, 0, 0, 0.3);
}
.cp_form .btn:focus {
	outline: none;
}

