@charset "utf-8";
/* ------------------------------------------------------------------
 * (C) KADOKAWA CORPORATION
------------------------------------------------------------------- */

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace, monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}

*,*::before,*::after { box-sizing: border-box; }

html {
	font-size: 62.5%;  
	-moz-text-size-adjust: none;
	-webkit-text-size-adjust: none;
	text-size-adjust: none;
}
body { 
	background: transparent url(../img/bg.png);
	color: #212121;
	position: relative;
	line-height:1.5;
	font-size: 1.6rem;
	font-family: "Noto Sans", Roboto, Segoe UI, "Helvetica Neue", Helvetica, Arial, sans-serif;
	font-feature-settings: "palt";
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
    text-size-adjust: 100%;
	text-rendering: optimizeSpeed;
}
input,button,input:focus,button:focus {
	outline: 0px none;
}
input:-webkit-autofill {
	-webkit-box-shadow: 0 0 0px 1000px white inset;
}
select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
a:link, a:visited { color: #212121; }
a:hover { color: #666666;text-decoration:none; }

/* class------------------------------------------------------*/
.txtwh {
	color: #ffffff;
}
.txtyel {
	color: #ffde00;
}
.lineyel {
	display: inline;
	background: linear-gradient(transparent 10%, #ffde00 10%);
}
.lineorg {
	display: inline;
	background: linear-gradient(transparent 10%, #ffab00 10%);
}
.txtshadow {
	text-shadow: 1px 0 0 rgb(33, 33, 33), -1px 0 0 rgb(33, 33, 33),
	             0 1px 0 rgb(33, 33, 33), 0 -1px 0 rgb(33, 33, 33),
				 1px 1px 0 rgb(33, 33, 33), -1px -1px 0 rgb(33, 33, 33),
				 1px -1px 0 rgb(33, 33, 33), -1px 1px 0 rgb(33, 33, 33),
				 0 3px 0 rgb(33, 33, 33);
}
.txtshadow[class^="line"] {
	padding: 0 0.3em;
}
.bullet {
	padding-left: 1em;
	position: relative;
}
.bullet::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 10px;
	height: 10px;
	background-color: #212121;
	border-radius: 50%;
}
h3.bullet::before {
	width: 14px;
	height: 14px;
}

/* header-----------------------------------------------------*/
header {
	margin: 0;
	padding: 0;
	background-color: #ffffff;
	position: relative;
	overflow: hidden;
	z-index: 1;
}
header::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
    height: 100%;
	background-image: url(../img/kv_online.jpg);
	background-size: cover;
	filter: blur(70px);
	transform: scale(1.1);
	z-index: -1;
}
header .header-title {
	margin: 0 auto;
	padding: 0;
	width: 900px;
	text-align: center;
}
header .header-logo {
	margin: 20px 20px 25px;
    padding: 0;
    border-radius: 20px;
	box-shadow: 4px 5px 0px 0px #000000;
    overflow: hidden;
}
header .header-logo img {
	width: 100%;
	vertical-align: bottom;
}
h1 {
	margin: 0;
	padding: 20px 0;
	color: #030303;
	position: relative;
	font-size: 4.2rem;
	font-family: Outfit, sans-serif;
	font-weight: 900;
	letter-spacing: .020em;
	line-height: 1;
	text-align: center;
	z-index: 1;
}
h1::before {
    content: "";
	background-color: #7cdbed;
	background-color: #ffffff;
    display: block;
    position: absolute;
    border: solid 1px #030303;
    border-bottom-left-radius: 100px;
    border-bottom-right-radius: 100px;
    width: 100%;
    height: 100%;
    top: 0;
	z-index: -1;
}
h1 span {
	margin: 0;
	padding: 20px 15px;
	display: block;
	font-size: 4.2rem;
	text-shadow: none;
}
/* main-----------------------------------------------------*/
main {
	margin: 40px auto 70px;
	padding: 40px 0;
	background-color: #ffffff;
	border-top: 1px solid #212121;
	border-bottom: 1px solid #212121;
	overflow: hidden;
}
main .main-inner {
	margin: 0 auto;
	width: 800px;
}
main .main-inner h2 {
	font-size: 2.0rem;
}

/* footer---------------------------------------------------*/
footer {
	padding: 40px 20px;
	background-color: #ffffff;
	border-top: 1px solid #212121;
}
footer .copytext { 
	font-size: 1.2rem;
	text-align: center;
}

/* ledad & notes ---------------------------------------------------*/
.leadsection, .notes {
	margin: 0 0 40px;
}
.leadsection p strong {
	padding: 10px;
	display: block;
	background-color: #efefef;
	font-size: 1.8rem;
	text-align: center;
}
.leadsection p {
	margin: 0 0 1.5em;
	font-size: 1.7rem;
}
.notes h2 {
	margin: 0;
	padding: 0.25em;
	font-size: 1.8rem;
	font-weight: 800;
	line-height: 1.6;
}
.notes dl {
	display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}
.notes dt {
	padding: 2rem;
	display: flex;
    align-items: center;
    justify-content: center;
    width: 200px;
    height: auto;
    text-align: center;
    background: #e7f9fd;
    border-radius: 1.875rem 0 0 1.875rem;
    font-size: 1.8rem;
    font-weight: 800;
}
.notes dd {
	margin: 0;
    padding: 12px 0;
	width: 570px;
    font-weight: 400;
}
.notes .section-box {
	margin: 0;
	text-align: left;
}
.notes p {
	margin: 0 0 1.5em;
}
.notes p:last-of-type {
	margin-bottom: 0;
}
.notes ul {
	margin: 0 1.25em;
	padding: 0;
}
.notes li {
	margin: 0 0 .5em;
}
.notes .txtlarge {
	margin-bottom: 1em !important;
	position: relative;
	font-size: 1.8rem;
}


/* form-----------------------------------------------------*/
#errMsg {
	margin: 0;
	padding: 1em 0 1.5em;
	color: #F10101;
	font-size: 1.4rem;
}
.form-contents h2 {
	margin: 0 0 1.5em;
	font-size: 1.8rem;
	text-align: center;
}
.form-contents h3 {
	margin: 2em 0 1em;
	font-size: 1.8rem;
}
.form-content-head {
	padding: 3px 15px;
	background-color: #ddebee;
	align-items: center;
	font-size: 1.5rem;
	font-weight: 700;
}
.form-label-required {
	margin: 0;
	padding: 2px;
	color: #ff3366;
	font-weight: 600;
}
.form-content-data {
	padding: 15px 15px 30px;
	word-break: break-word;
}
.form-content-data ul {
	margin: 0 0 1em;
	padding: 0 1.25em;
}
.form-content-data p {
	margin: 0 0 1em;
	font-size: 1.5rem;
}
.form-content-data .form-label-ex {
	margin: 0 0 10px;
	color: #309cb4;
}
.form-content-data .form-file-name {
	margin: 5px 0 5px 1em;
	display: inline;
	font-size: 1.5rem;
}
.form-input, .form-select, .form-text { 
	font-size: 1.6rem;
}
.form-input {
	padding: 7px;
	width: 100%;
	max-width: 100%;
	line-height: normal;
}
.form-input.min {
	margin-right: 5px;
	width: 50%;
	max-width: 200px;
}
.form-input.mic {
	margin-right: 5px;
	width: 30%;
	max-width: 100px;
}
.select-item {
	overflow: hidden;
}
.form-file {
	margin: 0 0;
	padding: 2px;
	position: relative;
	overflow: hidden;
	line-height: 1.6;
}
.form-file-btn {
    padding: 18px 20px;
    display: inline-block;
    background-color: #7cdcee;
	border: 1px solid #030303;
	box-shadow: 3px 4px 0px 0px #000000;
	border-radius: 4px;
	width: 260px;
	font-size: 2.2rem;
	line-height: 1;
	font-weight: 700;
    text-align: center;
	line-height: 1.4;
	vertical-align: middle;
	cursor: pointer;
}
.form-file .file-input {
    display: none;
    position: absolute;
    width: 1px;
}
.form-file-btn:hover {
	opacity: 0.7;
}
.form-file-btn:focus {
    outline: 2px solid #212121;
}
.form-select {
	padding: 10px ;
	border: 1px solid #999999;
	background: #ffffff url(../img/icn_dropdown.png) right 2% top 50% no-repeat;
	outline: none;
	width: auto;
	min-width: 100%;
}
.form-select option {
	background:#ffffff;
}
.form-text {
	padding: 7px;
	width: 100%;
	max-width: 100%;
}
.form-radio {
	margin-bottom: 1.5em;
}
.form-radio:last-child {
	margin-bottom: 0;
}
.form-radio label {	
	margin: 0 2em 0 0;
	width: fit-content;
	font-size: 1.5rem;
	line-height: 1.5;
	cursor: pointer;
}
.form-radio input[type="radio"] {
	margin: 0 5px 0 0;
	appearance: none;
	position: relative;
	width: 17px;
	height: 17px;
	border: 1px solid #ccc;
	border-radius: 9999px;
	cursor: pointer;
	vertical-align: -4px;
}
.form-radio input[type="radio"]:checked {
	border-color: #ffab00;
	background-color: #fff;
}
.form-radio input[type="radio"]:checked::after {
	margin: auto;
	content: "";
	position: absolute;
	inset: 0;
	width: 11px;
	height: 11px;
	border-radius: 9999px;
	background-color: #ffab00;
}
.form-check label {
	margin: 0 0 10px;
	padding-left: 1.75em;
	display: block;
	width: fit-content;
	font-size: 1.5rem;
	line-height: 1.5;
	cursor: pointer;
	text-indent: -1.75em;
}
.form-check input[type="checkbox"] {
	margin: 0 5px 0 0;
	appearance: none;
	position: relative;
	width: 18px;
	height: 18px;
	border: 1px solid #ccc;
	cursor: pointer;
	vertical-align: -4px;
}
.form-check input[type="checkbox"]:checked {
	background-color: #ffab00;
	border-color: #ffab00;
}
.form-check input[type="checkbox"]:checked::after {
	content: "";
	position: absolute;
	top: 4px;
	left: 3px;
	width: 11px;
	height: 5px;
	border-bottom: 2px solid #1e293b;
	border-left: 2px solid #1e293b;
	transform: rotate(-45deg);
}
.form-submit {
	margin: 0;
	padding: 15px 0 0;
}
.form-submit .submit { 
	margin: 20px auto;
	padding: 17px 20px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display:block;
	width:100%;
	background-color: #5d3dff;
	color: #ffffff;
	border-style: solid;
	border-color: #030303;
	border-width: 1px;
	box-shadow: 4px 5px 0px 0px #000000;
	border-radius: 40px;
	outline:none;
	font-size: 2.6rem;
	line-height: 1;
	font-weight: 700;
	font-weight:bold;
	line-height: 1.5;
	text-align:center;
	text-decoration:none;
	cursor:pointer;
}
.form-submit .submit span {
	display: block;
	font-size: 1.4rem;
}
.form-submit .submit:hover {
	opacity: 0.7;
}
.form-submit .submit:focus {
	outline: 2px solid #212121;
}
.form-submit .btn {
	padding: 10px 20px;
	border-color: #030303;
	border-style: solid;
	border-width: 1px;
	background:#969fa7;
}
.form-submit .btn:hover,
.form-submit .btn:focus {
	background:#aaaaaa;
}
.form-submit .btn small {
	font-size:1.3rem;
}
input[type="text"],
input[type="number"],
input[type="email"],
input[type="tel"],
input[type="radio"],
input[type="checkbox"], 
textarea {
	margin: 1px 2px 0 0;
	background-color: #ffffff;
	border: 1px solid #cccccc;
	border-radius: 4px;
}
input[type="text"]:focus,
input[type="number"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
textarea:focus,
.file-button:focus,
.radio-parent:focus,
.check-parent:focus {
	background-color: #f2f3f4;
    outline: 1px solid #ffab00;
}
.form-content-policycheck {
	margin:0 0 15px;
	padding:20px 15px;
	background: #F4F6F9;
	border: 1px solid #ddd;
	font-size: 1.6rem;
	text-align: center;
}
.form-content-policycheck strong {
	margin: 0 0 .5em;
	display: inline-block;
}
.form-content-policycheck .form-check,
.form-content-policycheck .form-check label {
	margin: 0;
}
/* autocomplete */
.form-autocomplete {
	margin: 0 0 1em;
    position: relative;
}
#suggestions-container {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    border: 1px solid #eeeeee;
    background-color: #ffffff;
    z-index: 10;
    max-height: 200px;
    overflow-y: auto;
}
.suggestion-item {
    padding: 10px;
    cursor: pointer;
}
.suggestion-item:hover {
    background-color: #f0f0f0;
}
.confirm .form-content-data p {
	font-size: 1.5rem;
}
.confirm .form-content-data p .ico-checked {
	margin-right: 7px;
	color: #ff3366;
	font-weight: 800;
}
.content-textbox {
	padding: 20px;
	min-height: 30vh;
}
.content-textbox h2 {
	text-align: left;
}
.content-textbox p {
	font-size: 1.6rem;
}
.content-textbox li {
	margin: 0 0 .5em;
}
@media screen and (max-width: 959px) {
	header {
		margin: 0;
		padding: 0;
	}
	header .header-title {
		width: 100%;
	}
	header .header-logo {
		margin: 0;
		border-radius: 0;
	}
	header .header-logo img {
		width: 100%;
	}
	main .main-inner {
		padding: 0 20px;
		width: 100%;
	}
	.notes dl {
		margin: 0 auto 20px;
		display: block;
	}
	.notes dt {
		border-radius: 20px 20px 0 0;
		width: 100%;
		font-size: 1.8rem;
		text-align: center;
	}
	.notes dd {
		width: 100%;
		font-size: 1.5rem;
	}
	#errMsg {
		padding: 1em 20px;
	}
}
@media screen and (max-width:640px) {
	body { 
		min-height: 100vh;
		position: relative;
		word-break: break-word;
	}
	.disp-pc { display: block; }
	.disp-sp { display: none; }
	header {
		margin: 0;
		padding: 0;
	}
	header .header-title {
		width: 100%;
	}
	header .header-logo {
		margin: 0;
		border-radius: 0;
	}
	header .header-logo img {
		width: 100%;
	}
	h1 {
		padding: 20px 0;
		font-size: 2.4rem;
	}
	h1::before {
		border-bottom-left-radius: 50px;
		border-bottom-right-radius: 50px;
	}
	h1 span {
		font-size: 2.0rem;
	}
	main {
		margin: 20px auto 40px;
		padding: 20px 0;
	}
	main .main-inner {
		padding: 0;
		width: 100%;
	}
	main .main-inner h2 {
		margin: 0 20px 20px;
		font-size: 1.8rem;
	}
	#errMsg {
		padding: 1em 20px;
	}
	footer { 
		margin: 30px 0 0;
		padding:25px 20px; 
		width:100%;
	}
	.notes {
		margin-bottom: 20px;
		padding: 0 20px;
	}
	.notes dl {
		margin: 0 auto 20px;
		display: block;
	}
	.notes dt {
		border-radius: 20px 20px 0 0;
		width: 100%;
		font-size: 1.8rem;
		text-align: center;
	}
	.notes dd {
		width: 100%;
		font-size: 1.5rem;
	}
	.notes ul {
		margin: 10px;
		padding-left: 1.25em;
	}
	.notes .txtlarge {
		font-size: 1.7rem;
	}
	.form-contents h2 {
		text-align: left;
	}
	.form-content-item { 
		width: 100%;
	}
	.form-content-head { 
		margin:0 0 10px;
		padding: 10px 20px;
		font-size: 1.5rem;
		vertical-align: middle;
	}
	.form-content-data {
		margin: 0;
		padding: 0 20px 20px;
		vertical-align: middle;
	}
	.form-content-data:last-of-type {
		padding-bottom: 10px;
	}
	.form-content-message {
		font-size:1.2rem;
	}
	.form-input,
	.form-select,
	.form-text {
		font-size: 1.6rem;
	}
	.form-input.min {
		width: 75%;
	}
	.form-input.mic {
		width: 80px;
	}
	.form-input.mid {
		width: 100%;
	}
	.form-select { 
		background: #ffffff url(../img/icn_dropdown_pc.png) right 2% top 50% no-repeat;
		width: auto;
		min-width: 200px;
	}
	.form-file {
		text-align: center;
	}
	.form-file-btn {
		margin: 0 auto 10px;
		padding: 10px 20px;
		font-size: 1.8rem;
	}
	.form-content-data .form-file-name {
		display: block;
		font-size: 1.6rem;
	}
	.form-submit { 
		padding: 0 20px;
	}
	.form-submit .submit {
		box-shadow: 2px 4px 0px 0px #000000;
		font-size: 2.0rem;
		width: 100%;
	}
	.confirm .form-content-data p {
		margin:5px 0;
	}
	.form-contents.content-textbox {
		padding: 0 20px 20px;
	}
	.form-contents.content-textbox h2 {
		margin: 0 0 20px;
	}
	.form-contents.content-textbox ul {
		padding: 0 0 0 1.5em;
	}
	.form-contents.content-textbox  p {
		font-size: 1.5rem;
	}
}
