@charset "utf-8";

/*----------------------------------------------------------------------> ▼ general <----------*/

#form .frame, 
#form .box {
	width: ;
}

@media (width <= 500px) {
	.submit {
		width: 100%;
	}
}

/*----------------------------------------------------------------------> ▼ cover_large <----------*/

.entry {
	max-width: 100%;
	margin: 0 auto;
}

@media (1281px <= width) {
	.entry {
		width: 1024px;
	}
}

@media (width <= 1280px) or (height <= 768px) {
	.entry {
		width: 800px;
	}
}

.entry > ul {

}

.entry > ul li {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	margin-top: 30px;
}

.entry > ul div {
	width: 100%;
	line-height: 1;
}

.entry > ul li div:first-of-type {
	display: flex;
	align-items: center;
	font-family: YuGo-B;
	font-size: ;
}

.entry > ul li div:last-of-type {
	margin-top: 10px;
}

@media (width <= 767px) {
	.entry > ul li {
		margin-top: 20px;
	}
	
	.entry > ul li div:first-of-type {
		align-items: ;
	}	
}

.entry input[type="text"],
.entry input[type="email"],
.entry select {
	width: 100%;
	height: var(--form_height);
	padding: 0px 20px;
	border: 1px solid #eee;
	border-radius: var(--border_radius);
	background: #f6f6f6;
}

.entry input[type="text"]:focus,
.entry input[type="email"]:focus,
.entry select:focus {
	border-color: var(--blue);
	background: #f6f6ff;
}

.entry textarea {
	height: 300px;
	padding: 15px 20px;
	border: 1px solid #f0f0f0;
	border-radius: var(--border_radius);
	background: #f6f6f6;
}

@media (width <= 768px) {
	.entry textarea {
		height: 200px;
	}
}

.entry *::placeholder {
	color: #ccc;
}

.required {
	margin-left: 10px;
	padding: 4px 10px;
	border: 1px solid var(--blue);
	border-radius: var(--border_radius);
	font-size: 13px;
	font-weight: bold;
	color: var(--blue);
}

@media (width <= 767px) {
	.required {
		padding: 3px 8px 2px;
		font-size: 11px;
	}
}

.postal {
	display: block;
	position: relative;
	overflow: hidden;
}

.postal::before {
	content: '〒';
	position: absolute;
	top: 1px;
	left: 1px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: var(--form_height);
	border-right: 1px solid #eee;
	font-weight: bold;
}

.postal input {
	margin-bottom: 15px;
	padding-left: 70px !important;
}	

@media (769px <= width) {
	.postal input {
		width: 50% !important;
	}	
}

@media (width <= 500px) {
	.postal input {
		margin-bottom: 5px;
	}	
}

@media (width <= 1023px) {
	.entry dl {
		flex-wrap: wrap;
	}

	.entry dt {
		width: 100%;
		line-height: 30px;
		font-size: 13px;
	}

	.entry dd {
		width: 100%;
	}

	.column_two span {
		width: 30px;
		font-size: 10px;
		letter-spacing: -1px;
	}

	.entry input:not([type="submit"]):not([type="checkbox"]),
	.entry select,
	.entry textarea {
		font-size: 16px;
	}

	.required {
		margin-left: ;
		font-size: ;
	}
}

/*----------------------------------------------------------------------> ▼ .reply <----------*/

.radio_button {
	display: flex;
	flex-wrap: wrap;
}

.radio_button input {
	display: none;
}

.radio_button label {
	border: 1px solid var(--blue);
	border-radius: var(--border_radius);
	cursor: pointer;

	color: var(--blue);
	font-family: YuGo-B;
	line-height: var(--form_height);
	letter-spacing: 2px;
	text-align: center;
}

.radio_button input:checked + label {
	background: var(--blue);
	color: #fff;
}

.radio_button label {
	width: calc((100% - 15px) /2);
}

.radio_button label:nth-of-type(2n) {
	margin-left: 15px;
}

@media (width <= 1023px) {
	.radio_button label {
	}
}

/*----------------------------------------------------------------------> ▼ .policy <----------*/

.policy {
	margin-top: 30px;
}

.policy * {
	color: #666;
}

.policy dl {
	flex-wrap: wrap;
	padding: 5px 20px 20px;
	border: 1px solid #f0f0f0;
	border-radius: var(--border_radius);
	background: #f6f6f6;
	overflow-y: scroll;
	resize: vertical; 
}

.policy dt,
.policy dd {
	width: 100%;
}

.policy dt {
	margin: 20px 0 10px;
	padding-left: 10px;
	border-left: 5px solid #aaa;
	font-weight: bold;
	line-height: 1;
}

.policy {
	padding-left: 0px;
}

.policy dl {
	height: 300px;
}

.policy dt {
	font-size: 0.9rem;
}

.policy dd {
	padding-left: 15px;
	font-size: 0.8rem;
}

@media (768px <= width <= 1023px) {
	.policy dl {
		height: 200px;
	}
}

@media (width <= 500px) {
	.policy dl {
		height: 110px;
	}
}

/*----------------------------------------------------------------------> ▼ .agreement <----------*/

.agreement {
	display: flex;
	flex-direction: row-reverse;
	align-items:center;	
	justify-content: center;
	padding: 30px 0;
}

.agreement input {
	display: none;
}

.agreement label {
	border-bottom: 1px solid #fff;
	cursor: pointer;
}

.agreement .checkbox {
	position: relative;
	aspect-ratio: 1 / 1;
	height: 1.5rem;
	border: 1px solid #444;
	margin-right: 15px;
	border-radius: var(--border_radius);
	cursor: pointer;
}

.agreement .checkbox::before {
	display: none;
	position: absolute;
	top: 5%;
	left: 20%;
	aspect-ratio: 4 / 1;
	width: 1.5rem;
	border-left: 4px solid var(--orange_2);
	border-bottom: 4px solid var(--orange_2);
	transform: rotate(-35deg);
}

#agreement:checked ~ .checkbox::before {
	content: '';
	display: block;
}


@media (hover: hover) and (pointer: fine) {
	.agreement label {
		transition: var(--transition);
	}

	.agreement:hover label {
		border-color: var(--orange_2);
		color: var(--orange_2);
	}
}


