@charset "utf-8";
/*
Theme Name: angel
Theme URI: 
Description: 
Author: jan39
Author URI: http://jan39.com

*/

.scroll_up {
	transition: 0.5s ease-in-out;
	transform: translateY(10px);
	opacity: 0;
}
.scroll_up.on {
	transform: translateY(0);
	opacity: 1.0;
}
.fade_in {
	transition: 0.7s ease-in-out;
	opacity: 0;
}
.fade_in.on {
	opacity: 1.0;
}

:root{
	--main-color: #70C5EF;
	--main-color2: #91DBFF;
	--main-color3: #AEE4FF;
	--sub-color: #FF9CC7;
	--white-color: #FFF;
}
* {
	min-height:0;
	min-width : 0;
}
.pc_none { display: none; }
.sp_none { display: block; }

body {
	font-family: "vdl-v7marugothic", sans-serif;
	font-weight: 600;
	font-style: normal;
	font-size: 18px;
	color: var(--main-color);
	line-height: 1.6;
	padding: 0;
	margin: 0;
	background-image: url(images/bg.jpg);
	background-size: contain;
}
h1, h2 {
	position: relative;
	font-family: "vdl-v7marugothic", sans-serif;
	font-size: 2.2rem;
	font-weight: bold;
	color: var(--sub-color);
	width: 400px;
	margin: 0 auto;
	text-align: center;
	padding-bottom: 10px;
	background: radial-gradient(circle, var(--sub-color) 45%, transparent 46%) bottom / 10px 3px repeat-x;
}
h1::before, h2::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
	height: 36px;
	background: url("images/title_l.png") no-repeat center / contain;
}
h1::after, h2::after {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
	height: 36px;
	background: url("images/title_r.png") no-repeat center / contain;
}
h3 {
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.4;
}
h4 {
	font-size: 1.5rem;
	font-weight: bold;
}
.wrap {
	width: 1200px;
	margin: 0 auto;
}
.wrap_min {
	width: 1024px;
	margin: 0 auto;
}
.inner {
	width: 75%;
	margin: 0 auto;
}
.w100 {
	width: 100%;
}
.wauto {
	width: auto;
}
.al_center {
	text-align: center;
}
.al_right {
	text-align: right;
}
.bold {
	font-weight: bold;
}

small {
	font-size: 80%;
}
a {
	text-decoration: none;
}
img {
	max-width: 100%;
}
p {
	margin: 0.8em 0;
}
dl {
	display: flex;
	gap: 40px;
	justify-content: center;
	align-items: center;
	margin: 40px 0;
	padding-bottom: 25px;
	background: radial-gradient(circle, var(--main-color) 45%, transparent 46%) bottom / 10px 3px repeat-x;
}
table {
	width: 100%;
}
th, td {
	padding: 10px 30px;
	border: 1px var(--main-color) solid;
}
th {
	background: var(--main-color);
	color: var(--white-color);
}
main {
}
section {
	position: relative;
	background: var(--white-color);
	border-radius: 30px 40px;
	padding: 30px;
	margin: 50px 0;
	box-shadow: 0 4px 12px rgba(112, 197, 239, 0.4);
}
header {
	position: relative;
}
.header_menu {
	background: var(--main-color);
	justify-content: center;
	display: flex;
	gap: 70px;
	border-radius: 30px;
	padding: 20px;
	position: absolute;
	width: 100%;
	bottom: -10px;
}
.header_menu a {
	font-family: kaisei-decol, sans-serif;
	font-weight: 600;
	color: var(--white-color);
	display: inline-flex;
	align-items: center;
	gap: 25px;
	text-decoration: none;
	font-size: 1.4rem;
}

.header_menu a::before,
.header_menu a::after {
  content: "";
  width: 20px;
  height: 20px;
  display: inline-block;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.header_menu a::before {
	background: url("images/menu_l.png") no-repeat center / contain;
}
.header_menu a::after {
	background: url("images/menu_r.png") no-repeat center / contain;
}
.head_reserve {
	position: absolute;
	right: -80px;
	bottom: 80px;
}
.head_reserve:hover {
	opacity: 0.9;
	transition: 0.5s;
}
footer {
	background: var(--main-color);
	color: var(--white-color);
	padding: 10px;
	line-height: 1.4;
}
footer ul {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 40px;
}
.footer_link img {
	margin: 0 5px;
}
.top_gallery {
	display: flex;
	gap: 30px;
	justify-content: center;
	text-align: center;
}
.top_gallery p {
	margin-bottom: 0;
}
.btn_reserve:hover {
	opacity: 0.9;
	transition: 0.5s;
}
.box_system {
	font-size: 1.3rem;
}
.system {
	display: flex;
	gap: 40px;
	align-items: center;
	justify-content: start;
	margin: 30px 0;
}
.system_chara {
	position: absolute;
	bottom: 0;
	right: 50px;
}
.sns {
	display: flex;
	gap: 40px;
	align-items: center;
	justify-content: center;
	margin: 30px 0 30px 200px;
}
.sns a:hover > img {
	opacity: 0.9;
	transition: 0.5s;
}
.sns_chara {
	position: absolute;
	bottom: 0;
	left: 0;
}
.box_rule {
	font-family: heisei-maru-gothic-std;
	font-weight: 400;
}
.box_rule p {
	text-align: center;
	color: var(--sub-color);
}
.rule {
	margin: 15px 0 15px 25px;
	line-height: 2;
}
.rule li {
	position: relative;
}
.rule li::before {
	content: "●";
	position: absolute;
	left: -1.5em;
	top: 0;
}
.img_rule {
	position: absolute;
	bottom: -20px;
	right: -140px;
}
.access {
	line-height: 2;
}
.access li:nth-of-type(4) {
	margin-top: 20px;
	color: var(--sub-color);
}
.img_access_logo {
	width: 320px;
}

@media screen and (max-width: 1500px) {
	.img_rule {
		right: -80px;
	}
}
@media screen and (max-width: 1400px) {
	.head_reserve {
		width: 120px;
		right: 0;
	}
	.img_rule {
		bottom: 0;
		right: 0;
		width: 150px;
	}
}
@media screen and (max-width: 1250px) {
	body {
		font-size: 0.95rem;
	}
	main {
		margin: 0 10px;
	}
	.wrap {
		width: calc(100% - 20px);
	}
	h1 {
		font-size: 1.8rem;
	}
	h2 {
		font-size: 1.8rem;
	}
	.system_chara {
		width: 160px;
		right: 0;
	}
	.sns {
		margin-left: 100px;
	}
	.sns_chara {
		width: 200px;
	}
}
@media screen and (max-width: 1024px) {
	.wrap_min {
		width: calc(100% - 20px);
	}
	.inner {
		width: 100%;
	}
	.header_menu a {
		font-size: 0.95rem;
	}
	footer {
		padding: 20px 20px 0;
	}
	footer ul {
		flex-wrap: wrap;
		gap: 0;
	}
	.footer_logo {
		margin: 0 15px;
	}
	footer ul li:nth-of-type(3), footer ul li:nth-of-type(4) {
		width: 100%;
		text-align: center;
	}
	footer ul li:nth-of-type(3) {
		margin-top: 20px;
	}
	.btn_reserve img {
		width: 420px;
	}
}
@media screen and (max-width: 800px) {
	section {
		padding: 20px 15px;
		margin: 30px 0;
	}
	.googlemaps {
		aspect-ratio: 16/9;
		height: auto;
	}
	h1, h2 {
		width: 100%;
		font-size: 1.6rem;
		padding-bottom: 5px;
	}
	h1::before, h2::before {
		width: 24px;
		height: 24px;
	}
	h1::after, h2::after {
		width: 24px;
		height: 24px;
	}
	h3 {
		font-size: 1.4rem;
	}
	h4 {
		font-size: 1.05rem;
	}
	dl {
		justify-content: start;
		gap: 10px;
		flex-wrap: wrap;
		margin: 20px 0;
	}
	dt {
		display: block;
		margin: 0 auto;
	}
	th, td {
		padding: 10px;
	}
	.header_menu {
		gap: 0;
		flex-wrap: wrap;
		padding: 5px 15px;
		position: relative;
		margin-top: -40px;
		z-index: 1;
	}
	.header_menu li {
		width: 50%;
	}
	.header_menu a {
		display: flex;
		justify-content: space-around;
		padding: 5px 0;
	}
	.head_reserve {
		position: fixed;
		width: 80px;
		right: 5px;
		bottom: 5px;
		z-index: 1;
	}
	footer {
		padding: 15px 0 0;
	}
	.footer_logo {
		margin: 0 10px;
	}
	.footer_logo img {
		width: 100px;
	}
	.top_gallery {
		gap: 20px;
		flex-wrap: wrap;
	}
	.box_system {
		font-size: 1.0rem;
	}
	.system {
		flex-wrap: wrap;
		gap: 10px;
	}
	.system li {
		width: 100%;
	}
	.system li:nth-of-type(1) {
		text-align: center;
	}
	.system_chara {
		width: 100px;
	}
	.tbl_system {
		margin-bottom: 60px;
	}
	.sns {
		flex-wrap: wrap;
		margin: 20px 0 100px;
		gap: 0;
	}
	.sns img {
		width: 150px;
	}
	.sns_chara {
		width: 140px;
	}
	.rule {
		margin-left: 20px;
		line-height: 1.6;
	}
	.img_rule {
		bottom: -60px;
		right: -10px;
		width: 100px;
	}
	.access {
		line-height: 1.6;
	}
	.img_access_logo {
		width: 200px;
	}
	.img_access_how {
		width: 100px;
	}
	.btn_reserve img {
		width: 320px;
	}
}
