/*! sanitize.css v5.0.0 | CC0 License | github.com/jonathantneal/sanitize.css */
*, ::before, ::after {
	background-repeat: no-repeat;
	box-sizing: inherit
}

::before, ::after {
	text-decoration: inherit;
	vertical-align: inherit
}

html {
	box-sizing: border-box;
	cursor: default;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%
}

article, aside, footer, header, nav, section {
	display: block
}

body {
	margin: 0
}

h1 {
	font-size: 2em;
	margin: .67em 0
}

figure, main {
	display: block
}

figure {
	margin: 1em 40px
}

hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible
}

nav ol, nav ul {
	list-style: none
}

pre {
	font-family: monospace, monospace;
	font-size: 1em
}

a {
	background-color: transparent;
	-webkit-text-decoration-skip: objects
}

abbr[title] {
	border-bottom: 0;
	text-decoration: underline
}

b, strong {
	font-weight: bolder
}

code, kbd, samp {
	font-family: monospace, monospace;
	font-size: 1em
}

dfn {
	font-style: italic
}

mark {
	background-color: #ff0;
	color: #000
}

small {
	font-size: 80%
}

sub, sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline
}

sub {
	bottom: -.25em
}

sup {
	top: -.5em
}

::-moz-selection {
	background-color: #b3d4fc;
	color: #000;
	text-shadow: none
}

::selection {
	background-color: #b3d4fc;
	color: #000;
	text-shadow: none
}

audio, canvas, iframe, img, svg, video {
	vertical-align: middle
}

audio, video {
	display: inline-block
}

audio:not([controls]) {
	display: none;
	height: 0
}

img {
	border-style: none
}

svg {
	fill: currentColor
}

svg:not(:root) {
	overflow: hidden
}

table {
	border-collapse: collapse
}

button, input, optgroup, select, textarea {
	margin: 0
}

button, input, select, textarea {
	color: inherit;
	font-family: inherit;
	font-size: inherit;
	line-height: inherit
}

button, input {
	overflow: visible
}

button, select {
	text-transform: none
}

button, html [type="button"], [type="reset"], [type="submit"] {
	-webkit-appearance: none
}

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
}

legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal
}

progress {
	display: inline-block;
	vertical-align: baseline
}

textarea {
	overflow: auto;
	resize: vertical
}

[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-cancel-button, [type="search"]::-webkit-search-decoration {
	-webkit-appearance: none
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit
}

details, menu {
	display: block
}

summary {
	display: list-item
}

canvas {
	display: inline-block
}

template {
	display: none
}

a, area, button, input, label, select, summary, textarea, [tabindex] {
	touch-action: manipulation
}

[hidden] {
	display: none
}

[aria-busy="true"] {
	cursor: progress
}

[aria-controls] {
	cursor: pointer
}

[aria-hidden="false"][hidden]:not(:focus) {
	clip: rect(0, 0, 0, 0);
	display: inherit;
	position: absolute
}

[aria-disabled] {
	cursor: default
}

html {
	-ms-overflow-style: scrollbar
}

.slick-slider {
	position: relative;
	display: block;
	box-sizing: border-box;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	touch-action: pan-y;
	-webkit-tap-highlight-color: transparent
}

.slick-list {
	position: relative;
	overflow: hidden;
	display: block;
	margin: 0;
	padding: 0
}

.slick-list:focus {
	outline: none
}

.slick-list.dragging {
	cursor: pointer;
	cursor: hand
}

.slick-slider .slick-track, .slick-slider .slick-list {
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0)
}

.slick-track {
	position: relative;
	left: 0;
	top: 0;
	display: block;
	margin-left: auto;
	margin-right: auto
}

.slick-track:before, .slick-track:after {
	content: "";
	display: table
}

.slick-track:after {
	clear: both
}

.slick-loading .slick-track {
	visibility: hidden
}

.slick-slide {
	float: left;
	height: 100%;
	min-height: 1px;
	display: none
}

[dir="rtl"] .slick-slide {
	float: right
}

.slick-slide img {
	display: block
}

.slick-slide.slick-loading img {
	display: none
}

.slick-slide.dragging img {
	pointer-events: none
}

.slick-initialized .slick-slide {
	display: block
}

.slick-loading .slick-slide {
	visibility: hidden
}

.slick-vertical .slick-slide {
	display: block;
	height: auto;
	border: 1px solid transparent
}

.slick-arrow.slick-hidden {
	display: none
}

/*! Lity - v2.4.1 - 2020-04-26
* http://sorgalla.com/lity/
* Copyright (c) 2015-2020 Jan Sorgalla; Licensed MIT */
.lity {
	z-index: 9990;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	white-space: nowrap;
	background: #0b0b0b;
	background: rgba(0, 0, 0, 0.9);
	outline: none !important;
	opacity: 0;
	transition: opacity 0.3s ease
}

.lity.lity-opened {
	opacity: 1
}

.lity.lity-closed {
	opacity: 0
}

.lity * {
	box-sizing: border-box
}

.lity-wrap {
	z-index: 9990;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	text-align: center;
	outline: none !important
}

.lity-wrap:before {
	content: '';
	display: inline-block;
	height: 100%;
	vertical-align: middle;
	margin-right: -0.25em
}

.lity-loader {
	z-index: 9991;
	color: #fff;
	position: absolute;
	top: 50%;
	margin-top: -0.8em;
	width: 100%;
	text-align: center;
	font-size: 14px;
	font-family: Arial, Helvetica, sans-serif;
	opacity: 0;
	transition: opacity 0.3s ease
}

.lity-loading .lity-loader {
	opacity: 1
}

.lity-container {
	z-index: 9992;
	position: relative;
	text-align: left;
	vertical-align: middle;
	display: inline-block;
	white-space: normal;
	max-width: 100%;
	max-height: 100%;
	outline: none !important
}

.lity-content {
	z-index: 9993;
	width: 100%;
	-webkit-transform: scale(1);
	transform: scale(1);
	transition: -webkit-transform 0.3s ease;
	transition: transform 0.3s ease;
	transition: transform 0.3s ease, -webkit-transform 0.3s ease
}

.lity-loading .lity-content, .lity-closed .lity-content {
	-webkit-transform: scale(0.8);
	transform: scale(0.8)
}

.lity-content:after {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	display: block;
	right: 0;
	width: auto;
	height: auto;
	z-index: -1;
	box-shadow: 0 0 8px rgba(0, 0, 0, 0.6)
}

.lity-close {
	z-index: 9994;
	width: 35px;
	height: 35px;
	position: fixed;
	right: 0;
	top: 0;
	-webkit-appearance: none;
	cursor: pointer;
	text-decoration: none;
	text-align: center;
	padding: 0;
	color: #fff;
	font-style: normal;
	font-size: 35px;
	font-family: Arial, Baskerville, monospace;
	line-height: 35px;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
	border: 0;
	background: none;
	outline: none;
	box-shadow: none
}

.lity-close::-moz-focus-inner {
	border: 0;
	padding: 0
}

.lity-close:hover, .lity-close:focus, .lity-close:active, .lity-close:visited {
	text-decoration: none;
	text-align: center;
	padding: 0;
	color: #fff;
	font-style: normal;
	font-size: 35px;
	font-family: Arial, Baskerville, monospace;
	line-height: 35px;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
	border: 0;
	background: none;
	outline: none;
	box-shadow: none
}

.lity-close:active {
	top: 1px
}

.lity-image img {
	max-width: 100%;
	display: block;
	line-height: 0;
	border: 0
}

.lity-iframe .lity-container, .lity-youtube .lity-container, .lity-vimeo .lity-container, .lity-facebookvideo .lity-container, .lity-googlemaps .lity-container {
	width: 100%;
	max-width: 964px
}

.lity-iframe-container {
	width: 100%;
	height: 0;
	padding-top: 56.25%;
	overflow: auto;
	pointer-events: auto;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-overflow-scrolling: touch
}

.lity-iframe-container iframe {
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
	background: #000
}

.lity-hide {
	display: none
}

.slick-dotted.slick-slider {
	margin: 0
}

.slick-dots {
	position: static;
	bottom: auto;
	list-style: none;
	display: flex;
	text-align: center;
	padding: 0;
	margin: 0;
	width: 100%;
	align-items: center;
	justify-content: center;
	padding: 2rem 0
}

.slick-dots li {
	position: relative;
	display: block;
	height: 2rem;
	width: 2rem;
	margin: 0 .5rem;
	padding: 0;
	cursor: pointer
}

.slick-dots li button {
	border: 0;
	background: transparent;
	display: block;
	height: 2rem;
	width: 2rem;
	outline: none;
	line-height: 0px;
	font-size: 0px;
	color: transparent;
	padding: 0;
	cursor: pointer
}

.slick-dots li button:hover, .slick-dots li button:focus {
	outline: none
}

.slick-dots li button:hover:before, .slick-dots li button:focus:before {
	opacity: 1
}

.slick-dots li button:before {
	position: absolute;
	top: 50%;
	left: 50%;
	content: '';
	transition: background-color .2s ease;
	width: 1.5rem;
	height: 1.5rem;
	background-color: rgba(0, 0, 0, 0.125);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	border-radius: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%)
}

.slick-dots li.slick-active button:before {
	background-color: #000;
	opacity: .85
}

.lity {
	background-color: rgba(255, 255, 255, 0.8)
}

@media (min-width: 768px) {
	.lity .lity-wrap {
		left: 9rem
	}
}

.lity .lity-close {
	text-shadow: none;
	position: absolute;
	color: #fff;
	text-indent: -99999px;
	top: 0rem;
	right: 0rem;
	width: 5rem;
	height: 5rem;
	cursor: pointer;
	overflow: hidden
}

::-moz-selection {
	background: #99D2DC;
	color: #fff
}

::selection {
	background: #99D2DC;
	color: #fff
}

html {
	position: relative;
	font-size: 2.416vw
}

@media (min-width: 768px) {
	html {
		font-size: 0.725vw
	}
}

@media (min-width: 992px) {
	html {
		font-size: 0.6945vw
	}
}

@media (min-width: 1440px) {
	html {
		font-size: 62.5%
	}
}

body {
	background: #fff;
	color: #000;
	font-family: YakuHanJP, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	letter-spacing: .07em;
	line-height: 1.78;
	-webkit-font-smoothing: subpixel-antialiased;
	-moz-osx-font-smoothing: unset;
	font-size: 1.3rem;
	font-weight: 500
}

@media only screen and (-webkit-min-device-pixel-ratio: 2), (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
	body {
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale
	}
}

@media (min-width: 768px) {
	body {
		font-size: 1.4rem
	}
}

html {
	min-height: 100%;
	display: flex
}

body {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	width: 100%
}

#wpadminbar {
	position: fixed !important
}

body.admin-bar .l-header {
	top: 46px !important
}

@media screen and (min-width: 782px) {
	body.admin-bar .l-header {
		top: 32px !important
	}
}

#colophon, footer {
	flex-shrink: 0;
	margin: auto 0 0
}

#content, main {
	display: block;
	width: 100%;
	flex: 1 0 auto;
	min-height: 1px
}

h1, h2, h3, h4 {
	line-height: 1.45
}

p {
	line-height: 2.2;
	margin: 0 0 1em;
	font-size: 1.3rem
}

@media (min-width: 768px) {
	p {
		font-size: 1.4rem
	}
}

img {
	max-width: 100%;
	height: auto
}

ul, ol {
	margin: 0 0 3em;
	padding: 0 0 0 2em
}

ul li, ol li {
	margin: 0 0 0.5em
}

a ::-moz-selection {
	background-color: #F7F7F7;
	color: #99D2DC
}

a ::selection {
	background-color: #F7F7F7;
	color: #99D2DC
}

@font-face {
	font-family: 'NotoSansJP';
	font-weight: 400;
	font-style: normal;
	font-display: swap;
	src: url("../font/NotoSansJP-Regular.woff2") format("woff2"), url("../font/NotoSansJP-Regular.woff") format("woff"), url("../font/NotoSansJP-Regular.otf") format("opentype")
}

@font-face {
	font-family: 'NotoSansJP';
	font-weight: 500;
	font-style: normal;
	font-display: swap;
	src: url("../font/NotoSansJP-Medium.woff2") format("woff2"), url("../font/NotoSansJP-Medium.woff") format("woff"), url("../font/NotoSansJP-Medium.otf") format("opentype")
}

@font-face {
	font-family: 'NotoSansJP';
	font-weight: 700;
	font-style: normal;
	font-display: swap;
	src: url("../font/NotoSansJP-Black.woff2") format("woff2"), url("../font/NotoSansJP-Black.woff") format("woff"), url("../font/NotoSansJP-Black.otf") format("opentype")
}

@font-face {
	font-family: 'YakuHanJP';
	font-weight: normal;
	font-style: normal;
	src: url("../font/YakuHanJP-Regular.woff2") format("woff2"), url("../font/YakuHanJP-Regular.woff") format("woff")
}

@font-face {
	font-family: 'YakuHanJP';
	font-weight: bold;
	font-style: normal;
	src: url("../font/YakuHanJP-Bold.woff2") format("woff2"), url("../font/YakuHanJP-Bold.woff") format("woff")
}

.page-loader {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	background-color: #fff;
	z-index: 999;
	will-change: transform
}

body.loaded .page-loader {
	-webkit-animation: slide-away 1.25s cubic-bezier(0.165, 0.84, 0.44, 1) 0ms forwards;
	animation: slide-away 1.25s cubic-bezier(0.165, 0.84, 0.44, 1) 0ms forwards;
	pointer-events: none
}

body.hold .page-loader {
	-webkit-animation: fade-in 300ms linear forwards 0ms;
	animation: fade-in 300ms linear forwards 0ms;
	pointer-events: all
}

.page-loader__innr {
	display: flex;
	position: relative;
	align-items: center;
	height: 100%;
	justify-content: center;
	width: 50%;
	max-width: 10rem;
	margin: 0 auto;
	z-index: 1;
	opacity: 0;
	-webkit-transform: translate3d(-5rem, 0, 0);
	transform: translate3d(-5rem, 0, 0);
	transition: opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear;
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1)
}

@media (min-width: 768px) {
	.page-loader__innr {
		width: 33.3333%
	}
}

body.init .page-loader__innr {
	opacity: 1;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0)
}

.page-loader__content {
	width: 100%;
	position: relative;
	color: #000
}

.page-loader__content::before, .page-loader__content::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 2;
	background-color: #fff;
	transition: -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition-delay: 100ms
}

.page-loader__content::after {
	background-color: rgba(255, 255, 255, 0.4);
	transition-delay: 500ms
}

body.init .page-loader__content {
	-webkit-animation: slide-away .75s cubic-bezier(0.165, 0.84, 0.44, 1) 2s forwards;
	animation: slide-away .75s cubic-bezier(0.165, 0.84, 0.44, 1) 2s forwards
}

body.init .page-loader__content::before, body.init .page-loader__content::after {
	-webkit-transform: translate3d(101%, 0, 0);
	transform: translate3d(101%, 0, 0)
}

.page-loader__svg {
	position: relative;
	z-index: 1;
	display: block;
	width: 100%;
	height: auto;
	fill: currentColor
}

@-webkit-keyframes slide-away {
	0% {
		display: block;
		opacity: 1;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0)
	}

	99% {
		opacity: 0;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0)
	}

	100% {
		opacity: 0;
		display: none;
		-webkit-transform: translate3d(101%, 0, 0);
		transform: translate3d(101%, 0, 0)
	}
}

@keyframes slide-away {
	0% {
		display: block;
		opacity: 1;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0)
	}

	99% {
		opacity: 0;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0)
	}

	100% {
		opacity: 0;
		display: none;
		-webkit-transform: translate3d(101%, 0, 0);
		transform: translate3d(101%, 0, 0)
	}
}

@-webkit-keyframes fade-in {
	0% {
		display: none;
		-webkit-transform: translate3d(101%, 0, 0);
		transform: translate3d(101%, 0, 0);
		opacity: 0
	}

	1% {
		display: block;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 0
	}

	100% {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 1;
		display: block
	}
}

@keyframes fade-in {
	0% {
		display: none;
		-webkit-transform: translate3d(101%, 0, 0);
		transform: translate3d(101%, 0, 0);
		opacity: 0
	}

	1% {
		display: block;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 0
	}

	100% {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 1;
		display: block
	}
}

@-webkit-keyframes fade-out {
	0% {
		display: block;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 1
	}

	99% {
		display: block;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 0
	}

	100% {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 0;
		display: none
	}
}

@keyframes fade-out {
	0% {
		display: block;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 1
	}

	99% {
		display: block;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 0
	}

	100% {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		opacity: 0;
		display: none
	}
}

.l-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 10
}

.l-content {
	padding: 6rem 0 0;
	width: 100%;
	overflow: hidden
}

@media (min-width: 768px) {
	.l-content {
		padding: 9rem 0 0 9rem
	}
}

.l-aside {
	display: none
}

@media (min-width: 768px) {
	.l-aside {
		display: block;
		position: fixed;
		width: 9rem;
		top: 0;
		left: 0;
		overflow: hidden;
		z-index: 8;
		background-color: #fff;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		height: 100vh
	}
}

.l-footer {
	position: relative;
	z-index: 1
}

@media (min-width: 768px) {
	.l-footer {
		padding: 0 0 0 9rem
	}
}

.l-page {
	overflow: hidden
}

.l-container {
	width: 100%;
	padding: 0 2rem
}

@media (min-width: 768px) {
	.l-container {
		padding: 0;
		max-width: 125rem;
		margin: 0 auto
	}
}

.l-wrap {
	display: block;
	margin: 5rem 0
}

.l-innr {
	padding: 6rem 2rem;
	margin: 0 auto
}

@media (min-width: 768px) {
	.l-innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

.l-innr--no-pt {
	padding: 6rem 2rem;
	margin: 0 auto;
	padding-top: 0 !important
}

@media (min-width: 768px) {
	.l-innr--no-pt {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

.l-innr--no-pb {
	padding: 6rem 2rem;
	margin: 0 auto;
	padding-bottom: 0 !important
}

@media (min-width: 768px) {
	.l-innr--no-pb {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

.l-row {
	margin: 0 0 -6rem
}

@media (min-width: 768px) {
	.l-row {
		display: flex;
		margin: 0 -2.3rem -6rem
	}
}

.l-row--reverse-pc {
	margin: 0 0 -6rem
}

@media (min-width: 768px) {
	.l-row--reverse-pc {
		display: flex;
		margin: 0 -2.3rem -6rem
	}
}

@media (min-width: 768px) {
	.l-row--reverse-pc {
		flex-flow: row-reverse
	}
}

.l-row--align-center {
	margin: 0 0 -6rem
}

@media (min-width: 768px) {
	.l-row--align-center {
		display: flex;
		margin: 0 -2.3rem -6rem
	}
}

@media (min-width: 768px) {
	.l-row--align-center {
		align-items: center
	}
}

.l-row__col--1 {
	display: block;
	min-height: 1px;
	width: 100%
}

@media (min-width: 768px) {
	.l-row__col--1 {
		padding: 0 2.3rem 6rem;
		max-width: 8.33333%;
		flex-basis: 8.33333%
	}
}

.l-row__col--6 {
	padding: 0 0 6rem;
	width: 100%
}

@media (min-width: 768px) {
	.l-row__col--6 {
		padding: 0 2.3rem 6rem;
		max-width: 50%;
		flex-basis: 50%
	}
}

.l-row__col--5 {
	padding: 0 0 6rem;
	width: 100%
}

@media (min-width: 768px) {
	.l-row__col--5 {
		padding: 0 2.3rem 6rem;
		max-width: 41.66667%;
		flex-basis: 41.66667%
	}
}

.l-blog {
	overflow: hidden;
	width: 100%
}

@media (min-width: 768px) {
	.l-blog__row {
		padding: 3rem 0 0;
		display: flex;
		justify-content: space-between
	}

	.l-blog__row::before {
		content: '';
		display: block;
		min-height: 0.1rem;
		flex: 0 0 22rem
	}
}

.l-blog__main {
	overflow: hidden
}

@media (min-width: 768px) {
	.l-blog__main {
		flex: 0 0 65rem
	}
}

.l-blog__article {
	margin: 0 0 8rem
}

@media (min-width: 768px) {
	.l-blog__article {
		margin: 0 0 10rem
	}
}

.l-blog__header {
	display: block;
	overflow: hidden
}

.l-blog__body {
	display: block
}

.l-blog__title {
	font-size: 1.8rem;
	margin: 0 0 2rem
}

@media (min-width: 768px) {
	.l-blog__title {
		font-size: 2rem
	}
}

.l-blog__meta {
	display: flex;
	margin: 0 0 2rem
}

.l-blog__date, .l-blog__cate {
	font-size: 1.8rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'550;
	line-height: 1.45
}

.l-blog__date {
	padding: 0 2rem 0 0;
	flex-shrink: 0;
	flex-grow: 0
}

.l-blog__cate {
	color: #99D2DC;
	flex-grow: 1;
	padding: 0 1rem
}

@media (min-width: 768px) {
	.l-blog__side {
		flex: 0 0 22rem
	}
}

.btn-rm {
	display: block;
	position: relative;
	color: #000;
	text-decoration: none;
	height: 4.8rem;
	padding: .8rem 0 0;
	overflow: hidden;
	width: 20rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'550;
	letter-spacing: 0.1em;
	font-size: 2.4rem
}

.touch-is-active .btn-rm.touched {
	opacity: .7
}

.mouse-is-active .btn-rm:hover {
	opacity: .7
}

.btn-rm--s {
	display: block;
	position: relative;
	color: #000;
	text-decoration: none;
	height: 4.8rem;
	padding: .8rem 0 0;
	overflow: hidden;
	width: 13rem;
	font-size: 1.7rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	height: 4.2rem
}

.touch-is-active .btn-rm--s.touched {
	opacity: .7
}

.mouse-is-active .btn-rm--s:hover {
	opacity: .7
}

.btn-rm--s .btn-rm__icon {
	width: 12.5rem
}

.btn-rm__text {
	display: block;
	line-height: 1;
	transition: padding .1s cubic-bezier(0.175, 0.885, 0.32, 1.275), color .1s linear
}

.btn-rm__icon {
	position: absolute;
	bottom: 0;
	right: .5rem;
	width: 19.5rem;
	height: .5rem;
	background-color: #000;
	transition: -webkit-transform .1s cubic-bezier(0.175, 0.885, 0.32, 1.275) .05s;
	transition: transform .1s cubic-bezier(0.175, 0.885, 0.32, 1.275) .05s;
	transition: transform .1s cubic-bezier(0.175, 0.885, 0.32, 1.275) .05s, -webkit-transform .1s cubic-bezier(0.175, 0.885, 0.32, 1.275) .05s
}

.btn-rm__icon::before {
	content: '';
	display: block;
	height: .5rem;
	width: 2.5rem;
	background-color: #000;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	position: absolute;
	right: -0.7rem;
	bottom: .5rem;
	z-index: 1
}

.btn-ch {
	display: inline-flex;
	position: relative;
	font-size: 2.4rem;
	color: #000;
	text-decoration: none;
	font-variation-settings: 'wght'550;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	letter-spacing: 0.1em;
	height: 5rem;
	padding: .8rem 0;
	overflow: hidden;
	border-bottom: 0.5rem solid #000;
	align-items: flex-end;
	cursor: pointer
}

.touch-is-active .btn-ch.touched {
	opacity: .7
}

.mouse-is-active .btn-ch:hover {
	opacity: .7
}

.btn-ch__text {
	display: block;
	line-height: 1;
	text-align: right;
	white-space: nowrap;
	padding: 0 0 0 1rem
}

.btn-ch__icon {
	display: block;
	position: relative;
	width: 1.3rem;
	height: 1.3rem;
	position: relative;
	top: -0.2rem
}

.btn-ch__icon::before, .btn-ch__icon::after {
	content: '';
	display: block;
	width: 1.2rem;
	height: .2rem;
	background-color: #000;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate3d(-50%, -50%, 0);
	transform: translate3d(-50%, -50%, 0)
}

.btn-ch__icon::after {
	-webkit-transform: translate3d(-50%, -50%, 0) rotate(90deg);
	transform: translate3d(-50%, -50%, 0) rotate(90deg)
}

.btn-vc, .btn-vc--wide {
	padding: 0 1.6rem;
	font-size: 1.6rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'550;
	text-decoration: none;
	color: #000;
	border: 0.3rem solid #000;
	line-height: 1;
	align-items: center;
	white-space: nowrap;
	height: 3rem;
	letter-spacing: 0.15rem
}

.btn-vc {
	display: inline-flex
}

.btn-vc--wide {
	display: flex;
	justify-content: center
}

@media (min-width: 768px) {
	.btn-vc--wide {
		display: inline-flex
	}
}

.btn-fl {
	display: flex;
	height: 6rem;
	align-items: center;
	justify-content: center;
	font-size: 1.6rem;
	background-color: #fff;
	border: 0.5rem solid #000;
	color: #000;
	text-decoration: none;
	font-weight: 700
}

@media (min-width: 768px) {
	.btn-fl {
		font-size: 2rem;
		height: 8rem
	}
}

.icon--tab {
	display: inline-block;
	width: 1.8rem;
	height: 1.8rem;
	vertical-align: baseline
}

.icon--tab::after {
	content: '';
	display: inline-block;
	width: 100%;
	height: 100%;
	background-image: url(../img/icon_outerlink_black.svg);
	background-size: 1.8rem 1.6rem;
	background-repeat: no-repeat;
	background-position: center 90%;
	-webkit-transform: translateY(0.25rem);
	transform: translateY(0.25rem)
}

.page-top {
	position: fixed;
	bottom: 1.6rem;
	right: 1.8rem;
	z-index: 9
}

@media (min-width: 768px) {
	.page-top {
		bottom: 2.3rem;
		right: 2.6rem
	}
}

.page-top__btn {
	display: block;
	width: 5rem;
	height: 5rem;
	border-radius: 100%;
	border: .3rem solid #fff;
	background-color: #000
}

.page-top__btn::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	display: block;
	top: 0;
	left: 0;
	background-size: 2.3rem 1.2rem;
	background-position: 50% 50%;
	background-repeat: no-repeat;
	background-image: url(../img/icon_scroll_arrow.svg)
}

.side-widgets {
	display: block
}

.side-widgets__row {
	display: flex;
	flex-wrap: wrap
}

@media (min-width: 768px) {
	.side-widgets__row {
		display: block
	}
}

.side-widgets__section {
	padding: 0 5rem 0 0
}

@media (min-width: 768px) {
	.side-widgets__section {
		padding: 0;
		margin: 0 0 4rem
	}
}

.side-widgets__title {
	font-size: 1.3rem;
	font-weight: 700;
	margin: 0 0 1rem;
	line-height: 1.45;
	color: #99D2DC
}

.side-widgets ul, .side-widgets__list {
	display: block;
	margin: 0;
	padding: 0;
	list-style: none
}

.side-widgets li, .side-widgets__item {
	direction: block;
	margin: 0;
	padding: 0
}

.side-widgets a, .side-widgets__link {
	color: #000;
	font-weight: 500;
	text-decoration: none;
	line-height: 1.78;
	font-size: 1.3rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'550;
	letter-spacing: 0.1em
}

.touch-is-active .side-widgets a.touched, .touch-is-active .side-widgets__link.touched {
	opacity: .7
}

.mouse-is-active .side-widgets a:hover, .mouse-is-active .side-widgets__link:hover {
	opacity: .7
}

.pagination {
	display: flex;
	justify-content: center;
	padding: 8rem 0 3rem
}

@media (min-width: 768px) {
	.pagination {
		padding: 8rem 0 4rem
	}
}

.pagination a, .pagination span {
	text-decoration: none;
	color: #000;
	width: 3rem;
	height: 3rem;
	line-height: 3rem;
	text-align: center;
	white-space: nowrap;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif
}

.pagination a.current, .pagination span.current {
	opacity: .5
}

.pagination__count {
	display: none
}

.pagination__next, .pagination__prev {
	width: 3rem;
	height: 3rem;
	margin: 0 2rem
}

.pagination__next a, .pagination__prev a {
	display: block;
	width: 100%;
	height: 100%;
	line-height: 3rem;
	color: #000;
	position: relative
}

.pagination__next a::before, .pagination__next a::after, .pagination__prev a::before, .pagination__prev a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: .58em;
	height: .58em;
	margin-top: -0.29em;
	margin-left: -0.29em
}

.pagination__next a::before, .pagination__next a::after {
	border-right: 0.2rem solid #000;
	border-top: 0.2rem solid #000;
	-webkit-transform: translate(-0.4rem, 0) rotate(45deg);
	transform: translate(-0.4rem, 0) rotate(45deg)
}

.pagination__next a::after {
	-webkit-transform: translate(0.4rem, 0) rotate(45deg);
	transform: translate(0.4rem, 0) rotate(45deg)
}

.pagination__prev a::before, .pagination__prev a::after {
	border-left: 0.2rem solid #000;
	border-top: 0.2rem solid #000;
	-webkit-transform: translate(-0.4rem, 0) rotate(-45deg);
	transform: translate(-0.4rem, 0) rotate(-45deg)
}

.pagination__prev a::after {
	-webkit-transform: translate(0.4rem, 0) rotate(-45deg);
	transform: translate(0.4rem, 0) rotate(-45deg)
}

.pagination__back {
	width: auto
}

.pagination__back a {
	width: auto;
	display: block;
	font-size: 1.6rem;
	line-height: 3rem;
	font-family: YakuHanJP, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif
}

.header {
	background-color: #fff;
	height: 6rem;
	display: flex
}

@media (min-width: 768px) {
	.header {
		height: 9rem
	}
}

.header__toggle {
	width: 6rem;
	height: 6rem
}

@media (min-width: 768px) {
	.header__toggle {
		width: 9rem;
		height: 9rem
	}
}

.header__branding {
	padding: 0 1rem 0 1rem;
	display: flex;
	align-items: center;
	height: 6rem
}

@media (min-width: 768px) {
	.header__branding {
		height: 9rem
	}
}

.header__info {
	display: none
}

@media (min-width: 768px) {
	.header__info {
		display: flex;
		margin: 0 0 0 auto;
		align-items: center;
		height: 100%;
		padding: 0 5rem 0 0
	}
}

.header__mail {
	margin: 0 0 0 auto
}

@media (min-width: 768px) {
	.header__mail {
		margin: 0
	}
}

.header__mail-link {
	display: flex;
	text-decoration: none;
	width: 6rem;
	height: 6rem;
	position: relative;
	background-image: url("../img/mail_sp.svg");
	background-size: 2.5rem 1.736rem;
	background-position: center center;
	transition: background-color .1s linear
}

@media (min-width: 768px) {
	.header__mail-link {
		width: 9rem;
		height: 9rem;
		background-image: url("../img/mail_pc.svg");
		background-color: #ccc;
		background-size: 3.6rem 2.5rem
	}
}

.touch-is-active .header__mail-link.touched {
	background-color: #99D2DC
}

.mouse-is-active .header__mail-link:hover {
	background-color: #99D2DC
}

.header__mail-text {
	position: absolute;
	clip: rect(1px, 1px, 1px, 1px);
	-webkit-clip-path: inset(0px 0px 99.9% 99.9%);
	clip-path: inset(0px 0px 99.9% 99.9%);
	overflow: hidden;
	height: 1px;
	width: 1px;
	padding: 0;
	border: 0;
	top: 50%
}

.h-trigger {
	cursor: pointer;
	border: 0;
	display: block;
	background-color: transparent;
	-webkit-appearance: none;
	overflow: hidden;
	position: relative;
	z-index: 999;
	display: flex;
	width: 100%;
	height: 100%;
	justify-content: center;
	align-items: center
}

.h-trigger__innr {
	display: block;
	overflow: hidden
}

.h-trigger__bar {
	margin-top: .6rem;
	background-color: #000;
	width: 2.3rem;
	height: .3rem;
	transition: width .3s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .1s linear, -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1), width .3s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .1s linear;
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1), width .3s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .1s linear, -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	display: block
}

.h-trigger__bar:nth-child(1) {
	margin-top: 0
}

@media (min-width: 768px) {
	.h-trigger__bar {
		width: 2.5rem
	}
}

.mouse-is-active .h-trigger:hover .h-trigger__bar:nth-child(2) {
	width: 72%
}

.mouse-is-active .h-trigger:hover .h-trigger__bar:nth-child(3) {
	width: 48%
}

.h-trigger.close .h-trigger__bar {
	width: 2.3rem !important
}

@media (min-width: 768px) {
	.h-trigger.close .h-trigger__bar {
		width: 2.5rem !important
	}
}

.h-trigger.close .h-trigger__bar:nth-child(1) {
	-webkit-transform: translate3d(0, .9rem, 0) rotate(-45deg);
	transform: translate3d(0, .9rem, 0) rotate(-45deg)
}

.h-trigger.close .h-trigger__bar:nth-child(2) {
	opacity: 0
}

.h-trigger.close .h-trigger__bar:nth-child(3) {
	-webkit-transform: translate3d(0, -.9rem, 0) rotate(45deg);
	transform: translate3d(0, -.9rem, 0) rotate(45deg)
}

.h-logo {
	width: 22rem;
	height: 2rem
}

@media (min-width: 768px) {
	.h-logo {
		width: 22rem;
		height: 2.3rem
	}
}

.h-logo__link {
	display: block;
	color: #000;
	text-decoration: none;
	height: 100%
}

.h-logo__svg {
	display: block;
	width: 100%;
	height: 100%
}

.h-num {
	font-size: 2.6rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	letter-spacing: 0.07em;
	font-variation-settings: 'wght'550
}

.h-num__text {
	font-size: 1.9rem
}

.h-num svg {
	display: block;
	width: 20.7rem
}

.g-nav {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #fff;
	z-index: 7;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	-webkit-transform: translate3d(0, -101vh, 0);
	transform: translate3d(0, -101vh, 0);
	opacity: 0;
	transition: opacity .75s linear, -webkit-transform 1ms linear .75s;
	transition: opacity .75s linear, transform 1ms linear .75s;
	transition: opacity .75s linear, transform 1ms linear .75s, -webkit-transform 1ms linear .75s
}

@media (min-width: 768px) {
	.g-nav {
		padding: 9rem 0 0;
		left: 9rem;
		-webkit-transform: translate3d(-101vw, 0, 0);
		transform: translate3d(-101vw, 0, 0);
		transition: opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1) .75s;
		transition: opacity .75s linear, transform .75s cubic-bezier(0.165, 0.84, 0.44, 1) .75s;
		transition: opacity .75s linear, transform .75s cubic-bezier(0.165, 0.84, 0.44, 1) .75s, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1) .75s
	}
}

.nav-open .g-nav {
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	opacity: 1;
	transition: opacity .3s linear
}

.g-nav__innr {
	width: 100%;
	text-align: center;
	overflow: auto;
	max-height: 100%;
	padding: 2rem 0
}

.g-nav__list {
	display: block;
	list-style: none;
	margin: 0;
	padding: 0;
	width: 100%;
	overflow: hidden;
	margin: 0 0 2rem
}

@media (min-width: 768px) {
	.g-nav__list {
		margin: 0 0 3rem
	}
}

.g-nav__item {
	display: block;
	margin: 0 0 1.5rem;
	text-align: center;
	opacity: 0;
	-webkit-transform: translate3d(0, -3rem, 0) rotateX(60deg);
	transform: translate3d(0, -3rem, 0) rotateX(60deg);
	transition: opacity .1s linear, -webkit-transform 0ms cubic-bezier(0.165, 0.84, 0.44, 1) .1s;
	transition: transform 0ms cubic-bezier(0.165, 0.84, 0.44, 1) .1s, opacity .1s linear;
	transition: transform 0ms cubic-bezier(0.165, 0.84, 0.44, 1) .1s, opacity .1s linear, -webkit-transform 0ms cubic-bezier(0.165, 0.84, 0.44, 1) .1s
}

.nav-open .g-nav__item {
	-webkit-transform: translate3d(0, 0rem, 0);
	transform: translate3d(0, 0rem, 0);
	opacity: 1;
	transition: opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear;
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.nav-open .g-nav__item:nth-of-type(1) {
	transition-delay: .04s
}

.nav-open .g-nav__item:nth-of-type(2) {
	transition-delay: .08s
}

.nav-open .g-nav__item:nth-of-type(3) {
	transition-delay: .12s
}

.nav-open .g-nav__item:nth-of-type(4) {
	transition-delay: .16s
}

.nav-open .g-nav__item:nth-of-type(5) {
	transition-delay: .2s
}

.nav-open .g-nav__item:nth-of-type(6) {
	transition-delay: .24s
}

.nav-open .g-nav__item:nth-of-type(7) {
	transition-delay: .28s
}

.nav-open .g-nav__item:nth-of-type(8) {
	transition-delay: .32s
}

@media (min-width: 768px) {
	.g-nav__item {
		margin: 0 0 2rem
	}
}

.g-nav__link {
	display: inline-block;
	color: #000;
	text-decoration: none
}

.g-nav__title {
	font-size: 2rem;
	font-weight: 700;
	line-height: inherit
}

.g-nav__sub-title {
	display: block;
	text-align: center;
	color: #99D2DC;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	letter-spacing: 0.1em;
	font-size: 1.7rem;
	font-variation-settings: 'wght'550
}

.g-nav__rc {
	display: inline-block;
	border-top: 2px solid #000;
	padding: 1.5rem;
	opacity: 0;
	-webkit-transform: translate3d(0, -3rem, 0) rotateX(60deg);
	transform: translate3d(0, -3rem, 0) rotateX(60deg)
}

@media (min-width: 768px) {
	.g-nav__rc {
		padding-bottom: 0
	}
}

.nav-open .g-nav__rc {
	-webkit-transform: translate3d(0, 0rem, 0);
	transform: translate3d(0, 0rem, 0);
	opacity: 1;
	transition: opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear;
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition-delay: .28s
}

.g-nav__rc-link {
	text-decoration: none;
	font-size: 2.7rem;
	color: #000;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	letter-spacing: 0.1em;
	font-weight: 400
}

.g-nav__sns {
	-webkit-transform: translate3d(0, -3rem, 0) rotateX(60deg);
	transform: translate3d(0, -3rem, 0) rotateX(60deg);
	opacity: 0
}

.nav-open .g-nav__sns {
	-webkit-transform: translate3d(0, 0rem, 0);
	transform: translate3d(0, 0rem, 0);
	opacity: 1;
	transition: opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear;
	transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear, -webkit-transform .75s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition-delay: .32s
}

@media (min-width: 768px) {
	.g-nav__sns {
		display: none
	}
}

.sidebar {
	display: block;
	height: 100%
}

.sidebar__row {
	display: flex;
	height: 100%;
	flex-direction: column;
	justify-content: space-between;
	padding: 3.4rem 0
}

.sidebar__spacer {
	flex: 1
}

.sidebar__mtitle {
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	letter-spacing: 0.316em;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-align: center;
	padding: 0 3.7rem 0 0;
	line-height: 1;
	flex: 2
}

.sidebar__mtitle span {
	display: block;
	font-size: 1.4rem;
	margin: 0;
	line-height: inherit;
	font-variation-settings: 'wght'430
}

.sidebar__sns {
	display: flex;
	flex: 1;
	justify-content: center;
	align-items: flex-end
}

.footer {
	overflow: hidden;
	background-color: #000;
	color: #fff
}

@media (min-width: 768px) {
	.footer__row {
		display: flex;
		margin: 0 -map-deep-get((z-index:(header:10, navigation:7, content:5, sidebar:8, footer:1, page-top:9), toggle-point:"md", gutter-width:(sp:2rem, pc:4.6rem), side-padd:(sp:2rem, pc:5rem), container-max-width-s:86rem, container-max-width-m:108rem, container-max-width:125rem), gutter-width, pc)/2
	}
}

@media (min-width: 768px) {
	.footer__row--reverse {
		display: flex;
		flex-direction: row-reverse;
		margin: 0 -map-deep-get((z-index:(header:10, navigation:7, content:5, sidebar:8, footer:1, page-top:9), toggle-point:"md", gutter-width:(sp:2rem, pc:4.6rem), side-padd:(sp:2rem, pc:5rem), container-max-width-s:86rem, container-max-width-m:108rem, container-max-width:125rem), gutter-width, pc)/2
	}
}

.footer__col {
	display: block;
	width: 100%
}

@media (min-width: 768px) {
	.footer__col {
		padding: 0 2.3rem;
		max-width: 50%;
		flex-basis: 50%
	}
}

@media (min-width: 768px) {
	.footer__spacer {
		display: none
	}
}

@media (min-width: 768px) {
	.footer__sns {
		display: none
	}
}

.footer__copyright {
	font-size: 1.3rem;
	margin: 0;
	padding: 0;
	line-height: 1.78
}

@media (min-width: 768px) {
	.footer__copyright {
		padding: 0 0 0 calc(16.66667% + 2.3rem)
	}
}

.f-info {
	display: block
}

.f-info__row {
	margin: 0 0 1.5rem
}

@media (min-width: 768px) {
	.f-info__row {
		display: flex;
		margin: 0 -map-deep-get((z-index:(header:10, navigation:7, content:5, sidebar:8, footer:1, page-top:9), toggle-point:"md", gutter-width:(sp:2rem, pc:4.6rem), side-padd:(sp:2rem, pc:5rem), container-max-width-s:86rem, container-max-width-m:108rem, container-max-width:125rem), gutter-width, pc)/2 1.5rem
	}
}

.f-info__visual {
	width: 100%
}

@media (min-width: 768px) {
	.f-info__visual {
		padding: 0 2.3rem;
		max-width: 16.66667%;
		flex-basis: 16.66667%
	}
}

.f-info__visual-img {
	display: block;
	width: 4.7rem;
	margin: 0 0 1.5rem
}

@media (min-width: 768px) {
	.f-info__visual-img {
		margin: 0 0 0 auto
	}
}

.f-info__content {
	width: 100%
}

@media (min-width: 768px) {
	.f-info__content {
		padding: 0 2.3rem;
		max-width: 83.33333%;
		flex-basis: 83.33333%
	}
}

.f-info__name {
	font-weight: 700;
	font-size: 2.5rem;
	margin: 0 0 1.5rem
}

@media (min-width: 768px) {
	.f-info__name {
		font-size: 3rem
	}
}

.f-info__address {
	display: block;
	font-style: normal;
	font-size: 1.3rem
}

.f-info__postcode, .f-info__detail, .f-info__num {
	display: block
}

.f-info__detail {
	margin: 0 0 1.5rem
}

.footer-nav {
	display: block
}

.footer-nav__list {
	margin: 0;
	padding: 0;
	list-style: none;
	-webkit-column-count: 2;
	-moz-column-count: 2;
	column-count: 2;
	-webkit-column-gap: 2rem;
	-moz-column-gap: 2rem;
	column-gap: 2rem
}

@media (min-width: 768px) {
	.footer-nav__list {
		-webkit-column-gap: 4.6rem;
		-moz-column-gap: 4.6rem;
		column-gap: 4.6rem;
		max-width: 83.33333%
	}
}

.footer-nav__item {
	-webkit-column-break-inside: avoid;
	-moz-column-break-inside: avoid;
	break-inside: avoid-column;
	display: block;
	margin: 0 0 1rem;
	padding: 0
}

.footer-nav__link {
	display: inline-block;
	color: inherit;
	text-decoration: none;
	font-size: 1.3rem
}

.bottom-menu {
	display: block
}

.bottom-menu__list {
	margin: 0;
	padding: 0;
	list-style: none;
	-webkit-column-count: 2;
	-moz-column-count: 2;
	column-count: 2;
	-webkit-column-gap: 2rem;
	-moz-column-gap: 2rem;
	column-gap: 2rem
}

@media (min-width: 768px) {
	.bottom-menu__list {
		-webkit-column-gap: 4.6rem;
		-moz-column-gap: 4.6rem;
		column-gap: 4.6rem;
		max-width: 83.33333%
	}
}

.bottom-menu__item {
	display: block
}

.bottom-menu__link {
	display: inline-flex;
	height: 1.4em;
	padding: 0 2rem;
	color: inherit;
	text-decoration: none;
	white-space: nowrap;
	font-size: 1.3rem;
	align-items: center;
	justify-content: center;
	border-left: .2rem solid #fff;
	border-right: .2rem solid #fff
}

.bottom-menu__link--outer {
	display: inline-flex;
	height: 1.4em;
	padding: 0 2rem;
	color: inherit;
	text-decoration: none;
	white-space: nowrap;
	font-size: 1.3rem;
	align-items: center;
	justify-content: center;
	border-left: .2rem solid #fff;
	border-right: .2rem solid #fff
}

.bottom-menu__link--outer::after {
	content: '';
	display: inline-block;
	width: 1.8rem;
	height: 1.6rem;
	background-image: url(../img/icon_outerlink.svg);
	background-size: 1.7rem 1.6rem;
	background-repeat: no-repeat;
	background-position: center center;
	margin: 0 0 0 .5rem
}

.top-kv {
	position: relative;
	margin: 0 0 0 2rem;
	overflow: hidden;
	max-height: calc(100vh - 6rem)
}

@media (min-width: 768px) {
	.top-kv {
		height: auto;
		margin: 0;
		width: 100%;
		max-height: calc(100vh - 9rem)
	}
}

.top-kv::before {
	content: '';
	display: block;
	padding: 0 0 153.38164%
}

@media (min-width: 768px) {
	.top-kv::before {
		padding: 0 0 56.14815%
	}
}

.top-kv__video-wrap {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.top-kv video {
	position: absolute;
	left: 50%;
	bottom: 0;
	min-width: 100%;
	min-height: 100%;
	z-index: 1;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%)
}

.top-kv__sp {
	display: block
}

@media (min-width: 768px) {
	.top-kv__sp {
		display: none
	}
}

.top-kv__pc {
	display: none
}

@media (min-width: 768px) {
	.top-kv__pc {
		display: block
	}
}

.top-kv__content {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2
}

.top-kv__catch {
	font-size: 3rem;
	margin: 0;
	font-weight: 700;
	text-align: center;
	color: #fff;
	letter-spacing: 0.2em;
	text-shadow: 0 0.3rem 0.6rem rgba(0, 0, 0, 0.2);
	line-height: 1em
}

@media (min-width: 768px) {
	.top-kv__catch {
		font-size: 5rem
	}
}

.top-kv__scroll {
	position: absolute;
	bottom: 3rem;
	width: 4rem;
	height: 3.2rem;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	z-index: 9
}

.top-kv__catch-span {
	opacity: 0;
	display: inline-block;
	line-height: 1em
}

.loaded .top-kv .top-kv__catch-span {
	-webkit-animation: anim_span_scroll .825s cubic-bezier(0.165, 0.84, 0.44, 1) 0.25s forwards;
	animation: anim_span_scroll .825s cubic-bezier(0.165, 0.84, 0.44, 1) 0.25s forwards
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(1) {
	-webkit-animation-delay: .46s;
	animation-delay: .46s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(2) {
	-webkit-animation-delay: .52s;
	animation-delay: .52s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(3) {
	-webkit-animation-delay: .58s;
	animation-delay: .58s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(4) {
	-webkit-animation-delay: .64s;
	animation-delay: .64s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(5) {
	-webkit-animation-delay: .7s;
	animation-delay: .7s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(6) {
	-webkit-animation-delay: .76s;
	animation-delay: .76s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(7) {
	-webkit-animation-delay: .82s;
	animation-delay: .82s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(8) {
	-webkit-animation-delay: .88s;
	animation-delay: .88s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(9) {
	-webkit-animation-delay: .94s;
	animation-delay: .94s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(10) {
	-webkit-animation-delay: 1s;
	animation-delay: 1s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(11) {
	-webkit-animation-delay: 1.06s;
	animation-delay: 1.06s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(12) {
	-webkit-animation-delay: 1.12s;
	animation-delay: 1.12s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(13) {
	-webkit-animation-delay: 1.18s;
	animation-delay: 1.18s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(14) {
	-webkit-animation-delay: 1.24s;
	animation-delay: 1.24s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(15) {
	-webkit-animation-delay: 1.3s;
	animation-delay: 1.3s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(16) {
	-webkit-animation-delay: 1.36s;
	animation-delay: 1.36s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(17) {
	-webkit-animation-delay: 1.42s;
	animation-delay: 1.42s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(18) {
	-webkit-animation-delay: 1.48s;
	animation-delay: 1.48s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(19) {
	-webkit-animation-delay: 1.54s;
	animation-delay: 1.54s
}

.loaded .top-kv .top-kv__catch-span:nth-of-type(20) {
	-webkit-animation-delay: 1.6s;
	animation-delay: 1.6s
}

@-webkit-keyframes anim_num_scroll {
	0% {
		opacity: 0;
		-webkit-transform: translateY(54%) rotateX(-90deg);
		transform: translateY(54%) rotateX(-90deg)
	}

	100% {
		opacity: 1;
		-webkit-transform: translateY(0) rotateX(0);
		transform: translateY(0) rotateX(0)
	}
}

@keyframes anim_num_scroll {
	0% {
		opacity: 0;
		-webkit-transform: translateY(54%) rotateX(-90deg);
		transform: translateY(54%) rotateX(-90deg)
	}

	100% {
		opacity: 1;
		-webkit-transform: translateY(0) rotateX(0);
		transform: translateY(0) rotateX(0)
	}
}

@-webkit-keyframes anim_span_scroll {
	0% {
		opacity: 0;
		-webkit-transform: translateY(30%) rotateX(-70deg);
		transform: translateY(30%) rotateX(-70deg)
	}

	100% {
		opacity: 1;
		-webkit-transform: translateY(0) rotateX(0);
		transform: translateY(0) rotateX(0)
	}
}

@keyframes anim_span_scroll {
	0% {
		opacity: 0;
		-webkit-transform: translateY(30%) rotateX(-70deg);
		transform: translateY(30%) rotateX(-70deg)
	}

	100% {
		opacity: 1;
		-webkit-transform: translateY(0) rotateX(0);
		transform: translateY(0) rotateX(0)
	}
}

.t-sections {
	display: flex;
	flex-direction: column
}

@media (min-width: 768px) {
	.t-sections {
		display: block
	}
}

.t-sections__charm {
	order: 1
}

.t-sections__concept {
	order: 0
}

.t-sections__works {
	order: 2
}

@media (min-width: 768px) {
	.t-sections__works {
		display: none
	}
}

.t-sections__news {
	order: 3
}

.t-charm {
	display: block
}

.t-charm__innr {
	padding: 6rem 2rem;
	margin: 0 auto
}

@media (min-width: 768px) {
	.t-charm__innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

@media (min-width: 768px) {
	.t-charm__row {
		display: flex;
		margin: 0 -2.3rem
	}
}

@media (min-width: 768px) {
	.t-charm__header {
		flex: 0 1 25rem;
		padding: 0 0 0 2.3rem
	}
}

@media (min-width: 768px) {
	.t-charm__body {
		flex: 1 0 100rem;
		padding: 0 2.3rem
	}
}

.t-charm__icon {
	width: 13.3rem
}

@media (min-width: 768px) {
	.t-charm__icon {
		margin: 0 auto
	}
}

.t-charm__icon-img {
	display: block;
	width: 100%;
	height: auto
}

.t-charm__foot {
	padding: 0 0 0 4rem
}

@media (min-width: 768px) {
	.t-charm__foot {
		padding: 0 0 0 46rem
	}
}

.t-headline {
	display: block;
	position: relative
}

.t-headline--charm {
	display: block;
	position: relative
}

.t-headline--charm .t-headline__body {
	position: absolute;
	bottom: 0;
	right: 2.5rem
}

@media (min-width: 768px) {
	.t-headline--charm .t-headline__body {
		position: static;
		bottom: auto;
		right: auto
	}
}

.t-headline--charm .t-headline__catch {
	width: 15.7rem;
	height: 4.56rem
}

.t-headline--concept .t-headline__catch {
	width: 20.4rem;
	height: 4.48rem
}

.t-headline--news .t-headline__catch {
	width: 12.7rem;
	height: 4.564rem
}

.t-headline--instagram .t-headline__catch {
	color: #fff;
	width: 26.1rem;
	height: 4.52rem
}

.t-headline--works .t-headline__catch {
	width: 16rem;
	height: 4.48rem
}

.t-headline__head {
	margin: 0 0 2.5rem
}

.t-headline__catch {
	font-size: 6rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	color: #99D2DC;
	font-weight: 700;
	letter-spacing: 0.07em;
	margin: 0;
	font-variation-settings: 'wght'330;
	line-height: 1.45
}

.t-headline__catch::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.t-headline__catch svg {
	display: block
}

.t-headline__catch.svg {
	margin: 0 0 1.5rem
}

.t-headline__catch.svg::before {
	display: none
}

.t-headline__title {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0 0 2rem
}

.t-headline__lead {
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.45;
	letter-spacing: 0.125em;
	margin: 0
}

.t-headline__text {
	font-weight: 500;
	font-size: 1.3rem;
	text-align: justify;
	letter-spacing: 0.09em
}

@media (min-width: 768px) {
	.t-headline__text {
		font-weight: 700
	}
}

@media (min-width: 768px) {
	.t-panels {
		display: flex;
		justify-content: space-between;
		align-items: flex-start
	}
}

.t-panels__item {
	overflow: hidden;
	width: 30rem
}

.t-panels__item:nth-of-type(1) {
	margin: 0 auto 3rem
}

@media (min-width: 768px) {
	.t-panels__item:nth-of-type(1) {
		margin: 6rem 0 0
	}
}

.t-panels__item:nth-of-type(2) {
	margin: 0 auto 3rem 0
}

@media (min-width: 768px) {
	.t-panels__item:nth-of-type(2) {
		margin: 0
	}
}

.t-panels__item:nth-of-type(3) {
	margin: 0 0 3rem auto
}

@media (min-width: 768px) {
	.t-panels__item:nth-of-type(3) {
		margin: 9.4rem 0 0
	}
}

.t-panels__link {
	display: block;
	border: solid 0.8rem #000;
	padding: 2.5rem;
	text-decoration: none;
	color: #000
}

.touch-is-active .t-panels__link.touched .t-panels__alph {
	-webkit-transform: translateZ(0) rotate(7deg);
	transform: translateZ(0) rotate(7deg)
}

.touch-is-active .t-panels__link.touched .t-panels__emph {
	background-size: 100% .5em
}

.mouse-is-active .t-panels__link:hover .t-panels__alph {
	-webkit-transform: translateZ(0) rotate(7deg);
	transform: translateZ(0) rotate(7deg)
}

.mouse-is-active .t-panels__link:hover .t-panels__emph {
	background-size: 100% .5em
}

.t-panels__alph {
	font-size: 8.5rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	transition: -webkit-transform .3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	transition: transform .3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	transition: transform .3s cubic-bezier(0.175, 0.885, 0.32, 1.275), -webkit-transform .3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	font-variation-settings: 'wght'400;
	margin: 0 0 2.5rem;
	line-height: 1;
	width: .65em
}

.t-panels__alph::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.2) * 0.5em)
}

.t-panels__alph::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.2) * 0.5em)
}

.t-panels__title {
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.78;
	margin: 0 0 2.5rem
}

.t-panels__title::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.78) * 0.5em)
}

.t-panels__title::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.78) * 0.5em)
}

.t-panels__emph {
	display: inline;
	position: relative;
	font: inherit;
	background-image: linear-gradient(#99D2DC, #99D2DC);
	background-repeat: no-repeat;
	background-position: 0 100%;
	background-size: 0% .5em;
	transition: background-size .75s cubic-bezier(0.175, 0.885, 0.32, 1.275)
}

.t-panels__text {
	font-size: 1.3rem;
	font-weight: 500;
	margin: 0;
	text-align: justify;
	line-height: 1.45
}

.t-panels__text::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.t-panels__text::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

@media (min-width: 768px) {
	.t-panels__text {
		font-weight: 700
	}
}

.t-concept {
	display: block;
	position: relative;
	padding: 0 0 5rem;
	z-index: 1;
	overflow: hidden
}

.t-concept__innr {
	padding: 6rem 2rem;
	margin: 0 auto
}

@media (min-width: 768px) {
	.t-concept__innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

@media (min-width: 768px) {
	.t-concept__row {
		display: flex
	}
}

@media (min-width: 768px) {
	.t-concept__row--reverse {
		display: flex;
		flex-flow: row-reverse
	}
}

.t-concept__row--body {
	display: flex;
	flex-wrap: wrap
}

.t-concept__top {
	position: relative;
	z-index: 1
}

.t-concept__h-btn {
	margin: 2rem 0 9rem
}

@media (min-width: 768px) {
	.t-concept__h-btn {
		margin: 2rem 0 0rem
	}
}

.t-concept__top-header {
	position: relative
}

.t-concept__top-header::after {
	content: '';
	display: block;
	width: 100vw;
	background-color: #fff;
	position: absolute;
	left: 0;
	top: -10rem;
	bottom: -5rem;
	z-index: -1
}

@media (min-width: 768px) {
	.t-concept__top-header {
		width: 100%;
		max-width: 50%;
		flex-basis: 50%;
		padding: 0 0 0 5rem
	}

	.t-concept__top-header::after {
		display: none
	}
}

.t-concept__top-visual {
	margin: 0 0 0 -2rem
}

@media (min-width: 768px) {
	.t-concept__top-visual {
		margin: 0;
		width: 100%;
		max-width: 50%;
		flex-basis: 50%;
		padding: 0 7rem 0 0
	}
}

.t-concept__top-v-img {
	display: block;
	width: 100%
}

.t-concept__body {
	position: relative;
	background-color: #F7F7F7;
	margin: 0 2rem;
	z-index: 1
}

@media (min-width: 768px) {
	.t-concept__body {
		margin: 0
	}
}

.t-concept__blog {
	margin: 2.5rem 0 0
}

@media (min-width: 768px) {
	.t-concept__blog {
		margin: 0
	}
}

.t-concept__foot {
	position: relative;
	z-index: 1;
	background-color: #F7F7F7;
	margin: 0 2rem;
	display: flex;
	justify-content: flex-end;
	padding: 0 2rem 5rem
}

@media (min-width: 768px) {
	.t-concept__foot {
		display: block;
		background-color: transparent;
		margin: 0 auto;
		max-width: 125rem;
		padding: 3rem 0 3rem 65rem
	}
}

@media (min-width: 768px) {
	.t-concept__bg {
		position: absolute;
		left: 50%;
		top: 0;
		bottom: 5rem;
		width: 100%;
		max-width: 125rem;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%)
	}
}

.t-concept__bg-innr {
	display: block;
	position: absolute;
	top: 0rem;
	bottom: 0;
	left: 8rem;
	background-color: #99D2DC;
	right: 0;
	z-index: 0
}

@media (min-width: 768px) {
	.t-concept__bg-innr {
		left: 12rem;
		right: auto;
		width: 46rem
	}
}

.t-works {
	display: block
}

@media (min-width: 768px) {
	.t-works {
		display: none
	}
}

.t-works__innr {
	padding: 6rem 2rem;
	margin: 0 auto
}

@media (min-width: 768px) {
	.t-works__innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

.t-works__item {
	position: relative;
	margin: 0 0 5rem;
	overflow: hidden
}

.t-works__link {
	color: #000;
	text-decoration: none
}

.touch-is-active .t-works__link.touched .t-works__visual {
	opacity: .7
}

.mouse-is-active .t-works__link:hover .t-works__visual {
	opacity: .7
}

.t-works__visual {
	margin: 6.5rem 0 0;
	padding: 0 6rem 0 0;
	transition: opacity .1s linear
}

.t-works__img-wrap {
	width: 100%;
	position: relative
}

.t-works__img-wrap::before {
	content: '';
	display: block;
	padding: 0 0 100%
}

.t-works__visual-img {
	display: block;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: 50% 50%;
	object-position: 50% 50%;
	font-family: "object-fit: cover; object-position: center;"
}

.t-works__visual-img-dummy {
	background-color: #efefef;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.t-works__info-box {
	position: absolute;
	top: 0;
	right: 0;
	width: 19.3rem;
	border: 0.5rem solid #000;
	padding: 2.8rem;
	background-color: #fff
}

.t-works__info-title {
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.45;
	margin: 0
}

.t-works__info-title::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.t-works__info-area {
	color: #99D2DC;
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0 0 3rem;
	line-height: 1.45
}

.t-works__info-area::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

.t-works__info-dscr {
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1.78
}

.t-works__info-dscr::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.78) * 0.5em)
}

.t-works__info-dscr::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.78) * 0.5em)
}

.t-works__foot {
	display: flex;
	justify-content: flex-end
}

.t-lv-grid {
	display: block
}

.t-lv-grid__row {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -0.5rem -4rem
}

@media (min-width: 768px) {
	.t-lv-grid__row {
		margin: 0 -2.3rem -4.6rem
	}
}

.t-lv-grid__item {
	display: block;
	width: 100%;
	max-width: 50%;
	flex-basis: 50%;
	padding: 0 0.5rem 4rem
}

@media (min-width: 768px) {
	.t-lv-grid__item {
		max-width: 25%;
		flex-basis: 25%;
		padding: 0 2.3rem 4.6rem;
		margin: 0
	}

	.t-lv-grid__item:nth-of-type(4n+1) {
		margin: 3.5rem 0 0
	}

	.t-lv-grid__item:nth-of-type(4n+2) {
		margin: 9.5rem 0 0
	}

	.t-lv-grid__item:nth-of-type(4n+4) {
		margin: 5.5rem 0 0
	}
}

.t-lv-grid__link {
	display: block;
	text-decoration: none;
	color: #000
}

.touch-is-active .t-lv-grid__link.touched .t-lv-grid__img, .touch-is-active .t-lv-grid__link.touched .t-lv-grid__img-dummy {
	-webkit-transform: translate3d(-1rem, -1rem, 0);
	transform: translate3d(-1rem, -1rem, 0);
	transition: -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.mouse-is-active .t-lv-grid__link:hover .t-lv-grid__img, .mouse-is-active .t-lv-grid__link:hover .t-lv-grid__img-dummy {
	-webkit-transform: translate3d(-1rem, -1rem, 0);
	transform: translate3d(-1rem, -1rem, 0);
	transition: -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.t-lv-grid__visual {
	margin: 0 0 1rem;
	position: relative;
	background-color: #99D2DC
}

.t-lv-grid__visual::before {
	content: '';
	display: block;
	padding: 0 0 100%
}

.t-lv-grid__img {
	display: block;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: 50% 50%;
	object-position: 50% 50%;
	font-family: "object-fit: cover; object-position: center;";
	transition: -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1), -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1)
}

.t-lv-grid__img-dummy {
	background-color: #fff;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1), -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1)
}

.t-lv-grid__title {
	display: none
}

@media (min-width: 768px) {
	.t-lv-grid__title {
		display: block;
		margin: 0 0 .25rem;
		font-size: 1.3rem;
		font-weight: 700;
		line-height: 1.45
	}
}

.t-lv-grid__date {
	line-height: 1.45;
	margin: 0;
	padding: 0;
	color: #99D2DC;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-size: 1.7rem;
	font-variation-settings: 'wght'430
}

.t-news {
	overflow: hidden;
	width: 100%
}

.t-news__innr {
	padding: 6rem 2rem;
	margin: 0 auto
}

@media (min-width: 768px) {
	.t-news__innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

@media (min-width: 768px) {
	.t-news__row {
		display: flex;
		align-items: flex-start;
		margin: 0 -2.3rem
	}
}

@media (min-width: 768px) {
	.t-news__main, .t-news__instagram {
		padding: 0 2.3rem;
		width: 100%;
		max-width: 50%;
		flex-basis: 50%
	}
}

@media (min-width: 768px) {
	.t-news__main {
		padding: 0 9.2rem 0 2.3rem
	}
}

.t-news__instagram {
	position: relative;
	position: relative;
	z-index: 1;
	padding: 5rem 0
}

.t-news__instagram::before {
	content: '';
	display: block;
	background-color: #99D2DC;
	position: absolute;
	top: 0;
	width: 100vw;
	left: -2rem;
	height: 100%;
	z-index: -1
}

@media (min-width: 768px) {
	.t-news__instagram::before {
		width: 50vw
	}
}

.t-news__instagram-list {
	margin: 0 -0.3rem
}

@media (min-width: 768px) {
	.t-news__instagram-list {
		margin: 0 -1rem
	}
}

.t-news__foot {
	padding: 2rem 0 5rem;
	display: flex;
	justify-content: flex-end
}

@media (min-width: 768px) {
	.t-news__foot {
		justify-content: center;
		padding: 2rem 0 5rem 3rem
	}
}

.ceo-name {
	padding: 2rem 0 0;
	font-weight: 700;
	font-size: 1.4rem;
	margin: 0;
	line-height: 1.45
}

@media (min-width: 768px) {
	.ceo-name {
		padding: 4rem 0 0;
		text-align: center
	}
}

.ceo-name__sign {
	display: inline-block;
	width: 14.2rem;
	margin: 0 0 0 2.5rem;
	position: relative;
	top: 1rem
}

@media (min-width: 768px) {
	.ceo-name__sign {
		top: 0
	}
}

.cm-table table, .cm-table thead, .cm-table tbody, .cm-table tr, .cm-table th, .cm-table td {
	display: block;
	text-align: left;
	font-size: 1.4rem;
	line-height: 1.78;
	padding: 0
}

.cm-table table {
	margin: 0 0 5rem
}

.cm-table table:last-child {
	margin: 0
}

@media (min-width: 768px) {
	.cm-table table {
		display: table;
		width: 100%;
		table-layout: fixed;
		margin: 0 0 2rem
	}
}

@media (min-width: 768px) {
	.cm-table tbody {
		display: table-row-group
	}
}

.cm-table tr {
	margin: 0 0 1.5rem
}

@media (min-width: 768px) {
	.cm-table tr {
		display: table-row;
		margin: 0;
		padding: .15rem 1.5rem
	}
}

.cm-table th {
	font-weight: 700
}

@media (min-width: 768px) {
	.cm-table th {
		display: table-cell;
		text-align: right;
		padding: .15rem 1.5rem;
		vertical-align: top
	}
}

.cm-table td {
	font-weight: 500
}

@media (min-width: 768px) {
	.cm-table td {
		display: table-cell;
		vertical-align: top
	}
}

.cm-table td ul {
	margin: 0;
	padding: 0;
	list-style: none
}

.cm-table td li {
	margin: 0;
	padding: 0;
	line-height: 1.78
}

.g-map {
	padding: 2rem
}

@media (min-width: 768px) {
	.g-map__spacer {
		padding: 5rem 0
	}
}

@media (min-width: 768px) {
	.g-map {
		padding: 0
	}
}

.g-map__innr {
	position: relative;
	width: 100%;
	max-height: 37rem
}

.g-map__innr::before {
	content: '';
	display: block;
	padding: 0 0 102.85714%
}

@media (min-width: 768px) {
	.g-map__innr::before {
		padding: 0 0 27.40741%
	}
}

.g-map__innr object, .g-map__innr embed, .g-map__innr iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.charm-title {
	margin: 0 0 2rem;
	line-height: 1.45;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'430;
	letter-spacing: 0.1em;
	font-size: 6rem
}

.charm-title::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

.charm-title::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

@media (min-width: 768px) {
	.charm-title {
		margin: 0 0 3rem
	}
}

.charm-title__text {
	font-size: 3.5rem;
	font-variation-settings: 'wght'550
}

.flow-block {
	display: block;
	margin: 0 auto;
	width: 100%;
	max-width: 103rem;
	position: relative;
	z-index: 1
}

.flow-block::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #efefef;
	z-index: -1;
	opacity: 0;
	-webkit-transform: translate3d(0, 4rem, 0) rotateX(15deg);
	transform: translate3d(0, 4rem, 0) rotateX(15deg)
}

.flow-block.in::before {
	opacity: 1;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	transition: opacity .75s linear, -webkit-transform .75s ease;
	transition: transform .75s ease, opacity .75s linear;
	transition: transform .75s ease, opacity .75s linear, -webkit-transform .75s ease
}

.flow-block__innr {
	margin: 0 auto;
	max-width: 70rem;
	padding: 4rem 4rem;
	-webkit-transform: translateZ(0);
	transform: translateZ(0)
}

@media (min-width: 768px) {
	.flow-block__innr {
		padding: 5rem 4rem
	}
}

.flow-block__title {
	font-size: 2.2rem;
	text-align: center;
	border-bottom: 0.3rem solid #000;
	padding: 0 0 2rem;
	margin: 0;
	font-weight: 700
}

@media (min-width: 768px) {
	.flow-block__title {
		font-size: 2.7rem
	}
}

.flow-block__visual {
	padding: 3rem 0 3rem
}

@media (min-width: 768px) {
	.flow-block__visual {
		padding: 5rem 0 5rem
	}
}

.flow-block__sp {
	display: block
}

@media (min-width: 768px) {
	.flow-block__sp {
		display: none
	}
}

.flow-block__sp-item {
	margin: 0 0 3rem
}

.flow-block__sp-item:last-child {
	margin: 0
}

.flow-block__sp-item img {
	display: block;
	width: 100%;
	height: auto
}

.flow-block__pc {
	display: none
}

@media (min-width: 768px) {
	.flow-block__pc {
		display: block;
		will-change: transform
	}
}

.flow-block__foot {
	border-top: 0.3rem solid #000;
	padding: 2rem 0 0;
	justify-content: center;
	display: flex
}

.flow-block__f-text {
	font-size: 1.6rem;
	line-height: 1.78
}

.flow-block__btn-wrap {
	margin: 3rem 0 0
}

@media (min-width: 768px) {
	.flow-block__btn-wrap {
		margin: 7rem 0 3rem
	}
}

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

.works-list {
	display: block
}

.works-list__row {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -0.5rem -5rem
}

@media (min-width: 768px) {
	.works-list__row {
		margin: 0 -2.3rem -4.6rem
	}
}

.works-list__item {
	display: block;
	width: 100%;
	padding: 0 0.5rem 5rem
}

@media (min-width: 768px) {
	.works-list__item {
		max-width: 25%;
		flex-basis: 25%;
		padding: 0 2.3rem 4.6rem;
		margin: 0
	}

	.works-list__item:nth-of-type(4n+1) {
		margin: 3.5rem 0 0
	}

	.works-list__item:nth-of-type(4n+2) {
		margin: 9.5rem 0 0
	}

	.works-list__item:nth-of-type(4n+4) {
		margin: 5.5rem 0 0
	}
}

.works-list__link {
	display: block
}

.touch-is-active .works-list__link.touched .works-list__img, .touch-is-active .works-list__link.touched .works-list__img-dummy {
	-webkit-transform: translate3d(-1rem, -1rem, 0);
	transform: translate3d(-1rem, -1rem, 0);
	transition: -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.mouse-is-active .works-list__link:hover .works-list__img, .mouse-is-active .works-list__link:hover .works-list__img-dummy {
	-webkit-transform: translate3d(-1rem, -1rem, 0);
	transform: translate3d(-1rem, -1rem, 0);
	transition: -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.works-list__visual {
	width: 100%;
	position: relative;
	background-color: #99D2DC
}

.works-list__visual::before {
	content: '';
	display: block;
	padding: 0 0 100%
}

.works-list__img {
	display: block;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: 50% 50%;
	object-position: 50% 50%;
	font-family: "object-fit: cover; object-position: center;";
	transition: -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1), -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1)
}

.works-list__img-dummy {
	background-color: #efefef;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1), -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1)
}

.works-list__coming {
	position: absolute;
	white-space: nowrap;
	top: 0%;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'550;
	letter-spacing: 0.075em;
	font-size: 2rem
}

.works-list__head {
	margin: 0 0 1.5rem
}

.works-list__title {
	font-size: 2rem;
	margin: 0;
	font-weight: 700;
	line-height: 1.45
}

.works-list__cate {
	display: inline-flex;
	color: #fff;
	background-color: #99D2DC;
	font-size: 1.5rem;
	height: 2.2rem;
	font-weight: 500;
	padding: 0 2rem;
	text-decoration: none;
	margin: 0 0 .5rem;
	line-height: 1;
	align-items: center
}

.works-list__meta-area {
	margin: 0 0 1rem
}

.works-list__area {
	display: inline-block;
	font-size: 1.5rem;
	font-weight: 500;
	padding: 0 1rem 0 0
}

.works-list__info {
	margin: .5rem 0 2rem;
	font-size: 1.3rem;
	line-height: 1.78
}

.works-list__dl {
	display: flex;
	margin: 0;
	padding: 0;
	width: 100%;
	position: relative
}

.works-list__dl:last-of-type {
	margin: 0 0 2.5rem
}

.works-list__dt {
	display: block;
	margin: 0;
	padding: 0 1rem 0 0;
	white-space: nowrap;
	font-size: 1.3rem;
	line-height: 1.78
}

.works-list__dd {
	display: block;
	margin: 0;
	padding: 0;
	flex: 1 0 auto;
	font-size: 1.3rem;
	line-height: 1.78
}

.newly-block {
	display: block
}

@media (min-width: 768px) {
	.newly-block__row {
		padding: 2rem 0 0;
		display: flex;
		margin: 0 -2.5rem
	}

	.newly-block__row::before {
		content: '';
		display: block;
		min-height: 0.1rem;
		width: 100%;
		max-width: 8.33333%;
		flex-basis: 8.33333%
	}
}

.newly-block__main {
	padding: 0 0 6rem;
	position: relative
}

@media (min-width: 768px) {
	.newly-block__main {
		max-width: 50%;
		flex-basis: 50%;
		padding: 0 2.5rem 8rem
	}
}

.newly-block__main::before {
	content: '';
	display: block;
	background-color: #99D2DC;
	width: 22rem;
	height: 24rem;
	position: absolute;
	left: -2rem;
	top: -2.5rem
}

@media (min-width: 768px) {
	.newly-block__main::before {
		left: -10rem;
		top: -4.5rem;
		width: 39rem;
		height: 42rem
	}
}

.newly-block__side {
	padding: 0
}

@media (min-width: 768px) {
	.newly-block__side {
		max-width: 33.33333%;
		flex-basis: 33.33333%;
		padding: 0 2.5rem 8rem
	}
}

.reform-block {
	display: block
}

@media (min-width: 768px) {
	.reform-block__innr {
		width: 100%;
		max-width: 83.33333%;
		margin: 0 auto
	}
}

.reform-block__main {
	display: block;
	position: relative
}

.reform-block__main::before {
	content: '';
	display: block;
	background-color: #99D2DC;
	width: 22rem;
	height: 24rem;
	position: absolute;
	left: -2rem;
	top: -2.5rem;
	z-index: -1
}

@media (min-width: 768px) {
	.reform-block__main::before {
		left: -10rem;
		top: -2.5rem;
		width: 39rem;
		height: 36rem
	}
}

.reform-block__section {
	padding: 0 0 4rem
}

.reform-block__visual {
	padding: 0 0 2rem
}

@media (min-width: 768px) {
	.reform-block__visual {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: 0 -2rem
	}
}

.reform-block__visual-item-caption {
	position: absolute;
	top: 2rem;
	left: 2rem;
	display: inline-flex;
	color: #fff;
	background-color: #99D2DC;
	font-size: 1.5rem;
	height: 2.2rem;
	font-weight: 500;
	padding: 0 2rem;
	text-decoration: none;
	margin: 0 0 .5rem;
	line-height: 1;
	align-items: center;
	text-transform: capitalize;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	letter-spacing: 0.075em;
	font-variation-settings: 'wght'550
}

@media (min-width: 768px) {
	.reform-block__visual-item-caption {
		top: 4rem;
		left: 4rem
	}
}

.reform-block__visual-item-caption.before {
	background-color: #fff;
	color: #000
}

.reform-block__visual-item {
	width: 100%;
	position: relative;
	margin: 0 0 2rem
}

@media (min-width: 768px) {
	.reform-block__visual-item {
		max-width: 50%;
		flex-basis: 50%;
		padding: 2rem;
		margin: 0
	}
}

.works-slide__item {
	position: relative;
	display: block !important
}

.works-slide__item::before {
	content: '';
	display: block;
	width: 100%;
	padding: 0 0 66.66667%
}

.works-slide__item-innr {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.works-slide__img {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: contain;
	object-fit: contain;
	-o-object-position: 50% 50%;
	object-position: 50% 50%;
	font-family: "object-fit: contain; object-position: center;"
}

.works-slide__thumbnail {
	padding: 2rem 0 0
}

.works-slide__thumbs {
	display: inline-block;
	height: 6rem;
	margin: 0 .4rem .6rem 0;
	cursor: pointer
}

@media (min-width: 768px) {
	.works-slide__thumbs {
		height: 8rem;
		margin: 0 .8rem 1.1rem 0
	}
}

.works-slide__thumbs-img {
	height: 100%
}

.catalog-block {
	display: block
}

.catalog-block__visual {
	display: block;
	margin: 4rem auto 2rem;
	width: 50%;
	max-width: 20.1rem
}

.catalog-block__visual-img {
	display: block;
	width: 100%;
	height: auto
}

.catalog-block__btn {
	display: flex;
	justify-content: center
}

.contact-block {
	display: block
}

.contact-block__dscr {
	font-size: 1.4rem;
	margin: 0 0 2rem
}

@media (min-width: 768px) {
	.contact-block__dscr {
		text-align: center
	}
}

.contact-block__dscr-num {
	display: inline-block;
	color: #99D2DC;
	font-size: 2.2rem;
	font-weight: 700;
	padding: 0 .25em
}

.contact-block__form {
	background-color: #efefef;
	width: 100%;
	max-width: 100rem;
	margin: 0 auto 6rem;
	padding: 4rem 2rem
}

@media (min-width: 768px) {
	.contact-block__form {
		padding: 4rem 10rem;
		margin: 0 auto 8rem
	}
}

.cf-form {
	display: block
}

.cf-form__title {
	text-align: center;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.45;
	margin: 0 0 3rem
}

.cf-form__title-mark {
	font-size: 1.4rem;
	padding: 0 1rem 0 0;
	color: #FF9933;
	font-weight: 700
}

.cf-form__block {
	background-color: #fff;
	padding: 6rem 2rem;
	margin: 0 0 6rem
}

@media (min-width: 768px) {
	.cf-form__block {
		padding: 6rem 10rem
	}
}

.cf-form__item {
	margin: 0 0 3rem
}

.cf-form__item:last-child {
	margin: 0
}

.cf-form__item-label {
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.45;
	margin: 0 0 .75rem
}

.cf-form__title-label-mark {
	color: #99D2DC;
	font-weight: 700;
	padding: 0 0 0 1rem;
	font-size: 1.4rem
}

.cf-form input[type="text"], .cf-form input[type="email"], .cf-form input[type="tel"], .cf-form textarea {
	width: 100%;
	outline: none;
	border-radius: 0;
	border: 1px solid #ccc;
	font-size: 16px;
	padding: 0.50rem 0.8rem;
	line-height: 1.9
}

@media (min-width: 768px) {
	.cf-form input[type="text"], .cf-form input[type="email"], .cf-form input[type="tel"], .cf-form textarea {
		font-size: 1.4rem
	}
}

.cf-form input[type="text"].wpcf7c-conf, .cf-form input[type="email"].wpcf7c-conf, .cf-form input[type="tel"].wpcf7c-conf, .cf-form textarea.wpcf7c-conf {
	background-color: #efefef !important;
	border: none
}

.cf-form textarea {
	height: 8rem;
	margin: .5rem 0 0
}

@media (min-width: 768px) {
	.cf-form textarea {
		height: 15rem
	}
}

.cf-form__select {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -1rem
}

@media (min-width: 768px) {
	.cf-form__select {
		margin: 0 -2.3rem
	}
}

.cf-form__select input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	outline: none;
	box-shadow: none;
	width: 2.4rem;
	height: 2.4rem;
	display: block;
	position: relative;
	cursor: pointer;
	flex-shrink: 0
}

.cf-form__select input::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	border: 1px solid #ccc
}

.cf-form__select input::after {
	content: '';
	display: block;
	position: absolute;
	left: 50%;
	top: 50%;
	width: 1.8rem;
	height: 1.8rem;
	background-color: #99D2DC;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	opacity: 0
}

.cf-form__select input:checked::after {
	opacity: 1
}

.cf-form__select .wpcf7-list-item {
	display: block;
	width: 100%;
	max-width: 50%;
	flex-basis: 50%;
	margin: 0 0 2rem;
	padding: 0 1rem
}

@media (min-width: 768px) {
	.cf-form__select .wpcf7-list-item {
		padding: 0 2.3rem
	}
}

.cf-form__select .wpcf7-list-item label {
	display: flex;
	cursor: pointer
}

.cf-form__select .wpcf7-list-item-label {
	font-size: 1.4rem;
	font-weight: 500;
	padding: 0 0 0 2rem
}

.cf-form__policy {
	text-align: center;
	padding: 0rem 0 4rem
}

.cf-form__policy-text {
	color: #FF0000;
	font-size: 1.2rem;
	max-width: 61.2rem;
	margin: 0 auto 2rem;
	text-align: left
}

.cf-form__policy-link {
	display: inline-block;
	font-size: 1.2rem;
	text-decoration: underline;
	cursor: pointer
}

.touch-is-active .cf-form__policy-link.touched {
	opacity: .7
}

.mouse-is-active .cf-form__policy-link:hover {
	opacity: .7
}

.cf-form input.wpcf7-back, .cf-form input[type="submit"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	box-shadow: none;
	outline: none;
	display: flex;
	width: 100%;
	height: 5rem;
	justify-content: center;
	align-items: center;
	font-size: 1.8rem;
	font-weight: 500;
	color: #fff;
	background-color: #707070;
	cursor: pointer;
	border-radius: 0
}

.touch-is-active .cf-form input.wpcf7-back.touched, .touch-is-active .cf-form input[type="submit"].touched {
	opacity: .7
}

.mouse-is-active .cf-form input.wpcf7-back:hover, .mouse-is-active .cf-form input[type="submit"]:hover {
	opacity: .7
}

.cf-form input.wpcf7-back {
	border: 2px solid #000 !important;
	background-color: #fff;
	color: #000
}

.touch-is-active .cf-form input.wpcf7-back.touched {
	opacity: .7
}

.mouse-is-active .cf-form input.wpcf7-back:hover {
	opacity: .7
}

body .wpcf7 {
	font-style: normal
}

body .wpcf7 .wpcf7-response-output {
	text-align: center;
	border: 1px solid rgba(69, 189, 207, 0.4);
	line-height: 1.45;
	padding: 1em 1em;
	font-size: 1.6rem
}

body .wpcf7 .wpcf7-validation-errors {
	border: 1px solid rgba(213, 193, 191, 0.7);
	background-color: rgba(238, 217, 217, 0.7)
}

body .wpcf7 .wpcf7-form.sent .wpcf7-response-output {
	display: block !important
}

body .wpcf7 .wpcf7-form.failed .wpcf7-response-output {
	display: block !important
}

::-webkit-input-placeholder {
	color: #969696;
	line-height: 1.9
}

:-ms-input-placeholder {
	color: #969696;
	line-height: 1.9
}

::-moz-placeholder {
	color: #969696;
	line-height: 1.9
}

::-ms-input-placeholder {
	color: #969696;
	line-height: 1.9
}

::placeholder {
	color: #969696;
	line-height: 1.9
}

.policy-content {
	width: 90vw;
	max-width: 120rem;
	background-color: #fff
}

.policy-content__innr {
	padding: 4rem 0
}

@media (min-width: 768px) {
	.policy-content__innr {
		padding: 8rem 4rem;
		max-width: 80rem;
		margin: 0 auto
	}
}

.policy-content__title {
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 4rem;
	text-align: center
}

@media (min-width: 768px) {
	.policy-content__title {
		margin: 0 0 5rem
	}
}

.policy-content__item-title {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 4rem 0 2rem
}

.policy-content__lead {
	margin: 0 0 4rem
}

@media (min-width: 768px) {
	.policy-content__lead {
		margin: 0 0 5rem
	}
}

.policy-content__body {
	overflow: auto;
	max-height: 60vh
}

.link-grids__innr {
	padding: 6rem 2rem;
	margin: 0 auto
}

@media (min-width: 768px) {
	.link-grids__innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

.link-grids__row {
	max-width: 37rem
}

@media (min-width: 768px) {
	.link-grids__row {
		display: flex;
		margin: 0;
		max-width: none;
		padding: 0 4.6rem
	}
}

.link-grids__item:nth-of-type(1) {
	margin: 0 2rem 3rem 0
}

.link-grids__item:nth-of-type(2) {
	display: none
}

.link-grids__item:nth-of-type(3) {
	margin: 0 0 0 2rem
}

@media (min-width: 768px) {
	.link-grids__item {
		padding: 0 2.3rem;
		width: 100%;
		max-width: 33.3333%;
		flex-basis: 33.3333%
	}

	.link-grids__item:nth-of-type(1) {
		margin: 0
	}

	.link-grids__item:nth-of-type(2) {
		display: block;
		margin: 7.5rem 0 0
	}

	.link-grids__item:nth-of-type(3) {
		margin: 2.5rem 0 0
	}
}

.link-grids__link {
	display: block;
	position: relative;
	overflow: hidden;
	text-decoration: none;
	color: #000
}

.touch-is-active .link-grids__link.touched::after {
	opacity: 1
}

.mouse-is-active .link-grids__link:hover::after {
	opacity: 1
}

.link-grids__link::after {
	content: '';
	display: block;
	width: 102%;
	height: 102%;
	position: absolute;
	top: -1%;
	left: -1%;
	opacity: 0;
	background-color: rgba(153, 210, 220, 0.4);
	transition: opacity .1s linear
}

.link-grids__content {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	flex-wrap: wrap;
	align-content: center;
	justify-content: center
}

.link-grids__catch {
	text-align: center;
	width: 100%;
	line-height: 1.45;
	margin: 0;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'550;
	font-weight: 400;
	letter-spacing: 0.1em;
	font-size: 2.8rem;
	margin: 0 0 .25rem
}

.link-grids__title {
	text-align: center;
	width: 100%;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.45;
	margin: 0
}

.link-grids__img {
	display: block;
	width: 100%
}

.sns-group {
	display: block;
	overflow: hidden
}

.sns-group__list {
	display: flex;
	list-style: none;
	margin: -1rem;
	padding: 0;
	justify-content: center
}

.sns-group__item {
	display: block;
	padding: 1rem;
	margin: 0
}

.sns-group__link {
	display: block;
	padding: .2rem;
	color: inherit
}

.sns-group__svg, .sns-group__img {
	display: block;
	width: 3.3rem;
	height: 3.3rem;
	text-decoration: none;
	color: inherit
}

@media (min-width: 768px) {
	.sns-group__svg, .sns-group__img {
		width: 2.2rem;
		height: 2.2rem
	}
}

.sns-group__svg {
	fill: currentColor;
	overflow: visible
}

.sns-group--column {
	display: block
}

.sns-group--column .sns-group__list {
	flex-direction: column
}

.sns-group--alignleft {
	display: block
}

.sns-group--alignleft .sns-group__list {
	justify-content: flex-start
}

.news-list {
	display: block;
	overflow: hidden
}

.news-list__list {
	display: block;
	margin: 0;
	padding: 0;
	list-style: none
}

.news-list__item {
	padding: 0;
	margin: 0 0 1.5rem
}

@media (min-width: 768px) {
	.news-list__item {
		display: flex;
		align-items: flex-start
	}
}

.news-list__head {
	display: flex
}

.news-list__date {
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	margin: 0;
	padding: 0;
	font-size: 1.8rem;
	width: 11rem;
	white-space: nowrap
}

.news-list__cate {
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	margin: 0;
	color: #99D2DC;
	font-size: 1.8rem;
	min-width: 8rem
}

@media (min-width: 768px) {
	.news-list__body {
		padding: .5rem 0 0 0rem
	}
}

.news-list__link {
	color: #000;
	text-decoration: none;
	display: block
}

.touch-is-active .news-list__link.touched {
	opacity: .7
}

.mouse-is-active .news-list__link:hover {
	opacity: .7
}

.news-list__title {
	margin: 0;
	line-height: 1.45
}

.f-banner {
	display: block
}

.f-banner__innr {
	padding: 6rem 2rem;
	margin: 0 auto
}

@media (min-width: 768px) {
	.f-banner__innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

@media (min-width: 768px) {
	.f-banner__innr {
		padding-bottom: 12rem !important
	}
}

.f-banner__innr--no-pt {
	padding: 6rem 2rem;
	margin: 0 auto;
	padding-top: 0rem
}

@media (min-width: 768px) {
	.f-banner__innr--no-pt {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

@media (min-width: 768px) {
	.f-banner__innr--no-pt {
		padding-top: 6rem
	}
}

@media (min-width: 768px) {
	.f-banner__row {
		display: flex;
		margin: 0 -2.3rem
	}
}

@media (min-width: 768px) {
	.f-banner__row--reverse {
		display: flex;
		flex-flow: row-reverse;
		margin: 0 -2.3rem
	}
}

.f-banner__item {
	overflow: hidden;
	position: relative;
	margin: 0 0 5rem
}

@media (min-width: 768px) {
	.f-banner__item {
		width: 100%;
		max-width: 50%;
		flex-basis: 50%;
		margin: 0;
		padding: 0 2.3rem
	}
}

.f-banner__item--type1 {
	overflow: hidden;
	position: relative;
	margin: 0 0 5rem
}

@media (min-width: 768px) {
	.f-banner__item--type1 {
		width: 100%;
		max-width: 50%;
		flex-basis: 50%;
		margin: 0;
		padding: 0 2.3rem
	}
}

.f-banner__item--type1 .f-banner__visual {
	margin: 0 0 5rem auto
}

@media (min-width: 768px) {
	.f-banner__item--type1 .f-banner__visual {
		margin: 0 0 1rem 11rem
	}
}

.f-banner__item--type1 .f-banner__info-box {
	top: auto;
	left: 0;
	bottom: 0;
	right: auto
}

@media (min-width: 768px) {
	.f-banner__item--type1 .f-banner__info-box {
		bottom: 2rem;
		left: 5rem
	}
}

.f-banner__item--type2 {
	overflow: hidden;
	position: relative;
	margin: 0 0 5rem
}

@media (min-width: 768px) {
	.f-banner__item--type2 {
		width: 100%;
		max-width: 50%;
		flex-basis: 50%;
		margin: 0;
		padding: 0 2.3rem
	}
}

.f-banner__item--type2 .f-banner__visual {
	margin: 0 0 8.5rem auto
}

@media (min-width: 768px) {
	.f-banner__item--type2 .f-banner__visual {
		margin: 7.5rem auto 0 7.5rem
	}
}

.f-banner__item--type2 .f-banner__info-box {
	top: auto;
	left: 0;
	bottom: 0;
	right: auto
}

@media (min-width: 768px) {
	.f-banner__item--type2 .f-banner__info-box {
		top: 0;
		bottom: auto
	}
}

.f-banner__item--type3 {
	overflow: hidden;
	position: relative;
	margin: 0 0 5rem;
	margin: 7.5rem auto 0 0
}

@media (min-width: 768px) {
	.f-banner__item--type3 {
		width: 100%;
		max-width: 50%;
		flex-basis: 50%;
		margin: 0;
		padding: 0 2.3rem
	}
}

@media (min-width: 768px) {
	.f-banner__item--type3 .f-banner__visual {
		margin: 0 auto 0 12.5rem
	}
}

@media (min-width: 768px) {
	.f-banner__item--type3 .f-banner__info-box {
		left: 5rem;
		top: auto;
		bottom: 0
	}
}

.f-banner__item--type3 .f-banner__mark {
	width: 7rem;
	position: absolute;
	top: 1rem;
	left: 5rem
}

@media (min-width: 768px) {
	.f-banner__item--type3 .f-banner__mark {
		position: relative;
		top: auto;
		left: auto
	}
}

.f-banner__item--type3 .f-banner__foot {
	padding: 0
}

@media (min-width: 768px) {
	.f-banner__item--type3 .f-banner__foot {
		padding: 2rem 0 0 46.5rem
	}
}

.f-banner__link {
	display: inline;
	color: #000;
	text-decoration: none
}

.touch-is-active .f-banner__link.touched .f-banner__visual {
	opacity: .7
}

.mouse-is-active .f-banner__link:hover .f-banner__visual {
	opacity: .7
}

.f-banner__visual {
	width: 30rem;
	margin: 6.5rem auto 0 0;
	position: relative;
	transition: opacity .1s linear
}

@media (min-width: 768px) {
	.f-banner__visual {
		margin: 7.5rem auto 0 7.5rem;
		width: 41.3rem
	}
}

.f-banner__icon--play {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 4.775rem;
	height: 5.514rem;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	background-image: url(../img/icon_play.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: 50% 50%
}

.f-banner__img {
	display: block;
	width: 100%
}

.f-banner__img.lazyload {
	opacity: 0
}

.f-banner__img.lazyload.lazyloaded {
	opacity: 1;
	transition: opacity .75s linear, -webkit-transform .75s ease;
	transition: transform .75s ease, opacity .75s linear;
	transition: transform .75s ease, opacity .75s linear, -webkit-transform .75s ease
}

.f-banner__info-box {
	position: absolute;
	top: 0;
	right: 0;
	width: 19.3rem;
	border: 0.5rem solid #000;
	padding: 2.3rem 2rem 2.3rem 2.3rem;
	background-color: #fff;
	letter-spacing: 0.1em
}

@media (min-width: 768px) {
	.f-banner__info-box {
		right: auto
	}
}

.f-banner__info-title {
	font-size: 2.8rem;
	line-height: 1.25;
	margin: 0;
	flex: 1 0 auto;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'550;
	letter-spacing: 0.055em;
	margin: 0 0 3rem;
	font-weight: 400
}

.f-banner__info-title::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.25) * 0.5em)
}

.f-banner__info-title::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.25) * 0.5em)
}

@media (min-width: 768px) {
	.f-banner__info-title {
		letter-spacing: 0.095em
	}
}

.f-banner__info-title--mbs {
	font-size: 2.8rem;
	line-height: 1.25;
	margin: 0;
	flex: 1 0 auto;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'550;
	letter-spacing: 0.055em;
	margin: 0 0 3rem;
	font-weight: 400;
	margin: 0 0 1.5rem
}

.f-banner__info-title--mbs::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.25) * 0.5em)
}

.f-banner__info-title--mbs::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.25) * 0.5em)
}

@media (min-width: 768px) {
	.f-banner__info-title--mbs {
		letter-spacing: 0.095em
	}
}

.f-banner__info-title--tab {
	position: relative
}

.f-banner__info-title--tab::after {
	content: '';
	display: block;
	position: absolute;
	right: 0;
	bottom: .5rem;
	width: 1.8rem;
	height: 1.8rem;
	background-image: url(../img/icon_outerlink_black.svg);
	background-size: 1.8rem 1.6rem;
	background-repeat: no-repeat;
	background-position: center 90%
}

.f-banner__info-dscr {
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1.45;
	margin: 0
}

.f-banner__info-dscr::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.f-banner__info-dscr::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

.f-banner__foot {
	display: flex;
	justify-content: flex-end;
	padding: 0 0 2.5rem
}

@media (min-width: 768px) {
	.f-banner__foot {
		display: block;
		padding: 0 0 0 27rem
	}
}

.f-contact {
	display: block;
	background-color: #d3d3d3;
	color: #fff
}

.f-contact__innr {
	padding: 6rem 2rem;
	margin: 0 auto
}

@media (min-width: 768px) {
	.f-contact__innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

.f-contact__title {
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-size: 6rem;
	text-align: center;
	letter-spacing: 0.1em;
	line-height: 1.45;
	margin: 0 0 2.3rem;
	font-variation-settings: 'wght'330
}

.f-contact__title::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.f-contact__title::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

.f-contact__title.svg {
	margin: 0 auto 3rem;
	display: block
}

.f-contact__title.svg::before, .f-contact__title.svg::after {
	display: none
}

.f-contact__title.svg svg {
	display: block;
	width: 19.8rem;
	height: 4.466rem;
	margin: 0 auto
}

.f-contact__wrap {
	display: block;
	width: 100%;
	margin: 0 auto;
	max-width: 54rem
}

.f-contact__btn {
	display: flex;
	color: #fff;
	width: 100%;
	height: 5.8rem;
	justify-content: center;
	align-items: center;
	text-decoration: none;
	font-weight: 700;
	font-size: 2rem;
	margin: 0 0 2.3rem;
	position: relative;
	z-index: 1;
	overflow: hidden
}

@media (min-width: 768px) {
	.f-contact__btn {
		height: 8rem
	}
}

.f-contact__btn::before {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	border: .5rem solid #fff
}

.f-contact__btn::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
	background-color: #fff;
	-webkit-transform: translate3d(-102%, 0, 0);
	transform: translate3d(-102%, 0, 0);
	transition: background-color .1s, -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1);
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1), background-color .1s;
	transition: transform .3s cubic-bezier(0.6, 0, 0.3, 1), background-color .1s, -webkit-transform .3s cubic-bezier(0.6, 0, 0.3, 1)
}

.touch-is-active .f-contact__btn.touched::after {
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	background-color: #99D2DC
}

.mouse-is-active .f-contact__btn:hover::after {
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	background-color: #99D2DC
}

.f-contact__btn-text {
	position: relative;
	z-index: 2
}

.f-contact__row {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	margin: 0 -1rem
}

.f-contact__tel, .f-contact__time {
	white-space: nowrap;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-variation-settings: 'wght'430;
	line-height: 1.45;
	padding: 0 1rem
}

.f-contact__tel::before, .f-contact__time::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.f-contact__tel::after, .f-contact__time::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

.f-contact__tel-text {
	font-size: 1.8rem;
	padding: 0 .5rem 0 0
}

@media (min-width: 768px) {
	.f-contact__tel-text {
		padding: 0 1rem 0 0;
		font-size: 2.2rem
	}
}

.f-contact__tel-num {
	font-size: 2.3rem
}

@media (min-width: 768px) {
	.f-contact__tel-num {
		font-size: 3.3rem
	}
}

.f-contact__time-text {
	font-size: 1.5rem;
	padding: 0 .5rem 0 0
}

@media (min-width: 768px) {
	.f-contact__time-text {
		font-size: 2.2rem;
		padding: 0 1rem 0 0
	}
}

.f-contact__time-symbol {
	font-size: 2.2rem
}

.f-contact__time-num {
	font-size: 2.2rem
}

@media (min-width: 768px) {
	.f-contact__time-num {
		font-size: 2.8rem
	}
}

.f-contact__spacer {
	width: 0.2rem;
	height: 3rem;
	flex: 0 0 0.2rem;
	background-color: #fff
}

.ns-visual {
	display: block;
	position: relative
}

.ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	z-index: -1;
		
}

.ns-visual__image-wrap {
	display: block;
	position: relative
}

.ns-visual__img {
	height: auto
}

.ns-visual__img.lazyload {
	opacity: 0
}

.ns-visual__img.lazyload.lazyloaded {
	opacity: 1;
	transition: opacity .75s linear, -webkit-transform .75s ease;
	transition: transform .75s ease, opacity .75s linear;
	transition: transform .75s ease, opacity .75s linear, -webkit-transform .75s ease
}

.ns-visual--ceo {
	position: relative
}

.ns-visual--ceo .ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	left: -2rem;
	top: 0;
	width: 34rem;
	height: 26.5rem
}

@media (min-width: 768px) {
	.ns-visual--ceo .ns-visual__bg {
		left: -5rem;
		width: 53rem;
		height: 41.5rem
	}
}

.ns-visual--ceo .ns-visual__image-wrap {
	display: block;
	position: relative;
	padding: 4.5rem 0 0 0;
	margin: 0 2.5rem 0 auto;
	width: 28.5rem
}

@media (min-width: 768px) {
	.ns-visual--ceo .ns-visual__image-wrap {
		width: 45.2rem;
		margin: 0 auto 0 6.5rem;
		padding: 6.5rem 0 0
	}
}

.ns-visual--ceo .ns-visual__ceo-stamp {
	display: block;
	width: 15.3rem;
	position: absolute;
	right: -2.5rem;
	top: 15.7rem
}

.ns-visual--ceo .ns-visual__ceo-stamp svg {
	width: 100%;
	height: auto
}

@media (min-width: 768px) {
	.ns-visual--ceo .ns-visual__ceo-stamp {
		width: 24rem;
		top: 25rem;
		right: -5rem
	}
}

.ns-visual--company {
	position: relative
}

.ns-visual--company .ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	right: -2rem;
	top: 0;
	width: 35rem;
	height: 28rem
}

@media (min-width: 768px) {
	.ns-visual--company .ns-visual__bg {
		right: auto;
		left: 5.5rem;
		width: 53rem;
		height: 41rem
	}
}

.ns-visual--company .ns-visual__image-wrap {
	display: block;
	position: relative;
	margin: 0 auto 0 0;
	width: 32rem;
	padding: 4.5rem 0 2rem
}

@media (min-width: 768px) {
	.ns-visual--company .ns-visual__image-wrap {
		padding: 6.5rem 0 0;
		width: 45rem;
		margin: 0 auto 0 0rem
	}
}

.ns-visual--charm-a {
	position: relative
}

.ns-visual--charm-a .ns-visual__bg {
  background-color: #99D2DC;
	position: absolute;
	left: -2rem;
	top: auto;
	width: 21.7rem;
	height: 28rem;
	bottom: 0;
}
@media (min-width: 768px) {
	.ns-visual--charm-a .ns-visual__bg {
		right: auto;
		left: 3rem;
		top: 0rem;
		bottom: auto;
		width: 58rem;
		height: 45rem;
		z-index:-1;
	}

	.ns-visual--charm-a .scrollin{
	animation:charm-a_bg 2s ease-in-out 1 forwards;
}

	@keyframes charm-a_bg{
		0% {
			z-index:1;
			top: 0rem;
			width: 58rem;
			height: 45rem;
		}
		50% {
		   width: 5rem;
		   height: 20rem;
			top: 0rem;
			z-index:1;
		}
			51%{
			z-index:0;
			}
		100% {
			top: 5rem;
			width: 31rem;
			height: 40rem;
			z-index:0;
		}
	}

}


.ns-visual--charm-a .ns-visual__image-wrap {
	display: block;
	position: relative;
	margin: 0 auto 0 0;
	width: 35rem;
	padding: 0 0 3rem
}

@media (min-width: 768px) {
	.ns-visual--charm-a .ns-visual__image-wrap {
		padding: 0rem 0 4.5rem;
		width: 50rem;
		margin: 0 auto 0 8rem
	}
}

.ns-visual--charm-b {
	position: relative
}

.ns-visual--charm-b .ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	left: auto;
	right: -2rem;
	top: 0;
	width: 35rem;
	height: 15.5rem
}

@media (min-width: 768px) {
	.ns-visual--charm-b .ns-visual__bg {
		right: 0;
		left: auto;
		top: 0;
		bottom: auto;
		width: 60rem;
		height: 45rem;
		z-index:-1;
	}
	.ns-visual--charm-b .scrollin{
	animation:charm-b_bg 2s ease-in-out 1 forwards;
}
	@keyframes charm-b_bg{
	0% {
	width: 60rem;
	height: 45rem;
		z-index:1;
	}
	50% {
	width: 8rem;
	height: 24rem;
		z-index:1;
	}
		51%{
		z-index:0;
		}
	100% {
	bottom: auto;
	width: 54rem;
	height: 24rem;
		z-index:0;
	}
}

}

.ns-visual--charm-b .ns-visual__image-wrap {
	display: block;
	position: relative;
	margin: 0 auto 0 0;
	width: 35rem;
	padding: 3rem 0 0
}

@media (min-width: 768px) {
	.ns-visual--charm-b .ns-visual__image-wrap {
		padding: 4rem 0 0;
		width: 50rem;
		margin: 0 auto 0 0rem
	}
}

.ns-visual--charm-c {
	position: relative
}

.ns-visual--charm-c .ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	right: -2rem;
	top: 0;
	width: 26rem;
	height: 30rem
}

@media (min-width: 768px) {
	.ns-visual--charm-c .ns-visual__bg {
		right: 0;
		left: auto;
		top: 0rem;
		bottom: auto;
		width: 60rem;
		height: 45rem;
		z-index:-1;
	}
	.ns-visual--charm-c .scrollin{
		animation:charm-c_bg 2s ease-in-out 1 forwards;
	}
	@keyframes charm-c_bg{
	0% {
	width: 60rem;
	height: 45rem;
		z-index:1;
	}
	50% {
	width: 30rem;
	height: 6rem;
		z-index:1;
	}
		51%{
		z-index:0;
		}
	100% {
				right: 0;
	bottom: auto;
	width: 45rem;
	height: 41rem;
		z-index:0;
	}
}

}

.ns-visual--charm-c .ns-visual__image-wrap {
	display: block;
	position: relative;
	margin: 0 auto 0 0;
	width: 35rem;
	padding: 4.5rem 0 0
}

@media (min-width: 768px) {
	.ns-visual--charm-c .ns-visual__image-wrap {
		padding: 6rem 0 4.5rem;
		width: 50rem;
		margin: 0 auto 0 8rem
	}
}

.ns-visual--voice-a {
	position: relative
}

.ns-visual--voice-a .ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	left: -2rem;
	top: -2rem;
	width: 21rem;
	height: 20rem
}

@media (min-width: 768px) {
	.ns-visual--voice-a .ns-visual__bg {
		display: none
	}
}

.ns-visual--voice-b {
	position: relative
}

@media (min-width: 768px) {
	.ns-visual--voice-b {
		padding: 2rem 0 0
	}
}

.ns-visual--voice-b .ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	display: none;
	z-index: -1
}

@media (min-width: 768px) {
	.ns-visual--voice-b .ns-visual__bg {
		display: block;
		left: -10rem;
		top: -2rem;
		width: 21rem;
		height: 20rem
	}
}

.ns-visual--voice-c {
	position: relative
}

@media (min-width: 768px) {
	.ns-visual--voice-c {
		padding: 2rem 0 0
	}
}

.ns-visual--voice-d {
	position: relative
}

.ns-visual--voice-d .ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	right: -2rem;
	top: -2rem;
	width: 10rem;
	height: 30rem
}

@media (min-width: 768px) {
	.ns-visual--voice-d .ns-visual__bg {
		height: 40rem;
		width: 14rem;
		top: -3rem;
		right: 4rem
	}
}

@media (min-width: 768px) {
	.ns-visual--voice-d .ns-visual__image-wrap {
		width: 50rem
	}
}

.ns-visual--voice-e {
	position: relative
}

.ns-visual--voice-e .ns-visual__bg {
	background-color: #99D2DC;
	position: absolute;
	left: -2rem;
	top: 4rem;
	width: 15rem;
	height: 25rem
}

@media (min-width: 768px) {
	.ns-visual--voice-e .ns-visual__bg {
		height: 34rem;
		width: 25rem;
		top: 9.5rem;
		left: auto;
		right: 4rem
	}
}

@media (min-width: 768px) {
	.ns-visual--voice-e .ns-visual__image-wrap {
		width: 50rem
	}
}

.page-kv {
	display: block;
	position: relative;
	width: 100%;
	margin: 0;
	padding: 0;
	overflow: hidden
}

.page-kv__content {
	position: relative;
	display: block;
	width: 100%;
	z-index: 2;
	max-height: 60rem;
	overflow: hidden
}

.page-kv__content::before {
	content: '';
	display: block;
	padding: 0 0 105.07614%
}

@media (min-width: 768px) {
	.page-kv__content::before {
		padding: 0 0 29.62963%
	}
}

.page-kv__wrap {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	align-items: center
}

.page-kv__innr {
	text-align: center;
	width: 100%;
	margin: 0 auto;
	max-width: 125rem
}

@media (min-width: 768px) {
	.page-kv__innr {
		padding: 6rem 0 0
	}
}

.page-kv__catch {
	color: #fff;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	font-size: 5.5rem;
	text-align: center;
	letter-spacing: 0.075em;
	line-height: 1.45;
	margin: 0 0 1.7rem;
	font-variation-settings: 'wght'430;
	text-shadow: 0 0.3rem 0.6rem rgba(0, 0, 0, 0.2);
	padding: 0 0 0 2rem
}

.page-kv__catch::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.page-kv__catch::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

@media (min-width: 768px) {
	.page-kv__catch {
		letter-spacing: 0.1em;
		margin: 0 0 1.5rem;
		font-size: 6rem;
		padding: 0
	}
}

.page-kv__catch.aboutus::before, .page-kv__catch.aboutus::after {
	display: none
}

.page-kv__catch.aboutus svg {
	width: 22.4rem;
	-webkit-filter: drop-shadow(0 0.3rem 0.6rem rgba(0, 0, 0, 0.2));
	filter: drop-shadow(0 0.3rem 0.6rem rgba(0, 0, 0, 0.2));
	height: 6.542rem
}

.page-kv__catch svg {
	display: block;
	margin: 0 auto
}

.page-kv__title {
	color: #fff;
	font-size: 2rem;
	text-align: center;
	letter-spacing: 0.15em;
	line-height: 1.45;
	margin: 0;
	text-shadow: 0 0.3rem 0.6rem rgba(0, 0, 0, 0.2);
	padding: 0 0 0 2rem
}

.page-kv__title::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.page-kv__title::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

@media (min-width: 768px) {
	.page-kv__title {
		padding: 0
	}
}

.page-kv__bg {
	position: absolute;
	top: 0;
	left: 2rem;
	right: 0;
	bottom: 0;
	z-index: 1
}

@media (min-width: 768px) {
	.page-kv__bg {
		left: 0
	}
}

.page-kv__bg-img {
	display: block;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: 50% 50%;
	object-position: 50% 50%;
	font-family: "object-fit: cover; object-position: center;";
	opacity: 0;
	-webkit-transform: translate3d(0, 0, 0) scale(1.05);
	transform: translate3d(0, 0, 0) scale(1.05);
	transition: opacity .75s linear, -webkit-transform 1.25s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: transform 1.25s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear;
	transition: transform 1.25s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .75s linear, -webkit-transform 1.25s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition-delay: 300ms
}

.page-kv__bg-img.lazyloaded {
	opacity: 1;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0)
}

.p-lead__catch {
	color: #99D2DC;
	margin: 0 auto 3rem
}

@media (min-width: 768px) {
	.p-lead__catch {
		margin: 0 auto 4rem
	}
}

.p-lead__catch.mission {
	width: 26rem
}

@media (min-width: 768px) {
	.p-lead__catch.mission {
		width: 35rem
	}
}

.p-lead__innr {
	padding: 6rem 2rem;
	margin: 0 auto;
	padding-top: 6rem;
	padding-bottom: 6rem
}

@media (min-width: 768px) {
	.p-lead__innr {
		padding: 6rem 5rem;
		max-width: 135rem
	}
}

@media (min-width: 768px) {
	.p-lead__innr {
		padding-top: 9rem;
		padding-bottom: 9rem
	}
}

.p-lead__title {
	text-align: center;
	font-size: 2.2rem;
	line-height: 1.78;
	letter-spacing: 0.1em;
	margin: 0
}

.p-lead__title::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.78) * 0.5em)
}

.p-lead__title::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.78) * 0.5em)
}

@media (min-width: 768px) {
	.p-lead__title {
		font-size: 2.7rem
	}
}

.p-lead__span {
	color: #99D2DC
}

.p-headline {
	text-align: center;
	margin: 0 0 6rem
}

.p-headline--company .p-headline__catch {
	width: 21.6rem;
	height: 6rem;
	margin: 0 auto;
	text-align: center
}

.p-headline--company .p-headline__title {
	text-align: center
}

.p-headline__catch {
	font-size: 6rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	color: #99D2DC;
	font-weight: 700;
	letter-spacing: 0.07em;
	margin: 0;
	font-variation-settings: 'wght'330;
	line-height: 1.45
}

.p-headline__catch::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.p-headline__catch svg {
	display: block
}

.p-headline__catch.svg {
	margin: 0 auto 1.5rem
}

.p-headline__catch.svg::before {
	display: none
}

.p-headline__title {
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 2rem;
	line-height: 1.45
}

.p-headline__title::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

.p-heading--2 {
	font-size: 2.1rem;
	margin: 0 0 3rem
}

.p-heading--2 .p-headline {
	text-align: center;
	margin: 0 0 6rem
}

.p-heading--2 .p-headline--company .p-heading--2 .p-headline__catch {
	width: 21.6rem;
	height: 6rem;
	margin: 0 auto;
	text-align: center
}

.p-heading--2 .p-headline--company .p-heading--2 .p-headline__title {
	text-align: center
}

.p-heading--2 .p-headline__catch {
	font-size: 6rem;
	font-family: Oswald, "Noto Sans", "NotoSansJP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", Meiryo, sans-serif;
	color: #99D2DC;
	font-weight: 700;
	letter-spacing: 0.07em;
	margin: 0;
	font-variation-settings: 'wght'330;
	line-height: 1.45
}

.p-heading--2 .p-headline__catch::before {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-top: calc((1 - 1.45) * 0.5em)
}

.p-heading--2 .p-headline__catch svg {
	display: block
}

.p-heading--2 .p-headline__catch.svg {
	margin: 0 auto 1.5rem
}

.p-heading--2 .p-headline__catch.svg::before {
	display: none
}

.p-heading--2 .p-headline__title {
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 2rem;
	line-height: 1.45
}

.p-heading--2 .p-headline__title::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	margin-bottom: calc((1 - 1.45) * 0.5em)
}

@media (min-width: 768px) {
	.p-heading--2 {
		font-size: 2.2rem;
		margin: 0 0 4rem
	}
}

.pop-content {
	position: relative;
	width: 100%;
	max-width: 86rem
}

.pop-content__close {
	position: absolute;
	top: 0rem;
	right: 0rem;
	width: 5rem;
	height: 5rem;
	cursor: pointer
}

.pop-content__close::before, .pop-content__close::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 2.5rem;
	height: .2rem;
	background-color: #fff;
	-webkit-transform: translate(-50%, -50%) rotate(45deg);
	transform: translate(-50%, -50%) rotate(45deg)
}

.pop-content__close::after {
	-webkit-transform: translate(-50%, -50%) rotate(-45deg);
	transform: translate(-50%, -50%) rotate(-45deg)
}

.pop-content__close.dark::before, .pop-content__close.dark::after {
	background-color: #000
}

.anim--fade-up {
	opacity: 0;
	-webkit-transform: translate3d(0, 4rem, 0) rotateX(15deg);
	transform: translate3d(0, 4rem, 0) rotateX(15deg)
}

.anim--fade-up.in {
	opacity: 1;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	transition: opacity .75s linear, -webkit-transform .75s ease;
	transition: transform .75s ease, opacity .75s linear;
	transition: transform .75s ease, opacity .75s linear, -webkit-transform .75s ease
}

.anim--fade-up.delay1 {
	transition-delay: .3s
}

.anim--fade-up.delay2 {
	transition-delay: .45s
}

.anim--fade-up.delay3 {
	transition-delay: .6s
}

.anim--fade-up.speed1 {
	transition-duration: .3s
}

.anim--fade-in {
	opacity: 0;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0)
}

.anim--fade-in.in {
	opacity: 1;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	transition: opacity .75s linear, -webkit-transform .75s ease;
	transition: transform .75s ease, opacity .75s linear;
	transition: transform .75s ease, opacity .75s linear, -webkit-transform .75s ease
}

.anim--fade-in.delay1 {
	transition-delay: .3s
}

.anim--fade-in.delay2 {
	transition-delay: .45s
}

.anim--fade-in.delay3 {
	transition-delay: .6s
}

.anim--fade-in.speed1 {
	transition-duration: .3s
}

.entry h1, .entry h2, .entry h3, .entry h4, .entry h5 {
	margin: 4rem 0 2rem;
	font-weight: 700
}

.entry h1 {
	font-size: 1.8rem
}

.entry h2 {
	font-size: 1.8rem
}

.entry h3 {
	font-size: 1.6rem
}

.entry h4 {
	font-size: 1.5rem
}

.entry h5 {
	font-size: 1.4rem
}

.entry p {
	font-size: 1.4rem;
	margin: 3rem 0
}

.entry ul, .entry ol {
	margin: 3rem 0
}

.entry ul li, .entry ol li {
	font-size: 1.4rem
}

.entry a {
	color: #99D2DC;
	text-decoration: underline;
	text-underline-position: under
}

.entry figure {
	margin: 3rem 0
}

.entry blockquote {
	display: block;
	-webkit-margin-before: 1em;
	margin-block-start: 1em;
	-webkit-margin-after: 1em;
	margin-block-end: 1em;
	-webkit-margin-start: 4rem;
	margin-inline-start: 4rem;
	-webkit-margin-end: 4rem;
	margin-inline-end: 4rem;
	border-left: 0.4rem solid #000;
	margin: 3rem 0;
	padding: 0 0 0 1rem
}

.entry blockquote p {
	margin: 0 0 1rem
}

.entry blockquote cite {
	font-size: 1.2rem;
	color: #666
}

.entry .wp-block-file, .entry .wp-block-gallery, .entry .wp-block-cover, .entry .wp-block-video, .entry .wp-block-pullquote, .entry .wp-block-code, .entry .wp-block-preformatted, .entry .wp-block-table, .entry .wp-block-verse, .entry .wp-block-button, .entry .wp-block-columns, .entry .wp-block-media-text, .entry .wp-block-calendar, .entry .wp-block-archives, .entry .wp-block-archives-list, .entry .wp-block-categories, .entry .wp-block-latest-posts, .entry .wp-block-search, .entry .wp-block-tag-cloud, .entry .wp-block-embed, .entry .wp-block-image {
	margin: 3rem 0
}

.entry .wp-block-image figcaption {
	text-align: center;
	font-size: 1.3rem;
	color: #666
}

.ib {
	display: inline-block;
	font: inherit
}

.no-pb {
	padding-bottom: 0 !important
}

.only-sp {
	display: block
}

@media (min-width: 768px) {
	.only-sp {
		display: none
	}
}

.only-pc {
	display: none
}

@media (min-width: 768px) {
	.only-pc {
		display: block
	}
}

.white-space-nowrap {
	white-space: nowrap
}

.force-hide {
	display: none !important
}

@media (min-width: 768px) {
	.t-news__main {
		width: 100%;
		max-width: 70%;
		display: flex;
		flex-basis: 100%;
	}

	.t-news__row {
		display: flex;
	}

	.t-headline--news {
		width: 30%;
	}

	.t-news__foot {
		width: 30%;
	}

	.t-news__instagram {
		width: 100%;
		max-width: 100%;
		flex-basis: 100%;
	}

	.t-news__instagram::before {
		width: 100vw;
	}

	.t-news__instagram-list {
		width: 80%;
		margin: auto;
	}

	.t-news__innr {
		max-width: 100vw;
	}

	ul.page-numbers {
		text-align: center;
	}

	ul.page-numbers li {
		list-style: none;
		display: inline-block;
	}

	ul.page-numbers li .current {
		font-size: 150%;
	}

	ul.page-numbers li a {
		text-decoration: none;
		color: white;
		padding: 8px;
		border-radius: 4px;
		background-color: #99D2DC;
	}

	ul.page-numbers li a.next {
		text-decoration: none;
		color: black;
		padding: 8px;
		border-radius: 4px;
		background-color: transparent;
	}

	.t-concept {
		padding-bottom: 0;
	}
