@charset "UTF-8";

@import url(/teaching/sagamihara/common/css/destyle.css);

@font-face {
	font-family: 'MPLUSRounded1c-ExtraBold';
	font-display: swap;
	src: url(/teaching/sagamihara/common/fonts/M_PLUS_Rounded_1c/MPLUSRounded1c-ExtraBold.ttf) format('TrueType');
}

body,
html {
	height: 100%;
	padding: 0;
}
body {
	color: #003067;
	font-size: 24px;
	font-family: 'MPLUSRounded1c-ExtraBold', sans-serif;
	line-height: 1.6;
}

/** .single-main */
.single-main {
	padding: 50px 0;
	background-image: url(/teaching/sagamihara/common/img/bg.png);
	background-size: contain;
}

/** .content */
.single-main .content {
	position: relative;
	width: 904px;
	min-width: 904px;
	margin: 25px auto;
	padding: 35px 0;
	background-image: url(/teaching/sagamihara/survey/img/bg_middle.png);
	background-repeat: repeat-y;
	background-size: contain;
}
.single-main .content::before {
	position: absolute;
	top: -25px;
	left: 0;
	width: 904px;
	height: 25px;
	background-image: url(/teaching/sagamihara/survey/img/bg_top.png);
	background-repeat: no-repeat;
	background-size: contain;
	content: '';
}
.single-main .content::after {
	position: absolute;
	bottom: -25px;
	left: 0;
	width: 904px;
	height: 25px;
	background-image: url(/teaching/sagamihara/survey/img/bg_bottom.png);
	background-repeat: no-repeat;
	background-size: contain;
	content: '';
}

/** .ruby-wrap */
.ruby-wrap {
	position: relative;
}
.ruby-wrap .ruby-rt {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 12px;
	word-break: keep-all;
}
.ruby-wrap .ruby-rt.size-s {
	top: -2px;
	font-size: 10px;
}

/** .content-title */
.survey .content-title {
	margin-bottom: 60px;
	text-align: center;
}
.survey .content-title .content-title-inner {
	display: inline-block;
	position: relative;
	padding: 0 90px;
}
.survey .content-title .content-title-inner::before {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 5px;
	border-radius: 5px;
	background-color: #003067;
	content: '';
}
.survey .content-title .content-title-inner h1 {
	position: relative;
	font-size: 40px;
	text-align: center;
}
.survey .content-title .content-title-inner h1::before {
	position: absolute;
	top: 28px;
	left: calc(50% - 270px);
	width: 71px;
	height: 74px;
	background-image: url(/teaching/sagamihara/survey/img/title_left.png);
	background-size: cover;
	transform: translate(-50%, -50%);
	content: '';
}
.survey .content-title .content-title-inner h1::after {
	position: absolute;
	top: 33px;
	right: calc(50% - 350px);
	width: 81px;
	height: 73px;
	background-image: url(/teaching/sagamihara/survey/img/title_right.png);
	background-size: cover;
	transform: translate(-50%, -50%);
	content: '';
}

/** .content-main */
.survey .content-main {
	padding: 0 70px;
}

/** .field-item */
.field-item {
	margin-bottom: 60px;
}
.field-item .field-label {
	margin-bottom: 20px;
}
.field-item .field-label .field-title {
	font-size: 27px;
}
.field-item .field-label .field-text {
	font-size: 30px;
	text-align: center;
}

/** .field-input */
.field-item .field-input {
	padding-left: 60px;
}

/** .radio-wrap */
.field-item .radio-wrap .radio-item {
	margin-bottom: 20px;
}
.field-item .radio-wrap input[type='radio'] {
	overflow: hidden;
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	border: 0;
	white-space: nowrap;
	clip: rect(0 0 0 0);
}
.field-item .radio-wrap label {
	display: block;
	position: relative;
	padding-left: 30px;
	text-indent: 0;
	cursor: pointer;
}
.field-item .radio-wrap label::before,
.field-item .radio-wrap label::after {
	display: block;
	position: absolute;
	top: 50%;
	border-radius: 50%;
	box-sizing: border-box;
	transform: translateY(-50%);
	content: '';
}
.field-item .radio-wrap label::before {
	left: 0;
	width: 20px;
	height: 20px;
	border: 1px solid #003067;
	border-radius: 50%;
	background-color: #fff;
}
.field-item .radio-wrap label::after {
	left: 5px;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: #003067;
	opacity: 0;
}
.field-item .radio-wrap input[type='radio']:checked + label::before {
	border: 1px solid #003067;
}
.field-item .radio-wrap input[type='radio']:checked + label::after {
	opacity: 1;
}

/** .checkbox-wrap */
.field-item .checkbox-wrap .checkbox-item {
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}
.field-item .checkbox-wrap .checkbox-item .checkbox-label-wrap {
	padding-left: 10px;
}
.field-item .checkbox-wrap .checkbox-item input[type='checkbox'] {
	position: relative;
	width: 20px;
	height: 20px;
	border: 1px solid #003067;
	border-radius: 3px;
	cursor: pointer;
}
.field-item .checkbox-wrap .checkbox-item input[type='checkbox']:checked {
	background-color: #003067;
}
.field-item .checkbox-wrap .checkbox-item input[type='checkbox']:checked::after {
	position: absolute;
	top: 4px;
	left: 2px;
	width: 14px;
	height: 8px;
	border-bottom: 3px solid #fff;
	border-left: 3px solid #fff;
	transform: rotate(-45deg);
	content: '';
}

/** .textbox-wrap */
.field-item .checkbox-wrap .textbox-wrap {
	width: 550px;
	margin-left: 30px;
}
.field-item .checkbox-wrap .textbox-wrap input[type='text'] {
	width: 100%;
	height: 44px;
	padding: 8px 16px;
	border: 1px solid #003067;
	border-radius: 3px;
	background: #fff;
	font-size: 17px;
	line-height: 1.4;
	resize: none;
}
.field-item .checkbox-wrap .textbox-wrap.is-password input[type='text']::-ms-reveal {
	display: none;
}

/* .textarea-wrap */
.field-item .textarea-wrap textarea {
	display: block;
	width: 600px;
	padding: 8px 16px;
	border: 1px solid #003067;
	border-radius: 3px;
	box-sizing: border-box;
	background: #fff;
	font-size: 17px;
	line-height: 1.4;
	appearance: none;
	resize: vertical;
}

/** .error-msg */
.error-msg {
	margin-bottom: 20px;
	color: #e30000;
	text-align: center;
}
.error-msg.is-hidden {
	display: none;
}

/** .submit-btn */
.submit-btn {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	width: 163px;
	height: 42px;
	margin: 0 auto;
	border-radius: 10px;
	background-color: #ccc;
	color: #fff;
	font-size: 18px;
	cursor: initial;
}
.submit-btn.is-active {
	background-color: #53b98d;
	transition: all .3s;
	cursor: pointer;
}
.submit-btn.is-active:hover {
	opacity: .7;
}
