* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.index_drag_and_drop {
	width: 100%;
	/*heightはbodyの高さを取得します*/
	position: absolute;
	overflow: hidden;
}


/*閉じるボタン*/
.btn {
	color: #fff;
	/* background: rgba(127, 194, 239, 1); */
	width: 30px;
	height: calc(30px + 2px);
	border-radius: 0 5px 0 0;
	text-align: center;
	display: table;
	cursor: pinter;
	z-index: 100;
	transition: background 0.1s;
}

.btn::before,
.btn::after {
	content: "";
	display: block;
	width: 20px;
	height: 2px;
	margin: 0 auto;
	background: #88a;
	border-radius: 5px;
	transition: background 0.1s;
}

.btn::before {
	margin-top: calc(30px - 0px - 50%);
	transform: rotate(45deg);
}

.btn::after {
	margin-top: calc(15px - 2px - 50%);
	transform: rotate(-45deg);
}

.btn:hover,
.btn:active {
	cursor: pinter;
	background: rgb(127, 194, 239);
}

.btn:hover::before,
.btn:hover::after,
.btn:active::before,
.btn:active::after {
	background: #fff;
}

.box {
	position: relative;
	border-radius: 5px;
	padding: 45px 1em;
	background: #fff;
	box-shadow: 0 2px 8px rgba(100, 100, 100, 0.5);
}

.box::before {
	content: "";
	display: block;
	position: absolute;
	box-sizing: border-box;
	top: 0;
	left: 0;
	width: 100%;
	height: 30px;
	background: #e0edff;
	border: 2px solid #e0edff;
	border-bottom: none;
	border-radius: 0px 0px 0 0;
}

.box_title {
	position: absolute;
	top: 0.55em;
	font-size: 0.7em;
	color: #333;
	font-weight: normal;
}

.index_box_text {
	font-family: 'M PLUS Rounded 1c', sans-serif;
	font-weight: bold;
	font-size: 0.85em;
}

.index_box_img {
	margin: 1em 0 -0.5em 0;
}


.box_title i {
	font-size: 1.5em;
	color: #777;
	vertical-align: middle;
	margin: 0 0.5em 0 -0.5em;
}

/* close button */
.action-close,
.action-close2,
.action-close3,
.action-close4 {
	position: relative;
	width: 250px;
}

.action-close .btn,
.action-close2 .btn,
.action-close3 .btn,
.action-close4 .btn {
	position: absolute;
	right: 0;
}

.action-close .box,
.action-close2 .box,
.action-close3 .box,
.action-close4 .box {
	border: 2px solid #e0edff;
}

/*チェックボックスを非表示に*/
.add-control .checkbox {
	display: none;
}

/*チェックボックスがonになったとき*/
.add-control .action-close #close:checked~.btn,
.add-control .action-close2 #close2:checked~.btn,
.add-control .action-close3 #close3:checked~.btn,
.add-control .action-close4 #close4:checked~.btn,

.add-control .action-close #close:checked~.box,
.add-control .action-close2 #close2:checked~.box,
.add-control .action-close3 #close3:checked~.box,
.add-control .action-close4 #close4:checked~.box {

	display: none;
}

/*各ボックスの位置調整*/
.box_position,
.box_position2,
.box_position3,
.box_position4 {
	position: absolute;
	opacity: 0;
	visibility: hidden;
}


.box_position.loaded_box {
	visibility: visible;
	top: 25em;
	left: 5%;
	animation: fade_in_box 1s ease 3s forwards;
}

.box_position2.loaded_box {
	visibility: visible;
	top: 28em;
	left: 7%;
	animation: fade_in_box 1s ease 3.5s forwards;
}

.box_position3.loaded_box {
	visibility: visible;
	top: 31em;
	left: 9%;
	animation: fade_in_box 1s ease 4s forwards;
}

.box_position4.loaded_box {
	visibility: visible;
	top: 34em;
	left: 11%;
	animation: fade_in_box 1s ease 4.5s forwards;
}

@keyframes fade_in_box {
	0% {
		opacity: 0;
		transform: translatey(30px);
	}

	100% {
		opacity: 1;
		transform: translatey(0px);
	}
}


/*boxをつかめるようにする＆カーソル*/
.drag-and-drop {
	cursor: move;
	position: absolute;
	z-index: 100;
}

/*.drag {
	z-index: 101;
}*/
/*ドラッグしているあいだ、ボックスを前面に出す*/


/*隠してるボックスを表示させるためのボタン*/
.open_drag-and-drop_button {
	padding: 0.7em 5em 0.8em 1em;
	background: rgba(224, 237, 255, 0.6);
	/* border: 5px solid rgb(224, 237, 255); */
	border-right: transparent;
	border-radius: 50px 0px 0px 50px;
	box-shadow: -1px 2px 3px 2px rgba(255, 255, 255, 0.5) inset,
		-5px -1px 5px 3px rgba(0, 0, 100, 0.1) inset,
		0px 0px 5px 5px rgba(224, 237, 255, 0.7) inset;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	color: #666;
	font-size: 1.2em;
	font-family: 'Fredoka One';
	text-align: center;
	letter-spacing: 0.02em;
	position: absolute;
	right: -14em;
	top: 8.5vh;
	z-index: 1000;
	cursor: pointer;
}

.open_drag-and-drop_button::after {
	content: "";
	display: block;
	position: absolute;
	top: 7px;
	left: 10px;
	width: 15px;
	height: 13px;
	background: rgba(255, 255, 255, 0.4);
	border-radius: 15px 10px 15px 10px;
}

.open_drag-and-drop_button.loaded_box {
	right: -4em;
	transition: right 1s cubic-bezier(0.65, 0.11, 0.22, 1.29) 3s;
}

.open_drag-and-drop_button.loaded_box.opened_drag-and-drop {
	background: rgba(127, 194, 239, 0.7);
	/* border: 5px solid rgb(127, 194, 239); */
	border-right: transparent;
	box-shadow: -1px 2px 3px 2px rgba(255, 255, 255, 0.5) inset,
		-5px -1px 5px 3px rgba(0, 0, 100, 0.1) inset,
		0px 0px 0px 5px rgba(127, 194, 239, 0.1) inset;
	backdrop-filter: blur(10px);
	color: #fff;
	right: -14em;
	transition: right 1s cubic-bezier(0.96, -0.29, 0.43, 0.94) 1.2s,
		background 0.3s ease 0.2s,
		border 0.3s ease 0.2s,
		box-shadow 0.3s ease 0.2s,
		color 0.3s ease 0.2s;
}

.notice {
	display: inline-block;
	width: 1.2em;
	height: 1.2em;
	margin: 0 0.3em;
	background: rgb(240, 10, 10);
	border-radius: 50%;
	color: #eee;
	font-family: 'Franklin Gothic Medium', 'Arial Narrow', Arial, sans-serif;
	font-weight: bold;
	text-align: center;
}


/****************
レスポンシブの記述
*****************/
@media screen and (max-width:1050px) and (min-width:600px) {
	.box_position.loaded_box {
		top: 25em;
		left: 3%;
	}

	.box_position2.loaded_box {
		top: 28em;
		left: 5%;
	}

	.box_position3.loaded_box {
		top: 31em;
		left: 7%;
	}

	.box_position4.loaded_box {
		top: 34em;
		left: 9%;
	}
}

@media screen and (max-width:599px) {
	.box_title {
		font-size: 0.5em;
		top: 0.75em;
	}

	.index_box_text {
		font-size: 0.7em;
		line-height: 1.6;
	}

	.action-close,
	.action-close2,
	.action-close3,.action-close4 {
		width: 170px;
	}

	.box_position.loaded_box {
		top: 10em;
		left: 2%;
	}

	.box_position2.loaded_box {
		top: 12.3em;
		left: 8%;
	}

	.box_position3.loaded_box {
		top: 14.6em;
		left: 14%;
	}

	.box_position4.loaded_box {
		top: 16.9em;
		left: 20%;
	}
}