@charset "utf-8";

html,
body {
	height: 100%;
	min-height: 100%;
	width: 100%;
	margin: 0;
	padding: 0;
	left: 0;
	top: 0;
}

body {
	animation: fadeIn 1s ease 0s 1 normal;
	-webkit-animation: fadeIn 1s ease 0s 1 normal;
	line-height: 1.8;
	margin: 0;
	color: #333333;
	position: relative;
	-webkit-touch-callout: none;
	user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-webkit-user-drag: none;
	-khtml-user-drag: none;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
}

.container {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

header {
	width: 100%;
}

.header {
	margin: 0 auto;
}

.title-header-area {
	height: 80px;
	display: flex;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
}

.maintitle-area,
.subtitle-area,
.garade-area {
	flex-basis: 100%;
}

.maintitle-area {
	text-align: center;
}

.img-header-subtitle,
.img-header-maintitle {
	height: 70px;
}

.main-area {
	padding: 1em;
	margin: 0 auto;
}

.first {
	background-color: #A8C6E8;
	text-align: center;
	color: #fff;
}

.second {
	background-color: #FCD68C;
	text-align: center;
	color: #fff;
}

.third {
	background-color: #BFDEAE;
	text-align: center;
	color: #fff;
}


.title-area {
	margin-top: 1em;
}

.title-img-area {
	text-align: center;
	padding: 1em 0;
}

.img-eyecatch {
	width: 78%;
	vertical-align: bottom;
}

.img-month {
	height: 50px;
	vertical-align: bottom;
}

.movie-area {
	padding: 0;
	text-align: center;
}

.p-movie {
	width: 78%;
}

.p-movie-l {
	width: 85%;
}

h3.text-title {
	font-size: 1.25em;
	margin-top: 1.5em;
	position: relative;
	padding: .5em 2em calc(0.5em + 10px);
	background: #fff100;
}

h3.text-title:before {
	position: absolute;
	top: -8px;
	left: -8px;
	width: 100%;
	height: 90%;
	content: '';
	border: 4px solid #000;
}

h3.modal-title {
	font-size: 1.15em;
	font-weight: bold;
	background: #ffd5e3;
	box-shadow: 0px 0px 0px 5px #ffd5e3;
	border: dashed 2px #fff;
	color: #333;
	padding: .5em .5em 0 .5em;
}

h3.main-title {
	width: calc(100% - 14px - 1em);
	background: #f08cc8;
	box-shadow: 0px 0px 0px 5px #f08cc8;
	border: dashed 2px #fff;
	color: #fff;
	padding: 0.2em 0.5em;
	font-size: 1.25em;
	margin: 1em auto;
}

/*
h4 {
	font-size: 1.25em;
	position: relative;
	padding: 1.5em 2em 1em 3em;
	border-bottom: 3px solid #000;
	margin: 2em 0 1.5em 0;
}

h4 span {
	font-size: 2.5em;
	position: absolute;
	bottom: -4px;
	left: 0;
	color: #043491;
}
*/

h4.title-plan {
	position: relative;
	padding: .5em .75em;
	background-color: #f0f0f0;
	border-radius: 6px;
	margin-bottom: 1.5em;
}

h4.title-plan::after {
	position: absolute;
	top: 100%;
	left: 30px;
	content: '';
	width: 0;
	height: 0;
	border: 10px solid transparent;
	border-top: 15px solid #f0f0f0;
}

.select-area {
	display: flex;
	flex-direction: column;
	text-align: center;
}

.img-btn {
	height: 60px;
}

.text-base {
	margin: 0;
}

.text-caution {
	margin: 2em 0 .5em 0;
}

.text-grade {
	font-weight: bold;
	font-size: 1.5em;
	text-align: right;
	padding: 0 1em;
}

.btn-area {
	display: flex;
	flex-direction: row;
}

.next-btn-area {
	display: flex;
	flex-direction: row;
	justify-content: flex-end;
}

.md-btn-area {
	width: 100%;
}

input {
	background: #fafafa;
	border: 1px solid #ccc;
	border-radius: 4px;
	padding: .5em 8px;
	margin: 2em 0;
	width: 12em;
	font-size: 1.25em;
}

input[type="number"]:focus {
	border: 1px solid #87cefa;
	box-shadow: 0 0 5px #87cefa;
	outline: 0;
}

button {
	border: none;
	padding: 0;
	border-radius: 8px;
	background: #efefef;
	padding: 8px;
	text-align: center;
	box-shadow: 2px 2px 4px #dcdddd;
	margin: .5em;
}

.btn-movie-area {
	text-decoration: none;
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 1em;
	margin: .25em 0;
}

.btn-movie,
.btn-start,
.btn-next {
	color: #fff;
	font-size: 1.15em;
	background: -moz-linear-gradient(top, #00A172, #7AC4A6);
	background: -webkit-linear-gradient(top, #00A172, #7AC4A6);
	background: linear-gradient(to bottom, #00A172, #7AC4A6);
	width: 100%;
	max-width: 240px;
	padding: 10px 0;
	animation: fadeIn 1s ease 0s 1 normal;
	-webkit-animation: fadeIn 1s ease 0s 1 normal;
	border-radius: 24px;
}

.btn-login,
.btn-cancel {
	text-decoration: none;
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 1em;
	margin: .25em 0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, .2);
	width: 80%;
	height: 54px;
}

.btn-login {
	background-color: #6a64b9;
}

.btn-cancel {
	background-color: #666;
}

.btn-link {
	display: inline-block;
	text-decoration: none;
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 1.25em;
	margin: .25em 0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, .2);
	width: 400px;
	background: -moz-linear-gradient(top, #00A172, #7AC4A6);
	background: -webkit-linear-gradient(top, #00A172, #7AC4A6);
	background: linear-gradient(to bottom, #00A172, #7AC4A6);
	border-radius: 8px;
	padding: .5em;
}

.btn-next-link {
	text-align: center;
	color: #fff;
	font-size: 1.15em;
	background: -moz-linear-gradient(top, #00A172, #7AC4A6);
	background: -webkit-linear-gradient(top, #00A172, #7AC4A6);
	background: linear-gradient(to bottom, #00A172, #7AC4A6);
	width: 100%;
	max-width: 240px;
	padding: .35em 0;
	animation: fadeIn 1s ease 0s 1 normal;
	-webkit-animation: fadeIn 1s ease 0s 1 normal;
	border-radius: 24px;
}

.item {
	padding: 0;
}

.exp-area {
	padding: 0;
	margin: 1em 0;
}

.information-area {
	background-color: aliceblue;
	border-radius: 8px;
	padding: 1em;
	margin: 1em 0;
	text-align: center;
}

img.img-exp {
	width: 100%;
	height: auto;
	margin: 1em 0;
}

button:focus {
	outline: none;
}

.enclosure {
	position: relative;
	margin: 2em auto 1em;
	padding: 1.2em;
	border: 3px solid #c8ebe5;
	background-color: #fff;
	box-shadow: 2px 2px 1px #dcdddd;
	border-radius: 8px;
}

.title-enclosure {
	position: absolute;
	left: 20px;
	top: -15px;
	padding: 0 .5em;
	font-weight: bold;
	font-size: 1.1em;
	color: #30cbd1;
	background-color: #fff;
}

p.text-base {
	font-size: 1em;
	padding: 6px 0;
}

p.text-note {
	font-size: .8em;
	margin-left: .8em;
	text-indent: -0.8em;
}

p.text-note:before {
	content: '※';
}

p.text-emphasis {
	color: red;
	font-weight: bold;
}

p.text-link {
	font-size: 1em;
	text-align: center;
	margin: 1em 0;
}

p.text-link a:hover {
	color: #e8380d;
	border: 1px solid #e8380d;
}

a {
	color: inherit;
	outline: none;
	text-decoration: none;
}

a.site-link {
	color: #00A172;
	border: 2px solid #00A172;
	padding: .25em 1em;
	border-radius: 20px;
}

.theme {
	font-size: 2em;
	font-weight: bold;
}

ul {
	padding-left: 1em 0;
}

.box-explanation {
	margin: 0;
	padding: 1em 0;
}

h4.box-title {
	border-bottom: 1px solid #333;
	color: #333;
	font-weight: bold;
}

.box-item {
	display: flex;
	flex-direction: row;
}

.box-text {
	max-width: 60%;
}

.box-image {
	width: 280px;
}

.box-image-item {
	width: 100%;
	vertical-align: bottom;
}

.image-answer {
	display: block;
	width: 60%;
	margin: 0 auto;
}

.accordion-container .accordion-title {
	background: -moz-linear-gradient(top, #00A172, #7AC4A6);
	background: -webkit-linear-gradient(top, #00A172, #7AC4A6);
	background: linear-gradient(to bottom, #00A172, #7AC4A6);
	color: #fff;
	border-radius: 8px;
	cursor: pointer;
	font-weight: bold;
	margin: 0;
	padding: 0.5em 0.5em 0.5em 1em;
	position: relative;
}

.accordion-content {
	background-color: #f4f9ff;
	text-align: center;
}

.accordion-container {
	padding: 0;
	margin: 0 auto;
}

ul {
	list-style: none;
}

ul.normal {
	list-style-type: disc;
	margin-left: 1.5em;
}

li {
	margin: 4px 0;
}

.accordion .inner {
	padding: 1em .5em;
	display: none;
}

.accordion p {
	cursor: pointer;
	position: relative;
}

p.number {
	font-size: 1.25em;
	font-weight: bold;
	margin-top: 1.5em;
}

.accordion-container .accordion-title::after {
	content: url(../images/down.svg);
	position: absolute;
	top: 12px;
	right: 16px;
	width: 20px;
	height: auto;
}

.accordion p.open::after {
	content: url(../images/up.svg);
	position: absolute;
	top: 12px;
	right: 16px;
	width: 20px;
	height: auto;
}

.accordion-container .accordion-title:hover {
	background-color: #acd171;
}

.display-none {
	display: none;
}

.md-perspective,
.md-perspective body {
	height: 100%;
	overflow: hidden;
}

.md-perspective body {
	background: #222;
	-webkit-perspective: 600px;
	-moz-perspective: 600px;
	perspective: 600px;
}

.md-modal {
	position: fixed;
	line-height: 1.8;
	width: 50%;
	height: auto;
	z-index: 2000;
	visibility: hidden;
}

.md-show {
	visibility: visible;
}

.md-overlay {
	position: fixed;
	width: 100%;
	height: 100%;
	visibility: hidden;
	top: 0;
	left: 0;
	z-index: 1000;
	opacity: 0;
	background: rgba(0, 0, 0, 0.65);
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
}

.md-show ~ .md-overlay {
	opacity: 1;
	visibility: visible;
}

.md-effect-1 .md-content {
	-webkit-transform: scale(0.7);
	-moz-transform: scale(0.7);
	-ms-transform: scale(0.7);
	transform: scale(0.7);
	opacity: 0;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
}

.md-show.md-effect-1 .md-content {
	-webkit-transform: scale(1);
	-moz-transform: scale(1);
	-ms-transform: scale(1);
	transform: scale(1);
	opacity: 1;
}

.md-content {
	text-align: center;
	padding: 1em;
	background-color: #fff;
	border-radius: 8px;
}

footer {
	width: 100%;
	height: 40px;
	background-color: #043491;
	display: flex;
	align-items: center;
	margin-top: auto;
}

.footer {
	margin: 0 auto;
	text-align: center;
}

.footer-text-area {
	margin: 0;
}

.text-muted {
	color: #fff;
	font-size: .75em;
	margin: 0;
}

#overlayResize {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.75);
}

.caution {
	position: absolute;
	width: 78%;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);
	z-index: 5002;
	display: none;
}

.caution-overlay {
	background-color: #fff !important;
	z-index: 5001 !important;
}

@media screen and (min-width:1025px) {

	.header,
	.main-area,
	.footer {
		width: 1024px;
	}

	.main-menu {
		width: 980px;
		margin: 0 auto;
	}

	.header .zkai-logo {
		left: 2em;
	}
}

@media screen and (max-width:812px) and (orientation: landscape) {
	h3.main-title {
		font-size: 1em;
		margin: 0 auto .5em;
	}

	.p-movie {
		width: auto;
		height: 62vh;
	}

	.p-movie-l {
		width: auto;
		height: 78vh;
	}
}

@media screen and (max-width:520px) {
	.title-header-area {
		height: auto;
		flex-direction: column;
	}

	.img-eyecatch {
		width: 100%;
	}

	.btn-login,
	.btn-cancel {
		width: 95%;
		height: 44px;
	}

	.img-btn {
		height: auto;
		width: 100%;
	}

	.img-header-subtitle,
	.img-header-maintitle {
		height: 50px;
		margin: .25em;
	}

	.md-modal {
		width: 90%;
	}

	.text-link {
		font-size: .8em;
	}

	h3.modal-title {
		font-size: 1em;
	}

	input {
		margin: 1.5em 0;
		font-size: 1em;
	}

	.btn-link {
		width: initial;
		display: block;
		padding: .25em;
	}

	.img-month {
		margin-bottom: 1em;
	}

	.theme {
		font-size: 1.5em;
	}

	.p-movie {
		width: 100%;
	}

	.image-answer {
		width: 100%;
		margin: 1em 0;
	}

	.box-item {
		flex-direction: column;
	}

	.box-text {
		max-width: inherit;
	}

	.box-image-item {
		margin: 1em 0;
	}
}
