﻿html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video {
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	border: 0;
	margin: 0;
	padding: 0
}

article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section {
	display: block
}

body {
	line-height: 1
}

ol:not(.markdown-body ol),ul:not(.markdown-body ul) {
	list-style: none
}

blockquote,q {
	quotes: none
}

blockquote:before,blockquote:after,q:before,q:after {
	content: "";
	content: none
}

table {
	border-collapse: collapse;
	border-spacing: 0
}

main {
	display: block
}

button {
	cursor: pointer;
	appearance: none;
	background-color: #0000;
	border: none;
	outline: none
}

input,button,select,textarea {
	appearance: none;
	font: inherit;
	background: 0 0;
	border: none;
	border-radius: 0;
	outline: none
}

*,:before,:after {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
	letter-spacing: 0;
	margin: 0;
	padding: 0
}

html {
	box-sizing: border-box;
	font-family: Noto Sans JP,sans-serif;
	font-size: 62.5%;
	font-weight: 400
}

body {
	color: #202733;
	font-smoothing: antialiased;
	text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-font-smoothing: antialiased;
	-ms-font-smoothing: antialiased;
	-o-font-smoothing: antialiased;
	-o-text-size-adjust: 100%;
	background-color: #f4f4f5;
	line-height: 1.5
}

a {
	color: inherit;
	cursor: pointer;
	text-decoration: none
}

img {
	vertical-align: bottom;
	width: 100%;
	max-width: 100%;
	height: auto;
	line-height: 1
}

input {
	outline: none
}

textarea {
	resize: none;
	outline: none
}

@font-face {
	font-family:swiper-icons;src:url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA");font-weight:400;font-style:normal
}

:root {
	--swiper-theme-color: #007aff
}

.swiper,swiper-container {
	z-index: 1;
	margin-left: auto;
	margin-right: auto;
	padding: 0;
	list-style: none;
	display: block;
	position: relative;
	overflow: hidden
}

.swiper-vertical>.swiper-wrapper {
	flex-direction: column
}

.swiper-wrapper {
	z-index: 1;
	width: 100%;
	height: 100%;
	transition-property: transform;
	-webkit-transition-timing-function: var(--swiper-wrapper-transition-timing-function,initial);
	transition-timing-function: var(--swiper-wrapper-transition-timing-function,initial);
	box-sizing: content-box;
	display: flex;
	position: relative
}

.swiper-android .swiper-slide,.swiper-wrapper {
	transform: translate(0,0)
}

.swiper-horizontal {
	-ms-touch-action: pan-y;
	touch-action: pan-y
}

.swiper-vertical {
	-ms-touch-action: pan-x;
	touch-action: pan-x
}

.swiper-slide,swiper-slide {
	flex-shrink: 0;
	width: 100%;
	height: 100%;
	transition-property: transform;
	display: block;
	position: relative
}

.swiper-slide-invisible-blank {
	visibility: hidden
}

.swiper-autoheight,.swiper-autoheight .swiper-slide {
	height: auto
}

.swiper-autoheight .swiper-wrapper {
	align-items: flex-start;
	transition-property: transform,height
}

.swiper-backface-hidden .swiper-slide {
	backface-visibility: hidden;
	transform: translateZ(0)
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
	perspective: 1200px
}

.swiper-3d .swiper-wrapper {
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d
}

.swiper-3d {
	perspective: 1200px
}

.swiper-3d .swiper-slide,.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom,.swiper-3d .swiper-cube-shadow {
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d
}

.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom {
	pointer-events: none;
	z-index: 10;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.swiper-3d .swiper-slide-shadow {
	background: #00000026
}

.swiper-3d .swiper-slide-shadow-left {
	background-image: linear-gradient(270deg,#00000080,#0000)
}

.swiper-3d .swiper-slide-shadow-right {
	background-image: linear-gradient(90deg,#00000080,#0000)
}

.swiper-3d .swiper-slide-shadow-top {
	background-image: linear-gradient(#0000,#00000080)
}

.swiper-3d .swiper-slide-shadow-bottom {
	background-image: linear-gradient(#00000080,#0000)
}

.swiper-css-mode>.swiper-wrapper {
	scrollbar-width: none;
	-ms-overflow-style: none;
	overflow: auto
}

.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar {
	display: none
}

.swiper-css-mode>.swiper-wrapper>.swiper-slide {
	scroll-snap-align: start start
}

.swiper-horizontal.swiper-css-mode>.swiper-wrapper {
	-webkit-scroll-snap-type: x mandatory;
	-ms-scroll-snap-type: x mandatory;
	scroll-snap-type: x mandatory
}

.swiper-vertical.swiper-css-mode>.swiper-wrapper {
	-webkit-scroll-snap-type: y mandatory;
	-ms-scroll-snap-type: y mandatory;
	scroll-snap-type: y mandatory
}

.swiper-css-mode.swiper-free-mode>.swiper-wrapper {
	-webkit-scroll-snap-type: none;
	-ms-scroll-snap-type: none;
	scroll-snap-type: none
}

.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide {
	scroll-snap-align: none
}

.swiper-centered>.swiper-wrapper:before {
	content: "";
	flex-shrink: 0;
	order: 9999
}

.swiper-centered>.swiper-wrapper>.swiper-slide {
	scroll-snap-align: center center;
	scroll-snap-stop: always
}

.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child {
	-webkit-margin-start: var(--swiper-centered-offset-before);
	margin-inline-start: var(--swiper-centered-offset-before)
}

.swiper-centered.swiper-horizontal>.swiper-wrapper:before {
	height: 100%;
	min-height: 1px;
	width: var(--swiper-centered-offset-after)
}

.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child {
	-webkit-margin-before: var(--swiper-centered-offset-before);
	margin-block-start: var(--swiper-centered-offset-before)
}

.swiper-centered.swiper-vertical>.swiper-wrapper:before {
	width: 100%;
	min-width: 1px;
	height: var(--swiper-centered-offset-after)
}

.swiper-lazy-preloader {
	z-index: 10;
	transform-origin: 50%;
	box-sizing: border-box;
	border: 4px solid var(--swiper-preloader-color,var(--swiper-theme-color));
	border-top-color: #0000;
	border-radius: 50%;
	width: 42px;
	height: 42px;
	margin-top: -21px;
	margin-left: -21px;
	position: absolute;
	top: 50%;
	left: 50%
}

.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,swiper-container:not(.swiper-watch-progress) .swiper-lazy-preloader,.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
	animation: 1s linear infinite swiper-preloader-spin
}

.swiper-lazy-preloader-white {
	--swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
	--swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
	0% {
		transform: rotate(0)
	}

	to {
		transform: rotate(360deg)
	}
}

.swiper-virtual .swiper-slide {
	-webkit-backface-visibility: hidden;
	transform: translateZ(0)
}

.swiper-virtual.swiper-css-mode .swiper-wrapper:after {
	content: "";
	pointer-events: none;
	position: absolute;
	top: 0;
	left: 0
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper:after {
	height: 1px;
	width: var(--swiper-virtual-size)
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper:after {
	width: 1px;
	height: var(--swiper-virtual-size)
}

:root {
	--swiper-navigation-size: 44px
}

.swiper-button-prev,.swiper-button-next {
	top: var(--swiper-navigation-top-offset,50%);
	width: calc(var(--swiper-navigation-size)/44*27);
	height: var(--swiper-navigation-size);
	margin-top: calc(0px - var(--swiper-navigation-size)/2);
	z-index: 10;
	cursor: pointer;
	color: var(--swiper-navigation-color,var(--swiper-theme-color));
	justify-content: center;
	align-items: center;
	display: flex;
	position: absolute
}

.swiper-button-prev.swiper-button-disabled,.swiper-button-next.swiper-button-disabled {
	opacity: .35;
	cursor: auto;
	pointer-events: none
}

.swiper-button-prev.swiper-button-hidden,.swiper-button-next.swiper-button-hidden {
	opacity: 0;
	cursor: auto;
	pointer-events: none
}

.swiper-navigation-disabled .swiper-button-prev,.swiper-navigation-disabled .swiper-button-next {
	display: none!important
}

.swiper-button-prev:after,.swiper-button-next:after {
	font-family: swiper-icons;
	font-size: var(--swiper-navigation-size);
	letter-spacing: 0;
	font-variant: initial;
	line-height: 1;
	text-transform: none!important
}

.swiper-button-prev,.swiper-rtl .swiper-button-next {
	left: var(--swiper-navigation-sides-offset,10px);
	right: auto
}

.swiper-button-prev:after,.swiper-rtl .swiper-button-next:after {
	content: "prev"
}

.swiper-button-next,.swiper-rtl .swiper-button-prev {
	right: var(--swiper-navigation-sides-offset,10px);
	left: auto
}

.swiper-button-next:after,.swiper-rtl .swiper-button-prev:after {
	content: "next"
}

.swiper-button-lock {
	display: none
}

.swiper-pagination {
	text-align: center;
	z-index: 10;
	transition: opacity .3s;
	position: absolute;
	transform: translate(0,0)
}

.swiper-pagination.swiper-pagination-hidden {
	opacity: 0
}

.swiper-pagination-disabled>.swiper-pagination,.swiper-pagination.swiper-pagination-disabled {
	display: none!important
}

.swiper-pagination-fraction,.swiper-pagination-custom,.swiper-horizontal>.swiper-pagination-bullets,.swiper-pagination-bullets.swiper-pagination-horizontal {
	bottom: var(--swiper-pagination-bottom,8px);
	top: var(--swiper-pagination-top,auto);
	width: 100%;
	left: 0
}

.swiper-pagination-bullets-dynamic {
	font-size: 0;
	overflow: hidden
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	position: relative;
	transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
	transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
	transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
	transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
	transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
	transform: scale(.33)
}

.swiper-pagination-bullet {
	width: var(--swiper-pagination-bullet-width,var(--swiper-pagination-bullet-size,8px));
	height: var(--swiper-pagination-bullet-height,var(--swiper-pagination-bullet-size,8px));
	border-radius: var(--swiper-pagination-bullet-border-radius,50%);
	background: var(--swiper-pagination-bullet-inactive-color,#000);
	opacity: var(--swiper-pagination-bullet-inactive-opacity,.2);
	display: inline-block
}

button.swiper-pagination-bullet {
	-webkit-box-shadow: none;
	box-shadow: none;
	appearance: none;
	border: none;
	margin: 0;
	padding: 0
}

.swiper-pagination-clickable .swiper-pagination-bullet {
	cursor: pointer
}

.swiper-pagination-bullet:only-child {
	display: none!important
}

.swiper-pagination-bullet-active {
	opacity: var(--swiper-pagination-bullet-opacity,1);
	background: var(--swiper-pagination-color,var(--swiper-theme-color))
}

.swiper-vertical>.swiper-pagination-bullets,.swiper-pagination-vertical.swiper-pagination-bullets {
	right: var(--swiper-pagination-right,8px);
	left: var(--swiper-pagination-left,auto);
	top: 50%;
	transform: translateY(-50%)
}

.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: var(--swiper-pagination-bullet-vertical-gap,6px)0;
	display: block
}

.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
	width: 8px;
	top: 50%;
	transform: translateY(-50%)
}

.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	transition: transform .2s,top .2s;
	display: inline-block
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 var(--swiper-pagination-bullet-horizontal-gap,4px)
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
	white-space: nowrap;
	left: 50%;
	transform: translate(-50%)
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	transition: transform .2s,left .2s
}

.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,:host(.swiper-horizontal.swiper-rtl) .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	transition: transform .2s,right .2s
}

.swiper-pagination-fraction {
	color: var(--swiper-pagination-fraction-color,inherit)
}

.swiper-pagination-progressbar {
	background: var(--swiper-pagination-progressbar-bg-color,#00000040);
	position: absolute
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	background: var(--swiper-pagination-color,var(--swiper-theme-color));
	transform-origin: 0 0;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	transform: scale(0)
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	transform-origin: 100% 0
}

.swiper-horizontal>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-horizontal,.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
	width: 100%;
	height: var(--swiper-pagination-progressbar-size,4px);
	top: 0;
	left: 0
}

.swiper-vertical>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-vertical,.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
	width: var(--swiper-pagination-progressbar-size,4px);
	height: 100%;
	top: 0;
	left: 0
}

.swiper-pagination-lock {
	display: none
}

.swiper-scrollbar {
	border-radius: var(--swiper-scrollbar-border-radius,10px);
	-ms-touch-action: none;
	background: var(--swiper-scrollbar-bg-color,#0000001a);
	position: relative
}

.swiper-scrollbar-disabled>.swiper-scrollbar,.swiper-scrollbar.swiper-scrollbar-disabled {
	display: none!important
}

.swiper-horizontal>.swiper-scrollbar,.swiper-scrollbar.swiper-scrollbar-horizontal {
	left: var(--swiper-scrollbar-sides-offset,1%);
	bottom: var(--swiper-scrollbar-bottom,4px);
	top: var(--swiper-scrollbar-top,auto);
	z-index: 50;
	height: var(--swiper-scrollbar-size,4px);
	width: calc(100% - 2*var(--swiper-scrollbar-sides-offset,1%));
	position: absolute
}

.swiper-vertical>.swiper-scrollbar,.swiper-scrollbar.swiper-scrollbar-vertical {
	left: var(--swiper-scrollbar-left,auto);
	right: var(--swiper-scrollbar-right,4px);
	top: var(--swiper-scrollbar-sides-offset,1%);
	z-index: 50;
	width: var(--swiper-scrollbar-size,4px);
	height: calc(100% - 2*var(--swiper-scrollbar-sides-offset,1%));
	position: absolute
}

.swiper-scrollbar-drag {
	background: var(--swiper-scrollbar-drag-bg-color,#00000080);
	border-radius: var(--swiper-scrollbar-border-radius,10px);
	width: 100%;
	height: 100%;
	position: relative;
	top: 0;
	left: 0
}

.swiper-scrollbar-cursor-drag {
	cursor: move
}

.swiper-scrollbar-lock {
	display: none
}

.swiper-zoom-container {
	text-align: center;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	display: flex
}

.swiper-zoom-container>img,.swiper-zoom-container>svg,.swiper-zoom-container>canvas {
	-o-object-fit: contain;
	object-fit: contain;
	max-width: 100%;
	max-height: 100%
}

.swiper-slide-zoomed {
	cursor: move;
	-ms-touch-action: none;
	touch-action: none
}

.swiper .swiper-notification,swiper-container .swiper-notification {
	pointer-events: none;
	opacity: 0;
	z-index: -1000;
	position: absolute;
	top: 0;
	left: 0
}

.swiper-free-mode>.swiper-wrapper {
	margin: 0 auto;
	transition-timing-function: ease-out
}

.swiper-grid>.swiper-wrapper {
	flex-wrap: wrap
}

.swiper-grid-column>.swiper-wrapper {
	flex-flow: column wrap
}

.swiper-fade.swiper-free-mode .swiper-slide {
	transition-timing-function: ease-out
}

.swiper-fade .swiper-slide {
	pointer-events: none;
	transition-property: opacity
}

.swiper-fade .swiper-slide .swiper-slide {
	pointer-events: none
}

.swiper-fade .swiper-slide-active,.swiper-fade .swiper-slide-active .swiper-slide-active {
	pointer-events: auto
}

.swiper-cube {
	overflow: visible
}

.swiper-cube .swiper-slide {
	pointer-events: none;
	backface-visibility: hidden;
	z-index: 1;
	visibility: hidden;
	transform-origin: 0 0;
	width: 100%;
	height: 100%
}

.swiper-cube .swiper-slide .swiper-slide {
	pointer-events: none
}

.swiper-cube.swiper-rtl .swiper-slide {
	transform-origin: 100% 0
}

.swiper-cube .swiper-slide-active,.swiper-cube .swiper-slide-active .swiper-slide-active {
	pointer-events: auto
}

.swiper-cube .swiper-slide-active,.swiper-cube .swiper-slide-next,.swiper-cube .swiper-slide-prev,.swiper-cube .swiper-slide-next+.swiper-slide {
	pointer-events: auto;
	visibility: visible
}

.swiper-cube .swiper-slide-shadow-top,.swiper-cube .swiper-slide-shadow-bottom,.swiper-cube .swiper-slide-shadow-left,.swiper-cube .swiper-slide-shadow-right {
	z-index: 0;
	backface-visibility: hidden
}

.swiper-cube .swiper-cube-shadow {
	opacity: .6;
	z-index: 0;
	width: 100%;
	height: 100%;
	position: absolute;
	bottom: 0;
	left: 0
}

.swiper-cube .swiper-cube-shadow:before {
	content: "";
	filter: blur(50px);
	background: #000;
	position: absolute;
	inset: 0
}

.swiper-flip {
	overflow: visible
}

.swiper-flip .swiper-slide {
	pointer-events: none;
	backface-visibility: hidden;
	z-index: 1
}

.swiper-flip .swiper-slide .swiper-slide {
	pointer-events: none
}

.swiper-flip .swiper-slide-active,.swiper-flip .swiper-slide-active .swiper-slide-active {
	pointer-events: auto
}

.swiper-flip .swiper-slide-shadow-top,.swiper-flip .swiper-slide-shadow-bottom,.swiper-flip .swiper-slide-shadow-left,.swiper-flip .swiper-slide-shadow-right {
	z-index: 0;
	backface-visibility: hidden
}

.swiper-creative .swiper-slide {
	backface-visibility: hidden;
	transition-property: transform,opacity,height;
	overflow: hidden
}

.swiper-cards {
	overflow: visible
}

.swiper-cards .swiper-slide {
	transform-origin: bottom;
	backface-visibility: hidden;
	overflow: hidden
}[data-simplebar] {
	flex-flow: column wrap;
	place-content: flex-start;
	align-items: flex-start;
	position: relative
}

.simplebar-wrapper {
	width: inherit;
	height: inherit;
	max-width: inherit;
	max-height: inherit;
	overflow: hidden
}

.simplebar-mask {
	direction: inherit;
	z-index: 0;
	margin: 0;
	padding: 0;
	position: absolute;
	inset: 0;
	overflow: hidden;
	width: auto!important;
	height: auto!important
}

.simplebar-offset {
	-webkit-overflow-scrolling: touch;
	margin: 0;
	padding: 0;
	position: absolute;
	inset: 0;
	direction: inherit!important;
	-webkit-box-sizing: inherit!important;
	box-sizing: inherit!important;
	resize: none!important
}

.simplebar-content-wrapper {
	direction: inherit;
	scrollbar-width: none;
	-ms-overflow-style: none;
	width: auto;
	max-width: 100%;
	height: 100%;
	max-height: 100%;
	display: block;
	position: relative;
	overflow: auto;
	box-sizing: border-box!important
}

.simplebar-content-wrapper::-webkit-scrollbar {
	width: 0;
	height: 0;
	display: none
}

.simplebar-hide-scrollbar::-webkit-scrollbar {
	width: 0;
	height: 0;
	display: none
}

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

.simplebar-placeholder {
	pointer-events: none;
	width: 100%;
	max-width: 100%;
	max-height: 100%
}

.simplebar-height-auto-observer-wrapper {
	float: left;
	z-index: -1;
	pointer-events: none;
	-webkit-box-flex: inherit;
	-webkit-flex-grow: inherit;
	-ms-flex-positive: inherit;
	flex-grow: inherit;
	flex-shrink: 0;
	flex-basis: 0;
	width: 100%;
	max-width: 1px;
	height: 100%;
	max-height: 1px;
	margin: 0;
	padding: 0;
	position: relative;
	overflow: hidden;
	-webkit-box-sizing: inherit!important;
	box-sizing: inherit!important
}

.simplebar-height-auto-observer {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
	opacity: 0;
	pointer-events: none;
	z-index: -1;
	width: 1000%;
	min-width: 1px;
	height: 1000%;
	min-height: 1px;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.simplebar-track {
	z-index: 1;
	pointer-events: none;
	position: absolute;
	bottom: 0;
	right: 0;
	overflow: hidden
}[data-simplebar].simplebar-dragging,[data-simplebar].simplebar-dragging .simplebar-content {
	pointer-events: none;
	-webkit-touch-callout: none;
	user-select: none
}[data-simplebar].simplebar-dragging .simplebar-track {
	pointer-events: all
}

.simplebar-scrollbar {
	min-height: 10px;
	position: absolute;
	left: 0;
	right: 0
}

.simplebar-scrollbar:before {
	content: "";
	opacity: 0;
	background: #000;
	border-radius: 7px;
	transition: opacity .2s linear .5s;
	position: absolute;
	left: 2px;
	right: 2px
}

.simplebar-scrollbar.simplebar-visible:before {
	opacity: .5;
	transition-duration: 0s;
	transition-delay: 0s
}

.simplebar-track.simplebar-vertical {
	width: 11px;
	top: 0
}

.simplebar-scrollbar:before {
	inset: 2px
}

.simplebar-track.simplebar-horizontal {
	height: 11px;
	left: 0
}

.simplebar-track.simplebar-horizontal .simplebar-scrollbar {
	width: auto;
	min-width: 10px;
	min-height: 0;
	inset: 0 auto 0 0
}[data-simplebar-direction=rtl] .simplebar-track.simplebar-vertical {
	left: 0;
	right: auto
}

.simplebar-dummy-scrollbar-size {
	opacity: 0;
	visibility: hidden;
	direction: rtl;
	width: 500px;
	height: 500px;
	position: fixed;
	overflow: scroll hidden;
	-ms-overflow-style: scrollbar!important
}

.simplebar-dummy-scrollbar-size>div {
	width: 200%;
	height: 200%;
	margin: 10px 0
}

.simplebar-hide-scrollbar {
	visibility: hidden;
	scrollbar-width: none;
	-ms-overflow-style: none;
	position: fixed;
	left: 0;
	overflow-y: scroll
}

.loading {
	z-index: 1000;
	pointer-events: none;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100vh;
	display: flex;
	position: fixed;
	top: 0;
	left: 0
}

.loading__bar {
	height: 5px;
	position: absolute;
	top: 0;
	left: 0
}

.loading__logo {
	opacity: 0;
	width: 248px;
	transition: all 1s
}

@media (width<=768px) {
	.loading__logo {
		width: 200px
	}
}

.container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 32px
}

@media (width<=768px) {
	.container {
		padding: 0 20px;
		max-width: 600px!important
	}
}

.container::-webkit-scrollbar {
	display: none
}

.btn {
	z-index: 1;
	will-change: transform;
	cursor: pointer;
	border-radius: 100px;
	width: 100%;
	height: 100%;
	transition: transform .3s cubic-bezier(.24,.45,.32,1);
	display: flex;
	position: relative
}

.btn.-normal {
	border: 1px solid;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: center;
	transition: all .3s cubic-bezier(.24,.45,.32,1);
	display: flex;
	overflow: hidden
}

.btn.-normal span {
	z-index: 1;
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500;
	transition: all .3s;
	position: relative
}

.btn.-normal span.arrow {
	background-color: #c9d1db;
	border: 1px solid;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	position: relative
}

@media (width<=768px) {
	.btn.-normal span.arrow {
		width: 52px;
		height: 20px
	}
}

.btn.-normal.-white {
	background-color: #fff;
	border-color: #c9d1db
}

.btn.-normal.-white:after {
	content: "";
	pointer-events: none;
	background-color: #0553dd;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

.btn.-normal.-white span {
	color: #202733
}

.btn.-normal.-white span.arrow {
	border-color: #fff;
	display: block;
	position: relative;
	overflow: hidden
}

.btn.-normal.-white span.arrow svg {
	fill: #202733;
	width: 16px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.btn.-normal.-white span.arrow svg:first-child {
	transform: translate(-150px)
}

.btn.-normal.-white:before {
	border-color: #fff
}

@media (hover:hover) {
	.btn.-normal.-white:hover {
		border-color: #0553dd
	}

	.btn.-normal.-white:hover span.arrow {
		background-color: #0553dd;
		border-color: #ffffff4d
	}

	.btn.-normal.-white:hover span.arrow svg {
		fill: #fff;
		transform: translate(150px)
	}

	.btn.-normal.-white:hover span.arrow svg:first-child {
		transform: translate(0)
	}

	.btn.-normal.-white:hover:before {
		background-color: #0000;
		border-color: #ffffff4d
	}

	.btn.-normal.-white:hover:after {
		transform: scale(10)
	}

	.btn.-normal.-white:hover span {
		color: #fff
	}
}

.btn.-normal.-white.-icon-arrow-right-up:before {
	background-size: 11px 11px
}

.btn.-normal.-main {
	background-color: #0553dd;
	border-color: #0553dd
}

.btn.-normal.-main:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

.btn.-normal.-main span {
	color: #fff
}

.btn.-normal.-main span.arrow {
	background-color: #0553dd;
	border-color: #c9d1db4d;
	display: block;
	position: relative;
	overflow: hidden
}

.btn.-normal.-main span.arrow svg {
	fill: #fff;
	width: 16px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.btn.-normal.-main span.arrow svg:first-child {
	transform: translate(-150px)
}

.btn.-normal.-main:before {
	background-color: #0000;
	border-color: #c9d1db4d
}

@media (hover:hover) {
	.btn.-normal.-main:hover {
		border-color: #c9d1db
	}

	.btn.-normal.-main:hover span.arrow {
		background-color: #c9d1db
	}

	.btn.-normal.-main:hover span.arrow svg {
		fill: #202733;
		transform: translate(150px)
	}

	.btn.-normal.-main:hover span.arrow svg:first-child {
		transform: translate(0)
	}

	.btn.-normal.-main:hover:before {
		background-color: #c9d1db;
		border-color: #ffffff4d
	}

	.btn.-normal.-main:hover:after {
		transform: scale(10)
	}

	.btn.-normal.-main:hover span {
		color: #202733
	}
}

.text-btn {
	align-items: center;
	display: inline-flex
}

.text-btn span.text {
	letter-spacing: .04em;
	margin-right: 12px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500
}

.text-btn span.arrow {
	border: 1px solid;
	border-radius: 50px;
	justify-content: center;
	align-items: center;
	width: 60px;
	height: 24px;
	transition: all .3s;
	display: flex;
	position: relative;
	overflow: hidden
}

.text-btn span.arrow svg {
	fill: #fff;
	width: 16px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.text-btn span.arrow svg:first-child {
	transform: translate(-150px)
}

.text-btn.-main span.arrow {
	background-color: #0553dd;
	border-color: #0553dd
}

@media (hover:hover) {
	.text-btn.-main:hover span.arrow {
		background-color: #c9d1db;
		border-color: #fff
	}

	.text-btn.-main:hover span.arrow svg {
		fill: #202733;
		transform: translate(150px)
	}

	.text-btn.-main:hover span.arrow svg:first-child {
		transform: translate(0)
	}
}

.breadcrumb {
	background-color: #fff;
	border-top: 1px solid #20273326;
	border-bottom: 1px solid #20273326
}

.breadcrumb__container {
	max-width: 1184px
}

.breadcrumb__list {
	flex-wrap: wrap;
	padding: 20px 0 18px;
	display: flex
}

@media (width<=768px) {
	.breadcrumb__list {
		padding: 8px 0
	}
}

.breadcrumb__item {
	margin-right: 12px;
	padding-left: 16px;
	position: relative
}

.breadcrumb__item.-first {
	padding-left: 0
}

.breadcrumb__item.-first:before {
	display: none
}

.breadcrumb__item:before {
	content: "";
	background-color: #0553dd;
	border-radius: 50%;
	width: 4px;
	height: 4px;
	display: block;
	position: absolute;
	top: 9px;
	left: 0
}

.breadcrumb__item span,.breadcrumb__item a {
	letter-spacing: -.01em;
	font-size: 14px;
	font-weight: 500
}

.breadcrumb__item a {
	color: #2027334d;
	transition: all .3s
}

.breadcrumb__item a:hover {
	color: #0553dd
}

.pagination .wp-pagenavi {
	justify-content: center;
	align-items: center;
	display: flex
}

.pagination span.pages,.pagination a.previouspostslink,.pagination a.nextpostslink {
	display: none
}

.pagination span.current,.pagination a.page,.pagination a.last,.pagination a.first {
	letter-spacing: -.01em;
	background-color: #c9d1db;
	border-radius: 100px;
	justify-content: center;
	align-items: center;
	width: 72px;
	height: 29px;
	margin: 0 4px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500;
	transition: all .3s;
	display: flex
}

@media (width<=768px) {
	.pagination span.current,.pagination a.page,.pagination a.last,.pagination a.first {
		width: 60px;
		height: 24px
	}
}

.pagination a.page,.pagination a.last,.pagination a.first {
	color: #fff;
	background-color: #0553dd
}

@media (hover:hover) {
	.pagination a.page:hover,.pagination a.last:hover,.pagination a.first:hover {
		color: #202733;
		background-color: #c9d1db
	}
}

.pagination span.extend {
	justify-content: space-between;
	width: 20px;
	height: 4px;
	margin: 0 16px;
	font-size: 0;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.pagination span.extend {
		margin: 0 8px
	}
}

.pagination span.extend:before,.pagination span.extend:after,.pagination span.extend span {
	content: "";
	background-color: #202733;
	border-radius: 50%;
	width: 4px;
	height: 4px;
	display: block
}

.form__row:not(:first-child) {
	margin-top: 52px
}

@media (width<=768px) {
	.form__row:not(:first-child) {
		margin-top: 48px
	}
}

.form__row.-privacy {
	justify-content: center;
	display: flex
}

.form__label {
	flex-wrap: wrap;
	align-items: center;
	padding-left: 14px;
	font-size: 14px;
	font-weight: 700;
	display: flex;
	position: relative
}

.form__label:before {
	content: "";
	background-color: #0553dd;
	border-radius: 50%;
	width: 6px;
	height: 6px;
	position: absolute;
	top: 8px;
	left: 0
}

.form__label .required {
	color: #fff;
	background-color: #0553dd;
	border-radius: 30px;
	margin-left: 12px;
	margin-right: 20px;
	padding: 2px 10px;
	font-size: 11px;
	font-weight: 400;
	display: inline-block
}

.form__label .sub-info {
	letter-spacing: .02em;
	color: #dd052f;
	font-size: 13px;
	font-weight: 400;
	display: inline-block
}

.form__control {
	width: 100%;
	margin-top: 12px
}

.form__control.-select {
	position: relative
}

.form__control.-select:after {
	content: "";
	background-color: #0553dd;
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: 11px 7px;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	position: absolute;
	top: 16px;
	right: 20px
}

.form__control input,.form__control textarea,.form__control select {
	letter-spacing: .04em;
	background-color: #fff;
	border: 1px solid #0000;
	border-radius: 4px;
	width: 100%;
	padding: 16px 20px;
	font-size: 16px;
	font-weight: 400;
	transition: all .3s
}

@media (width<=768px) {
	.form__control input,.form__control textarea,.form__control select {
		padding: 12px
	}
}

@media (hover:hover) {
	.form__control input:hover,.form__control textarea:hover,.form__control select:hover {
		border-color: #0553dd
	}
}

.form__control input:focus,.form__control textarea:focus,.form__control select:focus {
	border-color: #0553dd
}

.form__control input::-webkit-input-placeholder {
	color: #33333380
}

.form__control textarea::-webkit-input-placeholder {
	color: #33333380
}

.form__control select::-webkit-input-placeholder {
	color: #33333380
}

:is(.form__control input:-ms-input-placeholder,.form__control textarea:-ms-input-placeholder,.form__control select:-ms-input-placeholder) {
	color: #33333380
}

.form__control input::-moz-placeholder {
	color: #33333380
}

.form__control textarea::-moz-placeholder {
	color: #33333380
}

.form__control select::-moz-placeholder {
	color: #33333380
}

.form__control input::placeholder,.form__control textarea::placeholder,.form__control select::placeholder {
	color: #33333380
}

.form__control select {
	cursor: pointer
}

.form__control .wpcf7-not-valid-tip {
	letter-spacing: .02em;
	color: #dd052f;
	margin-top: 8px;
	font-size: 13px;
	display: block
}

.form .form__privacy+span.wpcf7-list-item-label {
	letter-spacing: .02em;
	align-items: center;
	font-size: 13px;
	display: inline-flex;
	position: relative
}

.form .form__privacy+span.wpcf7-list-item-label:before {
	content: "";
	background-color: #fff;
	border: 1px solid #c9d1db;
	border-radius: 4px;
	width: 24px;
	height: 24px;
	margin-right: 12px;
	display: inline-block
}

.form .form__privacy+span.wpcf7-list-item-label:after {
	content: "";
	border-top: 2px solid #0553dd;
	border-left: 2px solid #0553dd;
	width: 9px;
	height: 16px;
	display: none;
	position: absolute;
	top: 1px;
	left: 7px;
	transform: rotate(-135deg)
}

.form .form__privacy+span.wpcf7-list-item-label a {
	color: #0553dd;
	text-decoration: underline
}

.form .form__privacy:checked+span.wpcf7-list-item-label:after {
	display: block
}

.form__example {
	letter-spacing: .02em;
	margin-top: 8px;
	font-size: 13px;
	line-height: 2
}

.form__btn button {
	background-color: #0553dd;
	border: 1px solid #0553dd;
	border-radius: 100px;
	justify-content: center;
	align-items: center;
	width: 420px;
	height: 60px;
	margin: 28px auto 0;
	display: flex;
	position: relative;
	overflow: hidden
}

.form__btn button:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=768px) {
	.form__btn button {
		width: 100%;
		height: 48px
	}
}

.form__btn button:disabled {
	pointer-events: none;
	background-color: #c9d1db;
	border-color: #c9d1db
}

.form__btn button span {
	z-index: 1;
	color: #fff;
	letter-spacing: .04em;
	font-size: 13px;
	transition: all .3s;
	position: relative
}

@media (hover:hover) {
	.form__btn button:hover:after {
		transition-duration: .6s;
		transform: scale(20)
	}

	.form__btn button:hover span {
		color: #0553dd
	}
}

.form .wpcf7-spinner,.form .wpcf7 form.sent .wpcf7-response-output {
	display: none
}

.form form.invalid .wpcf7-response-output,.form .entry_content .inner form.invalid .wpcf7-response-output {
	color: red;
	letter-spacing: .02em;
	background-color: #fdebe5;
	border: 1px solid red;
	margin-top: 24px;
	font-size: 14px;
	line-height: 2
}

.form form.sent .wpcf7-response-output,.form .entry_content .inner form.sent .wpcf7-response-output {
	color: #3a87ad;
	background-color: #d9edf7;
	border: 1px solid #3a87ad
}

.form form .wpcf7-response-output,.form form .wpcf7-response-output {
	text-align: center;
	-ms-border-radius: 0;
	-o-border-radius: 0;
	border: 0;
	border-radius: 0;
	margin: 0;
	padding: 16px;
	font-weight: 700;
	line-height: 1.6
}

.hamburger-menu {
	pointer-events: none;
	opacity: 0;
	z-index: 9;
	background-color: #202733;
	flex-direction: column;
	width: 100%;
	height: 100dvh;
	transition: all .6s;
	display: flex;
	position: fixed;
	top: 0;
	left: 0;
	overflow: hidden
}

.hamburger-menu__lines {
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.hamburger-menu__left-line-wrap {
	width: 32%;
	position: absolute;
	bottom: -12%;
	left: -5%
}

@media (width<=768px) {
	.hamburger-menu__left-line-wrap {
		width: 39%;
		inset: -9% 4% auto auto;
		transform: rotate(-90deg)scaleX(-1)
	}
}

.hamburger-menu__left-line {
	width: 100%;
	padding-top: 145%;
	position: relative
}

.hamburger-menu__left-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.hamburger-menu__left-line svg .line-menu-left {
	fill: #fff;
	isolation: isolate;
	opacity: .07
}

.hamburger-menu__left-line svg .line-menu-left-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 150px
}

.hamburger-menu__right-line-wrap {
	width: 49%;
	position: absolute;
	top: -8%;
	right: -3%
}

@media (width<=768px) {
	.hamburger-menu__right-line-wrap {
		width: 64%;
		inset: auto -16% 4% auto;
		transform: rotate(90deg)
	}
}

.hamburger-menu__right-line {
	width: 100%;
	padding-top: 67.4%;
	position: relative
}

.hamburger-menu__right-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.hamburger-menu__right-line svg .line-menu-right {
	fill: #fff;
	isolation: isolate;
	opacity: .07
}

.hamburger-menu__right-line svg .line-menu-right-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 150px
}

.hamburger-menu__content {
	height: 100%;
	overflow-y: auto
}

.hamburger-menu__container {
	max-width: 1184px;
	height: 100%
}

.hamburger-menu__inner {
	padding: 88px 0 42px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.hamburger-menu__inner {
		padding: 0
	}
}

.hamburger-menu__left-col {
	flex-direction: column;
	width: calc(50% - 70px);
	padding: 120px 0 56px;
	display: flex
}

@media (width<=768px) {
	.hamburger-menu__left-col {
		width: 0;
		padding: 0
	}
}

.hamburger-menu__logo {
	width: 245px;
	transition: all .3s;
	display: flex
}

@media (width<=768px) {
	.hamburger-menu__logo {
		width: 100px;
		position: absolute;
		top: 16px;
		left: 0
	}
}

@media (hover:hover) {
	.hamburger-menu__logo:hover {
		opacity: .7
	}
}

.hamburger-menu__sub-info {
	margin-top: auto
}

@media (width<=768px) {
	.hamburger-menu__sub-info {
		display: none
	}
}

.hamburger-menu__info-list {
	display: flex
}

.hamburger-menu__info-item {
	margin-right: 20px
}

.hamburger-menu__info-link {
	letter-spacing: -.01em;
	color: #ffffffb3;
	font-size: 14px;
	font-weight: 500;
	transition: all .3s
}

@media (hover:hover) {
	.hamburger-menu__info-link:hover {
		color: #fff
	}
}

.hamburger-menu__copy {
	letter-spacing: -.01em;
	color: #fff;
	margin-top: 24px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px
}

.hamburger-menu__right-col {
	border-left: 1px solid #ffffff4d;
	flex-grow: 1;
	width: calc(50% + 70px);
	padding: 40px 0 56px 70px
}

@media (width<=768px) {
	.hamburger-menu__right-col {
		border-left: 0;
		width: 100%;
		padding: 120px 0 108px
	}
}

.hamburger-menu__item:not(:first-child) {
	margin-top: 48px
}

@media (width<=768px) {
	.hamburger-menu__item:not(:first-child) {
		margin-top: 24px
	}
}

.hamburger-menu__main-link {
	color: #fff;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 40px;
	font-weight: 200;
	transition: all .3s;
	display: inline-block
}

@media (width<=768px) {
	.hamburger-menu__main-link {
		font-size: 32px
	}
}

@media (hover:hover) {
	.hamburger-menu__main-link:hover {
		opacity: .7
	}
}

.hamburger-menu__sub-list {
	flex-wrap: wrap;
	width: 100%;
	display: flex
}

@media (width<=768px) {
	.hamburger-menu__sub-list {
		flex-direction: column;
		margin-top: 10px
	}
}

.hamburger-menu__sub-item {
	margin-top: 20px;
	margin-right: 20px
}

@media (width<=768px) {
	.hamburger-menu__sub-item {
		margin-top: 16px;
		margin-right: 0
	}
}

.hamburger-menu__sub-link {
	color: #ffffffb3;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500;
	transition: all .3s
}

@media (width<=768px) {
	.hamburger-menu__sub-link {
		font-size: 16px
	}
}

@media (hover:hover) {
	.hamburger-menu__sub-link:hover {
		color: #fff
	}
}

.subpage-nav {
	background-color: #fff;
	width: 100%;
	padding: 80px 0 160px
}

@media (width<=768px) {
	.subpage-nav {
		padding: 80px 0
	}
}

.subpage-nav__container {
	max-width: 1184px
}

.subpage-nav__list {
	flex-wrap: wrap;
	display: flex
}

@media (width<=1060px) {
	.subpage-nav__list {
		justify-content: space-between
	}
}

.subpage-nav__item {
	width: calc(33.3% - 13px);
	margin-top: -1px;
	margin-right: 20px
}

@media (width<=1060px) {
	.subpage-nav__item {
		width: calc(50% - 10px);
		margin-right: 0
	}
}

@media (width<=768px) {
	.subpage-nav__item {
		width: 100%
	}
}

.subpage-nav__item:nth-child(3n) {
	margin-right: 0
}

.subpage-nav__link {
	border-top: 1px solid #c9d1db;
	border-bottom: 1px solid #c9d1db;
	padding: 32px 20px 28px;
	transition: all .3s;
	display: block;
	position: relative;
	overflow: hidden
}

.subpage-nav__link:after {
	content: "";
	pointer-events: none;
	background-color: #f4f4f5;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=768px) {
	.subpage-nav__link {
		padding: 24px 16px
	}
}

.subpage-nav__jp-title {
	z-index: 1;
	letter-spacing: .02em;
	color: #0553dd;
	font-size: 12px;
	position: relative
}

.subpage-nav__en-title {
	z-index: 1;
	margin-top: 8px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 40px;
	font-weight: 200;
	position: relative
}

@media (width<=768px) {
	.subpage-nav__en-title {
		font-size: 24px
	}
}

.subpage-nav__more {
	z-index: 1;
	align-items: center;
	margin-top: 12px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.subpage-nav__more {
		justify-content: flex-end
	}
}

.subpage-nav__more-text {
	letter-spacing: .04em;
	margin-right: 12px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500
}

.subpage-nav__more-btn {
	background-color: #c9d1db;
	border-radius: 100px;
	justify-content: center;
	align-items: center;
	width: 60px;
	height: 24px;
	display: flex;
	position: relative;
	overflow: hidden
}

.subpage-nav__more-btn:after {
	content: "";
	pointer-events: none;
	background-color: #0553dd;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=768px) {
	.subpage-nav__more-btn {
		width: 52px;
		height: 20px
	}
}

.subpage-nav__more-btn span {
	z-index: 1;
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 13px;
	height: 11px;
	transition: all .3s;
	display: block;
	position: relative
}

@media (hover:hover) {
	.subpage-nav__link:hover:after {
		transform: scale(24)
	}

	.subpage-nav__link:hover .subpage-nav__more-btn:after {
		transform: scale(5)
	}
}

.contact-nav {
	padding: 20px
}

@media (width<=768px) {
	.contact-nav {
		padding: 32px 20px 52px
	}
}

.contact-nav__area {
	border-radius: 20px;
	padding: 40px 0 78px;
	transition: all .6s;
	position: relative;
	overflow: hidden
}

@media (width<=1060px) {
	.contact-nav__area {
		padding: 40px 0
	}
}

@media (width<=768px) {
	.contact-nav__area {
		border-radius: 4px;
		padding: 0
	}
}

.contact-nav__area.is-contact-hovered {
	background-color: #202733
}

.contact-nav__area.is-contact-hovered .contact-nav__bg-text-wrap p {
	color: #ffffff12
}

.contact-nav__area.is-business-hovered {
	background-color: #0553dd
}

.contact-nav__area.is-business-hovered .contact-nav__bg-text-wrap p {
	color: #ffffff12
}

.contact-nav__left-line {
	pointer-events: none;
	width: 122vw;
	min-width: 1630px;
	position: absolute;
	top: -3vw;
	left: -41vw;
	transform: rotate(14deg)
}

@media (width<=1250px) {
	.contact-nav__left-line {
		width: 150vw;
		left: -60vw
	}
}

@media (width<=1060px) {
	.contact-nav__left-line {
		left: -70%
	}
}

@media (width<=768px) {
	.contact-nav__left-line {
		display: none
	}
}

.contact-nav__left-line svg {
	width: 100%;
	height: auto
}

.contact-nav__left-line svg .line-left {
	fill: url(#contact-left-linear-gradient)
}

.contact-nav__left-line svg .line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.contact-nav__left-line svg .line-right {
	fill: url(#contact-right-linear-gradient)
}

.contact-nav__right-line {
	pointer-events: none;
	width: 122vw;
	min-width: 1630px;
	position: absolute;
	top: -1.5vw;
	right: -41vw;
	transform: rotate(348deg)
}

@media (width<=1250px) {
	.contact-nav__right-line {
		width: 150vw;
		right: -60vw
	}
}

@media (width<=1060px) {
	.contact-nav__right-line {
		right: -70%
	}
}

@media (width<=768px) {
	.contact-nav__right-line {
		display: none
	}
}

.contact-nav__right-line svg {
	width: 100%;
	height: auto
}

.contact-nav__right-line svg .line-right {
	fill: url(#business-right-linear-gradient)
}

.contact-nav__right-line svg .line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.contact-nav__right-line svg .line-left {
	fill: url(#business-left-linear-gradient)
}

.contact-nav__bg-text {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.contact-nav__bg-text-wrap {
	gap: 30px;
	display: flex;
	position: absolute;
	bottom: 0
}

.contact-nav__bg-text-wrap p {
	letter-spacing: -.04em;
	white-space: nowrap;
	color: #20273312;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 280px;
	font-weight: 100
}

@media (width<=1060px) {
	.contact-nav__bg-text-wrap p {
		font-size: 200px
	}
}

@media (width<=768px) {
	.contact-nav__bg-text-wrap p {
		font-size: 120px
	}
}

.contact-nav__cols {
	justify-content: space-between;
	max-width: 1184px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.contact-nav__cols {
		flex-flow: column wrap;
		padding: 0
	}
}

.contact-nav__col {
	border: 1px solid #fff;
	border-radius: 8px;
	flex-direction: column;
	width: calc(50% - 10px);
	padding: 60px 40px 40px;
	transition: all .6s;
	display: flex
}

@media (width<=1060px) {
	.contact-nav__col {
		padding: 30px 20px
	}
}

@media (width<=768px) {
	.contact-nav__col {
		border-radius: 4px;
		width: 100%;
		padding: 52px 20px
	}

	.contact-nav__col:first-child {
		margin-top: 12px
	}
}

.contact-nav__col.-contact {
	background-color: #202733
}

@media (width<=768px) {
	.contact-nav__col.-contact .contact-nav__col-more span.arrow {
		background-color: #0553dd
	}

	.contact-nav__col.-contact .contact-nav__col-more span.arrow svg {
		fill: #fff
	}
}

.contact-nav__col.-business {
	background-color: #0553dd
}

@media (width<=768px) {
	.contact-nav__col.-business .contact-nav__col-more span.arrow {
		background-color: #fff
	}

	.contact-nav__col.-business .contact-nav__col-more span.arrow svg {
		fill: #0553dd
	}
}

.contact-nav__col-head {
	margin-bottom: 148px;
	padding: 0 20px 32px;
	display: block;
	position: relative
}

@media (width<=768px) {
	.contact-nav__col-head {
		margin-bottom: 32px
	}
}

.contact-nav__col-head:before {
	content: "";
	background-color: #ffffff26;
	width: calc(100% - 40px);
	height: 1px;
	margin: 0 auto;
	transition: all .6s;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0
}

.contact-nav__col-head span {
	color: #fff;
	display: block
}

@media (width<=768px) {
	.contact-nav__col-head span {
		text-align: center
	}
}

.contact-nav__col-head span.en {
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.contact-nav__col-head span.jp {
	letter-spacing: .02em;
	margin-top: 12px;
	font-size: 20px;
	font-weight: 700
}

@media (width<=768px) {
	.contact-nav__col-head span.jp {
		font-size: 15px
	}
}

.contact-nav__col-more {
	justify-content: flex-end;
	align-items: center;
	margin-top: auto;
	display: flex
}

@media (width<=768px) {
	.contact-nav__col-more {
		justify-content: center
	}
}

.contact-nav__col-more span.text {
	letter-spacing: .04em;
	color: #fff;
	margin-right: 12px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500
}

.contact-nav__col-more span.arrow {
	background-color: #c9d1db;
	border-radius: 50px;
	justify-content: center;
	align-items: center;
	width: 60px;
	height: 24px;
	transition: all .3s;
	display: flex;
	position: relative;
	overflow: hidden
}

.contact-nav__col-more span.arrow svg {
	fill: #202733;
	width: 16px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.contact-nav__col-more span.arrow svg:first-child {
	transform: translate(-100px)
}

.contact-nav__col.is-off {
	background-color: #0000;
	opacity: .3!important
}

.contact-nav__col.is-off .contact-nav__col-head:before {
	opacity: 0
}

.contact-nav__col.is-off .contact-nav__col-more span.arrow {
	background-color: #fff
}

.contact-nav__col.is-off .contact-nav__col-more span.arrow svg {
	fill: #0553dd
}

.contact-nav__col.is-on {
	background-color: #0000
}

.contact-nav__col.is-on .contact-nav__col-head:before {
	background-color: #c9d1db
}

.contact-nav__col.is-on .contact-nav__col-more span.arrow {
	background-color: #fff
}

.contact-nav__col.is-on .contact-nav__col-more span.arrow svg {
	fill: #0553dd;
	transform: translate(100px)
}

.contact-nav__col.is-on .contact-nav__col-more span.arrow svg:first-child {
	transform: translate(0)
}

.hr-scroll {
	overflow: hidden
}

.hr-scroll__wrapper {
	width: 100%;
	height: 700px;
	padding-top: 74px;
	position: relative
}

@media (width<=768px) {
	.hr-scroll__wrapper {
		height: auto;
		padding-top: 0
	}
}

.hr-scroll__content {
	padding: 20px 80px 0;
	display: flex;
	position: absolute
}

@media (width<=768px) {
	.hr-scroll__content {
		flex-wrap: wrap;
		padding: 0 20px;
		position: static
	}
}

.hr-scroll__content:before {
	content: "";
	background-color: #c9d1db;
	width: calc(100% - 160px);
	height: 1px;
	margin: 0 auto;
	position: absolute;
	top: 0;
	left: 0;
	right: 0
}

@media (width<=768px) {
	.hr-scroll__content:before {
		width: calc(100% - 40px)
	}
}

.hr-scroll.-no-scroll .hr-scroll__content {
	width: 100%
}

.hr-scroll.-white-border .hr-scroll__content:before {
	background-color: #fff3
}

@media (width<=768px) {
	.hr-scroll.-white-border .hr-scroll__content:before {
		display: none
	}
}

.user-content * {
	letter-spacing: .02em;
	font-size: 14px
}

.user-content h2,.user-content h2>* {
	letter-spacing: .04em;
	font-size: 28px;
	font-weight: 700
}

@media (width<=768px) {
	.user-content h2,.user-content h2>* {
		font-size: 24px
	}
}

.user-content h3,.user-content h3>* {
	letter-spacing: .02em;
	font-size: 24px;
	font-weight: 700
}

@media (width<=768px) {
	.user-content h3,.user-content h3>* {
		font-size: 22px
	}
}

.user-content h4,.user-content h4>* {
	letter-spacing: .02em;
	font-size: 22px;
	font-weight: 700
}

@media (width<=768px) {
	.user-content h4,.user-content h4>* {
		font-size: 20px
	}
}

.user-content h5,.user-content h5>* {
	letter-spacing: .02em;
	color: #0553dd;
	font-size: 20px;
	font-weight: 700
}

@media (width<=768px) {
	.user-content h5,.user-content h5>* {
		font-size: 18px
	}
}

.user-content h6,.user-content h6>* {
	letter-spacing: .02em;
	color: #0553dd;
	font-size: 18px;
	font-weight: 700
}

@media (width<=768px) {
	.user-content h6,.user-content h6>* {
		font-size: 16px
	}
}

.user-content p {
	line-height: 2.14
}

.user-content a {
	color: #0553dd;
	text-decoration: underline;
	transition: all .3s
}

@media (hover:hover) {
	.user-content a:hover {
		opacity: .7
	}
}

.user-content strong,.user-content b {
	font-weight: 700
}

.user-content ul li {
	padding-left: 14px;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.73;
	position: relative
}

@media (width<=768px) {
	.user-content ul li {
		font-size: 14px
	}
}

.user-content ul li:not(:first-child) {
	margin-top: 16px
}

.user-content ul li:before {
	content: "";
	background-color: #0553dd;
	border-radius: 50%;
	width: 6px;
	height: 6px;
	display: block;
	position: absolute;
	top: 9px;
	left: 0
}

.user-content ol {
	counter-reset: li
}

.user-content ol li {
	padding-left: 28px;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.73;
	position: relative
}

@media (width<=768px) {
	.user-content ol li {
		font-size: 14px
	}
}

.user-content ol li:not(:first-child) {
	margin-top: 16px
}

.user-content ol li:before {
	counter-increment: li;
	content: "0" counter(li)".";
	color: #0553dd;
	letter-spacing: -.01em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-weight: 500;
	position: absolute;
	top: 1px;
	left: 0
}

.user-content ol li:nth-child(n+10):before {
	content: counter(li)"."
}

.user-content blockquote {
	background-color: #f4f4f5;
	padding: 32px 35px
}

@media (width<=768px) {
	.user-content blockquote {
		padding: 24px
	}
}

.user-content figure figcaption,.user-content .wp-caption .wp-caption-text {
	letter-spacing: .02em;
	text-align: center;
	border-bottom: 1px solid #20273326;
	margin: 0;
	padding: 20px 0 12px;
	font-size: 13px
}

.user-content figure figcaption img,.user-content .wp-caption .wp-caption-text img {
	border-radius: 4px
}

.user-content .wp-caption {
	max-width: 100%
}

.user-content table {
	border: 1px solid #c9d1db;
	font-size: 13px
}

.user-content table th,.user-content table td {
	border: 1px solid #c9d1db
}

.user-content table tr td {
	padding: 24px 20px
}

@media (width<=768px) {
	.user-content table tr td {
		padding: 16px 12px
	}
}

.user-content table tr td:first-child {
	background-color: #c9d1db;
	border-bottom: 1px solid #ffffff4d;
	font-weight: 700
}

.user-content table tr:last-child td:first-child {
	border-bottom: 1px solid #c9d1db
}

.user-content iframe {
	aspect-ratio: 16/9;
	height: auto;
	width: 100%!important
}

.user-content>:first-child {
	margin-top: 0
}

.user-content h2,.user-content h3,.user-content h4,.user-content h5,.user-content h6 {
	margin-top: 72px
}

@media (width<=768px) {
	.user-content h2,.user-content h3,.user-content h4,.user-content h5,.user-content h6 {
		margin-top: 40px
	}
}

.user-content h2 {
	margin-bottom: 32px
}

@media (width<=768px) {
	.user-content h2 {
		margin-bottom: 24px
	}
}

.user-content h3 {
	margin-bottom: 22px
}

@media (width<=768px) {
	.user-content h3 {
		margin-bottom: 20px
	}
}

.user-content h4 {
	margin-bottom: 20px
}

@media (width<=768px) {
	.user-content h4 {
		margin-bottom: 16px
	}
}

.user-content h5,.user-content h6 {
	margin-bottom: 16px
}

.user-content ul,.user-content ol {
	margin-top: 72px;
	margin-bottom: 16px
}

@media (width<=768px) {
	.user-content ul,.user-content ol {
		margin-top: 40px
	}
}

.user-content h2+ul,.user-content h3+ul,.user-content h4+ul,.user-content h5+ul,.user-content h6+ul,.user-content h2+ol,.user-content h3+ol,.user-content h4+ol,.user-content h5+ol,.user-content h6+ol {
	margin-top: 0
}

.user-content p+p {
	margin-top: 40px
}

@media (width<=768px) {
	.user-content p+p {
		margin-top: 24px
	}
}

.user-content figure,.user-content .wp-caption,.user-content iframe {
	margin-top: 40px;
	margin-bottom: 40px
}

.user-content blockquote {
	margin-top: 72px
}

@media (width<=768px) {
	.user-content blockquote {
		margin-top: 40px
	}
}

.user-content table {
	margin-top: 72px
}

@media (width<=768px) {
	.user-content table {
		margin-top: 40px
	}
}

.user-content .wp-block-table table {
	margin-top: 0
}

.user-content #toc_container {
	background-color: #f4f4f5;
	border: 1px solid #c9d1db;
	border-radius: 4px;
	width: 100%;
	margin-bottom: 106px;
	padding: 32px 40px 52px;
	position: relative
}

@media (width<=768px) {
	.user-content #toc_container {
		margin-bottom: 72px;
		padding: 20px 20px 30px
	}
}

.user-content #toc_container:before,.user-content #toc_container:after {
	content: "";
	display: block;
	position: absolute
}

.user-content #toc_container:before {
	background-color: #20273326;
	width: calc(100% + 60px);
	height: 1px;
	bottom: -60px;
	left: -30px
}

@media (width<=768px) {
	.user-content #toc_container:before {
		width: 100%;
		bottom: -42px;
		left: 0
	}
}

.user-content #toc_container:after {
	background-color: #0553dd;
	width: 20px;
	height: 2px;
	bottom: -60.5px;
	left: 0
}

@media (width<=768px) {
	.user-content #toc_container:after {
		bottom: -42.5px
	}
}

.user-content #toc_container .toc_title {
	letter-spacing: .04em;
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 10px;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.5
}

@media (width<=768px) {
	.user-content #toc_container .toc_title {
		font-size: 14px
	}
}

.user-content #toc_container .toc_list {
	counter-reset: li;
	margin-top: 20px;
	margin-bottom: 0
}

.user-content #toc_container .toc_list>li {
	flex-wrap: wrap;
	padding-left: 25px;
	display: flex
}

@media (width<=768px) {
	.user-content #toc_container .toc_list>li {
		padding-left: 20px
	}
}

.user-content #toc_container .toc_list>li:before {
	counter-increment: li;
	content: counter(li)".";
	color: #0553dd;
	background-color: #0000;
	border-radius: 0;
	width: auto;
	height: auto;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	top: 2px
}

@media (width<=768px) {
	.user-content #toc_container .toc_list>li:before {
		font-size: 13px
	}
}

.user-content #toc_container .toc_list>li ul {
	width: 100%;
	margin-top: 12px;
	margin-bottom: 0
}

.user-content #toc_container .toc_list>li ul li:before {
	display: none
}

@media (width<=768px) {
	.user-content #toc_container .toc_list>li ul li a {
		font-size: 12px
	}
}

.user-content #toc_container .toc_list>li a {
	color: #20273399;
	letter-spacing: .04em;
	font-size: 16px;
	font-weight: 700
}

@media (width<=768px) {
	.user-content #toc_container .toc_list>li a {
		font-size: 13px
	}
}

@media (hover:hover) {
	.user-content #toc_container .toc_list>li a:hover {
		color: #0553dd;
		opacity: 1
	}
}

.user-content #toc_container .toc_list>li a .toc_number {
	color: #0553dd;
	text-decoration: none
}

.service-modal {
	pointer-events: none;
	opacity: 0;
	z-index: 1000;
	width: 100%;
	height: 100dvh;
	padding: 20px;
	transition: all .3s;
	position: fixed;
	top: 0;
	left: 0
}

.service-modal.is-active {
	opacity: 1;
	pointer-events: auto;
	transition: all .3s
}

.service-modal__overlay {
	cursor: pointer;
	background-color: #000000bf;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.service-modal__wrap {
	width: 100%;
	max-width: 100%;
	height: 100%;
	margin: 0 auto;
	position: relative
}

.service-modal__group {
	background-color: #fff;
	border-radius: 20px;
	height: 100%;
	padding: 100px 0;
	display: none;
	position: relative;
	overflow: scroll
}

@media (width<=768px) {
	.service-modal__group {
		border-radius: 12px;
		padding: 60px 20px;
		overflow-y: scroll
	}
}

.service-modal__group.is-active {
	display: block
}

.service-modal__close {
	cursor: pointer;
	align-items: center;
	display: flex;
	position: absolute;
	top: 40px;
	right: 40px
}

@media (width<=768px) {
	.service-modal__close {
		top: 20px;
		right: 20px
	}
}

.service-modal__close span.close-text {
	letter-spacing: .04em;
	color: #202733;
	margin-right: 12px;
	font-size: 13px;
	font-weight: 500
}

.service-modal__close span.close-icon {
	background-color: #c9d1db;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	display: block;
	position: relative;
	overflow: hidden
}

.service-modal__close span.close-icon:after {
	content: "";
	pointer-events: none;
	background-color: #0553dd;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

.service-modal__close span.close-icon span:before,.service-modal__close span.close-icon span:after {
	content: "";
	z-index: 1;
	background-color: #202733;
	width: 16px;
	height: 1px;
	margin: auto;
	transition: all .3s;
	display: block;
	position: absolute;
	inset: 0
}

.service-modal__close span.close-icon span:before {
	transform: rotate(15deg)
}

.service-modal__close span.close-icon span:after {
	transform: rotate(-15deg)
}

@media (hover:hover) {
	.service-modal__close:hover .close-icon:after {
		transform: scale(5)
	}

	.service-modal__close:hover .close-icon span:before,.service-modal__close:hover .close-icon span:after {
		background-color: #fff
	}
}

.service-modal__container {
	max-width: 1184px
}

@media (width<=768px) {
	.service-modal__container {
		padding: 0
	}
}

.service-modal__top-row {
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 50px;
	display: flex
}

@media (width<=768px) {
	.service-modal__top-row {
		flex-wrap: wrap;
		padding-bottom: 32px
	}
}

.service-modal__img {
	background-color: #f4f4f5;
	border: 1px solid #c9d1db;
	border-radius: 8px;
	width: 50%;
	overflow: hidden
}

@media (width<=768px) {
	.service-modal__img {
		width: 100%
	}
}

.service-modal__info {
	width: 50%;
	padding-top: 52px;
	padding-left: 100px
}

@media (width<=1060px) {
	.service-modal__info {
		padding-top: 32px;
		padding-left: 32px
	}
}

@media (width<=768px) {
	.service-modal__info {
		width: 100%;
		padding-left: 0
	}
}

.service-modal__logo {
	border-bottom: 1px solid #c9d1db;
	margin-bottom: 20px;
	padding-bottom: 40px
}

@media (width<=768px) {
	.service-modal__logo {
		padding-bottom: 24px
	}
}

.service-modal__logo-wrap {
	width: 200px
}

.service-modal__info-wrap {
	max-width: 385px
}

.service-modal__title {
	letter-spacing: .04em;
	font-size: 20px;
	font-weight: 700
}

.service-modal__text {
	margin-top: 32px
}

@media (width<=768px) {
	.service-modal__text {
		margin-top: 16px
	}
}

.service-modal__text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 2
}

.service-modal__bottom-row {
	padding-top: 40px
}

.service-modal__list {
	justify-content: space-between;
	display: flex
}

@media (width<=768px) {
	.service-modal__list {
		flex-wrap: wrap
	}
}

.service-modal__item {
	background-color: #f4f4f5;
	border-radius: 8px;
	width: calc(50% - 6px);
	padding: 32px 35px 40px
}

@media (width<=768px) {
	.service-modal__item {
		width: 100%;
		padding: 20px
	}

	.service-modal__item:not(:first-child) {
		margin-top: 12px
	}
}

.service-modal__item-title {
	letter-spacing: .04em;
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 20px;
	padding-left: 18px;
	font-size: 16px;
	font-weight: 700;
	position: relative
}

.service-modal__item-title:before {
	content: "";
	background-color: #0553dd;
	border-radius: 50%;
	width: 8px;
	height: 8px;
	display: block;
	position: absolute;
	top: 9px;
	left: 0
}

.service-modal__item-text {
	margin-top: 20px
}

.service-modal__item-text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 2
}

.service-modal__btn {
	width: 232px;
	height: 56px;
	margin: 52px auto 0
}

@media (width<=768px) {
	.service-modal__btn {
		width: 210px;
		height: 48px
	}
}

.service-modal__btn .btn {
	padding: 16px 16px 16px 32px
}

.service-modal__btn .btn span {
	font-weight: 500
}

@media (width<=768px) {
	.service-modal__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.header {
	z-index: 10;
	width: 100%;
	padding: 50px 0;
	transition: all .6s;
	position: fixed;
	top: 0;
	left: 0
}

@media (width<=1060px) {
	.header {
		padding: 32px 0;
		position: absolute
	}
}

@media (width<=768px) {
	.header {
		padding: 16px 0
	}
}

.header:before {
	content: "";
	background-color: #fff;
	width: 100%;
	height: 100%;
	transition: all .6s;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	transform: translateY(-100%)
}

.header__container {
	justify-content: space-between;
	max-width: 1384px;
	display: flex;
	position: relative
}

.header__logo {
	pointer-events: auto;
	width: 210px;
	height: 43px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.header__logo {
		width: 100px;
		height: 30px
	}
}

.header__logo img {
	-o-object-fit: contain;
	object-fit: contain;
	width: 100%;
	height: 100%;
	transition: all .3s;
	position: absolute;
	top: 0;
	left: 0
}

.header__logo img.main {
	opacity: 1
}

.header__logo img.white {
	opacity: 0
}

.header__nav {
	align-items: center;
	display: flex
}

.header__nav-list {
	border-right: 1px solid #20273380;
	padding-right: 30px;
	transition: all .3s;
	display: flex
}

@media (width<=1060px) {
	.header__nav-list {
		display: none
	}
}

.header__nav-item {
	margin-left: 28px;
	position: relative
}

.header__nav-link {
	letter-spacing: -.01em;
	align-items: center;
	padding: 10px 0;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 14px;
	font-weight: 500;
	display: flex
}

.header__nav-link.is-active span.icon:before {
	opacity: 0;
	transform: rotate(90deg)
}

.header__nav-link.is-active span.icon:after {
	transform: rotate(180deg)
}

.header__nav-link .icon {
	background-color: #fff;
	border: 1px solid #2027334d;
	border-radius: 50%;
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	margin-left: 6px;
	display: block;
	position: relative
}

.header__nav-link .icon:before,.header__nav-link .icon:after {
	content: "";
	background-color: #202733;
	border-radius: 5px;
	width: 8px;
	height: 1.5px;
	margin: auto;
	transition: all .3s;
	display: block;
	position: absolute;
	inset: 0
}

.header__nav-link .icon:after {
	transform: rotate(90deg)
}

.header__nav-sub {
	opacity: 0;
	pointer-events: none;
	background-color: #fff;
	border-radius: 4px;
	min-width: 240px;
	padding: 30px 40px;
	transition: all .3s;
	position: absolute;
	left: 0;
	transform: translateY(10px)translate(-30%);
	box-shadow: 3px 3px 15px #00000014
}

.header__nav-sub.is-active {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0)translate(-30%)
}

.header__nav-sub-item:not(:first-child) {
	margin-top: 10px
}

.header__nav-sub-link {
	color: #202733;
	white-space: nowrap;
	align-items: center;
	font-size: 14px;
	font-weight: 500;
	transition: all .3s;
	display: flex
}

.header__nav-sub-link:after {
	content: "";
	opacity: 0;
	background-image: url(icon-arrow-right-main.ac019337.svg);
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 14px;
	height: 11px;
	margin-left: 8px;
	transition: all .3s;
	display: block;
	transform: translate(-5px)
}

@media (hover:hover) {
	.header__nav-sub-link:hover {
		color: #202733
	}

	.header__nav-sub-link:hover:after {
		opacity: 1;
		transform: translate(0)
	}
}

.header__nav-btns {
	padding-left: 32px;
	display: flex
}

.header__nav-btn {
	background-color: #0553dd;
	border: 1px solid #0553dd;
	border-radius: 100px;
	justify-content: center;
	align-items: center;
	width: 112px;
	height: 32px;
	transition: all .3s;
	display: flex;
	position: relative;
	overflow: hidden
}

.header__nav-btn:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=768px) {
	.header__nav-btn {
		display: none
	}
}

@media (hover:hover) {
	.header__nav-btn:hover {
		background-color: #fff
	}

	.header__nav-btn:hover:after {
		transform: scale(6)
	}

	.header__nav-btn:hover span {
		color: #0553dd
	}
}

.header__nav-btn span {
	z-index: 1;
	color: #fff;
	letter-spacing: -.01em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500;
	position: relative
}

.header__hamburger {
	background-color: #202733;
	border: 1px solid #202733;
	border-radius: 100px;
	width: 80px;
	height: 32px;
	margin-left: 12px;
	transition: all .3s;
	position: relative
}

@media (width<=768px) {
	.header__hamburger {
		width: 60px;
		height: 28px
	}
}

.header__hamburger span {
	background-color: #fff;
	width: 32px;
	height: 1.5px;
	margin: auto;
	transition: all .3s;
	display: block;
	position: absolute;
	inset: 0
}

@media (width<=768px) {
	.header__hamburger span {
		width: 28px
	}
}

.header__hamburger span:first-child {
	transform: translateY(-5px)
}

.header__hamburger span:nth-child(3) {
	transform: translateY(5px)
}

@media (hover:hover) {
	.header__hamburger:hover span:first-child {
		transform: translateY(-4px)
	}

	.header__hamburger:hover span:nth-child(3) {
		transform: translateY(4px)
	}
}

.footer {
	z-index: 2;
	background-color: #202733;
	padding: 100px 0 0;
	position: relative
}

@media (width<=768px) {
	.footer {
		padding: 60px 0
	}
}

.footer__container {
	max-width: 1440px;
	padding: 0 80px
}

@media (width<=768px) {
	.footer__container {
		padding: 0 20px
	}
}

.footer__top {
	border-bottom: 1px solid #ffffff4d;
	padding: 0 0 104px
}

@media (width<=768px) {
	.footer__top {
		padding-bottom: 40px
	}
}

.footer__nav-cols {
	justify-content: space-between;
	display: flex
}

@media (width<=768px) {
	.footer__nav-cols {
		flex-wrap: wrap;
		padding: 0 12px
	}
}

.footer__nav-col {
	flex: 1;
	padding-right: 24px
}

@media (width<=768px) {
	.footer__nav-col {
		flex-basis: 50%;
		width: 50%
	}

	.footer__nav-col:nth-child(n+3) {
		margin-top: 40px
	}
}

.footer__nav-col.-last {
	flex: 0 0 112px;
	margin-left: 24px;
	padding-right: 0
}

@media (width<=768px) {
	.footer__nav-col.-last {
		flex-basis: 50%;
		width: 50%;
		margin-left: 0
	}
}

.footer__nav-main-link {
	color: #fff;
	letter-spacing: -.01em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 15px;
	font-weight: 500;
	position: relative
}

.footer__nav-main-link:before {
	content: "";
	background-color: #0553dd;
	border-radius: 50%;
	width: 6px;
	height: 6px;
	transition: all .3s;
	display: block;
	position: absolute;
	top: 7px;
	left: -12px;
	transform: scale(0)
}

@media (hover:hover) {
	.footer a.footer__nav-main-link:hover:before {
		transform: scale(1)
	}
}

.footer__nav-list {
	margin-top: 24px
}

.footer__nav-item:not(:first-child) {
	margin-top: 12px
}

.footer__nav-sub-link {
	color: #ffffffb3;
	letter-spacing: -.01em;
	font-size: 13px;
	font-weight: 500;
	transition: all .3s
}

@media (hover:hover) {
	.footer__nav-sub-link:hover {
		color: #fff
	}
}

.footer__link-btn {
	color: #fff;
	background-color: #0553dd;
	border-radius: 100px;
	justify-content: center;
	align-items: center;
	width: 112px;
	height: 32px;
	margin-top: 24px;
	display: flex;
	position: relative;
	overflow: hidden
}

.footer__link-btn:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

.footer__link-btn span {
	letter-spacing: -.01em;
	z-index: 1;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500;
	transition: all .3s;
	position: relative
}

@media (hover:hover) {
	.footer__link-btn:hover {
		color: #0553dd
	}

	.footer__link-btn:hover:after {
		transform: scale(6)
	}
}

.footer__bottom {
	padding: 40px 0 0
}

@media (width<=768px) {
	.footer__bottom {
		padding-top: 20px
	}
}

.footer__control {
	justify-content: flex-end;
	display: flex
}

.footer__scroll {
	align-items: center;
	display: flex
}

@media (hover:hover) {
	.footer__scroll:hover .footer__scroll-btn {
		background-color: #0553dd;
		border-color: #0553dd
	}

	.footer__scroll:hover .footer__scroll-btn .arrow svg {
		fill: #fff;
		transform: translateY(-150px)
	}

	.footer__scroll:hover .footer__scroll-btn .arrow svg:first-child {
		transform: translateY(0)
	}
}

.footer__scroll-text {
	color: #fff;
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500
}

.footer__scroll-btn {
	border: 1px solid #ffffff80;
	border-radius: 100px;
	justify-content: center;
	align-items: center;
	width: 60px;
	height: 24px;
	margin-left: 12px;
	display: flex;
	position: relative;
	overflow: hidden
}

.footer__scroll-btn .arrow svg {
	fill: #fff;
	width: 11px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.footer__scroll-btn .arrow svg:first-child {
	transform: translateY(150px)
}

.footer__bottom-row {
	justify-content: space-between;
	align-items: flex-end;
	width: fit-content;
	display: flex;
	transform: translateY(-50px)
}

.footer__logo {
	width: 800px
}

@media (width<=1060px) {
	.footer__logo {
		width: 320px
	}
}

@media (width<=768px) {
	.footer__logo {
		display: none
	}
}

.footer__info {
	flex-direction: column;
	align-items: flex-end;
	display: flex
}

@media (width<=768px) {
	.footer__info {
		margin-top: 52px;
		margin-left: auto
	}
}

.footer__info-list {
	display: flex
}

.footer__info-item {
	margin-left: 20px
}

.footer__info-link {
	color: #ffffffb3;
	letter-spacing: -.01em;
	font-size: 14px;
	font-weight: 500;
	transition: all .3s
}

@media (width<=768px) {
	.footer__info-link {
		font-size: 12px
	}
}

@media (hover:hover) {
	.footer__info-link:hover {
		color: #fff
	}
}

.footer__copy {
	color: #fff;
	letter-spacing: -.01em;
	margin-top: 24px;
	font-size: 13px;
	font-weight: 500
}

@media (width<=768px) {
	.footer__copy {
		margin-top: 12px
	}
}

.front-page .top-line-wrap {
	position: relative
}

.front-page .top-line-wrap__lines {
	width: 100%;
	height: 100%;
	position: absolute
}

.front-page .top-lines {
	z-index: 1;
	pointer-events: none;
	align-items: center;
	height: 100vh;
	display: flex;
	position: sticky;
	top: 0
}

.front-page .top-lines__inner {
	align-items: center;
	width: 100%;
	height: 100%;
	display: flex;
	overflow: hidden
}

.front-page .top-lines__inner svg {
	width: 156vw;
	max-width: unset;
	flex-shrink: 0;
	height: auto;
	display: block
}

@media (width<=768px) {
	.front-page .top-lines__inner svg {
		width: 280vw
	}
}

.front-page .top-lines__parent #top-lines {
	transition: opacity .6s
}

.front-page .top-lines__parent #top-lines .cls-1 {
	fill: url(#linear-gradient);
	transition: opacity .6s
}

.front-page .top-lines__parent #top-lines .cls-3 {
	fill: url(#linear-gradient-2);
	transition: opacity .6s
}

.front-page .top-lines__parent #top-lines.is-gray {
	opacity: .13
}

.front-page .top-lines__parent #top-lines.is-gray .cls-1 {
	fill: url(#linear-gradient-gray-1)
}

.front-page .top-lines__parent #top-lines.is-gray .cls-3 {
	fill: url(#linear-gradient-gray-2)
}

@keyframes wabble {
	0% {
		transform: rotate(0)
	}

	50% {
		transform: rotate(-2deg)
	}

	to {
		transform: rotate(0)
	}
}

.front-page .section-title {
	position: relative
}

.front-page .section-title.-lg {
	padding: 40px 0 0 12px
}

@media (width<=768px) {
	.front-page .section-title.-lg {
		padding: 20px 0 0
	}
}

.front-page .section-title.-lg:before {
	content: "";
	transform-origin: 0;
	width: 80px;
	height: 1px;
	transition: all .6s;
	display: block;
	position: absolute;
	top: 32px;
	left: 0;
	transform: rotate(-23.4deg)
}

.front-page .section-title.-lg span {
	display: block
}

.front-page .section-title.-lg span.en {
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 100px;
	font-weight: 200;
	line-height: 1.3
}

@media (width<=768px) {
	.front-page .section-title.-lg span.en {
		font-size: 52px
	}
}

.front-page .section-title.-lg span.jp {
	letter-spacing: .04em;
	align-items: center;
	font-size: 14px;
	font-weight: 500;
	display: flex
}

.front-page .section-title.-lg span.jp:before {
	content: "";
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 20px;
	height: 18px;
	margin-right: 8px
}

.front-page .section-title.-lg.-white:before {
	background-color: #fff
}

.front-page .section-title.-lg.-white span {
	color: #fff
}

.front-page .section-title.-lg.-white span.jp:before {
	background-image: url(icon-title-acc-white.67bcf942.png)
}

.front-page .section-title.-lg.-main:before {
	background-color: #0553dd
}

.front-page .section-title.-lg.-main span.jp:before {
	background-image: url(icon-title-acc-white.67bcf942.png)
}

.front-page .section-title.-sm {
	padding: 32px 0 0 34px
}

@media (width<=768px) {
	.front-page .section-title.-sm {
		padding: 18px 0 0
	}
}

.front-page .section-title.-sm:before {
	content: "";
	transform-origin: 0;
	width: 40px;
	height: 1px;
	transition: all .6s;
	display: block;
	position: absolute;
	top: 16px;
	left: 0;
	transform: rotate(-23.4deg)
}

@media (width<=768px) {
	.front-page .section-title.-sm:before {
		top: 14px
	}
}

.front-page .section-title.-sm span {
	display: block
}

.front-page .section-title.-sm span.en {
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 80px;
	font-weight: 200;
	line-height: 1
}

@media (width<=768px) {
	.front-page .section-title.-sm span.en {
		font-size: 52px
	}
}

.front-page .section-title.-sm span.jp {
	letter-spacing: .04em;
	align-items: center;
	margin-top: 8px;
	font-size: 14px;
	font-weight: 500;
	display: flex
}

@media (width<=768px) {
	.front-page .section-title.-sm span.jp {
		font-size: 13px
	}
}

.front-page .section-title.-sm span.jp:before {
	content: "";
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 20px;
	height: 18px;
	margin-right: 8px
}

.front-page .section-title.-sm.-white:before {
	background-color: #fff
}

.front-page .section-title.-sm.-white span {
	color: #fff
}

.front-page .section-title.-sm.-white span.jp:before {
	background-image: url(icon-title-acc-white.67bcf942.png)
}

.front-page .section-title.-sm.-main:before {
	background-color: #0553dd
}

.front-page .section-title.-sm.-main span.jp:before {
	background-image: url(icon-title-acc-white.67bcf942.png)
}

.front-page .section-title.-lg:before,.front-page .section-title.-sm:before {
	width: 0
}

.front-page .section-title span.en,.front-page .section-title span.jp {
	opacity: 0;
	transition: all 1s cubic-bezier(.165,.84,.44,1) .2s;
	transform: translateY(30px)
}

.front-page .section-title.inview-is-visible.-lg:before {
	width: 80px
}

@media (width<=768px) {
	.front-page .section-title.inview-is-visible.-lg:before {
		width: 52px;
		top: 20px
	}
}

.front-page .section-title.inview-is-visible.-sm:before {
	width: 40px
}

.front-page .section-title.inview-is-visible span.en,.front-page .section-title.inview-is-visible span.jp {
	opacity: 1;
	transform: translateY(0)
}

.front-page .mv {
	background-color: #fff;
	flex-direction: column;
	height: 100vh;
	min-height: 780px;
	padding-bottom: 110px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.front-page .mv {
		background-color: #0000;
		height: auto;
		min-height: 0;
		padding: 110px 0 80px
	}
}

.front-page .mv__bg-text {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.front-page .mv__bg-text-wrap {
	z-index: 1;
	gap: 30px;
	display: flex;
	position: absolute;
	top: 50%;
	transform: translateY(-50%)
}

@media (width<=768px) {
	.front-page .mv__bg-text-wrap {
		top: 58%
	}
}

.front-page .mv__bg-text-wrap p {
	letter-spacing: -.04em;
	white-space: nowrap;
	color: #20273312;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 280px;
	font-weight: 100
}

@media (width<=1060px) {
	.front-page .mv__bg-text-wrap p {
		font-size: 200px
	}
}

@media (width<=768px) {
	.front-page .mv__bg-text-wrap p {
		font-size: 120px
	}
}

.front-page .mv__container {
	flex-grow: 1;
	align-items: flex-end;
	max-width: 1336px;
	height: 100%;
	display: flex
}

.front-page .mv__text-content {
	z-index: 2;
	width: 100%;
	margin: 0 auto;
	position: relative
}

@media (width<=768px) {
	.front-page .mv__text-content {
		margin-left: 0
	}
}

.front-page .mv__title {
	letter-spacing: .06em;
	width: fit-content;
	margin-left: auto;
	font-size: 22px;
	font-weight: bolder;
	line-height: 1.625
}

@media (width<=768px) {
	.front-page .mv__title {
		margin-left: 0;
		font-size: 22px;
		line-height: 1.59
	}

	.slogan-title {
		text-align: left;
		margin-top: 20px
	}
}

.front-page .mv__sub-title {
	color: #0553dd;
	letter-spacing: .04em;
	margin-top: 20px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 14px;
	font-weight: 500
}

@media (width<=768px) {
	.front-page .mv__sub-title {
		margin-top: 16px;
		font-size: 12px
	}
}

.front-page #line-left-mask path,.front-page #line-right-mask path {
	fill: none;
	stroke: #fff;
	stroke-width: 180px;
	stroke-linecap: round;
	stroke-linejoin: round
}

.front-page .about {
	background-color: #f4f4f5;
	padding: 0 20px;
	position: relative
}

@media (width<=768px) {
	.front-page .about {
		padding: 0 12px
	}
}

.front-page .about__header-trigger {
	width: 100%;
	height: 1px;
	position: absolute;
	top: 0;
	left: 0
}

.front-page .about__content {
	margin-top: -60px;
	padding: 200px 0;
	position: relative
}

@media (width<=768px) {
	.front-page .about__content {
		padding: 56px 0 60px
	}
}

.front-page .about__content:before {
	content: "";
	z-index: 1;
	background-color: #0553dd;
	border-radius: 20px;
	width: 100%;
	height: 100%;
	display: block;
	position: absolute;
	top: 0;
	left: 0
}

@media (width<=768px) {
	.front-page .about__content:before {
		border-radius: 12px
	}
}

.front-page .about__container {
	z-index: 2;
	position: relative
}

.front-page .about__inner {
	padding: 0 110px 0 54px
}

@media (width<=1060px) {
	.front-page .about__inner {
		padding: 0 40px
	}
}

@media (width<=768px) {
	.front-page .about__inner {
		padding: 0
	}
}

.front-page .about__cols {
	justify-content: space-between;
	width: 100%;
	margin-top: 110px;
	margin-left: 12px;
	display: flex
}

@media (width<=768px) {
	.front-page .about__cols {
		flex-wrap: wrap;
		margin-top: 40px;
		margin-left: 0
	}
}

.front-page .about__title-col {
	width: 50%
}

@media (width<=768px) {
	.front-page .about__title-col {
		width: 100%
	}
}

.front-page .about__sub-title span {
	display: block
}

.front-page .about__sub-title span.en {
	letter-spacing: .06em;
	color: #fff;
	font-size: 28px;
	font-weight: 700;
	line-height: 1.64
}

@media (width<=768px) {
	.front-page .about__sub-title span.en {
		font-size: 20px
	}
}

.front-page .about__sub-title span.jp {
	letter-spacing: .06em;
	color: #fff;
	margin-top: 8px;
	font-size: 28px;
	font-weight: 700
}

@media (width<=768px) {
	.front-page .about__sub-title span.jp {
		letter-spacing: .04em;
		font-size: 18px
	}
}

.front-page .about__text-col {
	width: 50%
}

@media (width<=768px) {
	.front-page .about__text-col {
		width: 100%
	}

	.front-page .about__text {
		margin-top: 40px
	}
}

.front-page .about__text p {
	letter-spacing: .04em;
	color: #fff;
	font-size: 13px;
	line-height: 2.57
}

@media (width<=768px) {
	.front-page .about__text p {
		letter-spacing: .06em;
		line-height: 2.15
	}
}

.front-page .about__text p+p {
	margin-top: 2.57em
}

@media (width<=768px) {
	.front-page .about__text p+p {
		margin-top: 2.15em
	}
}

.front-page .about__btn {
	width: 232px;
	height: 56px;
	margin-top: 80px
}

@media (width<=768px) {
	.front-page .about__btn {
		width: 210px;
		height: 48px;
		margin-top: 32px
	}
}

.front-page .about__btn .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.front-page .about__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.front-page .about__btn .btn span {
	font-weight: bolder
}

.front-page .service {
	padding: 132px 0 160px
}

@media (width<=768px) {
	.front-page .service {
		padding: 60px 0
	}
}

.front-page .service__head-container {
	max-width: 1184px;
	display: flex
}

@media (width<=768px) {
	.front-page .service__head-container {
		flex-wrap: wrap
	}
}

.front-page .service__head-title {
	width: 50%
}

@media (width<=768px) {
	.front-page .service__head-title {
		width: 100%
	}
}

.front-page .service__head-text {
	justify-content: center;
	width: 50%;
	padding-top: 68px;
	display: flex
}

@media (width<=768px) {
	.front-page .service__head-text {
		width: 100%;
		margin-top: 32px;
		padding-top: 0;
		padding-left: 0
	}
}

.front-page .service__head-text-inner {
	max-width: 420px;
	margin: 0 auto
}

.front-page .service__head-text-inner p {
	letter-spacing: .04em;
	font-size: 13px;
	line-height: 2
}

.front-page .service__head-btn {
	width: 232px;
	height: 56px;
	margin-top: 52px
}

@media (width<=768px) {
	.front-page .service__head-btn {
		width: 210px;
		height: 48px;
		margin-top: 32px
	}
}

.front-page .service__head-btn .btn {
	padding: 18px 18px 18px 32px
}

@media (width<=768px) {
	.front-page .service__head-btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.front-page .service__content {
	margin-top: 80px;
	overflow: hidden
}

@media (width<=768px) {
	.front-page .service__content {
		overflow: unset;
		margin-top: 52px
	}
}

.front-page .service__content-container {
	max-width: 1184px
}

@media (width<=768px) {
	.front-page .service__slider {
		display: none
	}
}

.front-page .service__list {
	display: none
}

@media (width<=768px) {
	.front-page .service__list {
		display: block
	}
}

.front-page .service__item:not(:first-child) {
	margin-top: 52px
}

.front-page .service__item-thumb {
	border: 1px solid #c9d1db;
	border-radius: 4px;
	width: 100%;
	overflow: hidden
}

.front-page .service__item-content {
	padding: 22px 12px 0
}

.front-page .service__item-title {
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 12px
}

.front-page .service__item-title span {
	display: block
}

.front-page .service__item-title span.en {
	letter-spacing: .04em;
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.front-page .service__item-title span.jp {
	letter-spacing: .04em;
	margin-top: 12px;
	font-size: 15px;
	font-weight: 700
}

.front-page .service__item-text {
	margin-top: 20px
}

.front-page .service__item-text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 1.85
}

.front-page .service__item-btn {
	margin-top: 24px
}

.front-page .service-slider {
	border-top: 1px solid #c9d1db;
	padding-top: 24px;
	overflow: visible
}

.front-page .service-slider.not-first-round .service-slider__indicator-bar span {
	transition: transform 5s linear 1s
}

.front-page .service-slider__wrapper {
	overflow: visible
}

.front-page .service-slider__slide {
	box-sizing: border-box;
	background-color: #fff;
	border-radius: 20px;
	width: 100%;
	padding: 80px 60px;
	display: flex;
	position: relative
}

.front-page .service-slider__slide.swiper-slide-active .service-slider__indicator-bar span {
	transform: scaleX(1)
}

.front-page .service-slider__num {
	background-color: #c9d1db;
	border-radius: 30px;
	padding: 2px 10px;
	font-size: 12px;
	position: absolute;
	top: 40px;
	right: 60px
}

.front-page .service-slider__img-col {
	flex-shrink: 0;
	width: 57%
}

.front-page .service-slider__img {
	border: 1px solid #c9d1db;
	border-radius: 8px;
	height: 379px;
	overflow: hidden
}

.front-page .service-slider__img img {
	object-fit: cover;
	height: 100%
}

.front-page .service-slider__indicator {
	max-width: 530px;
	margin-top: 40px
}

.front-page .service-slider__indicator-text {
	justify-content: flex-start;
	display: flex
}

.front-page .service-slider__indicator-text span.num {
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500
}

.front-page .service-slider__indicator-text span.num.-next {
	margin-left: auto
}

.front-page .service-slider__indicator-text span.name {
	letter-spacing: .02em;
	margin-left: 6px;
	font-size: 12px;
	font-weight: 700
}

.front-page .service-slider__indicator-bar {
	background-color: #20273326;
	width: 100%;
	height: 2px;
	margin-top: 20px;
	position: relative
}

.front-page .service-slider__indicator-bar:before,.front-page .service-slider__indicator-bar:after {
	content: "";
	background-color: #0553dd;
	width: 2px;
	height: 8px;
	display: block;
	position: absolute
}

.front-page .service-slider__indicator-bar:before {
	bottom: 0;
	left: 0
}

.front-page .service-slider__indicator-bar:after {
	bottom: 0;
	right: 0
}

.front-page .service-slider__indicator-bar span {
	transform-origin: 0;
	background-color: #0553dd;
	width: 100%;
	height: 2px;
	transition: transform 5s linear;
	position: absolute;
	bottom: 0;
	left: 0;
	transform: scaleX(0)
}

.front-page .service-slider__text-col {
	flex-direction: column;
	flex-grow: 1;
	justify-content: flex-end;
	padding-left: 80px;
	display: flex
}

.front-page .service-slider__title {
	border-bottom: 1px solid #20273326;
	padding-bottom: 16px;
	position: relative
}

.front-page .service-slider__title span {
	display: block
}

.front-page .service-slider__title span.en {
	color: #0553dd;
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.front-page .service-slider__title span.jp {
	letter-spacing: .04em;
	margin-top: 12px;
	font-size: 18px;
	font-weight: 700
}

.front-page .service-slider__text {
	padding-top: 28px
}

.front-page .service-slider__text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 1.85
}

.front-page .service-slider__btn {
	margin-top: 40px
}

.front-page .service-slider__btn .text-btn {
	cursor: pointer
}

.front-page .concept__wrap {
	padding: 0 20px
}

.front-page .concept__content {
	background-color: #fff;
	border-radius: 20px;
	padding: 240px 0 260px;
	position: relative
}

@media (width<=1060px) {
	.front-page .concept__content {
		padding: 120px 0
	}
}

@media (width<=768px) {
	.front-page .concept__content {
		border-radius: 12px;
		padding: 60px 0
	}
}

.front-page .concept__lines {
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.front-page .concept__top-line-wrap {
	width: 60%;
	position: absolute;
	top: -10%;
	left: -10%
}

@media (width<=768px) {
	.front-page .concept__top-line-wrap {
		top: -4%;
		left: auto;
		right: -12%;
		transform: scaleX(-1)
	}
}

.front-page .concept__top-line {
	width: 100%;
	padding-top: 74%;
	position: relative
}

.front-page .concept__top-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.front-page .concept__top-line svg .concept-top-line {
	fill: url(#concept-top-line-linear-gradient)
}

.front-page .concept__top-line svg .concept-top-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.front-page .concept__bottom-line-wrap {
	width: 60%;
	position: absolute;
	bottom: -13%;
	left: -4%
}

@media (width<=768px) {
	.front-page .concept__bottom-line-wrap {
		bottom: -4%;
		left: -9%
	}
}

.front-page .concept__bottom-line {
	width: 100%;
	padding-top: 67.3%;
	position: relative
}

.front-page .concept__bottom-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.front-page .concept__bottom-line svg .concept-bottom-line-mask {
	fill: url(#concept-top-line-linear-gradient)
}

.front-page .concept__bottom-line svg .concept-bottom-line {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.front-page .concept__container {
	justify-content: flex-end;
	max-width: 1184px;
	display: flex
}

.front-page .concept__text-content {
	max-width: 384px
}

.front-page .concept__text {
	letter-spacing: .04em;
	margin-top: 72px;
	padding-left: 34px;
	font-size: 13px;
	line-height: 2
}

@media (width<=768px) {
	.front-page .concept__text {
		margin-top: 32px;
		padding-left: 0
	}
}

.front-page .concept__btn {
	width: 232px;
	height: 56px;
	margin-top: 50px;
	margin-left: 34px
}

@media (width<=768px) {
	.front-page .concept__btn {
		width: 210px;
		height: 48px;
		margin-top: 32px;
		margin-left: 0
	}
}

.front-page .concept__btn .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.front-page .concept__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.front-page .concept__img-content {
	width: 62.6%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

@media (width<=768px) {
	.front-page .concept__img-content {
		width: 100%;
		height: auto;
		padding: 0 20px;
		position: static
	}
}

.front-page .concept__img {
	border-radius: 4px;
	position: absolute;
	overflow: hidden
}

@media (width<=768px) {
	.front-page .concept__img {
		position: static
	}
}

.front-page .concept__img.-first {
	width: 40%;
	max-width: 350px;
	top: 20%;
	left: 24%
}

@media (width<=1060px) {
	.front-page .concept__img.-first {
		width: 32%;
		top: 25%;
		left: 20%
	}
}

@media (width<=768px) {
	.front-page .concept__img.-first {
		width: 53%;
		margin-top: 52px
	}
}

.front-page .concept__img.-second {
	width: 52%;
	max-width: 455px;
	bottom: 20%;
	left: 32%
}

@media (width<=1060px) {
	.front-page .concept__img.-second {
		width: 40%;
		bottom: 22%;
		left: 24%
	}
}

@media (width<=768px) {
	.front-page .concept__img.-second {
		width: 65%;
		margin-top: 20px;
		margin-left: auto
	}
}

.front-page .news {
	padding: 164px 0 138px;
	overflow: hidden
}

@media (width<=768px) {
	.front-page .news {
		padding: 60px 0 50px
	}
}

.front-page .news__head {
	position: relative
}

.front-page .news__head-container {
	justify-content: space-between;
	align-items: center;
	max-width: 1184px;
	display: flex;
	position: relative
}

.front-page .news__head-large-text {
	letter-spacing: -.04em;
	color: #2027330d;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 280px;
	font-weight: 100;
	position: absolute;
	top: -140px;
	right: -40px
}

@media (width<=1060px) {
	.front-page .news__head-large-text {
		font-size: 200px;
		top: -80px;
		right: 20px
	}
}

@media (width<=768px) {
	.front-page .news__head-large-text {
		display: none
	}
}

.front-page .news__content {
	margin-top: 72px;
	position: relative
}

@media (width<=1060px) {
	.front-page .news__content {
		margin-top: 64px
	}
}

@media (width<=768px) {
	.front-page .news__content {
		margin-top: 16px
	}
}

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

@media (width<=1060px) {
	.front-page .news__selector-wrap {
		position: static
	}
}

.front-page .news__selector {
	z-index: 4;
	pointer-events: none;
	width: 100%;
	position: sticky;
	top: 160px;
	left: 0
}

@media (width<=1060px) {
	.front-page .news__selector {
		position: static
	}
}

.front-page .news__selector-container {
	max-width: 1184px
}

.front-page .news__selector-list {
	pointer-events: auto;
	width: 280px
}

@media (width<=1060px) {
	.front-page .news__selector-list {
		flex-wrap: wrap;
		width: 100%;
		display: flex
	}

	.front-page .news__selector-item {
		margin-top: 15px;
		margin-right: 24px
	}
}

@media (width<=768px) {
	.front-page .news__selector-item {
		margin-right: 16px
	}
}

.front-page .news__selector-item:not(:first-child) {
	margin-top: 15px
}

.front-page .news__selector-btn {
	letter-spacing: -.01em;
	color: #2027334d;
	padding-left: 18px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 15px;
	font-weight: 500;
	transition: all .3s;
	position: relative
}

@media (width<=1060px) {
	.front-page .news__selector-btn {
		padding-left: 0
	}
}

.front-page .news__selector-btn:before {
	content: "";
	opacity: 0;
	background-color: #0553dd;
	border-radius: 50%;
	width: 6px;
	height: 6px;
	display: block;
	position: absolute;
	top: 8px;
	left: 0
}

@media (width<=1060px) {
	.front-page .news__selector-btn:before {
		display: none
	}
}

.front-page .news__selector-btn.is-active {
	color: #202733
}

.front-page .news__selector-btn.is-active:before {
	opacity: 1
}

@media (hover:hover) {
	.front-page .news__selector-btn:hover {
		color: #202733
	}
}

.front-page .news__tab-item {
	display: none
}

@media (width<=1060px) {
	.front-page .news__list {
		margin-top: 32px
	}
}

.front-page .news__item {
	width: 100%;
	position: relative;
	overflow: hidden
}

.front-page .news__item-wrap {
	justify-content: flex-end;
	width: 100%;
	max-width: 1120px;
	margin: 0 auto;
	padding-left: 282px;
	padding-right: 32px;
	display: flex
}

@media (width<=1060px) {
	.front-page .news__item-wrap {
		padding-left: 32px
	}
}

@media (width<=768px) {
	.front-page .news__item-wrap {
		padding: 0 20px
	}
}

.front-page .news__link {
	flex-grow: 1;
	max-width: 840px;
	display: flex;
	position: relative
}

.front-page .news__link:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=1060px) {
	.front-page .news__link {
		max-width: 100%
	}
}

.front-page .news__link:after {
	transition: all .6s
}

@media (hover:hover) {
	.front-page .news__link:hover:after {
		transform: scale(100)
	}

	.front-page .news__link:hover .news__item-more span.-arrow {
		background-color: #0553dd
	}

	.front-page .news__link:hover .news__item-more span.-arrow svg {
		fill: #fff;
		transform: translate(150px)
	}

	.front-page .news__link:hover .news__item-more span.-arrow svg:first-child {
		transform: translate(0)
	}
}

.front-page .news__link-inner {
	z-index: 1;
	width: 100%;
	padding: 24px 0;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.front-page .news__link-inner {
		padding: 20px 0
	}
}

.front-page .news__link-inner:before {
	content: "";
	z-index: 3;
	background-color: #20273326;
	width: 100%;
	height: 1px;
	display: block;
	position: absolute;
	top: 0;
	left: 0
}

.front-page .news__thumb {
	width: 175px;
	margin-right: 35px;
	position: relative
}

@media (width<=768px) {
	.front-page .news__thumb {
		flex-shrink: 0;
		width: 38%;
		margin-right: 22px
	}
}

.front-page .news__thumb-wrap {
	border-radius: 4px;
	width: 100%;
	padding-top: 56%;
	position: relative;
	overflow: hidden
}

.front-page .news__thumb-wrap img {
	object-fit: cover;
	object-position: top;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.front-page .news__item-content {
	flex-direction: column;
	flex-grow: 1;
	display: flex
}

.front-page .news__item-info {
	justify-content: space-between;
	display: flex
}

@media (width<=768px) {
	.front-page .news__item-info {
		justify-content: flex-start
	}
}

.front-page .news__item-cat {
	background-color: #fff;
	border: 1px solid #c9d1db;
	border-radius: 100px;
	padding: 2px 10px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px
}

@media (width<=768px) {
	.front-page .news__item-cat {
		margin-right: 12px;
		padding: 0 10px;
		font-size: 11px
	}
}

.front-page .news__item-time {
	letter-spacing: .02em;
	color: #202733b3;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.front-page .news__item-title {
	letter-spacing: .06em;
	margin-top: 18px;
	font-size: 14px;
	font-weight: 700
}

@media (width<=768px) {
	.front-page .news__item-title {
		letter-spacing: .04em;
		margin-top: 8px;
		font-size: 13px
	}
}

.front-page .news__item-more {
	justify-content: flex-end;
	align-items: center;
	margin-top: 15px;
	display: flex
}

@media (width<=768px) {
	.front-page .news__item-more {
		display: none
	}
}

.front-page .news__item-more span.-text {
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500;
	display: none
}

.front-page .news__item-more span.-arrow {
	background-color: #c9d1db;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	margin-left: 12px;
	transition: all .6s;
	display: block;
	position: relative;
	overflow: hidden
}

.front-page .news__item-more span.-arrow svg {
	fill: #202733;
	width: 16px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.front-page .news__item-more span.-arrow svg:first-child {
	transform: translate(-150px)
}

.front-page .news__item:first-child .news__link-inner {
	padding: 32px 0
}

@media (width<=768px) {
	.front-page .news__item:first-child .news__link-inner {
		flex-wrap: wrap;
		padding: 20px 0 32px
	}
}

.front-page .news__item:first-child .news__thumb {
	width: 315px;
	margin-right: 52px
}

.front-page .news__item:first-child .news__thumb .news__thumb-wrap {
	width: 315px
}

@media (width<=768px) {
	.front-page .news__item:first-child .news__thumb {
		width: 100%;
		margin-right: 0
	}

	.front-page .news__item:first-child .news__item-info {
		justify-content: space-between;
		margin-top: 20px
	}
}

.front-page .news__item:first-child .news__item-time {
	font-size: 13px
}

.front-page .news__item:first-child .news__item-title {
	margin-top: 55px;
	margin-bottom: auto;
	font-size: 18px
}

@media (width<=1060px) {
	.front-page .news__item:first-child .news__item-title {
		margin-top: 32px
	}
}

@media (width<=768px) {
	.front-page .news__item:first-child .news__item-title {
		margin-top: 12px;
		font-size: 15px
	}

	.front-page .news__item:first-child .news__item-more {
		justify-content: flex-start;
		display: flex
	}
}

.front-page .news__item:first-child .news__item-more span.-text {
	display: block
}

@media (width<=768px) {
	.front-page .news__item:first-child .news__item-more span.-arrow {
		background-color: #0553dd
	}

	.front-page .news__item:first-child .news__item-more span.-arrow svg {
		fill: #fff
	}
}

.front-page .news__item:last-child .news__link-inner:after {
	content: "";
	z-index: 3;
	background-color: #20273326;
	width: 100%;
	height: 1px;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0
}

.front-page .news__btn {
	margin-top: 52px
}

@media (width<=768px) {
	.front-page .news__btn {
		margin-top: 32px
	}
}

.front-page .news__btn-container {
	justify-content: flex-end;
	max-width: 1184px;
	display: flex
}

.front-page .news__btn-wrap {
	width: 232px;
	height: 56px
}

@media (width<=768px) {
	.front-page .news__btn-wrap {
		width: 210px;
		height: 48px;
		margin: 0 auto
	}
}

.front-page .news__btn-wrap .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.front-page .news__btn-wrap .btn {
		padding: 14px 14px 14px 28px
	}
}

.front-page .news__btn-wrap .btn span {
	font-weight: 500
}

.front-page .career {
	padding-bottom: 140px;
	overflow: hidden
}

@media (width<=768px) {
	.front-page .career {
		border-bottom: 1px solid #20273326;
		padding-bottom: 60px
	}
}

.front-page .career__wrap {
	padding: 0 20px
}

@media (width<=768px) {
	.front-page .career__wrap {
		padding: 0 12px
	}
}

.front-page .career__content {
	background-color: #202733;
	border-radius: 20px;
	padding: 124px 0 158px;
	position: relative
}

@media (width<=768px) {
	.front-page .career__content {
		border-radius: 12px;
		padding: 60px 0
	}
}

.front-page .career__lines {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.front-page .career__top-line-wrap {
	width: 48%;
	position: absolute;
	top: -4%;
	left: -6%
}

@media (width<=768px) {
	.front-page .career__top-line-wrap {
		width: 60%;
		top: -2%;
		left: auto;
		right: -10%;
		transform: scaleX(-1)
	}
}

.front-page .career__top-line {
	width: 100%;
	padding-top: 67%;
	position: relative
}

.front-page .career__top-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.front-page .career__top-line svg .career-top-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.front-page .career__top-line svg .career-top-line {
	fill: #fff;
	isolation: isolate;
	opacity: .07
}

.front-page .career__right-line-wrap {
	width: 36%;
	position: absolute;
	bottom: -6%;
	right: -5%
}

@media (width<=768px) {
	.front-page .career__right-line-wrap {
		width: 50%;
		bottom: -5%;
		left: -8%;
		right: auto;
		transform: scaleX(-1)
	}
}

.front-page .career__right-line {
	width: 100%;
	padding-top: 152%;
	position: relative
}

.front-page .career__right-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.front-page .career__right-line svg .career-right-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.front-page .career__right-line svg .career-right-line {
	fill: #fff;
	isolation: isolate;
	opacity: .07
}

.front-page .career__img {
	margin-top: 80px;
	position: relative
}

@media (width<=768px) {
	.front-page .career__img {
		margin-top: 32px
	}
}

.front-page .career__img-wrap {
	border-radius: 20px;
	overflow: hidden
}

@media (width<=768px) {
	.front-page .career__img-wrap {
		border-radius: 4px;
		width: 100%;
		position: relative
	}
}

.front-page .career__scroll-text {
	width: 100vw;
	position: absolute;
	bottom: -90px;
	left: 0
}

@media (width<=768px) {
	.front-page .career__scroll-text {
		bottom: -28px
	}
}

.front-page .career__scroll-text-inner {
	gap: 20px;
	display: flex
}

.front-page .career__scroll-text-inner .career__scroll-text-group {
	align-items: center;
	gap: 20px;
	display: flex
}

.front-page .career__scroll-text-inner p {
	letter-spacing: -.04em;
	white-space: nowrap;
	color: #fff;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 200px;
	font-weight: 100;
	line-height: 1
}

@media (width<=1060px) {
	.front-page .career__scroll-text-inner p {
		font-size: 160px
	}
}

@media (width<=768px) {
	.front-page .career__scroll-text-inner p {
		font-size: 80px
	}
}

.front-page .career__scroll-text-inner .img {
	border-radius: 4px;
	flex-shrink: 0;
	width: 200px;
	display: block;
	overflow: hidden
}

@media (width<=1060px) {
	.front-page .career__scroll-text-inner .img {
		width: 160px
	}
}

@media (width<=768px) {
	.front-page .career__scroll-text-inner .img {
		width: 120px
	}
}

.front-page .career__scroll-text-part {
	align-items: center;
	gap: 20px;
	display: flex
}

.front-page .career__cols {
	margin-top: 115px;
	display: flex
}

@media (width<=768px) {
	.front-page .career__cols {
		flex-wrap: wrap;
		margin-top: 48px
	}
}

.front-page .career__title-col {
	width: 50%;
	padding-left: 70px
}

@media (width<=1060px) {
	.front-page .career__title-col {
		padding-left: 32px
	}
}

@media (width<=768px) {
	.front-page .career__title-col {
		width: 100%;
		padding-left: 0
	}
}

.front-page .career__title {
	color: #fff;
	letter-spacing: .06em;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.67
}

@media (width<=768px) {
	.front-page .career__title {
		letter-spacing: .04em;
		font-size: 18px
	}
}

.front-page .career__text-col {
	width: 50%;
	padding-left: 70px
}

@media (width<=1060px) {
	.front-page .career__text-col {
		padding-left: 32px
	}
}

@media (width<=768px) {
	.front-page .career__text-col {
		width: 100%;
		margin-top: 20px;
		padding-left: 0
	}
}

.front-page .career__text {
	letter-spacing: .04em;
	color: #fff;
	max-width: 380px;
	font-size: 13px;
	line-height: 2
}

.front-page .career__btn {
	width: 232px;
	height: 56px;
	margin-top: 48px
}

@media (width<=768px) {
	.front-page .career__btn {
		width: 210px;
		height: 48px;
		margin-top: 32px
	}
}

.front-page .career__btn .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.front-page .career__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.front-page .career__btn .btn span {
	font-weight: 500
}

@keyframes marquee {
	0% {
		translate: 0
	}

	to {
		translate: calc(-100% - 30px)
	}
}

.page-sub .sub-mv {
	border-bottom: 1px solid #c9d1db;
	width: 100%;
	height: 602px;
	position: relative
}

@media (width<=768px) {
	.page-sub .sub-mv {
		border-bottom: 0;
		height: auto
	}
}

.page-sub .sub-mv__bg-text {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-sub .sub-mv__bg-text-wrap {
	-webkit-font-smoothing: antialiased;
	flex-direction: row;
	flex: auto;
	gap: 50px;
	width: fit-content;
	display: flex;
	position: absolute;
	top: 50%;
	transform: translateY(-50%)
}

.page-sub .sub-mv__bg-text-wrap p {
	letter-spacing: -.04em;
	white-space: nowrap;
	color: #fff;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 280px;
	font-weight: 100
}

@media (width<=1060px) {
	.page-sub .sub-mv__bg-text-wrap p {
		font-size: 200px
	}
}

@media (width<=768px) {
	.page-sub .sub-mv__bg-text-wrap p {
		font-size: 120px
	}
}

.page-sub .sub-mv__lines {
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-sub .sub-mv__left-line-wrap {
	width: 56%;
	position: absolute;
	top: -20%;
	left: -22%
}

@media (width<=1060px) {
	.page-sub .sub-mv__left-line-wrap {
		width: 66%
	}
}

@media (width<=768px) {
	.page-sub .sub-mv__left-line-wrap {
		max-width: 400px;
		top: -8%;
		left: -15%
	}
}

.page-sub .sub-mv__left-line {
	width: 100%;
	padding-top: 64.86%;
	position: relative
}

.page-sub .sub-mv__left-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-sub .sub-mv__left-line svg .line-left {
	fill: url(#sub-mv-top-line-left-gradient)
}

.page-sub .sub-mv__left-line svg .line-left-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-sub .sub-mv__right-line-wrap {
	width: 56%;
	position: absolute;
	bottom: -14%;
	right: -18%
}

@media (width<=1060px) {
	.page-sub .sub-mv__right-line-wrap {
		width: 66%;
		bottom: -10%
	}
}

@media (width<=768px) {
	.page-sub .sub-mv__right-line-wrap {
		max-width: 400px;
		bottom: 6%;
		right: -24%;
		transform: rotate(270deg)scaleX(-1)
	}
}

.page-sub .sub-mv__right-line {
	width: 100%;
	padding-top: 64.86%;
	position: relative
}

.page-sub .sub-mv__right-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-sub .sub-mv__right-line svg .line-right {
	fill: url(#sub-mv-top-line-right-gradient)
}

.page-sub .sub-mv__right-line svg .line-right-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-sub .sub-mv__content {
	width: 100%;
	height: 100%;
	padding: 0 40px 52px;
	position: relative
}

@media (width<=768px) {
	.page-sub .sub-mv__content {
		padding: 152px 0 0
	}
}

.page-sub .sub-mv__inner {
	justify-content: space-between;
	align-items: flex-end;
	width: 100%;
	max-width: 1264px;
	height: 100%;
	margin: 0 auto;
	padding: 0 32px;
	display: flex
}

@media (width<=1060px) {
	.page-sub .sub-mv__inner {
		flex-flow: column wrap
	}
}

@media (width<=768px) {
	.page-sub .sub-mv__inner {
		max-width: 600px;
		padding: 0 20px
	}
}

@media (width<=1060px) {
	.page-sub .sub-mv__title {
		width: 100%;
		margin-top: auto
	}
}

@media (width<=768px) {
	.page-sub .sub-mv__title span {
		display: block
	}
}

.page-sub .sub-mv__title span.en {
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 92px;
	font-weight: 200
}

@media (width<=1250px) {
	.page-sub .sub-mv__title span.en {
		font-size: 80px
	}
}

@media (width<=768px) {
	.page-sub .sub-mv__title span.en {
		font-size: 52px
	}
}

.page-sub .sub-mv__title span.jp {
	letter-spacing: .04em;
	align-items: center;
	margin-top: 4px;
	font-size: 14px;
	font-weight: 500;
	display: flex
}

@media (width<=768px) {
	.page-sub .sub-mv__title span.jp {
		font-size: 13px
	}
}

.page-sub .sub-mv__title span.jp:before {
	content: "";
	background-image: url(icon-title-acc-white.67bcf942.png);
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 20px;
	height: 13px;
	margin-right: 8px
}

@media (width<=768px) {
	.page-sub .sub-mv__title span.jp:before {
		margin-right: 6px
	}
}

.page-sub .sub-mv__page-nav {
	margin-bottom: -92px;
	margin-right: -40px
}

@media (width<=1060px) {
	.page-sub .sub-mv__page-nav {
		margin-left: auto
	}
}

@media (width<=768px) {
	.page-sub .sub-mv__page-nav {
		margin: 60px 0 0
	}
}

.page-sub .sub-mv.-type-2 {
	border-bottom: 1px solid #c9d1db;
	height: auto;
	padding: 218px 0 78px
}

@media (width<=1060px) {
	.page-sub .sub-mv.-type-2 {
		padding: 160px 0 56px
	}
}

@media (width<=768px) {
	.page-sub .sub-mv.-type-2 {
		padding: 148px 0 48px
	}
}

.page-sub .sub-mv.-type-2 .sub-mv__container {
	max-width: 1184px
}

.page-sub .sub-mv.-type-2 .sub-mv__title {
	align-items: baseline;
	display: flex
}

@media (width<=768px) {
	.page-sub .sub-mv.-type-2 .sub-mv__title {
		flex-wrap: wrap
	}

	.page-sub .sub-mv.-type-2 .sub-mv__title span {
		width: 100%
	}
}

.page-sub .sub-mv.-type-2 .sub-mv__title span.jp {
	margin-left: 20px
}

@media (width<=768px) {
	.page-sub .sub-mv.-type-2 .sub-mv__title span.jp {
		margin-left: 0
	}
}

.page-sub .page-nav {
	background-color: #fff;
	border-radius: 4px;
	padding: 24px 40px 40px;
	position: relative
}

@media (width<=768px) {
	.page-sub .page-nav {
		width: 100%;
		padding: 20px 20px 32px
	}
}

.page-sub .page-nav__list {
	min-width: 200px
}

@media (width<=768px) {
	.page-sub .page-nav__list {
		flex-wrap: wrap;
		justify-content: space-between;
		display: flex
	}
}

.page-sub .page-nav__item {
	border-bottom: 1px solid #c9d1db
}

@media (width<=768px) {
	.page-sub .page-nav__item {
		width: calc(50% - 10px)
	}
}

.page-sub .page-nav__link {
	color: #202733bf;
	letter-spacing: -.01em;
	justify-content: space-between;
	align-items: center;
	padding: 16px 0;
	font-size: 13px;
	font-weight: 700;
	transition: all .3s;
	display: flex
}

@media (width<=768px) {
	.page-sub .page-nav__link {
		padding: 12px 0;
		font-size: 12px
	}
}

.page-sub .page-nav__link:after {
	content: "";
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 11px;
	height: 7px
}

@media (hover:hover) {
	.page-sub .page-nav__link:hover {
		color: #0553dd
	}
}

.page-sub .page-nav.-dark {
	background-color: #202733
}

.page-sub .page-nav.-dark:before {
	content: "";
	background-color: #ffffff0d;
	border-radius: 4px;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-sub .page-nav.-dark .page-nav__list {
	position: relative
}

.page-sub .page-nav.-dark .page-nav__item {
	border-bottom: 1px solid #fff3
}

.page-sub .page-nav.-dark .page-nav__link {
	color: #ffffffbf
}

@media (hover:hover) {
	.page-sub .page-nav.-dark .page-nav__link:hover {
		color: #fff
	}
}

.page-sub .sub-sec-head {
	text-align: center
}

.page-sub .sub-sec-head__title {
	padding-bottom: 36px;
	position: relative
}

@media (width<=768px) {
	.page-sub .sub-sec-head__title {
		padding-bottom: 24px
	}
}

.page-sub .sub-sec-head__title:after {
	content: "";
	background-color: #c9d1db;
	width: 100%;
	height: 1px;
	transition: all 1s cubic-bezier(.165,.84,.44,1) .2s;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	transform: scaleX(0)
}

.page-sub .sub-sec-head__title span {
	display: block
}

.page-sub .sub-sec-head__title span.en {
	letter-spacing: .04em;
	color: #0553dd;
	opacity: 0;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 15px;
	font-weight: 500;
	transition: all 1s cubic-bezier(.165,.84,.44,1) .2s;
	transform: translateY(30px)
}

@media (width<=768px) {
	.page-sub .sub-sec-head__title span.en {
		font-size: 13px
	}
}

.page-sub .sub-sec-head__title span.jp {
	letter-spacing: .06em;
	opacity: 0;
	margin-top: 16px;
	font-size: 24px;
	font-weight: 700;
	transition: all 1s cubic-bezier(.165,.84,.44,1) .2s;
	transform: translateY(30px)
}

@media (width<=768px) {
	.page-sub .sub-sec-head__title span.jp {
		margin-top: 8px;
		font-size: 20px
	}
}

.page-sub .sub-sec-head__text {
	letter-spacing: .03em;
	margin-top: 32px;
	font-size: 14px;
	line-height: 1.86
}

.page-sub .sub-sec-head.-white .sub-sec-head__title:after {
	background-color: #fff3
}

.page-sub .sub-sec-head.-white .sub-sec-head__title span.en,.page-sub .sub-sec-head.-white .sub-sec-head__title span.jp,.page-sub .sub-sec-head.-white .sub-sec-head__text {
	color: #fff
}

.page-sub .sub-sec-head .sub-sec-head__title.inview-is-visible span.en,.page-sub .sub-sec-head .sub-sec-head__title.inview-is-visible span.jp {
	opacity: 1;
	transform: translateY(0)
}

.page-sub .sub-sec-head .sub-sec-head__title.inview-is-visible:after {
	transform: scaleX(1)
}

.page-corporate .overview__container {
	max-width: 1184px
}

.page-corporate .overview__content {
	border-bottom: 1px solid #c9d1db;
	padding: 100px 0 10px
}

@media (width<=768px) {
	.page-corporate .overview__content {
		padding: 80px 0
	}
}

.page-corporate .overview__title {
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

.page-corporate .overview__cols {
	justify-content: space-between;
	margin-top: 72px;
	display: flex
}

@media (width<=1060px) {
	.page-corporate .overview__cols {
		flex-wrap: wrap
	}
}

@media (width<=768px) {
	.page-corporate .overview__cols {
		margin-top: 40px
	}
}

.page-corporate .overview__col {
	width: calc(50% - 20px)
}

@media (width<=1060px) {
	.page-corporate .overview__col {
		width: 100%
	}
}

.page-corporate .overview__data-item {
	padding: 25px 0 40px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.page-corporate .overview__data-item {
		flex-wrap: wrap;
		padding: 25px 0
	}
}

.page-corporate .overview__data-item:before,.page-corporate .overview__data-item:after {
	content: "";
	width: 100%;
	position: absolute;
	left: 0
}

.page-corporate .overview__data-item:before {
	background-color: #c9d1db;
	height: 1px;
	top: 0
}

.page-corporate .overview__data-item:after {
	content: "";
	background-color: #0553dd;
	width: 20px;
	height: 2px;
	position: absolute;
	top: -.5px
}

.page-corporate .overview__data-title {
	letter-spacing: .02em;
	flex-shrink: 0;
	width: 110px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.86
}

@media (width<=768px) {
	.page-corporate .overview__data-title {
		width: 100%
	}
}

.page-corporate .overview__data-desc {
	letter-spacing: .02em;
	flex-grow: 1;
	font-size: 14px;
	font-weight: 400;
	line-height: 1.86
}

@media (width<=768px) {
	.page-corporate .overview__data-desc {
		margin-top: 8px
	}
}

.page-corporate .structure__container {
	max-width: 1184px
}

.page-corporate .structure__content {
	justify-content: space-between;
	padding: 120px 0;
	display: flex
}

@media (width<=1060px) {
	.page-corporate .structure__content {
		flex-wrap: wrap
	}
}

@media (width<=768px) {
	.page-corporate .structure__content {
		padding: 80px 0
	}
}

.page-corporate .structure__title {
	letter-spacing: .02em;
	flex-shrink: 0;
	font-size: 13px;
	font-weight: 700
}

@media (width<=1060px) {
	.page-corporate .structure__title {
		width: 100%
	}
}

.page-corporate .structure__diagram {
	max-width: 840px;
	margin-left: 40px
}

@media (width<=1060px) {
	.page-corporate .structure__diagram {
		margin-top: 64px;
		margin-left: 0
	}
}

@media (width<=768px) {
	.page-corporate .structure__diagram {
		margin-top: 40px
	}
}

.page-corporate .manager {
	padding: 0 20px
}

.page-corporate .manager__wrap {
	background-color: #fff;
	border-radius: 20px;
	padding: 120px 0
}

@media (width<=768px) {
	.page-corporate .manager__wrap {
		border-radius: 12px;
		padding: 80px 0
	}
}

.page-corporate .manager__container {
	max-width: 1184px
}

.page-corporate .manager__content {
	justify-content: space-between;
	width: 100%;
	display: flex
}

@media (width<=1060px) {
	.page-corporate .manager__content {
		flex-wrap: wrap
	}
}

.page-corporate .manager__title {
	letter-spacing: .02em;
	flex-shrink: 0;
	font-size: 13px;
	font-weight: 700
}

@media (width<=1060px) {
	.page-corporate .manager__title {
		width: 100%
	}
}

.page-corporate .manager__blocks {
	width: 100%;
	max-width: 840px;
	margin-left: 40px
}

@media (width<=1060px) {
	.page-corporate .manager__blocks {
		margin-top: 64px;
		margin-left: 0
	}
}

@media (width<=768px) {
	.page-corporate .manager__blocks {
		margin-top: 40px
	}
}

.page-corporate .manager__block:not(:first-child) {
	margin-top: 80px
}

@media (width<=768px) {
	.page-corporate .manager__block:not(:first-child) {
		margin-top: 56px
	}
}

.page-corporate .manager__block-title {
	letter-spacing: .04em;
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 38px;
	font-size: 18px;
	font-weight: 700
}

@media (width<=768px) {
	.page-corporate .manager__block-title {
		padding-bottom: 16px
	}
}

.page-corporate .manager__list {
	flex-wrap: wrap;
	display: flex
}

@media (width<=768px) {
	.page-corporate .manager__list {
		justify-content: center
	}
}

.page-corporate .manager__item {
	cursor: pointer;
	width: calc(33.3% - 22px);
	margin-top: 52px;
	margin-right: 33px
}

.page-corporate .manager__item:nth-child(3n) {
	margin-right: 0
}

@media (width<=768px) {
	.page-corporate .manager__item {
		width: 100%;
		margin-top: 32px;
		margin-right: 0
	}
}

.page-corporate .manager__item-thumb {
	width: 100%;
	position: relative
}

@media (hover:hover) {
	.page-corporate .manager__item-thumb:hover img {
		scale: 1.1
	}

	.page-corporate .manager__item-thumb:hover .manager__item-btn {
		background-color: #fff;
		border-color: #0553dd
	}

	.page-corporate .manager__item-thumb:hover .manager__item-btn:before,.page-corporate .manager__item-thumb:hover .manager__item-btn:after {
		background-color: #0553dd
	}
}

.page-corporate .manager__item-thumb-wrap {
	border-radius: 4px;
	width: 100%;
	padding-top: 100%;
	position: relative;
	overflow: hidden
}

.page-corporate .manager__item-thumb-wrap img {
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
	transition: all .6s;
	position: absolute;
	top: 0;
	left: 0
}

.page-corporate .manager__item-btn {
	background-color: #0553dd;
	border: 1px solid #fff;
	border-radius: 50%;
	width: 40px;
	height: 40px;
	transition: all .6s;
	position: absolute;
	bottom: -20px;
	right: 8px
}

.page-corporate .manager__item-btn:before,.page-corporate .manager__item-btn:after {
	content: "";
	background-color: #fff;
	border-radius: 10px;
	width: 14px;
	height: 2px;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.page-corporate .manager__item-btn:after {
	transform: rotate(90deg)
}

.page-corporate .manager__item-content {
	margin-top: 16px
}

.page-corporate .manager__item-position {
	color: #202733bf;
	letter-spacing: .04em;
	font-size: 12px
}

.page-corporate .manager__item-name {
	letter-spacing: .04em;
	margin-top: 5px;
	font-size: 16px;
	font-weight: 700
}

.page-corporate .manager__modal {
	pointer-events: none;
	opacity: 0;
	z-index: 1000;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100dvh;
	padding: 20px 32px;
	transition: all .3s;
	display: flex;
	position: fixed;
	top: 0;
	left: 0
}

.page-corporate .manager__modal.is-active {
	opacity: 1;
	pointer-events: auto;
	transition: all .3s
}

.page-corporate .manager__modal-overlay {
	cursor: pointer;
	background-color: #000000bf;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-corporate .manager__modal-wrap {
	width: 100%;
	max-width: 1120px;
	height: 100%;
	max-height: 80%;
	margin: auto;
	position: relative
}

@media (width<=768px) {
	.page-corporate .manager__modal-wrap {
		max-height: 100%
	}
}

.page-corporate .manager__modal-item {
	background-color: #fff;
	border-radius: 20px;
	height: 100%;
	display: none;
	position: relative;
	overflow: hidden
}

@media (width<=768px) {
	.page-corporate .manager__modal-item {
		border-radius: 12px;
		padding: 20px;
		overflow-y: scroll
	}
}

.page-corporate .manager__modal-item.is-active {
	display: block
}

.page-corporate .manager__modal-img {
	width: 50%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

@media (width<=768px) {
	.page-corporate .manager__modal-img {
		border-radius: 12px;
		width: 100%;
		height: auto;
		padding-top: 100%;
		position: relative;
		overflow: hidden
	}
}

.page-corporate .manager__modal-img img {
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: 50% 25%;
	object-position: 50% 25%;
	height: 100%
}

@media (width<=768px) {
	.page-corporate .manager__modal-img img {
		width: 100%;
		position: absolute;
		top: 0;
		left: 0
	}
}

.page-corporate .manager__modal-body {
	height: 100%;
	padding-left: 50%;
	position: relative;
	overflow-y: scroll
}

@media (width<=768px) {
	.page-corporate .manager__modal-body {
		overflow-y: unset;
		height: auto;
		padding-left: 0
	}
}

.page-corporate .manager__modal-content {
	padding: 140px 32px
}

@media (width<=768px) {
	.page-corporate .manager__modal-content {
		padding: 40px 0 56px
	}
}

.page-corporate .manager__modal-close {
	align-items: center;
	display: flex;
	position: absolute;
	top: 40px;
	right: 40px
}

@media (width<=768px) {
	.page-corporate .manager__modal-close {
		top: auto;
		bottom: 4px;
		right: 0
	}
}

.page-corporate .manager__modal-close span.close-text {
	letter-spacing: .04em;
	color: #202733;
	margin-right: 12px;
	font-size: 13px;
	font-weight: 500
}

.page-corporate .manager__modal-close span.close-icon {
	background-color: #c9d1db;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	display: block;
	position: relative;
	overflow: hidden
}

.page-corporate .manager__modal-close span.close-icon:after {
	content: "";
	pointer-events: none;
	background-color: #0553dd;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

.page-corporate .manager__modal-close span.close-icon span:before,.page-corporate .manager__modal-close span.close-icon span:after {
	content: "";
	z-index: 1;
	background-color: #202733;
	width: 16px;
	height: 1px;
	margin: auto;
	transition: all .3s;
	display: block;
	position: absolute;
	inset: 0
}

.page-corporate .manager__modal-close span.close-icon span:before {
	transform: rotate(15deg)
}

.page-corporate .manager__modal-close span.close-icon span:after {
	transform: rotate(-15deg)
}

@media (hover:hover) {
	.page-corporate .manager__modal-close:hover .close-icon:after {
		transform: scale(5)
	}

	.page-corporate .manager__modal-close:hover .close-icon span:before,.page-corporate .manager__modal-close:hover .close-icon span:after {
		background-color: #fff
	}
}

.page-corporate .manager__modal-position {
	letter-spacing: .04em;
	color: #202733bf;
	font-size: 12px
}

.page-corporate .manager__modal-name {
	letter-spacing: .06em;
	margin-top: 8px;
	font-size: 24px;
	font-weight: 700
}

@media (width<=768px) {
	.page-corporate .manager__modal-name {
		font-size: 20px
	}
}

.page-corporate .manager__modal-text {
	letter-spacing: .04em;
	border-top: 1px solid #c9d1db;
	margin-top: 28px;
	padding-top: 32px;
	font-size: 13px;
	line-height: 2
}

@media (width<=768px) {
	.page-corporate .manager__modal-text {
		padding-top: 24px
	}
}

.page-corporate .manager__modal-sns {
	align-items: center;
	margin-top: 48px;
	display: flex
}

@media (width<=768px) {
	.page-corporate .manager__modal-sns {
		margin-top: 32px
	}
}

.page-corporate .manager__modal-sns-head {
	color: #20273380;
	flex-shrink: 0;
	align-items: center;
	margin-right: 20px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500;
	display: flex
}

.page-corporate .manager__modal-sns-head:after {
	content: "";
	background-color: #20273380;
	width: 24px;
	height: 1px;
	margin-left: 12px;
	display: block
}

.page-corporate .manager__modal-sns-list {
	align-items: center;
	display: flex
}

.page-corporate .manager__modal-sns-item {
	width: 32px;
	margin-right: 8px
}

.page-corporate .manager__modal-sns-link {
	width: 100%;
	transition: all .3s;
	display: flex
}

@media (hover:hover) {
	.page-corporate .manager__modal-sns-link:hover {
		opacity: .7
	}
}

.page-corporate .gallery {
	padding: 120px 0
}

@media (width<=768px) {
	.page-corporate .gallery {
		padding: 80px 0
	}
}

.page-corporate .gallery__slider-wrapper {
	transition-timing-function: linear!important
}

.page-corporate .access__container {
	max-width: 1184px
}

.page-corporate .access__content {
	border-top: 1px solid #c9d1db;
	justify-content: space-between;
	padding: 60px 0 120px;
	display: flex
}

@media (width<=1060px) {
	.page-corporate .access__content {
		flex-wrap: wrap
	}
}

@media (width<=768px) {
	.page-corporate .access__content {
		padding: 80px 0
	}
}

.page-corporate .access__text-wrap {
	padding-top: 138px
}

@media (width<=1060px) {
	.page-corporate .access__text-wrap {
		padding-top: 0
	}
}

.page-corporate .access__title {
	letter-spacing: .02em;
	flex-shrink: 0;
	font-size: 13px;
	font-weight: 700
}

.page-corporate .access__address {
	letter-spacing: .02em;
	margin-top: 40px;
	font-size: 13px;
	line-height: 2
}

@media (width<=768px) {
	.page-corporate .access__address {
		margin-top: 24px
	}
}

.page-corporate .access__map {
	width: 100%;
	max-width: 560px
}

@media (width<=1060px) {
	.page-corporate .access__map {
		max-width: 100%;
		margin-top: 64px
	}
}

@media (width<=768px) {
	.page-corporate .access__map {
		margin-top: 24px
	}
}

.page-corporate .access__map-wrap {
	border-radius: 8px;
	width: 100%;
	padding-top: 75%;
	position: relative;
	overflow: hidden
}

.page-corporate .access__map-wrap iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-partners .mv {
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: cover;
	width: 100%;
	height: 602px;
	padding-top: 220px;
	position: relative
}

@media (width<=768px) {
	.page-partners .mv {
		align-items: center;
		padding: 120px 0;
		display: flex
	}
}

.page-partners .mv:before {
	content: "";
	background-color: #20273380;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-partners .mv__container {
	max-width: 1184px
}

.page-partners .mv__content {
	flex-direction: column;
	align-items: center;
	padding: 0 32px 72px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.page-partners .mv__content {
		padding: 0 0 32px
	}
}

.page-partners .mv__content:after {
	content: "";
	background-color: #c9d1db;
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0
}

.page-partners .mv__intro {
	letter-spacing: .04em;
	color: #fff;
	font-size: 16px;
	font-weight: 700
}

@media (width<=768px) {
	.page-partners .mv__intro {
		font-size: 13px
	}
}

.page-partners .mv__title {
	letter-spacing: .06em;
	color: #fff;
	margin-top: 24px;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.625
}

@media (width<=768px) {
	.page-partners .mv__title {
		text-align: center;
		font-size: 24px
	}
}

.page-partners .mv__intro,.page-partners .mv__title {
	opacity: 0;
	transition: all 1s cubic-bezier(.165,.84,.44,1) .2s;
	transform: translateY(30px)
}

.page-partners .mv__content:after {
	transition: all 1s cubic-bezier(.165,.84,.44,1) .2s;
	transform: scaleX(0)
}

.page-partners .mv.inview-is-visible .mv__intro,.page-partners .mv.inview-is-visible .mv__title {
	opacity: 1;
	transform: translateY(0)
}

.page-partners .mv.inview-is-visible .mv__content:after {
	transform: scaleX(1)
}

.page-partners .point {
	padding: 80px 0 120px
}

@media (width<=768px) {
	.page-partners .point {
		padding: 80px 0
	}
}

.page-partners .point__container {
	max-width: 1184px
}

.page-partners .point__list {
	justify-content: space-between;
	margin-top: 60px;
	display: flex
}

@media (width<=768px) {
	.page-partners .point__list {
		flex-wrap: wrap;
		margin-top: 40px
	}
}

.page-partners .point__item {
	width: calc(33.3% - 23px)
}

@media (width<=768px) {
	.page-partners .point__item {
		width: 100%
	}

	.page-partners .point__item:not(:first-child) {
		margin-top: 40px
	}
}

.page-partners .point__item-thumb {
	border-radius: 4px;
	width: 100%;
	padding-top: 56%;
	position: relative;
	overflow: hidden
}

.page-partners .point__item-thumb img {
	-o-object-fit: cover;
	object-fit: cover;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-partners .point__item-content {
	margin-top: 24px;
	padding: 0 12px
}

.page-partners .point__item-title {
	letter-spacing: .04em;
	font-size: 18px;
	font-weight: 700
}

.page-partners .point__item-title span {
	color: #0553dd
}

.page-partners .point__item-text {
	letter-spacing: .02em;
	margin-top: 20px;
	font-size: 13px;
	line-height: 2
}

.page-partners .point__item-text strong {
	font-weight: 700
}

.page-partners .point__item-text a {
	color: #0553dd;
	text-decoration: underline
}

.page-partners .about__wrap {
	padding: 0 20px
}

.page-partners .about__content {
	background-color: #0553dd;
	border-radius: 20px;
	padding: 80px 40px 92px
}

@media (width<=768px) {
	.page-partners .about__content {
		border-radius: 12px;
		padding: 80px 0
	}
}

.page-partners .about__container {
	max-width: 1184px
}

.page-partners .about__list {
	margin-top: 60px
}

@media (width<=768px) {
	.page-partners .about__list {
		margin-top: 40px
	}
}

.page-partners .about__item {
	background-color: #ffffff1a;
	border-radius: 8px;
	align-items: flex-start;
	width: 100%;
	padding: 40px 70px;
	display: flex
}

@media (width<=1060px) {
	.page-partners .about__item {
		flex-wrap: wrap;
		padding: 40px
	}
}

@media (width<=768px) {
	.page-partners .about__item {
		padding: 20px
	}
}

.page-partners .about__item:not(:first-child) {
	margin-top: 12px
}

@media (width<=768px) {
	.page-partners .about__item:not(:first-child) {
		margin-top: 20px
	}
}

.page-partners .about__thumb {
	border-radius: 4px;
	flex-shrink: 0;
	width: 245px;
	margin-right: 35px;
	position: relative;
	overflow: hidden
}

@media (width<=1060px) {
	.page-partners .about__thumb {
		width: 100%;
		margin-right: 0
	}
}

.page-partners .about__thumb-wrap {
	width: 100%;
	height: 100%;
	padding-top: 66.9%;
	position: relative
}

.page-partners .about__thumb-wrap img {
	-o-object-fit: cover;
	object-fit: cover;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-partners .about__item-content {
	border-left: 1px solid #fff3;
	padding: 12px 0 20px 35px
}

@media (width<=1060px) {
	.page-partners .about__item-content {
		border-top: 1px solid #fff3;
		border-left: 0;
		margin-top: 30px;
		padding: 20px
	}
}

@media (width<=768px) {
	.page-partners .about__item-content {
		padding: 20px 0
	}
}

.page-partners .about__item-title {
	color: #fff;
	letter-spacing: .04em;
	font-size: 18px;
	font-weight: 700
}

.page-partners .about__item-text {
	letter-spacing: .02em;
	color: #fff;
	margin-top: 20px;
	font-size: 13px;
	line-height: 2
}

.page-partners .data {
	padding: 80px 0
}

.page-partners .data__container {
	max-width: 1184px
}

.page-partners .data__list {
	justify-content: space-between;
	width: 100%;
	max-width: 1050px;
	margin: 48px auto 0;
	display: flex
}

@media (width<=768px) {
	.page-partners .data__list {
		flex-wrap: wrap;
		max-width: 90%
	}
}

.page-partners .data__item {
	width: calc(33.3% - 36px)
}

@media (width<=1060px) {
	.page-partners .data__item {
		width: calc(33.3% - 24px)
	}
}

@media (width<=768px) {
	.page-partners .data__item {
		width: 100%
	}

	.page-partners .data__item:not(:first-child) {
		margin-top: 40px
	}
}

.page-partners .data__item-title {
	letter-spacing: .06em;
	text-align: center;
	font-size: 20px;
	font-weight: 700
}

.page-partners .data__item-graph {
	width: 100%;
	margin-top: 32px;
	padding-top: 100%;
	position: relative
}

@media (width<=768px) {
	.page-partners .data__item-graph {
		margin-top: 24px
	}
}

.page-partners .data__item-graph .graph {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-partners .data__item-graph .graph__bg {
	background-color: #fff;
	border-radius: 50%;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-partners .data__item-graph .graph__bar {
	position: relative
}

.page-partners .data__item-graph .graph__text {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0
}

.page-partners .data__item-graph .graph__text svg {
	width: 100%;
	height: auto
}

.page-partners .data__item .graph__bg {
	transition: all 1s;
	transform: scale(0)
}

.page-partners .data__item .graph__bar {
	transition: all 1s .3s;
	transform: scale(0)
}

.page-partners .data__item .graph__text {
	transition: all 1s
}

.page-partners .data__item .graph__text-group {
	opacity: 0;
	transition: all 1s;
	transform: translateY(20px)
}

.page-partners .data__item .graph__text-group.-one {
	transition-delay: .6s
}

.page-partners .data__item .graph__text-group.-two {
	transition-delay: .8s
}

.page-partners .data__item .graph__text-group.-three {
	transition-delay: 1s
}

.page-partners .data__item .graph__text-group.-four {
	transition-delay: 1.2s
}

.page-partners .data__item .graph__text-group.-five {
	transition-delay: 1.4s
}

.page-partners .data__item .graph__text-group.-six {
	transition-delay: 1.6s
}

.page-partners .data__item .graph__text-group.-seven {
	transition-delay: 1.8s
}

.page-partners .data__item.-age .graph__text {
	width: 104.3%
}

.page-partners .data__item.-type .graph__text {
	width: 106.6%
}

.page-partners .data__item.inview-is-visible .graph__bg,.page-partners .data__item.inview-is-visible .graph__bar {
	transform: scale(1)
}

.page-partners .data__item.inview-is-visible .graph__text-group {
	opacity: 1;
	transform: translateY(0)
}

.page-partners .client__wrap {
	padding: 0 20px
}

.page-partners .client__content {
	background-color: #fff;
	border-radius: 20px;
	padding: 80px 40px 92px
}

@media (width<=768px) {
	.page-partners .client__content {
		padding: 80px 0
	}
}

.page-partners .client__container {
	max-width: 1184px
}

.page-partners .client__list {
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: 8px;
	display: flex
}

.page-partners .client__item {
	width: calc(20% - 14px);
	margin-top: 52px
}

@media (width<=1060px) {
	.page-partners .client__item {
		width: calc(33.3% - 14px)
	}
}

@media (width<=768px) {
	.page-partners .client__item {
		width: calc(50% - 8px);
		margin-top: 20px
	}
}

.page-partners .faq {
	padding: 92px 0 160px
}

@media (width<=768px) {
	.page-partners .faq {
		padding: 80px 0 64px
	}
}

.page-partners .faq__list {
	width: 100%;
	max-width: 840px;
	margin: 60px auto 0
}

@media (width<=768px) {
	.page-partners .faq__list {
		margin-top: 40px
	}
}

.page-partners .faq__item {
	cursor: pointer;
	margin-top: 8px
}

.page-partners .faq__question {
	letter-spacing: .04em;
	background-color: #fff;
	border-radius: 8px;
	padding: 28px 94px 28px 72px;
	font-size: 16px;
	font-weight: 700;
	position: relative
}

@media (width<=768px) {
	.page-partners .faq__question {
		padding: 16px 56px 16px 50px
	}
}

.page-partners .faq__question .question {
	letter-spacing: -.01em;
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 20px;
	font-weight: 700;
	position: absolute;
	top: 25px;
	left: 35px
}

@media (width<=768px) {
	.page-partners .faq__question .question {
		top: 14px;
		left: 20px
	}
}

.page-partners .faq__question:after {
	content: "";
	background-color: #0553dd;
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: 11px 7px;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	margin: auto 0;
	transition: all .3s;
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 35px
}

@media (width<=768px) {
	.page-partners .faq__question:after {
		right: 20px
	}
}

.page-partners .faq__answer {
	padding: 20px 0 32px 35px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.page-partners .faq__answer {
		padding: 20px 0 32px 20px
	}
}

.page-partners .faq__answer .answer {
	letter-spacing: -.01em;
	color: #dd052f;
	margin-right: 22px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 20px;
	font-weight: 700;
	display: block
}

@media (width<=768px) {
	.page-partners .faq__answer .answer {
		margin-right: 16px
	}
}

.page-partners .faq__answer .answer-text {
	letter-spacing: .04em;
	font-size: 13px;
	line-height: 2
}

.page-partners .faq__item.is-open .faq__question:after {
	transform: rotate(180deg)
}

.page-agent .mv {
	background-color: #202733;
	width: 100%;
	height: 602px;
	position: relative
}

@media (width<=768px) {
	.page-agent .mv {
		height: auto;
		padding: 126px 0 380px
	}
}

.page-agent .mv__lines {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-agent .mv__top-line-wrap {
	width: 56%;
	position: absolute;
	top: -32%;
	left: -25%
}

@media (width<=768px) {
	.page-agent .mv__top-line-wrap {
		width: 64%;
		top: -6%;
		left: -15%
	}
}

.page-agent .mv__top-line {
	width: 100%;
	padding-top: 67.9%;
	position: relative
}

.page-agent .mv__top-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .mv__top-line svg .agent-mv-top-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .mv__top-line svg .agent-mv-top-line {
	fill: url(#agent-mv-top-line-gradient);
	isolation: isolate;
	opacity: .1
}

.page-agent .mv__bottom-line-wrap {
	width: 56%;
	position: absolute;
	bottom: -64%;
	right: -27%;
	transform: rotate(90deg)scaleX(-1)
}

@media (width<=1060px) {
	.page-agent .mv__bottom-line-wrap {
		bottom: -30%;
		right: -20%
	}
}

@media (width<=768px) {
	.page-agent .mv__bottom-line-wrap {
		width: 64%;
		bottom: -5%;
		right: -20%
	}
}

.page-agent .mv__bottom-line {
	width: 100%;
	padding-top: 67.9%;
	position: relative
}

.page-agent .mv__bottom-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .mv__bottom-line svg .agent-mv-bottom-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .mv__bottom-line svg .agent-mv-bottom-line {
	fill: url(#agent-mv-bottom-line-gradient);
	isolation: isolate;
	opacity: .1
}

.page-agent .mv__main-line-wrap {
	width: 117%;
	position: absolute;
	top: 82px;
	left: -92px
}

@media (width<=1060px) {
	.page-agent .mv__main-line-wrap {
		width: 125%;
		top: 14%;
		left: -7%
	}
}

@media (width<=768px) {
	.page-agent .mv__main-line-wrap {
		width: 180%;
		max-width: 1000px;
		top: 48%;
		left: -180px
	}
}

.page-agent .mv__main-line {
	width: 100%
}

.page-agent .mv__container {
	align-items: center;
	max-width: 1044px;
	height: 100%;
	display: flex;
	position: relative
}

.page-agent .mv__content {
	flex-direction: column;
	align-items: center;
	width: 285px;
	display: flex
}

@media (width<=768px) {
	.page-agent .mv__content {
		margin: 0 auto
	}
}

.page-agent .mv__logo {
	width: 280px
}

@media (width<=768px) {
	.page-agent .mv__logo {
		width: 240px
	}
}

.page-agent .mv__text {
	color: #fff;
	letter-spacing: .04em;
	text-align: center;
	margin-top: 40px;
	font-size: 16px;
	font-weight: 700;
	line-height: 2
}

.page-agent .intro {
	margin-top: 80px
}

@media (width<=768px) {
	.page-agent .intro {
		margin-top: 60px
	}
}

.page-agent .intro__wrap {
	padding: 0 20px
}

.page-agent .intro__content {
	background-color: #202733;
	border-radius: 20px;
	padding: 120px 40px 132px;
	position: relative
}

@media (width<=768px) {
	.page-agent .intro__content {
		border-radius: 12px;
		padding: 60px 20px
	}
}

.page-agent .intro__lines {
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-agent .intro__top-line-wrap {
	width: 38%;
	position: absolute;
	top: -14%;
	right: -8%
}

@media (width<=768px) {
	.page-agent .intro__top-line-wrap {
		top: -6%
	}
}

.page-agent .intro__top-line {
	width: 100%;
	padding-top: 103%;
	position: relative
}

.page-agent .intro__top-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .intro__top-line svg .intro-top-line {
	fill: url(#intro-top-line-linear-gradient)
}

.page-agent .intro__top-line svg .intro-top-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 160px
}

.page-agent .intro__bottom-line-wrap {
	width: 50%;
	position: absolute;
	bottom: -12%;
	left: -18%
}

@media (width<=768px) {
	.page-agent .intro__bottom-line-wrap {
		bottom: -6%
	}
}

.page-agent .intro__bottom-line {
	width: 100%;
	padding-top: 77%;
	position: relative
}

.page-agent .intro__bottom-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .intro__bottom-line svg .intro-bottom-line {
	fill: url(#intro-bottom-line-linear-gradient)
}

.page-agent .intro__bottom-line svg .intro-bottom-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 150px
}

.page-agent .intro__container {
	max-width: 1184px
}

@media (width<=768px) {
	.page-agent .intro__container {
		padding: 0
	}
}

.page-agent .intro__title {
	letter-spacing: .06em;
	text-align: center;
	color: #fff;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.75
}

@media (width<=768px) {
	.page-agent .intro__title {
		font-size: 20px
	}
}

.page-agent .intro__sub-title {
	letter-spacing: .04em;
	text-align: center;
	color: #c9d1db;
	margin-top: 30px;
	font-size: 18px;
	font-weight: 700
}

@media (width<=768px) {
	.page-agent .intro__sub-title {
		margin-top: 16px;
		font-size: 14px
	}
}

.page-agent .intro__text {
	letter-spacing: .04em;
	color: #fff;
	text-align: center;
	margin-top: 48px;
	font-size: 13px;
	line-height: 2
}

@media (width<=768px) {
	.page-agent .intro__text {
		margin-top: 24px
	}
}

.page-agent .data {
	padding: 80px 0 0
}

.page-agent .data__container {
	max-width: 1184px
}

.page-agent .data__list {
	justify-content: space-between;
	width: 100%;
	max-width: 1050px;
	margin: 48px auto 0;
	display: flex
}

@media (width<=768px) {
	.page-agent .data__list {
		flex-wrap: wrap;
		max-width: 90%
	}
}

.page-agent .data__item {
	width: calc(33.3% - 36px)
}

@media (width<=1060px) {
	.page-agent .data__item {
		width: calc(33.3% - 24px)
	}
}

@media (width<=768px) {
	.page-agent .data__item {
		width: 100%
	}

	.page-agent .data__item:not(:first-child) {
		margin-top: 40px
	}
}

.page-agent .data__item-title {
	letter-spacing: .06em;
	text-align: center;
	font-size: 20px;
	font-weight: 700
}

.page-agent .data__item-graph {
	width: 100%;
	margin-top: 32px;
	padding-top: 100%;
	position: relative
}

@media (width<=768px) {
	.page-agent .data__item-graph {
		margin-top: 24px
	}
}

.page-agent .data__item-graph .graph {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .data__item-graph .graph__bg {
	background-color: #fff;
	border-radius: 50%;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .data__item-graph .graph__bar {
	position: relative
}

.page-agent .data__item-graph .graph__text {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0
}

.page-agent .data__item-graph .graph__text svg {
	width: 100%;
	height: auto
}

.page-agent .data__item .graph__bg {
	transition: all 1s;
	transform: scale(0)
}

.page-agent .data__item .graph__bar {
	transition: all 1s .3s;
	transform: scale(0)
}

.page-agent .data__item .graph__text {
	transition: all 1s
}

.page-agent .data__item .graph__text-group {
	opacity: 0;
	transition: all 1s;
	transform: translateY(20px)
}

.page-agent .data__item .graph__text-group.-one {
	transition-delay: .6s
}

.page-agent .data__item .graph__text-group.-two {
	transition-delay: .8s
}

.page-agent .data__item .graph__text-group.-three {
	transition-delay: 1s
}

.page-agent .data__item .graph__text-group.-four {
	transition-delay: 1.2s
}

.page-agent .data__item .graph__text-group.-five {
	transition-delay: 1.4s
}

.page-agent .data__item .graph__text-group.-six {
	transition-delay: 1.6s
}

.page-agent .data__item .graph__text-group.-seven {
	transition-delay: 1.8s
}

.page-agent .data__item.-age .graph__text {
	width: 104.3%
}

.page-agent .data__item.-type .graph__text {
	width: 106.6%
}

.page-agent .data__item.inview-is-visible .graph__bg,.page-agent .data__item.inview-is-visible .graph__bar {
	transform: scale(1)
}

.page-agent .data__item.inview-is-visible .graph__text-group {
	opacity: 1;
	transform: translateY(0)
}

.page-agent .feature {
	padding: 80px 0 0
}

.page-agent .feature__container {
	max-width: 1184px
}

.page-agent .feature__list {
	justify-content: space-between;
	margin-top: 48px;
	display: flex
}

@media (width<=768px) {
	.page-agent .feature__list {
		flex-wrap: wrap;
		margin-top: 24px
	}
}

.page-agent .feature__item {
	width: calc(33.3% - 33px)
}

@media (width<=1060px) {
	.page-agent .feature__item {
		width: calc(33.3% - 12px)
	}
}

@media (width<=768px) {
	.page-agent .feature__item {
		width: 100%
	}

	.page-agent .feature__item:not(:first-child) {
		margin-top: 40px
	}
}

.page-agent .feature__item-img {
	border-radius: 4px;
	width: 100%;
	overflow: hidden
}

.page-agent .feature__item-content {
	margin-top: 24px
}

@media (width<=768px) {
	.page-agent .feature__item-content {
		margin-top: 16px
	}
}

.page-agent .feature__item-title {
	letter-spacing: .04em;
	color: #0553dd;
	align-items: center;
	min-height: 56px;
	font-size: 18px;
	font-weight: 700;
	display: flex
}

@media (width<=768px) {
	.page-agent .feature__item-title {
		min-height: 0
	}
}

.page-agent .feature__item-text {
	margin-top: 20px
}

@media (width<=768px) {
	.page-agent .feature__item-text {
		margin-top: 16px
	}
}

.page-agent .feature__item-text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 2
}

.page-agent .point {
	background-color: #fff;
	padding: 80px 0 92px
}

@media (width<=768px) {
	.page-agent .point {
		padding: 60px 0
	}
}

.page-agent .point__container {
	max-width: 1184px
}

.page-agent .point__list {
	justify-content: space-between;
	margin-top: 52px;
	display: flex
}

@media (width<=1060px) {
	.page-agent .point__list {
		flex-wrap: wrap;
		margin-top: 32px
	}
}

@media (width<=768px) {
	.page-agent .point__list {
		margin-top: 16px
	}
}

.page-agent .point__item {
	width: calc(25% - 9px)
}

@media (width<=1060px) {
	.page-agent .point__item {
		width: calc(50% - 10px);
		margin-top: 20px
	}
}

@media (width<=768px) {
	.page-agent .point__item {
		width: 100%;
		margin-top: 16px
	}
}

.page-agent .point__item-title {
	color: #fff;
	text-align: center;
	background-color: #0553dd;
	border-radius: 8px 8px 0 0;
	width: 100%;
	padding: 16px;
	font-size: 16px;
	font-weight: 700
}

.page-agent .point__item-body {
	background-color: #f4f4f5;
	border-radius: 0 0 8px 8px;
	padding: 28px 16px 40px
}

.page-agent .point__item-sub-text {
	letter-spacing: .04em;
	text-align: center;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.86
}

.page-agent .point__item-main-text {
	color: #0553dd;
	letter-spacing: .04em;
	text-align: center;
	margin-top: 8px;
	font-size: 20px;
	font-weight: 700
}

.page-agent .point__item-main-text span {
	font-size: 32px
}

.page-agent .point__item-btn {
	justify-content: center;
	margin-top: 32px;
	display: flex
}

.page-agent .point__item-btn .text-btn span.arrow {
	background-color: #c9d1db;
	border-color: #c9d1db
}

.page-agent .point__item-btn .text-btn span.arrow svg {
	fill: #202733;
	transform: rotate(-45deg)
}

.page-agent .point__item-btn .text-btn span.arrow svg:first-child {
	transform: rotate(-45deg)translate(-100px)
}

@media (hover:hover) {
	.page-agent .point__item-btn .text-btn:hover span.arrow {
		background-color: #0553dd;
		border-color: #0553dd
	}

	.page-agent .point__item-btn .text-btn:hover span.arrow svg {
		fill: #fff;
		transform: rotate(-45deg)translate(100px)
	}

	.page-agent .point__item-btn .text-btn:hover span.arrow svg:first-child {
		transform: rotate(-45deg)translate(0)
	}
}

.page-agent .point__btn {
	width: 420px;
	height: 56px;
	margin: 52px auto 0
}

@media (width<=768px) {
	.page-agent .point__btn {
		width: 100%;
		height: 58px
	}
}

.page-agent .point__btn .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.page-agent .point__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

@media (hover:hover) {
	.page-agent .point__btn .btn:hover:after {
		transform: scale(20)
	}
}

.page-agent .bg-main {
	background-color: #fff;
	padding: 0 20px 80px
}

@media (width<=768px) {
	.page-agent .bg-main {
		padding-bottom: 60px
	}
}

.page-agent .bg-main__body {
	background-color: #0553dd;
	border-radius: 20px;
	position: relative
}

@media (width<=768px) {
	.page-agent .bg-main__body {
		border-radius: 12px
	}
}

.page-agent .bg-main__lines {
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-agent .bg-main__top-line-wrap {
	width: 60%;
	position: absolute;
	top: -4%;
	right: -25%
}

.page-agent .bg-main__top-line {
	width: 100%;
	padding-top: 65.7%;
	position: relative
}

.page-agent .bg-main__top-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .bg-main__top-line svg .main-top-line {
	fill: url(#main-top-line-linear-gradient)
}

.page-agent .bg-main__top-line svg .main-top-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .bg-main__middle-line-wrap {
	width: 40%;
	position: absolute;
	top: 34%;
	left: -20%
}

.page-agent .bg-main__middle-line {
	width: 100%;
	padding-top: 151%;
	position: relative
}

.page-agent .bg-main__middle-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .bg-main__middle-line svg .main-middle-line {
	fill: url(#main-middle-line-linear-gradient)
}

.page-agent .bg-main__middle-line svg .main-middle-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .bg-main__bottom-line-wrap {
	width: 54%;
	position: absolute;
	bottom: -4%;
	right: -18%
}

.page-agent .bg-main__bottom-line {
	width: 100%;
	padding-top: 66.1%;
	position: relative
}

.page-agent .bg-main__bottom-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .bg-main__bottom-line svg .main-bottom-line {
	fill: url(#main-bottom-line-linear-gradient)
}

.page-agent .bg-main__bottom-line svg .main-bottom-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .case-card {
	background-color: #fff;
	border-radius: 8px;
	padding: 24px 20px 32px
}

.page-agent .case-card__head {
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 24px
}

.page-agent .case-card__num {
	color: #0553dd;
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.page-agent .case-card__title {
	letter-spacing: .04em;
	margin-top: 12px;
	font-size: 16px;
	font-weight: 700
}

.page-agent .case-card__title span {
	letter-spacing: .04em;
	margin-left: 8px;
	font-size: 14px;
	font-weight: 400
}

.page-agent .case-card__body {
	padding-top: 24px
}

.page-agent .case-card__cols {
	justify-content: space-between;
	display: flex
}

@media (width<=1060px) {
	.page-agent .case-card__cols {
		flex-wrap: wrap
	}
}

.page-agent .case-card__col {
	width: calc(50% - 10px)
}

@media (width<=1060px) {
	.page-agent .case-card__col {
		width: 100%
	}
}

.page-agent .case-card__box {
	position: relative
}

.page-agent .case-card__box-title {
	letter-spacing: .04em;
	text-align: center;
	color: #fff;
	border-radius: 8px 8px 0 0;
	justify-content: center;
	align-items: center;
	min-height: 82px;
	padding: 16px 16px 18px;
	font-size: 16px;
	font-weight: 700;
	display: flex
}

.page-agent .case-card__box-body {
	background-color: #f4f4f5;
	border-radius: 0 0 8px 8px
}

.page-agent .case-card__box-text {
	letter-spacing: .04em;
	justify-content: center;
	align-items: baseline;
	font-weight: 700;
	display: flex
}

.page-agent .case-card__box-text span {
	margin: 0 4px
}

.page-agent .case-card__box.-before .case-card__box-body {
	padding: 20px 16px 32px
}

.page-agent .case-card__box.-before .case-card__box-title {
	background-color: #202733
}

.page-agent .case-card__box.-before .case-card__box-text {
	font-size: 20px
}

@media (width<=768px) {
	.page-agent .case-card__box.-before .case-card__box-text {
		font-size: 18px
	}
}

.page-agent .case-card__box.-before .case-card__box-text span {
	font-size: 32px
}

@media (width<=768px) {
	.page-agent .case-card__box.-before .case-card__box-text span {
		font-size: 28px
	}
}

.page-agent .case-card__box.-before:after {
	content: "";
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 13px;
	height: 22px;
	display: block;
	position: absolute;
	top: 79px;
	right: -17px
}

@media (width<=1060px) {
	.page-agent .case-card__box.-before:after {
		margin: 0 auto;
		inset: auto 0 -24px;
		transform: rotate(90deg)
	}

	.page-agent .case-card__box.-after {
		margin-top: 24px
	}
}

.page-agent .case-card__box.-after .case-card__box-body {
	padding: 24px 16px 40px
}

.page-agent .case-card__box.-after .case-card__box-title {
	background-color: #0553dd
}

.page-agent .case-card__box.-after .case-card__box-text {
	color: #0553dd;
	font-size: 24px
}

@media (width<=768px) {
	.page-agent .case-card__box.-after .case-card__box-text {
		font-size: 20px
	}
}

.page-agent .case-card__box.-after .case-card__box-text span {
	font-size: 40px
}

@media (width<=768px) {
	.page-agent .case-card__box.-after .case-card__box-text span {
		font-size: 32px
	}
}

.page-agent .case {
	padding: 80px 0 0;
	position: relative
}

@media (width<=768px) {
	.page-agent .case {
		padding: 60px 0 0
	}
}

.page-agent .case__container {
	max-width: 1184px
}

.page-agent .case__list {
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: 40px;
	display: flex
}

@media (width<=768px) {
	.page-agent .case__list {
		margin-top: 16px
	}
}

.page-agent .case__item {
	width: calc(50% - 6px);
	margin-top: 12px
}

@media (width<=768px) {
	.page-agent .case__item {
		width: 100%
	}
}

.page-agent .voice {
	padding: 92px 0
}

@media (width<=768px) {
	.page-agent .voice {
		padding: 60px 0
	}
}

.page-agent .voice__container {
	max-width: 1184px
}

.page-agent .voice__list {
	padding: 0 70px
}

@media (width<=1060px) {
	.page-agent .voice__list {
		padding: 0
	}
}

.page-agent .voice__item {
	margin-top: 52px;
	display: flex
}

@media (width<=768px) {
	.page-agent .voice__item {
		flex-wrap: wrap
	}
}

.page-agent .voice__profile {
	flex-shrink: 0;
	width: 140px;
	margin-right: 70px
}

@media (width<=1060px) {
	.page-agent .voice__profile {
		margin-right: 40px
	}
}

@media (width<=768px) {
	.page-agent .voice__profile {
		width: 100px;
		margin: 0 auto
	}
}

.page-agent .voice__profile-img {
	border-radius: 50%;
	width: 100%;
	padding-top: 100%;
	position: relative;
	overflow: hidden
}

.page-agent .voice__profile-img img {
	-o-object-fit: cover;
	object-fit: cover;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .voice__profile-text {
	color: #fff;
	text-align: center;
	letter-spacing: .02em;
	margin-top: 12px;
	font-size: 13px
}

.page-agent .voice__card {
	background-color: #fff;
	border-radius: 0 8px 8px;
	padding: 40px 35px 52px
}

@media (width<=768px) {
	.page-agent .voice__card {
		border-radius: 8px;
		margin-top: 24px;
		padding: 40px 20px
	}
}

.page-agent .voice__card-status {
	position: relative
}

.page-agent .voice__card-status:after {
	content: "";
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 22px;
	height: 13px;
	margin: 0 auto;
	display: block;
	position: absolute;
	top: 72px;
	left: 0;
	right: 0
}

@media (width<=768px) {
	.page-agent .voice__card-status:after {
		top: 86px
	}
}

.page-agent .voice__card-status-text {
	letter-spacing: .04em;
	color: #fff;
	border-radius: 4px;
	justify-content: center;
	align-items: center;
	padding: 16px;
	font-size: 16px;
	font-weight: 700;
	display: flex
}

@media (width<=768px) {
	.page-agent .voice__card-status-text {
		flex-direction: column;
		font-size: 15px
	}
}

.page-agent .voice__card-status-text span {
	letter-spacing: .04em;
	margin-left: 4px;
	font-size: 14px;
	font-weight: 400
}

@media (width<=768px) {
	.page-agent .voice__card-status-text span {
		margin-top: 3px;
		margin-left: 0;
		font-size: 13px
	}
}

.page-agent .voice__card-status-text.-before {
	background-color: #202733
}

.page-agent .voice__card-status-text.-after {
	background-color: #0553dd;
	margin-top: 45px
}

@media (width<=768px) {
	.page-agent .voice__card-status-text.-after {
		margin-top: 32px
	}
}

.page-agent .voice__card-text {
	letter-spacing: .02em;
	margin-top: 40px;
	font-size: 13px;
	line-height: 2
}

@media (width<=768px) {
	.page-agent .voice__card-text {
		margin-top: 32px
	}
}

.page-agent .contact-banner {
	margin: 80px 0 92px
}

@media (width<=768px) {
	.page-agent .contact-banner {
		margin: 60px 0
	}
}

.page-agent .contact-banner__container {
	max-width: 1184px
}

.page-agent .contact-banner__content {
	background-color: #0553dd;
	border-radius: 8px;
	padding: 40px;
	position: relative
}

@media (width<=768px) {
	.page-agent .contact-banner__content {
		padding: 40px 20px
	}
}

.page-agent .contact-banner__lines {
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-agent .contact-banner__left-line-wrap {
	width: 77%;
	position: absolute;
	top: -188%;
	left: -58%
}

@media (width<=768px) {
	.page-agent .contact-banner__left-line-wrap {
		top: -26%;
		left: -48%
	}
}

.page-agent .contact-banner__left-line {
	width: 100%;
	padding-top: 67%;
	position: relative
}

.page-agent .contact-banner__left-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .contact-banner__left-line svg .banner-1-left-line {
	fill: url(#banner-1-left-line-linear-gradient)
}

.page-agent .contact-banner__left-line svg .banner-1-left-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .contact-banner__left-line svg .banner-2-left-line {
	fill: url(#banner-2-left-line-linear-gradient)
}

.page-agent .contact-banner__left-line svg .banner-2-left-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .contact-banner__right-line-wrap {
	width: 75%;
	position: absolute;
	top: -200%;
	right: -18%
}

@media (width<=768px) {
	.page-agent .contact-banner__right-line-wrap {
		width: 70%;
		top: auto;
		bottom: -40%;
		right: -24%;
		transform: rotate(105deg)
	}
}

.page-agent .contact-banner__right-line {
	width: 100%;
	padding-top: 71%;
	position: relative
}

.page-agent .contact-banner__right-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .contact-banner__right-line svg .banner-1-line-right {
	fill: url(#banner-1-line-right-linear-gradient)
}

.page-agent .contact-banner__right-line svg .banner-1-line-right-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .contact-banner__right-line svg .banner-2-line-right {
	fill: url(#banner-2-line-right-linear-gradient)
}

.page-agent .contact-banner__right-line svg .banner-2-line-right-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .contact-banner__inner {
	justify-content: space-between;
	align-items: center;
	width: 100%;
	max-width: 840px;
	margin: 0 auto;
	display: flex
}

@media (width<=768px) {
	.page-agent .contact-banner__inner {
		flex-wrap: wrap;
		position: relative
	}
}

.page-agent .contact-banner__inner:before {
	content: "";
	background-color: #fff3;
	order: 1;
	width: 1px;
	height: 100px;
	display: block
}

@media (width<=768px) {
	.page-agent .contact-banner__inner:before {
		width: 100%;
		height: 1px
	}
}

.page-agent .contact-banner__text {
	flex-shrink: 0;
	padding: 0 30px 0 35px
}

@media (width<=768px) {
	.page-agent .contact-banner__text {
		text-align: center;
		width: 100%;
		padding-bottom: 24px
	}
}

.page-agent .contact-banner__text span {
	display: block
}

.page-agent .contact-banner__text span.en {
	letter-spacing: .04em;
	color: #ffffff80;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 15px;
	font-weight: 500
}

@media (width<=768px) {
	.page-agent .contact-banner__text span.en {
		font-size: 13px
	}
}

.page-agent .contact-banner__text span.jp {
	letter-spacing: .04em;
	color: #fff;
	margin-top: 12px;
	font-size: 20px;
	font-weight: 700
}

@media (width<=768px) {
	.page-agent .contact-banner__text span.jp {
		margin-top: 8px;
		font-size: 18px
	}
}

.page-agent .contact-banner__btn {
	flex-grow: 1;
	order: 2;
	max-width: 420px
}

@media (width<=1060px) {
	.page-agent .contact-banner__btn {
		margin-left: 40px
	}
}

@media (width<=768px) {
	.page-agent .contact-banner__btn {
		margin-top: 24px;
		margin-left: auto;
		margin-right: auto
	}
}

.page-agent .contact-banner__btn .btn {
	background-color: #fff;
	padding: 18px 18px 18px 32px
}

.page-agent .contact-banner__btn .btn span {
	color: #0553dd;
	font-weight: 700
}

@media (width<=768px) {
	.page-agent .contact-banner__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

@media (hover:hover) {
	.page-agent .contact-banner__btn .btn:hover {
		background-color: #0000;
		border-color: #c9d1db4d
	}

	.page-agent .contact-banner__btn .btn:hover span {
		color: #fff
	}

	.page-agent .contact-banner__btn .btn:hover span.arrow {
		background-color: #0553dd
	}

	.page-agent .contact-banner__btn .btn:hover span.arrow svg {
		fill: #fff
	}

	.page-agent .contact-banner__btn .btn:hover:after {
		background-color: #0553dd;
		transform: scale(24)
	}
}

.page-agent .advisor__wrap {
	padding: 0 20px
}

.page-agent .advisor__content {
	background-color: #fff;
	border-radius: 20px;
	padding: 80px 40px 92px
}

@media (width<=768px) {
	.page-agent .advisor__content {
		border-radius: 12px;
		padding: 60px 20px
	}
}

.page-agent .advisor__container {
	max-width: 1184px
}

@media (width<=768px) {
	.page-agent .advisor__container {
		padding: 0
	}
}

.page-agent .advisor__list {
	justify-content: space-between;
	margin-top: 48px;
	display: flex
}

@media (width<=1060px) {
	.page-agent .advisor__list {
		flex-wrap: wrap;
		margin-top: 24px
	}
}

@media (width<=768px) {
	.page-agent .advisor__list {
		margin-top: 16px
	}
}

.page-agent .advisor__item {
	border: 1px solid #c9d1db;
	border-radius: 8px;
	width: calc(25% - 9px);
	overflow: hidden
}

@media (width<=1060px) {
	.page-agent .advisor__item {
		width: calc(50% - 10px);
		margin-top: 20px
	}
}

@media (width<=768px) {
	.page-agent .advisor__item {
		width: 100%;
		margin-top: 16px
	}
}

.page-agent .advisor__thumb {
	border-bottom: 1px solid #c9d1db;
	width: 100%;
	padding-top: 75%;
	position: relative
}

.page-agent .advisor__thumb img {
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .advisor__item-content {
	background-color: #f4f4f5;
	padding: 24px 20px 30px
}

.page-agent .advisor__name {
	padding-bottom: 16px
}

.page-agent .advisor__name span {
	display: block
}

.page-agent .advisor__name span.en {
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.page-agent .advisor__name span.jp {
	letter-spacing: .04em;
	margin-top: 4px;
	font-size: 16px;
	font-weight: 700
}

.page-agent .advisor__about {
	border-top: 1px solid #c9d1db;
	padding-top: 16px
}

.page-agent .advisor__about ul li {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 1.86;
	display: flex
}

.page-agent .advisor__about ul li:before {
	content: "・"
}

.page-agent .advisor__about-head {
	letter-spacing: .02em;
	color: #0553dd;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.86
}

.page-agent .faq {
	padding: 80px 0 0
}

@media (width<=768px) {
	.page-agent .faq {
		padding: 60px 0 0
	}
}

.page-agent .faq__list {
	width: 100%;
	max-width: 840px;
	margin: 60px auto 0
}

@media (width<=768px) {
	.page-agent .faq__list {
		margin-top: 40px
	}
}

.page-agent .faq__item {
	cursor: pointer;
	margin-top: 8px
}

.page-agent .faq__question {
	letter-spacing: .04em;
	background-color: #fff;
	border-radius: 8px;
	padding: 28px 94px 28px 72px;
	font-size: 16px;
	font-weight: 700;
	position: relative
}

@media (width<=768px) {
	.page-agent .faq__question {
		padding: 16px 56px 16px 50px
	}
}

.page-agent .faq__question .question {
	letter-spacing: -.01em;
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 20px;
	font-weight: 700;
	position: absolute;
	top: 25px;
	left: 35px
}

@media (width<=768px) {
	.page-agent .faq__question .question {
		top: 14px;
		left: 20px
	}
}

.page-agent .faq__question:after {
	content: "";
	background-color: #0553dd;
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: 11px 7px;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	margin: auto 0;
	transition: all .3s;
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 35px
}

@media (width<=768px) {
	.page-agent .faq__question:after {
		right: 20px
	}
}

.page-agent .faq__answer {
	padding: 20px 0 32px 35px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.page-agent .faq__answer {
		padding: 20px 0 32px 20px
	}
}

.page-agent .faq__answer .answer {
	letter-spacing: -.01em;
	color: #dd052f;
	margin-right: 22px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 20px;
	font-weight: 700;
	display: block
}

@media (width<=768px) {
	.page-agent .faq__answer .answer {
		margin-right: 16px
	}
}

.page-agent .faq__answer .answer-text {
	letter-spacing: .04em;
	font-size: 13px;
	line-height: 2
}

.page-agent .faq__item.is-open .faq__question:after {
	transform: rotate(180deg)
}

.page-agent .download {
	padding: 92px 0 120px
}

@media (width<=768px) {
	.page-agent .download {
		padding: 60px 0
	}
}

.page-agent .download__container {
	max-width: 1184px
}

.page-agent .download__list {
	justify-content: space-between;
	margin-top: 48px;
	display: flex
}

@media (width<=768px) {
	.page-agent .download__list {
		flex-wrap: wrap;
		margin-top: 32px
	}
}

.page-agent .download__item {
	border-top: 1px solid #20273326;
	border-bottom: 1px solid #20273326;
	width: calc(50% - 20px)
}

@media (width<=768px) {
	.page-agent .download__item {
		width: 100%;
		margin-top: -1px
	}
}

.page-agent .download__link {
	justify-content: space-between;
	align-items: center;
	padding: 24px 12px 28px 20px;
	display: flex;
	position: relative;
	overflow: hidden
}

.page-agent .download__link:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

.page-agent .download__link:hover:after {
	transform: scale(30)
}

.page-agent .download__link:hover .download__icon {
	background-color: #0553dd
}

.page-agent .download__link-text {
	z-index: 1;
	position: relative
}

.page-agent .download__link-text span {
	display: block
}

.page-agent .download__link-text span.en {
	letter-spacing: .04em;
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.page-agent .download__link-text span.jp {
	letter-spacing: .04em;
	margin-top: 12px;
	font-size: 16px;
	font-weight: 700
}

.page-agent .download__icon {
	z-index: 1;
	background-color: #c9d1db;
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: 15px 15px;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	transition: all .3s;
	display: block;
	position: relative
}

.page-agent .download__contact {
	background-color: #0553dd;
	border-radius: 8px;
	margin-top: 60px;
	padding: 40px 0;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.page-agent .download__contact {
		flex-wrap: wrap;
		padding: 40px 20px
	}
}

.page-agent .download__contact:after {
	content: "";
	background-color: #fff3;
	width: 1px;
	height: 186px;
	margin: auto;
	display: block;
	position: absolute;
	inset: 0
}

@media (width<=768px) {
	.page-agent .download__contact:after {
		width: calc(100% - 40px);
		height: 1px
	}
}

.page-agent .download__lines {
	pointer-events: none;
	border-radius: 8px;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-agent .download__left-line-wrap {
	width: 76%;
	position: absolute;
	top: -102%;
	left: -48%
}

@media (width<=768px) {
	.page-agent .download__left-line-wrap {
		top: -15%;
		left: -40%
	}
}

.page-agent .download__left-line {
	width: 100%;
	padding-top: 62%;
	position: relative
}

.page-agent .download__left-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .download__left-line svg .download-left-line {
	fill: url(#download-left-line-linear-gradient)
}

.page-agent .download__left-line svg .download-left-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .download__right-line-wrap {
	width: 84%;
	position: absolute;
	top: 10%;
	right: -22%
}

@media (width<=768px) {
	.page-agent .download__right-line-wrap {
		top: auto;
		bottom: -24%;
		right: -20%;
		transform: rotate(-15deg)
	}
}

.page-agent .download__right-line {
	width: 100%;
	padding-top: 62%;
	position: relative
}

.page-agent .download__right-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-agent .download__right-line svg .download-right-line {
	fill: url(#download-right-line-linear-gradient)
}

.page-agent .download__right-line svg .download-right-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-agent .download__contact-col {
	width: 50%;
	padding: 16px 70px 20px
}

@media (width<=1060px) {
	.page-agent .download__contact-col {
		padding: 16px 24px 20px
	}
}

@media (width<=768px) {
	.page-agent .download__contact-col {
		width: 100%;
		padding: 0
	}

	.page-agent .download__contact-col:first-child {
		padding-bottom: 32px
	}

	.page-agent .download__contact-col:last-child {
		padding-top: 32px
	}

	.page-agent .download__contact-col-head {
		text-align: center
	}
}

.page-agent .download__contact-col-head span {
	display: block
}

.page-agent .download__contact-col-head span.en {
	color: #ffffff80;
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 15px;
	font-weight: 500
}

@media (width<=768px) {
	.page-agent .download__contact-col-head span.en {
		font-size: 13px
	}
}

.page-agent .download__contact-col-head span.jp {
	letter-spacing: .04em;
	color: #fff;
	margin-top: 12px;
	font-size: 20px;
	font-weight: 700
}

@media (width<=768px) {
	.page-agent .download__contact-col-head span.jp {
		margin-top: 8px;
		font-size: 18px
	}
}

.page-agent .download__contact-btn {
	width: 100%;
	height: 60px;
	margin-top: 32px
}

@media (width<=768px) {
	.page-agent .download__contact-btn {
		height: 48px
	}
}

.page-agent .download__contact-btn .btn {
	background-color: #fff;
	border: 1px solid #0000;
	padding: 18px 18px 18px 32px
}

@media (width<=768px) {
	.page-agent .download__contact-btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-agent .download__contact-btn .btn span {
	color: #0553dd;
	font-weight: 700
}

.page-agent .download__contact-btn .btn span.arrow {
	background-color: #0553dd
}

.page-agent .download__contact-btn .btn span.arrow svg {
	fill: #fff
}

@media (hover:hover) {
	.page-agent .download__contact-btn .btn:hover {
		background-color: #0000;
		border-color: #c9d1db4d
	}

	.page-agent .download__contact-btn .btn:hover span {
		color: #fff
	}

	.page-agent .download__contact-btn .btn:hover span.arrow {
		background-color: #0553dd
	}

	.page-agent .download__contact-btn .btn:hover span.arrow svg {
		fill: #fff
	}

	.page-agent .download__contact-btn .btn:hover:after {
		background-color: #0553dd;
		transform: scale(20)
	}
}

.page-agent .download__cm-btn {
	width: 420px;
	height: 60px;
	margin: 60px auto 0
}

@media (width<=768px) {
	.page-agent .download__cm-btn {
		width: 100%;
		height: 48px;
		margin-top: 40px
	}
}

.page-agent .download__cm-btn .btn {
	padding: 18px 18px 18px 32px
}

@media (width<=768px) {
	.page-agent .download__cm-btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-agent .download__cm-btn .btn span {
	font-weight: 700
}

@media (hover:hover) {
	.page-agent .download__cm-btn .btn:hover:after {
		transform: scale(25)
	}
}

.page-service .service-card__head {
	justify-content: space-between;
	display: flex
}

.page-service .service-card__cat {
	color: #0553dd;
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.page-service .service-card__num {
	background-color: #c9d1db;
	border-radius: 50px;
	align-items: center;
	padding: 2px 10px;
	display: flex
}

.page-service .service-card__num span {
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px
}

.page-service .service-card__num span.hyphen {
	margin: 0 4px
}

.page-service .service-card__thumb {
	background-color: #f4f4f5;
	border: 1px solid #c9d1db;
	border-radius: 8px;
	width: 100%;
	margin-top: 32px;
	overflow: hidden
}

@media (width<=768px) {
	.page-service .service-card__thumb {
		margin-top: 24px
	}
}

.page-service .service-card__content {
	margin-top: 28px;
	padding: 0 12px
}

@media (width<=768px) {
	.page-service .service-card__content {
		padding: 0
	}
}

.page-service .service-card__title {
	letter-spacing: .03em;
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 12px;
	font-size: 16px;
	font-weight: 700
}

.page-service .service-card__text {
	margin-top: 20px
}

.page-service .service-card__text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 1.85
}

.page-service .service-card__view-more {
	cursor: pointer;
	margin-top: 28px
}

.page-service .service-card__view-more span.arrow svg:first-child {
	transform: translate(-100px)
}

@media (hover:hover) {
	.page-service .service-card__view-more:hover span.arrow svg {
		transform: translate(100px)
	}

	.page-service .service-card__view-more:hover span.arrow svg:first-child {
		transform: translate(0)
	}
}

.page-service .agent {
	padding: 80px 0 0
}

@media (width<=768px) {
	.page-service .agent {
		padding: 60px 0 0
	}
}

.page-service .agent__wrap {
	padding: 0 20px
}

.page-service .agent__content {
	background-color: #fff;
	border-radius: 20px;
	padding: 120px 0;
	position: relative
}

@media (width<=768px) {
	.page-service .agent__content {
		border-radius: 12px;
		padding: 60px 0
	}
}

.page-service .agent__container {
	max-width: 1184px
}

.page-service .agent__title {
	letter-spacing: .02em;
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 40px;
	font-size: 13px;
	font-weight: 700
}

@media (width<=768px) {
	.page-service .agent__title {
		padding-bottom: 16px
	}
}

.page-service .agent__content-inner {
	padding: 60px 70px 0
}

@media (width<=1060px) {
	.page-service .agent__content-inner {
		padding: 60px 0 0
	}
}

@media (width<=768px) {
	.page-service .agent__content-inner {
		padding-top: 32px
	}
}

.page-service .agent__content-inner+.agent__content-inner {
	margin-top: 60px
}

.page-service .agent__cols {
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: center;
	display: flex
}

@media (width<=768px) {
	.page-service .agent__cols {
		flex-direction: column
	}
}

.page-service .agent__img-col {
	background-color: #f4f4f5;
	border: 1px solid #c9d1db;
	border-radius: 8px;
	flex-grow: 1;
	flex-shrink: 0;
	max-width: 58.5%;
	overflow: hidden
}

@media (width<=1060px) {
	.page-service .agent__img-col {
		max-width: 50%
	}
}

@media (width<=768px) {
	.page-service .agent__img-col {
		max-width: 100%
	}
}

.page-service .agent__text-col {
	margin-right: 70px
}

@media (width<=1060px) {
	.page-service .agent__text-col {
		margin-right: 40px
	}
}

@media (width<=768px) {
	.page-service .agent__text-col {
		margin-top: 24px;
		margin-right: 0
	}
}

.page-service .agent__sub-title {
	letter-spacing: .04em;
	font-size: 20px;
	font-weight: 700
}

.page-service .agent__text {
	letter-spacing: .02em;
	margin-top: 32px;
	font-size: 13px;
	line-height: 2
}

@media (width<=768px) {
	.page-service .agent__text {
		margin-top: 16px
	}
}

.page-service .agent__btn {
	width: 232px;
	height: 56px;
	margin-top: 52px
}

@media (width<=768px) {
	.page-service .agent__btn {
		width: 210px;
		height: 48px;
		margin-top: 32px
	}
}

.page-service .agent__btn .btn {
	padding: 16px 16px 16px 32px
}

.page-service .agent__btn .btn span {
	font-weight: 500
}

@media (width<=768px) {
	.page-service .agent__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-service .agent__list {
	margin-top: 52px
}

.page-service .agent__item {
	background-color: #f4f4f5;
	border-radius: 8px;
	padding: 40px 70px;
	display: flex
}

@media (width<=768px) {
	.page-service .agent__item {
		flex-wrap: wrap;
		padding: 20px
	}
}

.page-service .agent__item:not(:first-child) {
	margin-top: 12px
}

.page-service .agent__item-title {
	border-right: 1px solid #c9d1db;
	flex-shrink: 0;
	width: 210px;
	min-height: 65px;
	margin-right: 35px
}

@media (width<=768px) {
	.page-service .agent__item-title {
		border-bottom: 1px solid #c9d1db;
		border-right: 0;
		width: 100%;
		min-height: 0;
		margin-right: 0;
		padding-bottom: 12px
	}
}

.page-service .agent__item-title p {
	letter-spacing: .04em;
	align-items: center;
	margin-top: 8px;
	font-size: 16px;
	font-weight: 700;
	display: flex;
	position: relative
}

.page-service .agent__item-title p:before {
	content: "";
	background-color: #0553dd;
	border-radius: 50%;
	width: 8px;
	height: 8px;
	margin-right: 10px;
	display: block
}

@media (width<=768px) {
	.page-service .agent__item-content {
		margin-top: 16px
	}
}

.page-service .agent__item-content p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 2
}

.page-service .media {
	background-color: #fff;
	padding: 120px 0
}

@media (width<=768px) {
	.page-service .media {
		padding: 60px 0
	}
}

.page-service .media__container {
	max-width: 1184px
}

.page-service .media__title {
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

@media (width<=768px) {
	.page-service .media__title {
		padding-bottom: 24px
	}
}

.page-service .media__list {
	display: flex
}

@media (width<=768px) {
	.page-service .media__list {
		flex-wrap: wrap
	}
}

.page-service .media__item {
	background-color: #f4f4f5;
	border-radius: 8px;
	width: 495px;
	height: 610px;
	margin-right: 12px;
	padding: 22px 35px 52px
}

@media (width<=768px) {
	.page-service .media__item {
		width: 100%;
		height: auto;
		margin-top: 24px;
		margin-right: 0;
		padding: 30px 20px
	}
}

.page-service .media__item:first-child {
	margin-left: 80px
}

@media (width<=768px) {
	.page-service .media__item:first-child {
		margin-left: 0
	}
}

.page-service .media__item:last-child {
	margin-right: 80px
}

@media (width<=768px) {
	.page-service .media__item:last-child {
		margin-right: 0
	}
}

.page-service .media__item .service-card__thumb {
	background-color: #fff
}

.page-service .coaching {
	padding: 120px 0
}

@media (width<=768px) {
	.page-service .coaching {
		padding: 60px 0
	}
}

.page-service .coaching__container {
	max-width: 1184px
}

.page-service .coaching__title {
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

@media (width<=768px) {
	.page-service .coaching__title {
		padding-bottom: 24px
	}
}

.page-service .coaching__list {
	display: flex
}

@media (width<=768px) {
	.page-service .coaching__list {
		flex-wrap: wrap
	}
}

.page-service .coaching__item {
	background-color: #fff;
	border-radius: 8px;
	width: 495px;
	height: 610px;
	margin-right: 12px;
	padding: 22px 35px 52px
}

@media (width<=768px) {
	.page-service .coaching__item {
		width: 100%;
		height: auto;
		margin-top: 24px;
		margin-right: 0;
		padding: 30px 20px
	}
}

.page-service .coaching__item:first-child {
	margin-left: 80px
}

@media (width<=768px) {
	.page-service .coaching__item:first-child {
		margin-left: 0
	}
}

.page-service .coaching__item:last-child {
	margin-right: 80px
}

@media (width<=768px) {
	.page-service .coaching__item:last-child {
		margin-right: 0
	}
}

.page-service .new {
	padding: 120px 0
}

@media (width<=768px) {
	.page-service .new {
		padding: 60px 0
	}
}

.page-service .new__container {
	max-width: 1184px
}

.page-service .new__title {
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

@media (width<=768px) {
	.page-service .new__title {
		padding-bottom: 24px
	}
}

.page-service .new__list {
	display: flex
}

@media (width<=768px) {
	.page-service .new__list {
		flex-wrap: wrap
	}
}

.page-service .new__item {
	background-color: #fff;
	border-radius: 8px;
	width: 495px;
	height: 610px;
	margin-right: 12px;
	padding: 22px 35px 52px
}

@media (width<=768px) {
	.page-service .new__item {
		width: 100%;
		height: auto;
		margin-top: 24px;
		margin-right: 0;
		padding: 30px 20px
	}
}

.page-service .new__item:first-child {
	margin-left: 80px
}

@media (width<=768px) {
	.page-service .new__item:first-child {
		margin-left: 0
	}
}

.page-service .new__item:last-child {
	margin-right: 80px
}

@media (width<=768px) {
	.page-service .new__item:last-child {
		margin-right: 0
	}
}

.page-business .concept {
	padding: 80px 20px 0
}

.page-business .concept__content {
	background-color: #0553dd;
	border-radius: 20px;
	padding: 120px 0 100px;
	position: relative
}

@media (width<=768px) {
	.page-business .concept__content {
		border-radius: 12px;
		padding: 80px 0
	}
}

.page-business .concept__lines {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-business .concept__top-line-wrap {
	width: 54%;
	position: absolute;
	top: -40%;
	right: 16%
}

@media (width<=1060px) {
	.page-business .concept__top-line-wrap {
		top: -15%
	}
}

.page-business .concept__top-line {
	width: 100%;
	padding-top: 68.4%;
	position: relative
}

.page-business .concept__top-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-business .concept__top-line svg .line-concept-top {
	fill: url(#line-concept-top-linear-gradient);
	isolation: isolate;
	opacity: .13
}

.page-business .concept__top-line svg .line-concept-top-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-business .concept__bottom-line-wrap {
	width: 54%;
	position: absolute;
	bottom: -14%;
	right: -6%
}

.page-business .concept__bottom-line {
	width: 100%;
	padding-top: 66.8%;
	position: relative
}

.page-business .concept__bottom-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-business .concept__bottom-line svg .line-concept-bottom {
	fill: url(#line-concept-bottom-linear-gradient);
	isolation: isolate;
	opacity: .13
}

.page-business .concept__bottom-line svg .line-concept-bottom-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-business .concept__container {
	max-width: 1184px
}

.page-business .concept__cols {
	display: flex
}

@media (width<=1060px) {
	.page-business .concept__cols {
		flex-wrap: wrap;
		max-width: 75%;
		margin: 0 auto
	}
}

@media (width<=768px) {
	.page-business .concept__cols {
		max-width: 600px
	}
}

.page-business .concept__text-col {
	color: #fff;
	flex-grow: 1;
	max-width: 460px;
	padding-left: 36px
}

@media (width<=1060px) {
	.page-business .concept__text-col {
		max-width: 100%;
		padding-left: 0
	}
}

.page-business .concept__title {
	color: #fff;
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

@media (width<=1060px) {
	.page-business .concept__title {
		max-width: 75%;
		margin: 0 auto
	}
}

@media (width<=768px) {
	.page-business .concept__title {
		max-width: 600px
	}
}

.page-business .concept__sub-title {
	letter-spacing: .06em;
	margin-top: 72px;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.75
}

@media (width<=768px) {
	.page-business .concept__sub-title {
		margin-top: 32px;
		font-size: 20px
	}
}

.page-business .concept__text {
	margin-top: 40px
}

@media (width<=768px) {
	.page-business .concept__text {
		margin-top: 32px
	}
}

.page-business .concept__text p {
	letter-spacing: .04em;
	font-size: 13px;
	line-height: 2
}

.page-business .concept__btn {
	width: 232px;
	height: 56px;
	margin-top: 50px
}

@media (width<=768px) {
	.page-business .concept__btn {
		width: 210px;
		height: 48px;
		margin-top: 32px
	}
}

.page-business .concept__btn .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.page-business .concept__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-business .concept__btn .btn span {
	font-weight: 500
}

.page-business .concept__img-col {
	flex-grow: 1;
	flex-shrink: 1;
	margin-top: 58px;
	margin-left: 64px
}

@media (width<=1060px) {
	.page-business .concept__img-col {
		margin-left: 0
	}
}

@media (width<=768px) {
	.page-business .concept__img-col {
		margin-top: 40px
	}
}

.page-business .strategy {
	background-color: #fff;
	padding: 120px 0
}

@media (width<=768px) {
	.page-business .strategy {
		padding: 80px 0
	}
}

.page-business .strategy__container {
	max-width: 1184px
}

.page-business .strategy__head {
	border-bottom: 1px solid #c9d1db;
	justify-content: space-between;
	padding-bottom: 60px;
	display: flex
}

@media (width<=1060px) {
	.page-business .strategy__head {
		flex-wrap: wrap
	}
}

.page-business .strategy__title {
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

.page-business .strategy__text {
	letter-spacing: .04em;
	max-width: 420px;
	margin: 0 32px;
	font-size: 13px;
	line-height: 2
}

@media (width<=768px) {
	.page-business .strategy__text {
		max-width: 100%;
		margin: 24px 0 0
	}
}

.page-business .strategy__btn {
	width: 232px;
	height: 56px;
	margin-top: auto
}

@media (width<=1060px) {
	.page-business .strategy__btn {
		margin-top: 40px;
		margin-left: auto
	}
}

@media (width<=768px) {
	.page-business .strategy__btn {
		width: 210px;
		height: 48px;
		margin-left: 0
	}
}

.page-business .strategy__btn .btn {
	padding: 16px 16px 16px 32px
}

.page-business .strategy__btn .btn span {
	font-weight: 500
}

@media (width<=768px) {
	.page-business .strategy__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-business .strategy__content {
	padding-top: 60px
}

.page-business .goal__container {
	max-width: 1184px
}

.page-business .goal__content {
	border-bottom: 1px solid #c9d1db;
	align-items: center;
	padding: 120px 0;
	display: flex
}

@media (width<=1060px) {
	.page-business .goal__content {
		flex-wrap: wrap
	}
}

@media (width<=768px) {
	.page-business .goal__content {
		padding: 80px 0
	}
}

.page-business .goal__text-col {
	flex-grow: 1;
	flex-shrink: 0;
	max-width: 350px;
	margin-right: 105px
}

@media (width<=1060px) {
	.page-business .goal__text-col {
		max-width: 75%;
		margin: 0 auto
	}
}

@media (width<=768px) {
	.page-business .goal__text-col {
		width: 100%;
		max-width: 600px
	}
}

.page-business .goal__title {
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

.page-business .goal__text {
	border-top: 1px solid #c9d1db;
	margin-top: 40px;
	padding-top: 40px
}

@media (width<=768px) {
	.page-business .goal__text {
		margin-top: 24px;
		padding-top: 24px
	}
}

.page-business .goal__text p {
	letter-spacing: .04em;
	font-size: 13px;
	line-height: 2
}

.page-business .goal__img-col {
	background-color: #f4f4f5;
	border: 1px solid #c9d1db;
	border-radius: 8px;
	padding: 56px 32px 48px
}

@media (width<=1060px) {
	.page-business .goal__img-col {
		max-width: 75%;
		margin: 56px auto 0
	}
}

@media (width<=768px) {
	.page-business .goal__img-col {
		max-width: 100%;
		margin-top: 40px;
		padding: 12px
	}
}

.page-business .field {
	padding: 120px 0
}

@media (width<=768px) {
	.page-business .field {
		padding: 80px 0
	}
}

.page-business .field__container {
	max-width: 1044px
}

@media (width<=1060px) {
	.page-business .field__container {
		max-width: 75%
	}
}

@media (width<=768px) {
	.page-business .field__container {
		max-width: 600px
	}
}

.page-business .field__head {
	justify-content: space-between;
	display: flex
}

@media (width<=1060px) {
	.page-business .field__head {
		flex-wrap: wrap
	}
}

.page-business .field__title {
	letter-spacing: .02em;
	margin-right: 40px;
	font-size: 13px;
	font-weight: 700
}

.page-business .field__text {
	max-width: 700px
}

@media (width<=1060px) {
	.page-business .field__text {
		margin-top: 40px
	}
}

@media (width<=768px) {
	.page-business .field__text {
		margin-top: 24px
	}
}

.page-business .field__text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 2
}

.page-business .field__diagram {
	margin-top: 80px
}

@media (width<=768px) {
	.page-business .field__diagram {
		margin-top: 40px
	}
}

.page-business .bg-white {
	background-color: #f4f4f5;
	position: relative
}

.page-business .bg-white__lines {
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

.page-business .bg-white__right-line-wrap {
	width: 32%;
	position: absolute;
	top: 13%;
	right: -15.5%
}

.page-business .bg-white__right-line {
	width: 100%;
	padding-top: 181%;
	position: relative
}

.page-business .bg-white__right-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-business .bg-white__right-line svg .sub-line-right {
	fill: url(#sub-line-right-vt-linear-gradient)
}

.page-business .bg-white__right-line svg .sub-line-right-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-business .bg-white__bottom-line-wrap {
	width: 44%;
	position: absolute;
	bottom: -5%;
	left: -26%
}

@media (width<=1060px) {
	.page-business .bg-white__bottom-line-wrap {
		bottom: 0
	}
}

@media (width<=768px) {
	.page-business .bg-white__bottom-line-wrap {
		bottom: -1%
	}
}

.page-business .bg-white__bottom-line {
	width: 100%;
	padding-top: 120%;
	position: relative
}

.page-business .bg-white__bottom-line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-business .bg-white__bottom-line svg .sub-line-bottom {
	fill: url(#sub-line-bottom-hr-linear-gradient)
}

.page-business .bg-white__bottom-line svg .sub-line-bottom-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 180px
}

.page-career .bg-dark {
	background-color: #202733;
	position: relative
}

.page-career .mindset-card {
	opacity: 0;
	border-radius: 8px;
	padding: 30px 40px 0;
	transition: all 1s cubic-bezier(.165,.84,.44,1) .2s;
	position: relative;
	overflow: hidden;
	transform: translateY(30px)
}

.page-career .mindset-card.inview-is-visible {
	opacity: 1;
	transform: translateY(0)
}

.page-career .mindset-card:before {
	content: "";
	background-color: #fff;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-career .mindset-card__num {
	color: #202733b3;
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500;
	position: relative
}

.page-career .mindset-card__title {
	border-bottom: 1px solid #fff3;
	margin-top: 24px;
	padding-bottom: 32px;
	position: relative
}

@media (width<=768px) {
	.page-career .mindset-card__title {
		margin-top: 20px;
		padding-bottom: 20px
	}
}

.page-career .mindset-card__title span.en {
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 40px;
	font-weight: 200;
	line-height: 1.1;
	display: block
}

@media (width<=768px) {
	.page-career .mindset-card__title span.en {
		font-size: 32px
	}
}

.page-career .mindset-card__title span.jp {
	letter-spacing: .04em;
	margin-top: 8px;
	padding-left: 18px;
	font-size: 16px;
	display: block;
	position: relative
}

@media (width<=768px) {
	.page-career .mindset-card__title span.jp {
		margin-top: 4px;
		padding-left: 16px;
		font-size: 13px
	}
}

.page-career .mindset-card__title span.jp:before {
	content: "";
	background-color: #0553dd;
	border-radius: 50%;
	width: 8px;
	height: 8px;
	display: block;
	position: absolute;
	top: 9px;
	left: 0
}

.page-career .mindset-card__line-wrap {
	position: absolute;
	bottom: 0;
	right: 0
}

.page-career .mindset-card__line {
	width: 100%;
	padding-top: 93.3%;
	position: relative
}

.page-career .mindset-card__line svg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-career .mindset-card__lines.-first .mindset-card__line-wrap {
	width: 85%;
	bottom: -4%
}

@media (width<=768px) {
	.page-career .mindset-card__lines.-first .mindset-card__line-wrap {
		width: 77%
	}
}

.page-career .mindset-card__lines.-first .mindset-card__line svg .mindset-1-line-right {
	fill: #0553dd
}

.page-career .mindset-card__lines.-first .mindset-card__line svg .mindset-1-line-left {
	fill: #2e87fa
}

.page-career .mindset-card__lines.-first .mindset-card__line svg .mindset-1-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 80px
}

.page-career .mindset-card__lines.-second .mindset-card__line-wrap {
	width: 100%;
	bottom: -15%;
	left: -10%;
	right: auto
}

.page-career .mindset-card__lines.-second .mindset-card__line {
	width: 130%
}

@media (width<=768px) {
	.page-career .mindset-card__lines.-second .mindset-card__line {
		width: 124%
	}
}

.page-career .mindset-card__lines.-second .mindset-card__line svg .mindset-2-line-top {
	fill: #0553dd
}

.page-career .mindset-card__lines.-second .mindset-card__line svg .mindset-2-line-bottom {
	fill: #2e87fa
}

.page-career .mindset-card__lines.-second .mindset-card__line svg .mindset-2-line-mask {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10;
	stroke-width: 80px
}

.page-career .mindset-card__lines.-third .mindset-card__line-wrap {
	width: 80%;
	bottom: -5%;
	left: 10%;
	right: auto
}

.page-career .mindset-card__lines.-third .mindset-card__line {
	width: 100%
}

.page-career .mindset-card__lines.-third .mindset-card__line svg .mindset-3-line-darker {
	fill: #0553dd
}

.page-career .mindset-card__lines.-third .mindset-card__line svg .mindset-3-line-lighter {
	fill: #2e87fa
}

.page-career .mindset-card__lines.-third .mindset-card__line svg .mindset-3-line-middle {
	stroke-width: 45px
}

.page-career .mindset-card__lines.-third .mindset-card__line svg .mindset-3-line-middle,.page-career .mindset-card__lines.-third .mindset-card__line svg .mindset-3-line-bottom,.page-career .mindset-card__lines.-third .mindset-card__line svg .mindset-3-line-top {
	fill: none;
	stroke: #fff;
	stroke-miterlimit: 10
}

.page-career .mindset-card__lines.-third .mindset-card__line svg .mindset-3-line-bottom {
	stroke-width: 35px
}

.page-career .mindset-card__lines.-third .mindset-card__line svg .mindset-3-line-top {
	stroke-width: 61px
}

.page-career .mindset-card__lines.-fourth .mindset-card__line-wrap {
	width: 90%;
	bottom: -11%;
	left: 18%;
	right: auto
}

@media (width<=768px) {
	.page-career .mindset-card__lines.-fourth .mindset-card__line-wrap {
		bottom: -13%
	}
}

.page-career .mindset-card__lines.-fourth .mindset-card__line {
	width: 100%
}

.page-career .mindset-card__lines.-fifth .mindset-card__line-wrap {
	width: 142%;
	bottom: -47%;
	right: -56%
}

@media (width<=768px) {
	.page-career .mindset-card__lines.-fifth .mindset-card__line-wrap {
		width: 122%;
		bottom: -52%;
		right: -46%
	}
}

.page-career .mv {
	width: 100%;
	padding: 218px 0 0;
	position: relative
}

@media (width<=768px) {
	.page-career .mv {
		padding: 152px 0 0
	}
}

.page-career .mv__bg-text {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 144px;
	left: 0;
	overflow: hidden
}

@media (width<=768px) {
	.page-career .mv__bg-text {
		height: 156px;
		top: 166px
	}
}

.page-career .mv__bg-text-wrap {
	gap: 30px;
	display: flex;
	position: absolute;
	top: 50%;
	transform: translateY(-50%)
}

.page-career .mv__bg-text-wrap p {
	letter-spacing: -.04em;
	white-space: nowrap;
	color: #ffffff0d;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 280px;
	font-weight: 100
}

@media (width<=1060px) {
	.page-career .mv__bg-text-wrap p {
		font-size: 200px
	}
}

@media (width<=768px) {
	.page-career .mv__bg-text-wrap p {
		font-size: 120px
	}
}

.page-career .mv__content {
	width: 100%;
	padding: 0 40px;
	position: relative
}

@media (width<=768px) {
	.page-career .mv__content {
		padding: 0
	}
}

.page-career .mv__inner {
	justify-content: space-between;
	align-items: flex-start;
	width: 100%;
	max-width: 1264px;
	height: 100%;
	margin: 0 auto;
	padding: 0 32px;
	display: flex;
	position: relative
}

@media (width<=1060px) {
	.page-career .mv__inner {
		padding: 0
	}
}

@media (width<=768px) {
	.page-career .mv__inner {
		flex-wrap: wrap;
		padding: 0 20px
	}
}

.page-career .mv__title {
	align-items: baseline;
	display: flex
}

@media (width<=1060px) {
	.page-career .mv__title {
		flex-direction: column
	}
}

@media (width<=768px) {
	.page-career .mv__title {
		flex-wrap: wrap
	}
}

.page-career .mv__title span {
	color: #fff
}

@media (width<=768px) {
	.page-career .mv__title span {
		width: 100%;
		display: block
	}
}

.page-career .mv__title span.en {
	margin-right: 20px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 80px;
	font-weight: 200
}

@media (width<=768px) {
	.page-career .mv__title span.en {
		font-size: 52px
	}
}

.page-career .mv__title span.jp {
	letter-spacing: .04em;
	align-items: center;
	margin-top: 4px;
	font-size: 14px;
	font-weight: 500;
	display: flex
}

@media (width<=768px) {
	.page-career .mv__title span.jp {
		font-size: 13px
	}
}

.page-career .mv__title span.jp:before {
	content: "";
	background-image: url(icon-title-acc-white.67bcf942.png);
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: contain;
	width: 20px;
	height: 13px;
	margin-right: 8px
}

@media (width<=768px) {
	.page-career .mv__title span.jp:before {
		margin-right: 6px
	}
}

.page-career .mv__page-nav {
	z-index: 1;
	position: absolute;
	top: 0;
	right: 0
}

@media (width<=768px) {
	.page-career .mv__page-nav {
		margin-top: 60px;
		position: static
	}
}

.page-career .message {
	padding-top: 100px;
	padding-bottom: 160px
}

@media (width<=768px) {
	.page-career .message {
		padding: 60px 0
	}
}

.page-career .message__container {
	max-width: 904px;
	padding-right: 300px
}

@media (width<=1060px) {
	.page-career .message__container {
		padding-right: 360px
	}
}

@media (width<=768px) {
	.page-career .message__container {
		padding-right: 20px
	}
}

.page-career .message__title {
	letter-spacing: .02em;
	color: #fff;
	font-size: 13px;
	font-weight: 700
}

.page-career .message__sub-title {
	letter-spacing: .06em;
	color: #fff;
	margin-top: 60px;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.75
}

@media (width<=768px) {
	.page-career .message__sub-title {
		letter-spacing: .04em;
		margin-top: 32px;
		font-size: 18px
	}
}

.page-career .message__text {
	margin-top: 40px
}

.page-career .message__text p {
	letter-spacing: .06em;
	color: #fff;
	font-size: 14px;
	line-height: 2.57
}

@media (width<=768px) {
	.page-career .message__text p {
		font-size: 13px;
		line-height: 2.1
	}
}

.page-career .message__btn {
	width: 232px;
	height: 56px;
	margin-top: 52px
}

@media (width<=768px) {
	.page-career .message__btn {
		width: 210px;
		height: 48px;
		margin-top: 32px
	}
}

.page-career .message__btn .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.page-career .message__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-career .design__wrap {
	padding: 0 20px
}

.page-career .design__content {
	background-color: #fff;
	border-radius: 20px;
	padding: 120px 0
}

@media (width<=768px) {
	.page-career .design__content {
		border-radius: 12px;
		padding: 60px 0
	}
}

.page-career .design__container {
	max-width: 1184px
}

.page-career .design__head {
	border-bottom: 1px solid #c9d1db;
	justify-content: space-between;
	padding: 0 70px 52px;
	display: flex
}

@media (width<=768px) {
	.page-career .design__head {
		flex-wrap: wrap;
		padding: 0 0 32px
	}
}

.page-career .design__title {
	letter-spacing: .02em;
	margin-right: 40px;
	font-size: 13px;
	font-weight: 700
}

@media (width<=768px) {
	.page-career .design__title {
		width: 100%;
		margin-right: 0
	}
}

.page-career .design__text {
	max-width: 560px
}

@media (width<=768px) {
	.page-career .design__text {
		margin-top: 32px
	}
}

.page-career .design__text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 2
}

.page-career .design__body {
	align-items: center;
	padding-top: 60px;
	display: flex
}

@media (width<=768px) {
	.page-career .design__body {
		flex-wrap: wrap;
		padding-top: 32px
	}
}

.page-career .design__diagram {
	width: 50%;
	padding: 0 70px
}

@media (width<=1060px) {
	.page-career .design__diagram {
		padding: 0 35px
	}
}

@media (width<=768px) {
	.page-career .design__diagram {
		width: 100%;
		max-width: 500px;
		margin: 40px auto 0;
		padding: 0
	}
}

.page-career .design__diagram:last-child {
	padding: 0 70px 0 0
}

@media (width<=1060px) {
	.page-career .design__diagram:last-child {
		padding: 0 35px 0 0
	}
}

@media (width<=768px) {
	.page-career .design__diagram:last-child {
		max-width: 600px;
		padding: 0
	}
}

.page-career .design__list {
	width: 50%;
	padding-right: 70px
}

@media (width<=768px) {
	.page-career .design__list {
		width: 100%;
		margin-top: 20px;
		padding-right: 0
	}
}

.page-career .design__item {
	justify-content: space-between;
	max-width: 490px;
	display: flex
}

@media (width<=768px) {
	.page-career .design__item {
		max-width: 100%
	}
}

.page-career .design__item-main {
	background-color: #f4f4f5;
	border: 1px solid #c9d1db;
	border-radius: 4px;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 55%;
	padding: 15px 0;
	display: flex
}

@media (width<=768px) {
	.page-career .design__item-main {
		padding: 11px 0
	}
}

.page-career .design__item-main span {
	display: block
}

.page-career .design__item-main span.year {
	letter-spacing: .04em;
	color: #0553dd;
	font-size: 12px;
	font-weight: 700
}

@media (width<=768px) {
	.page-career .design__item-main span.year {
		font-size: 10px
	}
}

.page-career .design__item-main span.goal {
	letter-spacing: .04em;
	margin-top: 4px;
	font-size: 16px;
	font-weight: 700
}

@media (width<=768px) {
	.page-career .design__item-main span.goal {
		margin-top: 0;
		font-size: 13px
	}
}

.page-career .design__item-sub {
	text-align: center;
	background-color: #0553dd;
	border-radius: 4px;
	justify-content: center;
	align-items: center;
	width: calc(45% - 8px);
	padding: 15px 0;
	display: flex
}

.page-career .design__item-sub p {
	color: #fff;
	letter-spacing: .04em;
	font-size: 13px;
	font-weight: 700
}

@media (width<=768px) {
	.page-career .design__item-sub p {
		font-size: 10px
	}
}

.page-career .design__item-arrow {
	justify-content: center;
	width: 55%;
	margin: 16px 0;
	display: flex
}

@media (width<=768px) {
	.page-career .design__item-arrow {
		margin: 10px 0
	}
}

.page-career .design__item-arrow img {
	width: 24px
}

@media (width<=768px) {
	.page-career .design__item-arrow img {
		width: 15px
	}
}

.page-career .mindset {
	padding: 140px 0 120px
}

@media (width<=768px) {
	.page-career .mindset {
		padding: 60px 0
	}
}

.page-career .mindset__container {
	max-width: 1184px
}

@media (width<=768px) {
	.page-career .mindset__container {
		max-width: 600px
	}
}

.page-career .mindset__title {
	letter-spacing: .02em;
	color: #fff;
	font-size: 13px;
	font-weight: 700
}

.page-career .mindset__list {
	display: flex
}

@media (width<=768px) {
	.page-career .mindset__list {
		flex-wrap: wrap;
		max-width: 600px;
		margin: 32px auto 0
	}
}

.page-career .mindset__item {
	width: 400px;
	height: 560px;
	margin-right: 12px
}

@media (width<=768px) {
	.page-career .mindset__item {
		width: 100%;
		height: auto;
		margin-top: 8px;
		margin-right: 0;
		padding: 16px 20px 62vw
	}
}

.page-career .mindset__item:first-child {
	margin-left: 80px
}

@media (width<=768px) {
	.page-career .mindset__item:first-child {
		margin-top: 0;
		margin-left: 0
	}
}

.page-career .mindset__item:last-child {
	margin-right: 80px
}

@media (width<=768px) {
	.page-career .mindset__item:last-child {
		margin-right: 0
	}
}

.page-career .gallery {
	padding: 120px 0 172px;
	position: relative
}

@media (width<=768px) {
	.page-career .gallery {
		padding: 60px 0 80px
	}
}

.page-career .gallery__slider-wrapper {
	transition-timing-function: linear!important
}

.page-career .gallery__large-text {
	text-align: center;
	color: #fff;
	z-index: 1;
	width: 100%;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 14vw;
	font-weight: 100;
	line-height: 1;
	position: absolute;
	bottom: 4vw;
	left: 0
}

@media (width>=1440px) {
	.page-career .gallery__large-text {
		font-size: 200px;
		bottom: 72px
	}
}

@media (width<=768px) {
	.page-career .gallery__large-text {
		bottom: 15vw
	}
}

.page-career .interview__wrap {
	padding: 0 20px
}

.page-career .interview__content {
	background-color: #fff;
	border-radius: 20px;
	padding: 120px 0
}

@media (width<=768px) {
	.page-career .interview__content {
		border-radius: 12px;
		padding: 60px 0
	}
}

.page-career .interview__container {
	max-width: 1184px
}

.page-career .interview__title {
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

.page-career .interview__list {
	justify-content: space-between;
	margin-top: 72px;
	display: flex
}

@media (width<=768px) {
	.page-career .interview__list {
		flex-wrap: wrap;
		margin-top: 32px
	}
}

.page-career .interview__item {
	width: calc(33.3% - 46px)
}

@media (width<=768px) {
	.page-career .interview__item {
		width: 100%
	}

	.page-career .interview__item:not(:first-child) {
		margin-top: 40px
	}
}

.page-career .interview__item-thumb {
	width: 100%;
	padding-top: 56%;
	position: relative
}

.page-career .interview__item-thumb img {
	-o-object-fit: cover;
	object-fit: cover;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.page-career .interview__item-body {
	margin-top: 24px
}

@media (width<=768px) {
	.page-career .interview__item-body {
		margin-top: 16px
	}
}

.page-career .interview__item-title {
	letter-spacing: .04em;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.625;
	display: -webkit-box;
	overflow: hidden
}

@media (width<=768px) {
	.page-career .interview__item-title {
		font-size: 15px
	}
}

.page-career .interview__item-excerpt {
	letter-spacing: .02em;
	color: #202733bf;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	margin-top: 20px;
	font-size: 13px;
	line-height: 2;
	display: -webkit-box;
	overflow: hidden
}

@media (width<=768px) {
	.page-career .interview__item-excerpt {
		margin-top: 16px
	}
}

.page-career .interview__item-btn {
	margin-top: 32px
}

@media (width<=768px) {
	.page-career .interview__item-btn {
		margin-top: 24px
	}
}

.page-career .interview__item-btn .text-btn span.arrow {
	background-color: #c9d1db;
	border-color: #c9d1db
}

.page-career .interview__item-btn .text-btn span.arrow svg {
	fill: #202733
}

.page-career .interview__item-btn .text-btn span.arrow svg:first-child {
	transform: translate(-100px)
}

@media (hover:hover) {
	.page-career .interview__item-btn .text-btn:hover span.arrow {
		background-color: #0553dd;
		border-color: #0553dd
	}

	.page-career .interview__item-btn .text-btn:hover span.arrow svg {
		fill: #fff;
		transform: translate(100px)
	}

	.page-career .interview__item-btn .text-btn:hover span.arrow svg:first-child {
		transform: translate(0)
	}
}

.page-career .interview__btn {
	width: 232px;
	height: 56px;
	margin: 52px auto 0
}

@media (width<=768px) {
	.page-career .interview__btn {
		width: 210px;
		height: 48px
	}
}

.page-career .interview__btn .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.page-career .interview__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-career .interview__btn .btn span.arrow svg {
	fill: #202733
}

.page-career .interview__btn .btn span.arrow svg:first-child {
	transform: translate(-100px)
}

@media (hover:hover) {
	.page-career .interview__btn .btn:hover span.arrow {
		background-color: #0553dd
	}

	.page-career .interview__btn .btn:hover span.arrow svg {
		fill: #fff;
		transform: translate(100px)
	}

	.page-career .interview__btn .btn:hover span.arrow svg:first-child {
		transform: translate(0)
	}
}

.page-career .book {
	padding: 0 0 120px
}

@media (width<=768px) {
	.page-career .book {
		padding: 0 0 60px
	}
}

.page-career .book__container {
	max-width: 1184px
}

.page-career .book__content {
	border-top: 1px solid #c9d1db;
	flex-direction: row-reverse;
	align-items: center;
	padding: 60px 70px 0;
	display: flex
}

@media (width<=768px) {
	.page-career .book__content {
		flex-flow: column wrap;
		padding: 60px 0 0
	}
}

.page-career .book__img {
	border: 1px solid #c9d1db;
	border-radius: 8px;
	flex-grow: 1;
	max-width: 560px;
	overflow: hidden
}

@media (width<=768px) {
	.page-career .book__img {
		border-radius: 4px
	}
}

.page-career .book__text-wrap {
	max-width: 350px;
	margin-right: 70px
}

@media (width<=768px) {
	.page-career .book__text-wrap {
		margin-top: 32px;
		margin-right: 0
	}
}

.page-career .book__title {
	letter-spacing: .04em;
	font-size: 20px;
	font-weight: 700
}

@media (width<=768px) {
	.page-career .book__title {
		font-size: 16px
	}
}

.page-career .book__text {
	margin-top: 32px
}

@media (width<=768px) {
	.page-career .book__text {
		margin-top: 24px
	}
}

.page-career .book__text p {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 2
}

.page-career .book__btn {
	width: 232px;
	height: 56px;
	margin-top: 52px
}

@media (width<=768px) {
	.page-career .book__btn {
		width: 210px;
		height: 48px;
		margin-top: 32px
	}
}

.page-career .book__btn .btn {
	padding: 16px 16px 16px 32px
}

@media (width<=768px) {
	.page-career .book__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-career .book__btn .btn span.arrow svg {
	fill: #202733
}

.page-career .book__btn .btn span.arrow svg:first-child {
	transform: translate(-100px)
}

@media (hover:hover) {
	.page-career .book__btn .btn:hover span.arrow {
		background-color: #0553dd
	}

	.page-career .book__btn .btn:hover span.arrow svg {
		fill: #fff;
		transform: translate(100px)
	}

	.page-career .book__btn .btn:hover span.arrow svg:first-child {
		transform: translate(0)
	}
}

.page-career .faq {
	padding: 120px 0
}

@media (width<=768px) {
	.page-career .faq {
		padding: 60px 0
	}
}

.page-career .faq__container {
	max-width: 1184px
}

.page-career .faq__content {
	justify-content: space-between;
	display: flex
}

@media (width<=768px) {
	.page-career .faq__content {
		flex-wrap: wrap
	}
}

.page-career .faq__title {
	letter-spacing: .02em;
	margin-right: 40px;
	font-size: 13px;
	font-weight: 700
}

@media (width<=768px) {
	.page-career .faq__title {
		width: 100%;
		margin-right: 0
	}
}

.page-career .faq__list {
	width: 100%;
	max-width: 840px;
	margin: 0 auto
}

@media (width<=768px) {
	.page-career .faq__list {
		margin-top: 24px
	}
}

.page-career .faq__item {
	cursor: pointer;
	margin-top: 8px
}

.page-career .faq__question {
	letter-spacing: .04em;
	background-color: #fff;
	border-radius: 8px;
	padding: 28px 94px 28px 72px;
	font-size: 16px;
	font-weight: 700;
	position: relative
}

@media (width<=768px) {
	.page-career .faq__question {
		padding: 16px 56px 16px 50px
	}
}

.page-career .faq__question .question {
	letter-spacing: -.01em;
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 20px;
	font-weight: 700;
	position: absolute;
	top: 25px;
	left: 35px
}

@media (width<=768px) {
	.page-career .faq__question .question {
		top: 14px;
		left: 20px
	}
}

.page-career .faq__question:after {
	content: "";
	background-color: #0553dd;
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: 11px 7px;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	margin: auto 0;
	transition: all .3s;
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 35px
}

@media (width<=768px) {
	.page-career .faq__question:after {
		right: 20px
	}
}

.page-career .faq__answer {
	padding: 20px 0 32px 35px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.page-career .faq__answer {
		padding: 20px 0 32px 20px
	}
}

.page-career .faq__answer .answer {
	letter-spacing: -.01em;
	color: #dd052f;
	margin-right: 22px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 20px;
	font-weight: 700;
	display: block
}

@media (width<=768px) {
	.page-career .faq__answer .answer {
		margin-right: 16px
	}
}

.page-career .faq__answer .answer-text {
	letter-spacing: .04em;
	font-size: 13px;
	line-height: 2
}

.page-career .faq__item.is-open .faq__question:after {
	transform: rotate(180deg)
}

.page-career .job {
	background-color: #fff;
	padding: 120px 0 160px
}

@media (width<=768px) {
	.page-career .job {
		padding: 60px 0
	}
}

.page-career .job__content {
	margin-top: 72px;
	position: relative
}

@media (width<=1060px) {
	.page-career .job__content {
		margin-top: 64px
	}
}

@media (width<=768px) {
	.page-career .job__content {
		margin-top: 16px
	}
}

.page-career .job__container {
	max-width: 1184px
}

.page-career .job__title {
	letter-spacing: .02em;
	font-size: 13px;
	font-weight: 700
}

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

@media (width<=1060px) {
	.page-career .job__selector-wrap {
		position: static
	}
}

.page-career .job__selector {
	z-index: 4;
	pointer-events: none;
	width: 100%;
	position: sticky;
	top: 160px;
	left: 0
}

@media (width<=1060px) {
	.page-career .job__selector {
		position: static
	}
}

.page-career .job__selector-container {
	max-width: 1184px
}

.page-career .job__selector-list {
	pointer-events: auto;
	width: 280px
}

@media (width<=1060px) {
	.page-career .job__selector-list {
		flex-wrap: wrap;
		width: 100%;
		display: flex
	}

	.page-career .job__selector-item {
		margin-top: 15px;
		margin-right: 24px
	}
}

@media (width<=768px) {
	.page-career .job__selector-item {
		margin-top: 8px;
		margin-right: 16px
	}
}

.page-career .job__selector-item:not(:first-child) {
	margin-top: 15px
}

@media (width<=768px) {
	.page-career .job__selector-item:not(:first-child) {
		margin-top: 8px
	}
}

.page-career .job__selector-btn {
	letter-spacing: .04em;
	color: #2027334d;
	padding-left: 18px;
	font-size: 13px;
	font-weight: 700;
	transition: all .3s;
	position: relative
}

@media (width<=1060px) {
	.page-career .job__selector-btn {
		padding-left: 0
	}
}

.page-career .job__selector-btn:before {
	content: "";
	opacity: 0;
	background-color: #0553dd;
	border-radius: 50%;
	width: 6px;
	height: 6px;
	display: block;
	position: absolute;
	top: 8px;
	left: 0
}

@media (width<=1060px) {
	.page-career .job__selector-btn:before {
		display: none
	}
}

.page-career .job__selector-btn.is-active {
	color: #202733
}

.page-career .job__selector-btn.is-active:before {
	opacity: 1
}

@media (hover:hover) {
	.page-career .job__selector-btn:hover {
		color: #202733
	}
}

@media (width<=768px) {
	.page-career .job__tab {
		margin-top: 40px
	}
}

.page-career .job__tab-item {
	display: none
}

.page-career .job__tab-title-wrap {
	width: 100%;
	max-width: 1120px;
	margin: 80px auto 30px;
	padding-left: 282px;
	padding-right: 32px
}

@media (width<=768px) {
	.page-career .job__tab-title-wrap {
		max-width: 600px;
		margin: 60px auto 16px;
		padding: 0 20px
	}
}

.page-career .job__tab-title-wrap:first-of-type {
	margin-top: 0
}

.page-career .job__tab-title {
	letter-spacing: .04em;
	font-size: 20px;
	font-weight: 700
}

@media (width<=768px) {
	.page-career .job__tab-title {
		font-size: 15px
	}
}

@media (width<=1060px) {
	.page-career .job__list {
		margin-top: 32px
	}
}

@media (width<=768px) {
	.page-career .job__list {
		max-width: 600px;
		margin: 16px auto 0
	}
}

.page-career .job__item {
	width: 100%;
	position: relative;
	overflow: hidden
}

.page-career .job__item-wrap {
	justify-content: flex-end;
	width: 100%;
	max-width: 1184px;
	margin: 0 auto;
	padding-left: 282px;
	padding-right: 32px;
	display: flex
}

@media (width<=1060px) {
	.page-career .job__item-wrap {
		padding-left: 32px
	}
}

@media (width<=768px) {
	.page-career .job__item-wrap {
		padding: 0 20px
	}
}

.page-career .job__link {
	flex-grow: 1;
	max-width: 840px;
	display: flex;
	position: relative
}

.page-career .job__link:after {
	content: "";
	pointer-events: none;
	background-color: #f4f4f5;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=1060px) {
	.page-career .job__link {
		max-width: 100%
	}
}

.page-career .job__link:after {
	transition: all .6s
}

@media (hover:hover) {
	.page-career .job__link:hover:after {
		transform: scale(100)
	}

	.page-career .job__link:hover .job__item-btn span.arrow {
		background-color: #0553dd;
		border-color: #0553dd
	}

	.page-career .job__link:hover .job__item-btn span.arrow svg {
		fill: #fff;
		transform: translate(100px)
	}

	.page-career .job__link:hover .job__item-btn span.arrow svg:first-child {
		transform: translate(0)
	}
}

.page-career .job__link-inner {
	z-index: 1;
	width: 100%;
	padding: 60px 0 52px;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.page-career .job__link-inner {
		padding: 24px 0
	}
}

.page-career .job__link-inner:before {
	content: "";
	z-index: 3;
	background-color: #20273326;
	width: 100%;
	height: 1px;
	display: block;
	position: absolute;
	top: 0;
	left: 0
}

.page-career .job__link-cols {
	display: flex
}

@media (width<=768px) {
	.page-career .job__link-cols {
		flex-wrap: wrap
	}
}

.page-career .job__info-col {
	flex-shrink: 0;
	width: 214px;
	padding-right: 40px
}

@media (width<=768px) {
	.page-career .job__info-col {
		width: 100%;
		padding-right: 0
	}
}

.page-career .job__info-title {
	letter-spacing: .04em;
	padding-left: 18px;
	font-size: 16px;
	font-weight: 700;
	position: relative
}

@media (width<=768px) {
	.page-career .job__info-title {
		font-size: 14px
	}
}

.page-career .job__info-title:before {
	content: "";
	background-color: #0553dd;
	border-radius: 50%;
	width: 8px;
	height: 8px;
	position: absolute;
	top: 9px;
	left: 0
}

.page-career .job__tag {
	flex-wrap: wrap;
	margin-top: 16px;
	display: flex
}

@media (width<=768px) {
	.page-career .job__tag {
		margin-top: 8px
	}
}

.page-career .job__tag li {
	color: #202733bf;
	background-color: #fff;
	border: 1px solid #c9d1db;
	border-radius: 40px;
	margin-top: 4px;
	margin-right: 4px;
	padding: 0 10px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 700
}

@media (width<=768px) {
	.page-career .job__text-col {
		margin-top: 20px
	}
}

.page-career .job__text {
	letter-spacing: .02em;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	font-size: 13px;
	line-height: 2;
	display: -webkit-box;
	overflow: hidden
}

.page-career .job__item-btn {
	margin-top: 32px
}

@media (width<=768px) {
	.page-career .job__item-btn {
		margin-top: 24px
	}
}

.page-career .job__item-btn .text-btn span.arrow {
	background-color: #c9d1db;
	border-color: #c9d1db
}

.page-career .job__item-btn .text-btn span.arrow svg {
	fill: #202733
}

.page-career .job__item-btn .text-btn span.arrow svg:first-child {
	transform: translate(-100px)
}

.page-career .job__item.-no-item {
	pointer-events: none
}

.page-career .job__item.-no-item .job__link-inner {
	letter-spacing: .04em;
	color: #20273380;
	text-align: center;
	justify-content: center;
	padding: 60px 0;
	font-size: 16px;
	font-weight: 700;
	display: flex
}

@media (width<=768px) {
	.page-career .job__item.-no-item .job__link-inner {
		padding: 24px 0
	}
}

.page-career .job__item:last-child .job__link-inner:after {
	content: "";
	z-index: 3;
	background-color: #20273326;
	width: 100%;
	height: 1px;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0
}

.page-contact .contact-nav {
	background-color: #fff;
	margin-top: 80px;
	padding: 100px 0 120px
}

@media (width<=768px) {
	.page-contact .contact-nav {
		padding: 80px 0
	}
}

.page-contact .contact-nav__container {
	max-width: 1184px
}

.page-contact .contact-nav__text {
	letter-spacing: .02em;
	font-size: 13px;
	line-height: 2
}

.page-contact .contact-nav__text span {
	color: #0553dd;
	font-weight: 700
}

.page-contact .contact-nav__list {
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: 40px;
	display: flex
}

@media (width<=768px) {
	.page-contact .contact-nav__list {
		flex-wrap: wrap
	}
}

.page-contact .contact-nav__item {
	border-top: 1px solid #c9d1db;
	border-bottom: 1px solid #c9d1db;
	width: calc(50% - 20px);
	margin-top: -1px
}

@media (width<=768px) {
	.page-contact .contact-nav__item {
		width: 100%
	}
}

.page-contact .contact-nav__link {
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: center;
	height: 100%;
	padding: 24px 12px 28px 22px;
	display: flex;
	position: relative;
	overflow: hidden
}

.page-contact .contact-nav__link:after {
	content: "";
	pointer-events: none;
	background-color: #f4f4f5;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=768px) {
	.page-contact .contact-nav__link {
		padding: 20px 12px
	}
}

.page-contact .contact-nav__link span.arrow {
	z-index: 1;
	background-color: #c9d1db;
	border-radius: 50px;
	justify-content: center;
	align-items: center;
	width: 60px;
	height: 24px;
	transition: all .3s;
	display: flex;
	position: relative;
	overflow: hidden
}

.page-contact .contact-nav__link span.arrow svg {
	fill: #202733;
	width: 16px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.page-contact .contact-nav__link span.arrow svg:first-child {
	transform: translate(-150px)
}

.page-contact .contact-nav__link.-ext span.arrow svg:first-child {
	transform: translate(-100px)
}

.page-contact .contact-nav__link:after {
	transition-duration: .6s
}

@media (hover:hover) {
	.page-contact .contact-nav__link:hover span.arrow {
		background-color: #0553dd;
		border-color: #fff
	}

	.page-contact .contact-nav__link:hover span.arrow svg {
		fill: #fff;
		transform: translate(150px)
	}

	.page-contact .contact-nav__link:hover span.arrow svg:first-child {
		transform: translate(0)
	}

	.page-contact .contact-nav__link:hover:before {
		background-color: #0553dd
	}

	.page-contact .contact-nav__link:hover:after {
		transform: scale(25)
	}

	.page-contact .contact-nav__link:hover.-ext span.arrow svg {
		fill: #fff;
		transform: translate(100px)
	}

	.page-contact .contact-nav__link:hover.-ext span.arrow svg:first-child {
		transform: translate(0)
	}

	.page-contact .contact-nav__link.-download:hover .contact-nav__download-icon {
		background-color: #0553dd
	}
}

.page-contact .contact-nav__link-inner {
	z-index: 1;
	flex-direction: column;
	display: flex;
	position: relative
}

.page-contact .contact-nav__link-category {
	color: #0553dd;
	letter-spacing: .04em;
	margin-bottom: 12px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.page-contact .contact-nav__link-text {
	letter-spacing: .04em;
	flex-wrap: wrap;
	align-items: center;
	font-size: 16px;
	font-weight: 700;
	display: flex
}

.page-contact .contact-nav__link-logo {
	margin-right: 8px;
	display: block
}

.page-contact .contact-nav__link-logo.-majicari {
	max-width: 190px
}

@media (width<=768px) {
	.page-contact .contact-nav__link-logo.-majicari {
		max-width: 110px
	}
}

.page-contact .contact-nav__link-logo.-tenshoku {
	max-width: 200px
}

@media (width<=768px) {
	.page-contact .contact-nav__link-logo.-tenshoku {
		max-width: 120px
	}
}

.page-contact .contact-nav__link-logo.-calling {
	max-width: 180px;
	transform: translateY(8px)
}

@media (width<=768px) {
	.page-contact .contact-nav__link-logo.-calling {
		max-width: 100px;
		transform: translateY(0)
	}
}

.page-contact .contact-nav__link-logo.-agent {
	max-width: 180px
}

.page-contact .contact-nav__download-icon {
	z-index: 1;
	background-color: #c9d1db;
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: 15px 15px;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	transition: all .3s;
	display: block;
	position: relative
}

.page-contact .contact-nav__title {
	margin-top: 80px
}

.page-contact .contact-nav__title span {
	display: block
}

.page-contact .contact-nav__title span.en {
	color: #0553dd;
	letter-spacing: .04em;
	margin-bottom: 12px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.page-contact .contact-nav__title span.jp {
	letter-spacing: .04em;
	font-size: 16px;
	font-weight: 700
}

.page-contact .contact {
	padding: 120px 0 140px
}

@media (width<=768px) {
	.page-contact .contact {
		padding: 80px 0
	}
}

.page-contact .contact__container {
	max-width: 1184px
}

.page-contact .contact__head {
	border-bottom: 1px solid #20273326;
	padding-bottom: 40px
}

.page-contact .contact__head-inner {
	width: 100%;
	max-width: 840px;
	margin: 0 auto
}

.page-contact .contact__head-title span {
	display: block
}

.page-contact .contact__head-title span.en {
	color: #0553dd;
	letter-spacing: .04em;
	margin-bottom: 12px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.page-contact .contact__head-title span.jp {
	letter-spacing: .04em;
	font-size: 16px;
	font-weight: 700
}

.page-contact .contact__head-text {
	letter-spacing: .02em;
	margin-top: 24px;
	font-size: 13px;
	line-height: 2
}

.page-contact .contact__form {
	padding: 52px 0 120px
}

@media (width<=768px) {
	.page-contact .contact__form {
		padding: 0 0 80px
	}
}

.page-contact .contact__form-inner {
	width: 100%;
	max-width: 840px;
	margin: 0 auto
}

.page-contact .contact__bottom {
	border-top: 1px solid #20273326;
	border-bottom: 1px solid #20273326;
	width: 100%
}

.page-contact .contact__bottom-link {
	justify-content: space-between;
	align-items: flex-end;
	padding: 52px 35px 72px;
	display: flex;
	position: relative;
	overflow: hidden
}

.page-contact .contact__bottom-link:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=768px) {
	.page-contact .contact__bottom-link {
		flex-direction: column;
		align-items: center;
		padding: 40px 12px
	}
}

.page-contact .contact__bottom-link:hover:after {
	transition-duration: .6s;
	transform: scale(50)
}

.page-contact .contact__bottom-wrap {
	z-index: 1;
	display: block;
	position: relative
}

.page-contact .contact__bottom-title {
	letter-spacing: .04em;
	color: #0553dd;
	font-size: 16px;
	font-weight: 700;
	display: block
}

@media (width<=768px) {
	.page-contact .contact__bottom-title {
		text-align: center
	}
}

.page-contact .contact__bottom-text {
	letter-spacing: .02em;
	margin-top: 24px;
	font-size: 13px;
	line-height: 2;
	display: block
}

.page-contact .contact__bottom-btn {
	z-index: 1;
	align-items: center;
	display: inline-flex;
	position: relative
}

@media (width<=768px) {
	.page-contact .contact__bottom-btn {
		justify-content: center;
		margin-top: 32px;
		display: flex
	}
}

.page-contact .contact__bottom-btn span {
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500
}

.page-contact .contact__bottom-btn:after {
	content: "";
	background-color: #0553dd;
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: 13px 11px;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	margin-left: 12px
}

.page-thanks .mv {
	padding: 218px 0 170px;
	position: relative
}

@media (width<=768px) {
	.page-thanks .mv {
		padding: 160px 0 120px
	}
}

.page-thanks .mv__bg-text {
	width: 100%;
	position: absolute;
	bottom: -43px;
	left: 0;
	overflow: hidden
}

@media (width<=768px) {
	.page-thanks .mv__bg-text {
		bottom: -16px
	}
}

.page-thanks .mv__bg-text-wrap {
	gap: 30px;
	display: flex
}

.page-thanks .mv__bg-text-wrap p {
	letter-spacing: -.04em;
	white-space: nowrap;
	color: #fff;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 280px;
	font-weight: 100;
	line-height: 1
}

@media (width<=1060px) {
	.page-thanks .mv__bg-text-wrap p {
		font-size: 200px
	}
}

@media (width<=768px) {
	.page-thanks .mv__bg-text-wrap p {
		font-size: 120px
	}
}

.page-thanks .mv__container {
	max-width: 1184px
}

.page-thanks .mv__title {
	text-align: center;
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 36px
}

.page-thanks .mv__title span {
	display: block
}

.page-thanks .mv__title span.en {
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 72px;
	font-weight: 500
}

@media (width<=768px) {
	.page-thanks .mv__title span.en {
		font-size: 40px
	}
}

.page-thanks .mv__title span.jp {
	letter-spacing: .06em;
	margin-top: 8px;
	font-size: 24px;
	font-weight: 700
}

@media (width<=768px) {
	.page-thanks .mv__title span.jp {
		font-size: 16px
	}
}

.page-thanks .mv__text {
	letter-spacing: .03em;
	text-align: center;
	margin-top: 32px;
	font-size: 14px;
	line-height: 1.86
}

.page-thanks .mv__text a {
	color: #0553dd;
	text-decoration: underline
}

.page-thanks .mv__btn {
	width: 232px;
	height: 56px;
	margin: 48px auto 0
}

@media (width<=768px) {
	.page-thanks .mv__btn {
		width: 210px;
		height: 48px
	}
}

.page-thanks .mv__btn .btn {
	padding: 0 16px 0 32px
}

@media (width<=768px) {
	.page-thanks .mv__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-not-found .mv {
	padding: 218px 0 170px;
	position: relative
}

@media (width<=768px) {
	.page-not-found .mv {
		padding: 160px 0 120px
	}
}

.page-not-found .mv__bg-text {
	width: 100%;
	position: absolute;
	bottom: -43px;
	left: 0;
	overflow: hidden
}

@media (width<=768px) {
	.page-not-found .mv__bg-text {
		bottom: -16px
	}
}

.page-not-found .mv__bg-text-wrap {
	gap: 30px;
	display: flex
}

.page-not-found .mv__bg-text-wrap p {
	letter-spacing: -.04em;
	white-space: nowrap;
	color: #fff;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 280px;
	font-weight: 100;
	line-height: 1
}

@media (width<=1060px) {
	.page-not-found .mv__bg-text-wrap p {
		font-size: 200px
	}
}

@media (width<=768px) {
	.page-not-found .mv__bg-text-wrap p {
		font-size: 120px
	}
}

.page-not-found .mv__container {
	max-width: 1184px
}

.page-not-found .mv__title {
	text-align: center;
	border-bottom: 1px solid #c9d1db;
	padding-bottom: 36px
}

.page-not-found .mv__title span {
	display: block
}

.page-not-found .mv__title span.en {
	color: #0553dd;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 72px;
	font-weight: 500
}

@media (width<=768px) {
	.page-not-found .mv__title span.en {
		font-size: 40px
	}
}

.page-not-found .mv__title span.jp {
	letter-spacing: .06em;
	margin-top: 8px;
	font-size: 24px;
	font-weight: 700
}

@media (width<=768px) {
	.page-not-found .mv__title span.jp {
		font-size: 16px
	}
}

.page-not-found .mv__text {
	letter-spacing: .03em;
	text-align: center;
	margin-top: 32px;
	font-size: 14px;
	line-height: 1.86
}

.page-not-found .mv__text a {
	color: #0553dd;
	text-decoration: underline
}

.page-not-found .mv__btn {
	width: 232px;
	height: 56px;
	margin: 48px auto 0
}

@media (width<=768px) {
	.page-not-found .mv__btn {
		width: 210px;
		height: 48px
	}
}

.page-not-found .mv__btn .btn {
	padding: 0 16px 0 32px
}

@media (width<=768px) {
	.page-not-found .mv__btn .btn {
		padding: 14px 14px 14px 28px
	}
}

.page-privacy .privacy {
	padding-bottom: 80px
}

@media (width<=768px) {
	.page-privacy .privacy {
		padding-bottom: 60px
	}
}

.page-privacy .privacy__container {
	max-width: 1184px
}

.page-privacy .privacy__body {
	background-color: #fff;
	padding: 60px 70px 100px
}

@media (width<=768px) {
	.page-privacy .privacy__body {
		padding: 40px 20px
	}
}

.page-privacy .privacy__content ul li,.page-privacy .privacy__content ol li {
	font-weight: 500;
	line-height: 2
}

.page-terms .terms {
	padding-bottom: 80px
}

@media (width<=768px) {
	.page-terms .terms {
		padding-bottom: 60px
	}
}

.page-terms .terms__container {
	max-width: 1184px
}

.page-terms .terms__body {
	background-color: #fff;
	padding: 60px 70px 100px
}

@media (width<=768px) {
	.page-terms .terms__body {
		padding: 40px 20px
	}
}

.page-terms .terms__content ul li,.page-terms .terms__content ol li {
	font-weight: 500;
	line-height: 2
}

.single-news .news-head {
	border-bottom: 1px solid #c9d1db;
	padding: 222px 0 48px;
	position: relative
}

@media (width<=768px) {
	.single-news .news-head {
		padding-top: 120px
	}
}

.single-news .news-head__container {
	max-width: 904px
}

.single-news .news-head__info {
	align-items: center;
	display: flex
}

.single-news .news-head__cat {
	background-color: #fff;
	border: 1px solid #c9d1db;
	border-radius: 50px;
	margin-right: 12px;
	padding: 2px 10px;
	transition: all .3s
}

.single-news .news-head__cat span {
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px
}

@media (hover:hover) {
	.single-news .news-head__cat:hover {
		color: #fff;
		background-color: #0553dd;
		border-color: #0553dd
	}
}

.single-news .news-head__time {
	letter-spacing: .02em;
	color: #202733b3;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 14px;
	font-weight: 500
}

.single-news .news-head__title {
	letter-spacing: .06em;
	margin-top: 14px;
	font-size: 32px;
	font-weight: 700
}

@media (width<=768px) {
	.single-news .news-head__title {
		font-size: 28px
	}
}

.single-news .news-main {
	border-bottom: 1px solid #c9d1db
}

.single-news .news-main__container {
	max-width: 1184px
}

.single-news .news-main__body {
	background-color: #fff
}

.single-news .news-main__article {
	padding: 60px 70px 100px
}

@media (width<=768px) {
	.single-news .news-main__article {
		padding: 40px 20px 60px
	}
}

.single-news .news-main__thumb {
	width: 100%;
	padding-top: 56%;
	position: relative
}

.single-news .news-main__thumb img {
	-o-object-fit: cover;
	object-fit: cover;
	border-radius: 4px;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.single-news .news-main__user-content {
	max-width: 840px;
	margin: 0 auto;
	padding: 60px 30px 0;
	position: relative
}

@media (width<=768px) {
	.single-news .news-main__user-content {
		margin-top: 10px;
		padding: 30px 0 0
	}
}

.single-news .news-main__sns-list {
	border-top: 1px solid #c9d1db;
	border-bottom: 1px solid #c9d1db;
	height: 156px;
	display: flex
}

@media (width<=768px) {
	.single-news .news-main__sns-list {
		height: 80px
	}
}

.single-news .news-main__sns-item {
	width: 25%;
	height: 100%;
	position: relative
}

.single-news .news-main__sns-item:not(:last-child) {
	border-right: 1px solid #c9d1db
}

.single-news .news-main__sns-link {
	justify-content: center;
	align-items: center;
	height: 100%;
	display: flex;
	overflow: hidden
}

.single-news .news-main__sns-link span.icon {
	width: 40px;
	height: 40px;
	display: block;
	position: relative
}

.single-news .news-main__sns-link span.icon.-tw:before {
	background-color: #1da1f2
}

.single-news .news-main__sns-link span.icon.-fb:before {
	background-color: #1877f2
}

.single-news .news-main__sns-link span.icon.-hatena:before {
	background-color: #01a5df
}

.single-news .news-main__sns-link span.icon.-pocket:before {
	background-color: #dd4f5a
}

.single-news .news-main__sns-link span.icon:before {
	content: "";
	border-radius: 50%;
	width: 40px;
	height: 40px;
	transition: all .6s;
	display: block;
	position: absolute;
	top: 0;
	left: 0
}

.single-news .news-main__sns-link span.icon img {
	z-index: 1;
	position: relative
}

.single-news .news-main__sns-link span.text {
	letter-spacing: .02em;
	z-index: 1;
	margin-left: 8px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 14px;
	font-weight: 500;
	transition: all .6s;
	position: relative
}

@media (width<=768px) {
	.single-news .news-main__sns-link span.text {
		display: none
	}
}

@media (hover:hover) {
	.single-news .news-main__sns-link:hover span.icon:before {
		transform: scale(40)
	}

	.single-news .news-main__sns-link:hover span.text {
		color: #fff
	}
}

.single-news .news-main__nav {
	justify-content: center;
	align-items: center;
	padding: 80px 0;
	display: flex
}

@media (width<=768px) {
	.single-news .news-main__nav {
		padding: 40px 0
	}
}

.single-news .news-main__nav-link {
	align-items: center;
	display: flex
}

.single-news .news-main__nav-link span.arrow {
	background-color: #0553dd;
	border-radius: 50px;
	width: 60px;
	height: 24px;
	transition: all .3s;
	display: block;
	position: relative;
	overflow: hidden
}

.single-news .news-main__nav-link span.arrow svg {
	fill: #fff;
	width: 14px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0;
	transform: scaleX(-1)
}

.single-news .news-main__nav-link span.arrow svg:first-child {
	transform: scaleX(-1)translate(-150px)
}

.single-news .news-main__nav-link span.text {
	letter-spacing: .04em;
	margin-left: 12px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500
}

@media (hover:hover) {
	.single-news .news-main__nav-link:hover span.arrow {
		background-color: #c9d1db
	}

	.single-news .news-main__nav-link:hover span.arrow svg {
		fill: #202733;
		transform: translate(-150px)scaleX(-1)
	}

	.single-news .news-main__nav-link:hover span.arrow svg:first-child {
		transform: translate(0)scaleX(-1)
	}
}

.single-news .news-related {
	padding: 140px 0
}

@media (width<=768px) {
	.single-news .news-related {
		padding: 60px 0 40px
	}
}

.single-news .news-related__content {
	position: relative
}

.single-news .news-related__title {
	z-index: 2;
	pointer-events: none;
	position: relative
}

.single-news .news-related__title-container {
	max-width: 1184px;
	margin-bottom: -18px;
	position: relative
}

@media (width<=768px) {
	.single-news .news-related__title-container {
		margin-bottom: 24px
	}
}

.single-news .news-related__title-container span {
	letter-spacing: .02em;
	pointer-events: auto;
	font-size: 13px;
	font-weight: 700
}

.single-news .news-related__item {
	width: 100%;
	position: relative;
	overflow: hidden
}

.single-news .news-related__item-wrap {
	justify-content: flex-end;
	width: 100%;
	max-width: 1120px;
	margin: 0 auto;
	padding-left: 282px;
	display: flex
}

@media (width<=768px) {
	.single-news .news-related__item-wrap {
		padding: 0 20px
	}
}

.single-news .news-related__link {
	flex-grow: 1;
	max-width: 840px;
	display: flex;
	position: relative
}

.single-news .news-related__link:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .6s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (hover:hover) {
	.single-news .news-related__link:hover:after {
		transform: scale(100)
	}

	.single-news .news-related__link:hover .news-related__item-more span.-arrow {
		background-color: #0553dd
	}

	.single-news .news-related__link:hover .news-related__item-more span.-arrow svg {
		fill: #fff;
		transform: translate(150px)
	}

	.single-news .news-related__link:hover .news-related__item-more span.-arrow svg:first-child {
		transform: translate(0)
	}
}

.single-news .news-related__link-inner {
	z-index: 1;
	width: 100%;
	padding: 24px 0;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.single-news .news-related__link-inner {
		padding: 20px 0
	}
}

.single-news .news-related__link-inner:before {
	content: "";
	z-index: 3;
	background-color: #20273326;
	width: 100%;
	height: 1px;
	display: block;
	position: absolute;
	top: 0;
	left: 0
}

.single-news .news-related__thumb {
	width: 175px;
	margin-right: 35px;
	position: relative
}

.single-news .news-related__thumb-wrap {
	border-radius: 4px;
	width: 100%;
	padding-top: 56%;
	position: relative;
	overflow: hidden
}

.single-news .news-related__thumb-wrap img {
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.single-news .news-related__item-content {
	flex-direction: column;
	flex-grow: 1;
	display: flex
}

.single-news .news-related__item-info {
	justify-content: space-between;
	display: flex
}

@media (width<=768px) {
	.single-news .news-related__item-info {
		justify-content: flex-start
	}
}

.single-news .news-related__item-cat {
	background-color: #fff;
	border: 1px solid #c9d1db;
	border-radius: 100px;
	padding: 2px 10px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px
}

@media (width<=768px) {
	.single-news .news-related__item-cat {
		margin-right: 12px;
		padding: 0 10px;
		font-size: 11px
	}
}

.single-news .news-related__item-time {
	letter-spacing: .02em;
	color: #202733b3;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.single-news .news-related__item-title {
	letter-spacing: .06em;
	margin-top: 18px;
	font-size: 14px;
	font-weight: 700
}

@media (width<=768px) {
	.single-news .news-related__item-title {
		letter-spacing: .04em;
		margin-top: 8px;
		font-size: 13px
	}
}

.single-news .news-related__item-more {
	justify-content: flex-end;
	align-items: center;
	margin-top: 15px;
	display: flex
}

@media (width<=768px) {
	.single-news .news-related__item-more {
		display: none
	}
}

.single-news .news-related__item-more span.-text {
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500;
	display: none
}

.single-news .news-related__item-more span.-arrow {
	background-color: #c9d1db;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	margin-left: 12px;
	transition: all .6s;
	display: block;
	position: relative;
	overflow: hidden
}

.single-news .news-related__item-more span.-arrow svg {
	fill: #202733;
	width: 16px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.single-news .news-related__item-more span.-arrow svg:first-child {
	transform: translate(-150px)
}

.single-news .news-related__item:last-child .news-related__link-inner:after {
	content: "";
	z-index: 3;
	background-color: #20273326;
	width: 100%;
	height: 1px;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0
}

.single-news .news-related__btn {
	margin-top: 52px
}

@media (width<=768px) {
	.single-news .news-related__btn {
		margin-top: 40px
	}
}

.single-news .news-related__btn-container {
	max-width: 1184px
}

.single-news .news-related__btn-wrap {
	justify-content: flex-end;
	display: flex
}

.archive-news .news-article__content {
	margin-top: 100px;
	margin-bottom: 140px;
	position: relative
}

@media (width<=1060px) {
	.archive-news .news-article__content {
		margin-top: 64px;
		margin-bottom: 100px
	}
}

@media (width<=768px) {
	.archive-news .news-article__content {
		margin-top: 32px;
		margin-bottom: 48px
	}
}

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

@media (width<=1060px) {
	.archive-news .news-article__selector-wrap {
		position: static
	}
}

.archive-news .news-article__selector {
	z-index: 4;
	pointer-events: none;
	width: 100%;
	position: sticky;
	top: 160px;
	left: 0
}

@media (width<=1060px) {
	.archive-news .news-article__selector {
		position: static
	}
}

.archive-news .news-article__selector-container {
	max-width: 1184px
}

.archive-news .news-article__selector-list {
	pointer-events: auto;
	width: 280px
}

@media (width<=1060px) {
	.archive-news .news-article__selector-list {
		flex-wrap: wrap;
		width: 100%;
		display: flex
	}

	.archive-news .news-article__selector-item {
		margin-top: 15px;
		margin-right: 24px
	}
}

@media (width<=768px) {
	.archive-news .news-article__selector-item {
		margin-right: 16px
	}
}

.archive-news .news-article__selector-item:not(:first-child) {
	margin-top: 15px
}

.archive-news .news-article__selector-btn {
	letter-spacing: -.01em;
	color: #2027334d;
	padding-left: 18px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 15px;
	font-weight: 500;
	transition: all .3s;
	position: relative
}

@media (width<=1060px) {
	.archive-news .news-article__selector-btn {
		padding-left: 0
	}
}

.archive-news .news-article__selector-btn:before {
	content: "";
	opacity: 0;
	background-color: #0553dd;
	border-radius: 50%;
	width: 6px;
	height: 6px;
	display: block;
	position: absolute;
	top: 8px;
	left: 0
}

@media (width<=1060px) {
	.archive-news .news-article__selector-btn:before {
		display: none
	}
}

.archive-news .news-article__selector-btn.is-active {
	color: #202733
}

.archive-news .news-article__selector-btn.is-active:before {
	opacity: 1
}

@media (hover:hover) {
	.archive-news .news-article__selector-btn:hover {
		color: #202733
	}
}

@media (width<=1060px) {
	.archive-news .news-article__list {
		margin-top: 32px
	}
}

.archive-news .news-article__item {
	width: 100%;
	position: relative;
	overflow: hidden
}

.archive-news .news-article__item-wrap {
	justify-content: flex-end;
	width: 100%;
	max-width: 1152px;
	margin: 0 auto;
	padding-left: 282px;
	padding-right: 32px;
	display: flex
}

@media (width<=1060px) {
	.archive-news .news-article__item-wrap {
		padding-left: 32px
	}
}

@media (width<=768px) {
	.archive-news .news-article__item-wrap {
		padding: 0 20px
	}
}

.archive-news .news-article__link {
	flex-grow: 1;
	max-width: 840px;
	display: flex;
	position: relative
}

.archive-news .news-article__link:after {
	content: "";
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	margin: 0 auto;
	transition: all .3s;
	display: block;
	position: absolute;
	bottom: -13px;
	left: 0;
	right: 0;
	transform: scale(0)
}

@media (width<=1060px) {
	.archive-news .news-article__link {
		max-width: 100%
	}
}

.archive-news .news-article__link:after {
	transition: all .6s
}

@media (hover:hover) {
	.archive-news .news-article__link:hover:after {
		transform: scale(100)
	}

	.archive-news .news-article__link:hover .news-article__item-more span.-arrow {
		background-color: #0553dd
	}

	.archive-news .news-article__link:hover .news-article__item-more span.-arrow svg {
		fill: #fff;
		transform: translate(150px)
	}

	.archive-news .news-article__link:hover .news-article__item-more span.-arrow svg:first-child {
		transform: translate(0)
	}
}

.archive-news .news-article__link-inner {
	z-index: 1;
	width: 100%;
	padding: 24px 0;
	display: flex;
	position: relative
}

@media (width<=768px) {
	.archive-news .news-article__link-inner {
		padding: 20px 0
	}
}

.archive-news .news-article__link-inner:before {
	content: "";
	z-index: 3;
	background-color: #20273326;
	width: 100%;
	height: 1px;
	display: block;
	position: absolute;
	top: 0;
	left: 0
}

.archive-news .news-article__thumb {
	width: 175px;
	margin-right: 35px;
	position: relative
}

@media (width<=768px) {
	.archive-news .news-article__thumb {
		flex-shrink: 0;
		width: 38%;
		margin-right: 22px
	}
}

.archive-news .news-article__thumb-wrap {
	border-radius: 4px;
	width: 100%;
	padding-top: 56%;
	position: relative;
	overflow: hidden
}

.archive-news .news-article__thumb-wrap img {
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}

.archive-news .news-article__item-content {
	flex-direction: column;
	flex-grow: 1;
	display: flex
}

.archive-news .news-article__item-info {
	justify-content: space-between;
	display: flex
}

@media (width<=768px) {
	.archive-news .news-article__item-info {
		justify-content: flex-start
	}
}

.archive-news .news-article__item-cat {
	background-color: #fff;
	border: 1px solid #c9d1db;
	border-radius: 100px;
	padding: 2px 10px;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px
}

@media (width<=768px) {
	.archive-news .news-article__item-cat {
		margin-right: 12px;
		padding: 0 10px;
		font-size: 11px
	}
}

.archive-news .news-article__item-time {
	letter-spacing: .02em;
	color: #202733b3;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 12px;
	font-weight: 500
}

.archive-news .news-article__item-title {
	letter-spacing: .06em;
	margin-top: 18px;
	font-size: 14px;
	font-weight: 700
}

@media (width<=768px) {
	.archive-news .news-article__item-title {
		letter-spacing: .04em;
		margin-top: 8px;
		font-size: 13px
	}
}

.archive-news .news-article__item-more {
	justify-content: flex-end;
	align-items: center;
	margin-top: 15px;
	display: flex
}

@media (width<=768px) {
	.archive-news .news-article__item-more {
		display: none
	}
}

.archive-news .news-article__item-more span.-text {
	letter-spacing: .04em;
	font-family: Hanken Grotesk,Noto Sans JP,sans-serif;
	font-size: 13px;
	font-weight: 500;
	display: none
}

.archive-news .news-article__item-more span.-arrow {
	background-color: #c9d1db;
	border-radius: 100px;
	width: 60px;
	height: 24px;
	margin-left: 12px;
	transition: all .6s;
	display: block;
	position: relative;
	overflow: hidden
}

.archive-news .news-article__item-more span.-arrow svg {
	fill: #202733;
	width: 16px;
	height: auto;
	margin: auto;
	transition: all .6s;
	position: absolute;
	inset: 0
}

.archive-news .news-article__item-more span.-arrow svg:first-child {
	transform: translate(-150px)
}

.archive-news .news-article__item:last-child .news-article__link-inner:after {
	content: "";
	z-index: 3;
	background-color: #20273326;
	width: 100%;
	height: 1px;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0
}

.archive-news .news-article__pagination {
	margin-bottom: 140px
}

@media (width<=1060px) {
	.archive-news .news-article__pagination {
		margin-bottom: 100px
	}
}

@media (width<=768px) {
	.archive-news .news-article__pagination {
		margin-bottom: 48px
	}
}

.archive-news .news-article__pagination-container {
	max-width: 1184px
}

.sp {
	display: none
}

@media (width<=768px) {
	.sp {
		display: block
	}
}

.pc-sp {
	display: none
}

@media (width<=1060px) {
	.pc-sp {
		display: block
	}
}

@media (width<=768px) {
	.pc {
		display: none
	}
}

.is-loading {
	pointer-events: none
}

.is-loading .loading__logo {
	opacity: 1
}

.is-loading-done {
	pointer-events: auto
}

.is-scroll-disabled {
	overflow: hidden
}

.is-header-white .header__logo img.main {
	opacity: 0
}

.is-header-white .header__logo img.white {
	opacity: 1
}

.is-header-white .header__nav-link {
	color: #fff
}

.is-header-white .header__nav-link span.icon {
	background-color: #0000;
	border-color: #ffffff4d
}

.is-header-white .header__nav-link span.icon:before,.is-header-white .header__nav-link span.icon:after {
	background-color: #fff
}

.is-header-white .header__hamburger {
	background-color: #20273380;
	border: 1px solid #ffffff80
}

.is-scrolled .header {
	padding: 24px 0
}

@media (width<=768px) {
	.is-scrolled .header {
		padding: 16px 0
	}
}

.is-scrolled .header:before {
	transform: translateY(0)
}

.is-scrolled .header__logo img.main {
	opacity: 1
}

.is-scrolled .header__logo img.white {
	opacity: 0
}

.is-scrolled .header__nav-link {
	color: #202733
}

.is-scrolled .header__nav-link span.icon {
	background-color: #fff;
	border: 1px solid #2027334d
}

.is-scrolled .header__nav-link span.icon:before,.is-scrolled .header__nav-link span.icon:after {
	background-color: #202733
}

.is-scrolled .header__hamburger {
	background-color: #202733;
	border-color: #202733
}

.is-hamburger-open {
	overflow: hidden
}

.is-hamburger-open .hamburger-menu {
	pointer-events: auto;
	opacity: 1
}

.is-hamburger-open .header:before {
	transform: translateY(-100%)
}

.is-hamburger-open .header__logo {
	pointer-events: none;
	opacity: 0
}

.is-hamburger-open .header__nav-list {
	opacity: 0;
	pointer-events: none
}

.is-hamburger-open .header__hamburger {
	background-color: #fff;
	border-color: #fff
}

.is-hamburger-open .header__hamburger span {
	background-color: #202733
}

.is-hamburger-open .header__hamburger span:first-child {
	transform: rotate(-15deg)
}

.is-hamburger-open .header__hamburger span:nth-child(2) {
	opacity: 0;
	transform: translate(-20px)
}

.is-hamburger-open .header__hamburger span:nth-child(3) {
	transform: rotate(15deg)
}

.inview {
	opacity: 0;
	transition: all 1s cubic-bezier(.165,.84,.44,1) .2s;
	transform: translateY(30px)
}

.inview.inview-is-visible {
	opacity: 1;
	transform: translateY(0)
}

.video-container {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden
}

video {
	width: 100%;
	height: 100%
}

source {
	height: 100vw
}

@media (width<=768px) {
	video {
		width: auto
	}
}

.iso-card {
	width: 400px;
	margin: auto;
	display: block
}

.bottom-company-name {
	justify-content: flex-end;
	display: flex
}
/*# sourceMappingURL=index.6b857116.css.map */
