html {
	overflow-x: hidden;
}

body {
	overflow-x: hidden;
	background: #fff;
	color: #003d63;
	font-size: 1.6rem;
	line-height: 2.1em;
	letter-spacing: 0.07em;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	font-style: normal;
	text-align: center;
	transition: all 0.3s;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	font-feature-settings: "palt";
}

body .mfp-bg {
	background: #fff;
	opacity: 0.9;
}

body .mfp-wrap {
	cursor: pointer;
}

body .mfp-wrap::before,
body .mfp-wrap::after {
	content: "";
	position: absolute;
	top: -2px;
	right: 0;
	width: 124px;
	height: 1px;
	background-color: #003d63;
	display: inline-block;
	transition: 0.4s;
	box-sizing: border-box;
	transform-origin: top right;
	pointer-events: none;
}

body .mfp-wrap:before {
	transform: translateY(89px) rotate(45deg);
}

body .mfp-wrap:after {
	transform: rotate(-45deg);
}

body button.mfp-close {
	display: none;
}

a {
	transition: all 0.3s;
	text-decoration: none;
	color: #8650a9;
}

a:hover {
	color: #fea0ae;
}

a > img {
	transition: all 0.3s;
}

h1,
h2,
h3,
h4,
p,
dl,
dt,
dd,
strong,
em {
	margin: 0;
	padding: 0;
	font-size: inherit;
	line-height: inherit;
	font-weight: inherit;
	font-style: inherit;
}

ul,
ol,
dl,
dt,
dd {
	list-style: none;
	margin: 0;
	padding: 0;
}

li {
	list-style: inherit;
	margin: 0;
	padding: 0;
}

img,
video {
	box-sizing: border-box;
	outline: none;
	max-width: 100%;
	font-size: 1px !important;
	line-height: 0 !important;
	vertical-align: middle;
}

figure {
	outline: none;
	margin: 0;
	padding: 0;
	max-width: 100%;
}

pre,
code {
	box-sizing: border-box;
	overflow: auto;
	margin: 0;
	border: 1px solid rgba(0, 61, 99, 0.4);
	padding: 10px 20px;
	max-height: 200px;
	background: rgba(0, 61, 99, 0.1);
	font-size: inherit;
	line-height: 1.4em;
	font-family: inherit;
	font-weight: inherit;
	font-style: italic;
}

rt {
	position: absolute;
	transform: translateY(0.2em);
}

hr {
	display: block;
	margin: 30px 0;
	border: none;
	width: 100%;
	height: 1px;
	background: #003d63;
}

#Cover {
	position: fixed;
	left: 0;
	top: 0;
	z-index: -1;
	opacity: 0;
	width: 100%;
	height: 100%;
	background: #fff;
	text-align: center;
}

#Cover .anime {
	opacity: 0;
	display: block;
	width: auto;
	position: absolute;
	left: 50%;
	top: 50%;
	width: 100%;
	max-width: 700px;
	filter: blur(12px);
	transform: translate(-50%, -50%);
	transition: all 0.4s;
}

#Cover .anime.show {
	opacity: 1;
	filter: blur(0);
	transition: all 0.4s;
}

#Cover.show {
	z-index: 60000;
	opacity: 1;
}

.c-particle {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: calc(100% + 480px);
	overflow: hidden;
	z-index: -4;
}

.c-particle li {
	position: absolute;
	transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1);
	transform-origin: center center;
	width: 100%;
	background-size: 800px, 800px;
	background-position: left top, right top;
	background-repeat: no-repeat, no-repeat;
}

.c-particle li.particle01 {
	max-width: none;
	aspect-ratio: 800/3100;
	background-image: url(../img/bg_noise01_left_pc.png), url(../img/bg_noise01_right_pc.png);
}

.c-particle li.particle02 {
	max-width: none;
	aspect-ratio: 800/3100;
	background-image: url(../img/bg_noise02_left_pc.png), url(../img/bg_noise02_right_pc.png);
}

.c-particle li:nth-child(2n) {
	transition-duration: 2s;
}

.c-particle li:nth-child(3n+1) {
	left: 0;
}

.c-particle li:nth-child(3n+2) {
	right: auto;
	left: 0;
}

.c-particle li:nth-child(3n+3) {
	left: 0;
	transform: none;
}

.c-particle li:nth-child(1),
.c-particle li:nth-child(2) {
	top: 8.4%;
}

.c-particle li:nth-child(3),
.c-particle li:nth-child(4) {
	top: 48%;
}

.c-title {
	width: 100%;
	height: -moz-fit-content;
	height: fit-content;
	color: #8650a9;
	font-family: "Josefin Sans", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 4.8em;
	letter-spacing: 0.02em;
	text-align: left;
	position: relative;
	box-sizing: border-box;
	padding-left: 32px;
	padding-bottom: 16px;
}

.c-title::before,
.c-title:after {
	content: "";
	display: block;
	position: absolute;
	background-color: #8650a9;
}

.c-title::before {
	top: 24%;
	left: 0;
	transform: translateY(-50%);
	width: 20px;
	height: 6px;
}

.c-title::after {
	bottom: 0;
	left: 70px;
	width: calc(100% - 40px);
	height: 2px;
}

.c-title._col {
	letter-spacing: 0.07em;
	transform-origin: 0 0;
	transform: rotate(90deg);
}

.c-bnr {
	position: relative;
	right: 0;
	width: 100%;
	z-index: 100;
	opacity: 0;
	transform: translateY(100px);
	transition: all 0.4s ease;
}

.c-bnr.is-float {
	position: fixed;
	opacity: 1;
	bottom: 0;
	transform: translateY(0);
}

.c-bnr.is-set {
	position: relative;
	bottom: auto;
	opacity: 1;
	transform: translateY(0);
}

.c-bnr__img {
	position: relative;
	width: 100%;
	display: block;
}

.c-bnr__img img {
	display: block;
	width: 100%;
}

.l-inner {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 40px;
	box-sizing: border-box;
}

.l-detail {
	position: relative;
	box-sizing: border-box;
	padding: 40px 0;
	z-index: 1;
}

.l-detail::before,
.l-detail::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: calc(50% - 50vw);
}

.l-detail::before {
	background: #003d63;
	width: 100vw;
	height: 100%;
	z-index: -2;
}

.l-detail::after {
	display: block;
	width: 338px;
	height: 338px;
	clip-path: polygon(0 0, 0 100%, 100% 0);
	background-color: #fea0ae;
	z-index: -1;
}

.l-detail .local-nav {
	left: -10px;
}

.l-detail .local-nav ul > li {
	margin: 10px;
}

.l-detail > .inner {
	margin-right: calc(50% - 50vw + 7px);
}

.l-detail > .inner > header {
	position: relative;
	z-index: 1;
	padding: 50px 80px;
	margin-bottom: -2px;
	background: linear-gradient(transparent 0, #f2f3f5 0), linear-gradient(transparent 0, #f2f3f5 0), linear-gradient(transparent 0, #f2f3f5 0), linear-gradient(135deg, transparent 15px, #f2f3f5 15px);
	background-position: bottom left, bottom right, top right, top left;
	background-size: 51% 51%;
	background-repeat: no-repeat;
}

.l-detail > .inner > header h1 {
	font-size: 1.25em;
	letter-spacing: 0.075em;
	line-height: 1.85em;
	display: block;
}

.l-detail > .inner > .contents {
	background-color: #dae3eb;
	box-sizing: border-box;
	padding: 52px 80px 80px;
}

@media screen and (max-width: 768px) {

body {
	font-size: 2.4rem;
	letter-spacing: 0.075em;
}

a:hover {
	color: #8650a9;
}

hr {
	margin: 40px 0;
	height: 2px;
}

.c-particle {
	height: calc(100% + 900px);
}

.c-particle li {
	background-size: 100%;
	background-position: center;
	background-repeat: no-repeat;
}

.c-particle li.particle01 {
	aspect-ratio: 750/6100;
	background-image: url(../img/bg_noise01_sp.png);
}

.c-particle li.particle02 {
	aspect-ratio: 750/6100;
	background-image: url(../img/bg_noise02_sp.png);
}

.c-particle li:nth-child(1),
.c-particle li:nth-child(2) {
	top: 1.4%;
}

.c-title {
	font-size: 3.3em;
	letter-spacing: 0;
	padding-bottom: 7px;
}

.c-title::before {
	top: 34%;
}

.c-title._col {
	letter-spacing: 0.05em;
}

.l-detail::after {
	width: 338px;
	height: 338px;
}

.l-detail .local-nav {
	left: -5px;
}

.l-detail .local-nav ul > li {
	margin: 10px 5px;
}

.l-detail > .inner {
	width: calc(100% + 50px);
	margin-right: 0;
	margin-left: -10px;
}

.l-detail > .inner > header {
	background: linear-gradient(transparent 0, #f2f3f5 0), linear-gradient(transparent 0, #f2f3f5 0), linear-gradient(transparent 0, #f2f3f5 0), linear-gradient(135deg, transparent 20px, #f2f3f5 20px);
	background-position: bottom left, bottom right, top right, top left;
	background-size: 52% 52%;
	background-repeat: no-repeat;
	padding: 44px 40px;
}

.l-detail > .inner > header h1 {
	font-size: 1.28em;
	letter-spacing: 0.06em;
}

.l-detail > .inner > .contents {
	padding: 64px 40px 78px;
}

}


/*# sourceMappingURL=../map/common.css.map */
