@charset "UTF-8";

/* base */

/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

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 {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

/* HTML5 display-role reset for older browsers */

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

body {
	line-height: 1;
}

ol,
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;
}

:root {
	--scrollbar: 0;
}

html {
	font-size: 62.5%;
	scroll-behavior: smooth;
}

html:has(#navi[aria-hidden=false]) {
	overflow: hidden;
}

body {
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1.4rem;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
	color: #000;
	word-wrap: break-word;
}

a {
	color: inherit;
}

div[id],
section[id],
article[id] {
	scroll-margin-top: 80px;
}

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

input,
textarea,
select,
button {
	font: inherit;
	color: inherit;
	outline: none;
}

button,
a,
select {
	cursor: pointer;
}

button:focus-visible,
a:focus-visible,
select:focus-visible {
	outline: auto;
	outline-color: #000;
}

/* for development */

pre {
	padding: 15px;
	background: #eee;
	font-size: 1.2rem;
	line-height: 1.2;
}

/* Tools */

.text-left {
	text-align: left;
}

.text-center {
	text-align: center;
}

.text-right {
	text-align: right;
}

.d-block {
	display: block;
}

.d-inline-block {
	display: inline-block;
}

.hidden {
	display: none !important;
}

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

.clearfix::after {
	clear: both;
}

.clear {
	clear: both;
}

/* show only  SP/PC
-------------------------------*/

.sp-only {
	display: none !important;
}

.sp-only-2 {
	display: none !important;
}

.pc-only {
	display: block !important;
}

.pc-only-2 {
	display: inline-block !important;
}

/* font
-------------------------------*/

.fw-700 {
	font-weight: 700;
}

/* margin
-------------------------------*/

.mt-0 {
	margin-top: 0px !important;
}

.mb-0 {
	margin-bottom: 0px !important;
}

.mr-0 {
	margin-right: 0px !important;
}

.ml-0 {
	margin-left: 0px !important;
}

.mx-0 {
	margin-left: 0px !important;
	margin-right: 0px !important;
}

.my-0 {
	margin-top: 0px !important;
	margin-bottom: 0px !important;
}

.mt-5 {
	margin-top: 5px !important;
}

.mb-5 {
	margin-bottom: 5px !important;
}

.mr-5 {
	margin-right: 5px !important;
}

.ml-5 {
	margin-left: 5px !important;
}

.mx-5 {
	margin-left: 5px !important;
	margin-right: 5px !important;
}

.my-5 {
	margin-top: 5px !important;
	margin-bottom: 5px !important;
}

.mt-10 {
	margin-top: 10px !important;
}

.mb-10 {
	margin-bottom: 10px !important;
}

.mr-10 {
	margin-right: 10px !important;
}

.ml-10 {
	margin-left: 10px !important;
}

.mx-10 {
	margin-left: 10px !important;
	margin-right: 10px !important;
}

.my-10 {
	margin-top: 10px !important;
	margin-bottom: 10px !important;
}

.mt-15 {
	margin-top: 15px !important;
}

.mb-15 {
	margin-bottom: 15px !important;
}

.mr-15 {
	margin-right: 15px !important;
}

.ml-15 {
	margin-left: 15px !important;
}

.mx-15 {
	margin-left: 15px !important;
	margin-right: 15px !important;
}

.my-15 {
	margin-top: 15px !important;
	margin-bottom: 15px !important;
}

.mt-20 {
	margin-top: 20px !important;
}

.mb-20 {
	margin-bottom: 20px !important;
}

.mr-20 {
	margin-right: 20px !important;
}

.ml-20 {
	margin-left: 20px !important;
}

.mx-20 {
	margin-left: 20px !important;
	margin-right: 20px !important;
}

.my-20 {
	margin-top: 20px !important;
	margin-bottom: 20px !important;
}

.mt-25 {
	margin-top: 25px !important;
}

.mb-25 {
	margin-bottom: 25px !important;
}

.mr-25 {
	margin-right: 25px !important;
}

.ml-25 {
	margin-left: 25px !important;
}

.mx-25 {
	margin-left: 25px !important;
	margin-right: 25px !important;
}

.my-25 {
	margin-top: 25px !important;
	margin-bottom: 25px !important;
}

.mt-30 {
	margin-top: 30px !important;
}

.mb-30 {
	margin-bottom: 30px !important;
}

.mr-30 {
	margin-right: 30px !important;
}

.ml-30 {
	margin-left: 30px !important;
}

.mx-30 {
	margin-left: 30px !important;
	margin-right: 30px !important;
}

.my-30 {
	margin-top: 30px !important;
	margin-bottom: 30px !important;
}

.mt-35 {
	margin-top: 35px !important;
}

.mb-35 {
	margin-bottom: 35px !important;
}

.mr-35 {
	margin-right: 35px !important;
}

.ml-35 {
	margin-left: 35px !important;
}

.mx-35 {
	margin-left: 35px !important;
	margin-right: 35px !important;
}

.my-35 {
	margin-top: 35px !important;
	margin-bottom: 35px !important;
}

.mt-40 {
	margin-top: 40px !important;
}

.mb-40 {
	margin-bottom: 40px !important;
}

.mr-40 {
	margin-right: 40px !important;
}

.ml-40 {
	margin-left: 40px !important;
}

.mx-40 {
	margin-left: 40px !important;
	margin-right: 40px !important;
}

.my-40 {
	margin-top: 40px !important;
	margin-bottom: 40px !important;
}

.mt-45 {
	margin-top: 45px !important;
}

.mb-45 {
	margin-bottom: 45px !important;
}

.mr-45 {
	margin-right: 45px !important;
}

.ml-45 {
	margin-left: 45px !important;
}

.mx-45 {
	margin-left: 45px !important;
	margin-right: 45px !important;
}

.my-45 {
	margin-top: 45px !important;
	margin-bottom: 45px !important;
}

.mt-50 {
	margin-top: 50px !important;
}

.mb-50 {
	margin-bottom: 50px !important;
}

.mr-50 {
	margin-right: 50px !important;
}

.ml-50 {
	margin-left: 50px !important;
}

.mx-50 {
	margin-left: 50px !important;
	margin-right: 50px !important;
}

.my-50 {
	margin-top: 50px !important;
	margin-bottom: 50px !important;
}

.mt-55 {
	margin-top: 55px !important;
}

.mb-55 {
	margin-bottom: 55px !important;
}

.mr-55 {
	margin-right: 55px !important;
}

.ml-55 {
	margin-left: 55px !important;
}

.mx-55 {
	margin-left: 55px !important;
	margin-right: 55px !important;
}

.my-55 {
	margin-top: 55px !important;
	margin-bottom: 55px !important;
}

.mt-60 {
	margin-top: 60px !important;
}

.mb-60 {
	margin-bottom: 60px !important;
}

.mr-60 {
	margin-right: 60px !important;
}

.ml-60 {
	margin-left: 60px !important;
}

.mx-60 {
	margin-left: 60px !important;
	margin-right: 60px !important;
}

.my-60 {
	margin-top: 60px !important;
	margin-bottom: 60px !important;
}

.mt-65 {
	margin-top: 65px !important;
}

.mb-65 {
	margin-bottom: 65px !important;
}

.mr-65 {
	margin-right: 65px !important;
}

.ml-65 {
	margin-left: 65px !important;
}

.mx-65 {
	margin-left: 65px !important;
	margin-right: 65px !important;
}

.my-65 {
	margin-top: 65px !important;
	margin-bottom: 65px !important;
}

.mt-70 {
	margin-top: 70px !important;
}

.mb-70 {
	margin-bottom: 70px !important;
}

.mr-70 {
	margin-right: 70px !important;
}

.ml-70 {
	margin-left: 70px !important;
}

.mx-70 {
	margin-left: 70px !important;
	margin-right: 70px !important;
}

.my-70 {
	margin-top: 70px !important;
	margin-bottom: 70px !important;
}

.mt-75 {
	margin-top: 75px !important;
}

.mb-75 {
	margin-bottom: 75px !important;
}

.mr-75 {
	margin-right: 75px !important;
}

.ml-75 {
	margin-left: 75px !important;
}

.mx-75 {
	margin-left: 75px !important;
	margin-right: 75px !important;
}

.my-75 {
	margin-top: 75px !important;
	margin-bottom: 75px !important;
}

.mt-80 {
	margin-top: 80px !important;
}

.mb-80 {
	margin-bottom: 80px !important;
}

.mr-80 {
	margin-right: 80px !important;
}

.ml-80 {
	margin-left: 80px !important;
}

.mx-80 {
	margin-left: 80px !important;
	margin-right: 80px !important;
}

.my-80 {
	margin-top: 80px !important;
	margin-bottom: 80px !important;
}

.mt-85 {
	margin-top: 85px !important;
}

.mb-85 {
	margin-bottom: 85px !important;
}

.mr-85 {
	margin-right: 85px !important;
}

.ml-85 {
	margin-left: 85px !important;
}

.mx-85 {
	margin-left: 85px !important;
	margin-right: 85px !important;
}

.my-85 {
	margin-top: 85px !important;
	margin-bottom: 85px !important;
}

.mt-90 {
	margin-top: 90px !important;
}

.mb-90 {
	margin-bottom: 90px !important;
}

.mr-90 {
	margin-right: 90px !important;
}

.ml-90 {
	margin-left: 90px !important;
}

.mx-90 {
	margin-left: 90px !important;
	margin-right: 90px !important;
}

.my-90 {
	margin-top: 90px !important;
	margin-bottom: 90px !important;
}

.mt-95 {
	margin-top: 95px !important;
}

.mb-95 {
	margin-bottom: 95px !important;
}

.mr-95 {
	margin-right: 95px !important;
}

.ml-95 {
	margin-left: 95px !important;
}

.mx-95 {
	margin-left: 95px !important;
	margin-right: 95px !important;
}

.my-95 {
	margin-top: 95px !important;
	margin-bottom: 95px !important;
}

.mt-100 {
	margin-top: 100px !important;
}

.mb-100 {
	margin-bottom: 100px !important;
}

.mr-100 {
	margin-right: 100px !important;
}

.ml-100 {
	margin-left: 100px !important;
}

.mx-100 {
	margin-left: 100px !important;
	margin-right: 100px !important;
}

.my-100 {
	margin-top: 100px !important;
	margin-bottom: 100px !important;
}

.mt-auto {
	margin-top: auto !important;
}

.mb-auto {
	margin-bottom: auto !important;
}

.mr-auto {
	margin-right: auto !important;
}

.ml-auto {
	margin-left: auto !important;
}

.mx-auto {
	margin-left: auto !important;
	margin-right: auto !important;
}

.my-auto {
	margin-top: auto !important;
	margin-bottom: auto !important;
}

/* padding
-------------------------------*/

.p-0 {
	padding: 0px !important;
}

.pt-0 {
	padding-top: 0px !important;
}

.pb-0 {
	padding-bottom: 0px !important;
}

.pr-0 {
	padding-right: 0px !important;
}

.pl-0 {
	padding-left: 0px !important;
}

.px-0 {
	padding-left: 0px !important;
	padding-right: 0px !important;
}

.py-0 {
	padding-top: 0px !important;
	padding-bottom: 0px !important;
}

.p-5 {
	padding: 5px !important;
}

.pt-5 {
	padding-top: 5px !important;
}

.pb-5 {
	padding-bottom: 5px !important;
}

.pr-5 {
	padding-right: 5px !important;
}

.pl-5 {
	padding-left: 5px !important;
}

.px-5 {
	padding-left: 5px !important;
	padding-right: 5px !important;
}

.py-5 {
	padding-top: 5px !important;
	padding-bottom: 5px !important;
}

.p-10 {
	padding: 10px !important;
}

.pt-10 {
	padding-top: 10px !important;
}

.pb-10 {
	padding-bottom: 10px !important;
}

.pr-10 {
	padding-right: 10px !important;
}

.pl-10 {
	padding-left: 10px !important;
}

.px-10 {
	padding-left: 10px !important;
	padding-right: 10px !important;
}

.py-10 {
	padding-top: 10px !important;
	padding-bottom: 10px !important;
}

.p-15 {
	padding: 15px !important;
}

.pt-15 {
	padding-top: 15px !important;
}

.pb-15 {
	padding-bottom: 15px !important;
}

.pr-15 {
	padding-right: 15px !important;
}

.pl-15 {
	padding-left: 15px !important;
}

.px-15 {
	padding-left: 15px !important;
	padding-right: 15px !important;
}

.py-15 {
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}

.p-20 {
	padding: 20px !important;
}

.pt-20 {
	padding-top: 20px !important;
}

.pb-20 {
	padding-bottom: 20px !important;
}

.pr-20 {
	padding-right: 20px !important;
}

.pl-20 {
	padding-left: 20px !important;
}

.px-20 {
	padding-left: 20px !important;
	padding-right: 20px !important;
}

.py-20 {
	padding-top: 20px !important;
	padding-bottom: 20px !important;
}

.p-25 {
	padding: 25px !important;
}

.pt-25 {
	padding-top: 25px !important;
}

.pb-25 {
	padding-bottom: 25px !important;
}

.pr-25 {
	padding-right: 25px !important;
}

.pl-25 {
	padding-left: 25px !important;
}

.px-25 {
	padding-left: 25px !important;
	padding-right: 25px !important;
}

.py-25 {
	padding-top: 25px !important;
	padding-bottom: 25px !important;
}

.p-30 {
	padding: 30px !important;
}

.pt-30 {
	padding-top: 30px !important;
}

.pb-30 {
	padding-bottom: 30px !important;
}

.pr-30 {
	padding-right: 30px !important;
}

.pl-30 {
	padding-left: 30px !important;
}

.px-30 {
	padding-left: 30px !important;
	padding-right: 30px !important;
}

.py-30 {
	padding-top: 30px !important;
	padding-bottom: 30px !important;
}

.p-35 {
	padding: 35px !important;
}

.pt-35 {
	padding-top: 35px !important;
}

.pb-35 {
	padding-bottom: 35px !important;
}

.pr-35 {
	padding-right: 35px !important;
}

.pl-35 {
	padding-left: 35px !important;
}

.px-35 {
	padding-left: 35px !important;
	padding-right: 35px !important;
}

.py-35 {
	padding-top: 35px !important;
	padding-bottom: 35px !important;
}

.p-40 {
	padding: 40px !important;
}

.pt-40 {
	padding-top: 40px !important;
}

.pb-40 {
	padding-bottom: 40px !important;
}

.pr-40 {
	padding-right: 40px !important;
}

.pl-40 {
	padding-left: 40px !important;
}

.px-40 {
	padding-left: 40px !important;
	padding-right: 40px !important;
}

.py-40 {
	padding-top: 40px !important;
	padding-bottom: 40px !important;
}

.p-45 {
	padding: 45px !important;
}

.pt-45 {
	padding-top: 45px !important;
}

.pb-45 {
	padding-bottom: 45px !important;
}

.pr-45 {
	padding-right: 45px !important;
}

.pl-45 {
	padding-left: 45px !important;
}

.px-45 {
	padding-left: 45px !important;
	padding-right: 45px !important;
}

.py-45 {
	padding-top: 45px !important;
	padding-bottom: 45px !important;
}

.p-50 {
	padding: 50px !important;
}

.pt-50 {
	padding-top: 50px !important;
}

.pb-50 {
	padding-bottom: 50px !important;
}

.pr-50 {
	padding-right: 50px !important;
}

.pl-50 {
	padding-left: 50px !important;
}

.px-50 {
	padding-left: 50px !important;
	padding-right: 50px !important;
}

.py-50 {
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}

.p-55 {
	padding: 55px !important;
}

.pt-55 {
	padding-top: 55px !important;
}

.pb-55 {
	padding-bottom: 55px !important;
}

.pr-55 {
	padding-right: 55px !important;
}

.pl-55 {
	padding-left: 55px !important;
}

.px-55 {
	padding-left: 55px !important;
	padding-right: 55px !important;
}

.py-55 {
	padding-top: 55px !important;
	padding-bottom: 55px !important;
}

.p-60 {
	padding: 60px !important;
}

.pt-60 {
	padding-top: 60px !important;
}

.pb-60 {
	padding-bottom: 60px !important;
}

.pr-60 {
	padding-right: 60px !important;
}

.pl-60 {
	padding-left: 60px !important;
}

.px-60 {
	padding-left: 60px !important;
	padding-right: 60px !important;
}

.py-60 {
	padding-top: 60px !important;
	padding-bottom: 60px !important;
}

.p-65 {
	padding: 65px !important;
}

.pt-65 {
	padding-top: 65px !important;
}

.pb-65 {
	padding-bottom: 65px !important;
}

.pr-65 {
	padding-right: 65px !important;
}

.pl-65 {
	padding-left: 65px !important;
}

.px-65 {
	padding-left: 65px !important;
	padding-right: 65px !important;
}

.py-65 {
	padding-top: 65px !important;
	padding-bottom: 65px !important;
}

.p-70 {
	padding: 70px !important;
}

.pt-70 {
	padding-top: 70px !important;
}

.pb-70 {
	padding-bottom: 70px !important;
}

.pr-70 {
	padding-right: 70px !important;
}

.pl-70 {
	padding-left: 70px !important;
}

.px-70 {
	padding-left: 70px !important;
	padding-right: 70px !important;
}

.py-70 {
	padding-top: 70px !important;
	padding-bottom: 70px !important;
}

.p-75 {
	padding: 75px !important;
}

.pt-75 {
	padding-top: 75px !important;
}

.pb-75 {
	padding-bottom: 75px !important;
}

.pr-75 {
	padding-right: 75px !important;
}

.pl-75 {
	padding-left: 75px !important;
}

.px-75 {
	padding-left: 75px !important;
	padding-right: 75px !important;
}

.py-75 {
	padding-top: 75px !important;
	padding-bottom: 75px !important;
}

.p-80 {
	padding: 80px !important;
}

.pt-80 {
	padding-top: 80px !important;
}

.pb-80 {
	padding-bottom: 80px !important;
}

.pr-80 {
	padding-right: 80px !important;
}

.pl-80 {
	padding-left: 80px !important;
}

.px-80 {
	padding-left: 80px !important;
	padding-right: 80px !important;
}

.py-80 {
	padding-top: 80px !important;
	padding-bottom: 80px !important;
}

.p-85 {
	padding: 85px !important;
}

.pt-85 {
	padding-top: 85px !important;
}

.pb-85 {
	padding-bottom: 85px !important;
}

.pr-85 {
	padding-right: 85px !important;
}

.pl-85 {
	padding-left: 85px !important;
}

.px-85 {
	padding-left: 85px !important;
	padding-right: 85px !important;
}

.py-85 {
	padding-top: 85px !important;
	padding-bottom: 85px !important;
}

.p-90 {
	padding: 90px !important;
}

.pt-90 {
	padding-top: 90px !important;
}

.pb-90 {
	padding-bottom: 90px !important;
}

.pr-90 {
	padding-right: 90px !important;
}

.pl-90 {
	padding-left: 90px !important;
}

.px-90 {
	padding-left: 90px !important;
	padding-right: 90px !important;
}

.py-90 {
	padding-top: 90px !important;
	padding-bottom: 90px !important;
}

.p-95 {
	padding: 95px !important;
}

.pt-95 {
	padding-top: 95px !important;
}

.pb-95 {
	padding-bottom: 95px !important;
}

.pr-95 {
	padding-right: 95px !important;
}

.pl-95 {
	padding-left: 95px !important;
}

.px-95 {
	padding-left: 95px !important;
	padding-right: 95px !important;
}

.py-95 {
	padding-top: 95px !important;
	padding-bottom: 95px !important;
}

.p-100 {
	padding: 100px !important;
}

.pt-100 {
	padding-top: 100px !important;
}

.pb-100 {
	padding-bottom: 100px !important;
}

.pr-100 {
	padding-right: 100px !important;
}

.pl-100 {
	padding-left: 100px !important;
}

.px-100 {
	padding-left: 100px !important;
	padding-right: 100px !important;
}

.py-100 {
	padding-top: 100px !important;
	padding-bottom: 100px !important;
}

/* gap
-------------------------------*/

/* grid
-------------------------------*/

.grid-1col > *,
.grid-2col > *,
.grid-3col > *,
.grid-4col > * {
	min-width: 0;
}

.grid-1col {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
}

.grid-2col {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.grid-3col {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.grid-4col {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}

/* Layout */

.l-body {
	width: 100%;
}

.l-body.is-fixed {
	position: fixed;
}

.l-header {
	padding: 1em;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background: #EEE;
}

.l-wrapper {
	position: relative;
	width: 87.2%;
	margin-left: auto;
	margin-right: auto;
}

/* Module */

.noscript {
	font-size: 16px;
	line-height: 1.4;
	text-align: center;
	padding: 1em;
	border: 3px solid red;
}

.noscript span {
	color: red;
}

.text-base {
	font-size: 1.6rem;
	line-height: 1.8;
}

.text-base p:not(:last-child),
.text-base ol:not(:last-child),
.text-base ul:not(:last-child) {
	margin-bottom: 1.8em;
}

.text-lg {
	font-size: 2rem;
	line-height: 1.8;
}

.text-lg p:not(:last-child),
.text-lg ol:not(:last-child),
.text-lg ul:not(:last-child) {
	margin-bottom: 1.8em;
}

.text-sm {
	font-size: 1.4rem;
	line-height: 1.8;
}

.text-sm p:not(:last-child),
.text-sm ol:not(:last-child),
.text-sm ul:not(:last-child) {
	margin-bottom: 1.8em;
}

.text-note {
	padding-left: 1em;
	text-indent: -1em;
}

.button-primary {
	background: #004ea2;
	color: #FFF;
	font-weight: 600;
	letter-spacing: 0.08em;
	border: none;
	width: 26rem;
	height: 4.5rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-shadow: none;
	box-shadow: none;
	border-radius: 5px;
	text-decoration: none;
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.button-primary::after {
	content: "";
	display: inline-block;
	width: 1rem;
	aspect-ratio: 1/1;
	background: url(../img/icon_ex.svg) no-repeat center/contain;
	margin-left: 0.6em;
}

.firstview {
	position: relative;
}

.firstview__catch {
	position: sticky;
	top: 0;
	right: 0;
	z-index: 10;
	width: 50%;
	height: 100vh;
	margin-left: auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.firstview__catch img {
	display: block;
}

.firstview__catch__inner {
	width: 66%;
	max-width: 500px;
	margin: 0 auto;
}

.firstview__inner {
	width: 100%;
	height: 100vh;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
	position: sticky;
	top: 0;
	left: 0;
}

.firstview__inner--1 {
	margin-top: -100vh;
}

.firstview__col {
	position: relative;
	width: 50%;
	height: 100%;
	background: #FFF;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.firstview__col--text {
	background: #004ea2;
}

.firstview__col--head {
	background: #f0893a;
}

.firstview__logo {
	width: 56.7%;
}

.firstview__logo img {
	display: block;
	width: 100%;
}

.firstview__image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.firstview__image::after {
	content: "";
	background: rgba(35, 24, 21, 0.2);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.firstview__image img {
	display: block;
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.firstview__lead {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
	color: #FFF;
	font-size: clamp(1.4rem, 0.4746987952rem + 1.2048192771vw, 1.8rem);
	font-weight: 500;
	line-height: 2;
}

.firstview__lead p:not(:last-child) {
	margin-left: 2em;
}

.catching-image {
	position: relative;
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	height: calc(100vh + 500px);
}

.catching-image__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
}

.catching-image__col {
	width: 50%;
	height: 100%;
}

.catching-image__col img {
	display: block;
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.news {
	background: #FFF;
}

.news__body {
	min-height: 100vh;
	padding: 60px 0;
	text-align: center;
	color: #004ea2;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: calc(100% - 50px);
	margin: 0 auto;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.news__label {
	font-family: "Lato", sans-serif;
	font-size: 2rem;
	margin-bottom: 30px;
}

.news__label::after {
	content: "";
	width: 1px;
	height: 20px;
	background: currentColor;
	display: block;
	margin: 10px auto;
}

.news__heading {
	font-size: 2.8rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.75;
	margin-bottom: 38px;
}

.news__text {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.04em;
}

.news__text p:not(:last-child) {
	margin-bottom: 2em;
}

.concept {
	position: relative;
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.concept__bg {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
	z-index: -1;
}

.concept__bg__col {
	width: 50%;
	height: 100%;
	position: relative;
}

.concept__bg__col img {
	display: block;
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.concept__bg__sp-white {
	display: block;
	width: 100%;
	height: 100%;
	background: #FFF;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
}

.concept__main-screen {
	padding-top: clamp(80px, (100vh - 590px) * 0.5, (100vh - 590px) * 0.5);
}

.concept__body {
	position: relative;
	background: rgba(255, 255, 255, 0.9);
	width: 1000px;
	max-width: calc(100% - 50px);
	min-height: 590px;
	margin: 0 auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	color: #2d465a;
}

.concept__head {
	width: 50%;
	padding-right: 0.7%;
	padding-bottom: 25px;
}

.concept__head img {
	display: block;
	width: 60%;
	margin: 0 auto;
}

.concept__main {
	width: 50%;
	padding: 80px 6%;
}

.concept__heading {
	position: relative;
	border-bottom: 1px solid #506478;
	padding-bottom: 40px;
	margin-bottom: 30px;
}

.concept__heading::after {
	content: "";
	display: block;
	width: 30px;
	height: 3px;
	background: #506478;
	position: absolute;
	bottom: 0;
	left: 0;
	-webkit-transform: translate(0, 50%);
	transform: translate(0, 50%);
}

.concept__heading__en {
	font-size: 1.4rem;
	font-weight: 300;
	font-family: "Lato", sans-serif;
	margin-bottom: 10px;
}

.concept__heading__jp {
	font-weight: 500;
	font-size: 2.4rem;
	letter-spacing: 0.1em;
}

.concept__text {
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.02em;
	text-align: justify;
}

.concept__footer {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.concept__footer__haze {
	height: 280px;
}

.concept__footer__col {
	width: 50%;
	position: relative;
}

.concept__footer__col--main {
	background: #FFF;
	opacity: 0;
}

.concept__footer__margin {
	height: 200px;
}

.footer {
	position: sticky;
	top: 0;
	left: 0;
	z-index: 10;
	height: 100vh;
	width: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	z-index: 10;
	opacity: 0;
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.footer.is-visible {
	opacity: 1;
}

.footer-logo {
	width: 25rem;
	margin-bottom: 15px;
}

.sns-link {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 18px;
	margin-top: 40px;
}

.sns-link__item a {
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.copyright {
	font-size: 1.4rem;
	color: #004ea2;
	position: absolute;
	bottom: 40px;
	left: 0;
	width: 100%;
	text-align: center;
}

@media (hover: hover) {

.button-primary:hover {
	background: #f0893a;
}

.sns-link__item a:hover {
	opacity: 0.6;
}

}

@media (min-aspect-ratio: 110/58) {

.firstview__lead {
	font-size: clamp(1.2rem, 3vh, 1.8rem);
}

}

@media screen and (min-width: 1000px) {

.text-left-pc { /* 767px以上 */
	text-align: left;
}

.text-center-pc { /* 767px以上 */
	text-align: center;
}

.text-right-pc { /* 767px以上 */
	text-align: right;
}

.l-wrapper { /* 767px以上 */
}

}

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

.text-left-sp { /* 767px以下 */
	text-align: left;
}

.text-center-sp { /* 767px以下 */
	text-align: center;
}

.text-right-sp { /* 767px以下 */
	text-align: right;
}

.sp-only { /* 767px以下 */
	display: block !important;
}

.sp-only-2 { /* 767px以下 */
	display: inline-block !important;
}

.pc-only { /* 767px以下 */
	display: none !important;
}

.pc-only-2 { /* 767px以下 */
	display: none !important;
}

/* 767px以下 */

.mt-0-sp {
	margin-top: 0px !important;
}

.mb-0-sp {
	margin-bottom: 0px !important;
}

.mr-0-sp {
	margin-right: 0px !important;
}

.ml-0-sp {
	margin-left: 0px !important;
}

.mx-0-sp {
	margin-left: 0px !important;
	margin-right: 0px !important;
}

.my-0-sp {
	margin-top: 0px !important;
	margin-bottom: 0px !important;
}

/* 767px以下 */

.mt-5-sp {
	margin-top: 5px !important;
}

.mb-5-sp {
	margin-bottom: 5px !important;
}

.mr-5-sp {
	margin-right: 5px !important;
}

.ml-5-sp {
	margin-left: 5px !important;
}

.mx-5-sp {
	margin-left: 5px !important;
	margin-right: 5px !important;
}

.my-5-sp {
	margin-top: 5px !important;
	margin-bottom: 5px !important;
}

/* 767px以下 */

.mt-10-sp {
	margin-top: 10px !important;
}

.mb-10-sp {
	margin-bottom: 10px !important;
}

.mr-10-sp {
	margin-right: 10px !important;
}

.ml-10-sp {
	margin-left: 10px !important;
}

.mx-10-sp {
	margin-left: 10px !important;
	margin-right: 10px !important;
}

.my-10-sp {
	margin-top: 10px !important;
	margin-bottom: 10px !important;
}

/* 767px以下 */

.mt-15-sp {
	margin-top: 15px !important;
}

.mb-15-sp {
	margin-bottom: 15px !important;
}

.mr-15-sp {
	margin-right: 15px !important;
}

.ml-15-sp {
	margin-left: 15px !important;
}

.mx-15-sp {
	margin-left: 15px !important;
	margin-right: 15px !important;
}

.my-15-sp {
	margin-top: 15px !important;
	margin-bottom: 15px !important;
}

/* 767px以下 */

.mt-20-sp {
	margin-top: 20px !important;
}

.mb-20-sp {
	margin-bottom: 20px !important;
}

.mr-20-sp {
	margin-right: 20px !important;
}

.ml-20-sp {
	margin-left: 20px !important;
}

.mx-20-sp {
	margin-left: 20px !important;
	margin-right: 20px !important;
}

.my-20-sp {
	margin-top: 20px !important;
	margin-bottom: 20px !important;
}

/* 767px以下 */

.mt-25-sp {
	margin-top: 25px !important;
}

.mb-25-sp {
	margin-bottom: 25px !important;
}

.mr-25-sp {
	margin-right: 25px !important;
}

.ml-25-sp {
	margin-left: 25px !important;
}

.mx-25-sp {
	margin-left: 25px !important;
	margin-right: 25px !important;
}

.my-25-sp {
	margin-top: 25px !important;
	margin-bottom: 25px !important;
}

/* 767px以下 */

.mt-30-sp {
	margin-top: 30px !important;
}

.mb-30-sp {
	margin-bottom: 30px !important;
}

.mr-30-sp {
	margin-right: 30px !important;
}

.ml-30-sp {
	margin-left: 30px !important;
}

.mx-30-sp {
	margin-left: 30px !important;
	margin-right: 30px !important;
}

.my-30-sp {
	margin-top: 30px !important;
	margin-bottom: 30px !important;
}

/* 767px以下 */

.mt-35-sp {
	margin-top: 35px !important;
}

.mb-35-sp {
	margin-bottom: 35px !important;
}

.mr-35-sp {
	margin-right: 35px !important;
}

.ml-35-sp {
	margin-left: 35px !important;
}

.mx-35-sp {
	margin-left: 35px !important;
	margin-right: 35px !important;
}

.my-35-sp {
	margin-top: 35px !important;
	margin-bottom: 35px !important;
}

/* 767px以下 */

.mt-40-sp {
	margin-top: 40px !important;
}

.mb-40-sp {
	margin-bottom: 40px !important;
}

.mr-40-sp {
	margin-right: 40px !important;
}

.ml-40-sp {
	margin-left: 40px !important;
}

.mx-40-sp {
	margin-left: 40px !important;
	margin-right: 40px !important;
}

.my-40-sp {
	margin-top: 40px !important;
	margin-bottom: 40px !important;
}

/* 767px以下 */

.mt-45-sp {
	margin-top: 45px !important;
}

.mb-45-sp {
	margin-bottom: 45px !important;
}

.mr-45-sp {
	margin-right: 45px !important;
}

.ml-45-sp {
	margin-left: 45px !important;
}

.mx-45-sp {
	margin-left: 45px !important;
	margin-right: 45px !important;
}

.my-45-sp {
	margin-top: 45px !important;
	margin-bottom: 45px !important;
}

/* 767px以下 */

.mt-50-sp {
	margin-top: 50px !important;
}

.mb-50-sp {
	margin-bottom: 50px !important;
}

.mr-50-sp {
	margin-right: 50px !important;
}

.ml-50-sp {
	margin-left: 50px !important;
}

.mx-50-sp {
	margin-left: 50px !important;
	margin-right: 50px !important;
}

.my-50-sp {
	margin-top: 50px !important;
	margin-bottom: 50px !important;
}

/* 767px以下 */

.mt-55-sp {
	margin-top: 55px !important;
}

.mb-55-sp {
	margin-bottom: 55px !important;
}

.mr-55-sp {
	margin-right: 55px !important;
}

.ml-55-sp {
	margin-left: 55px !important;
}

.mx-55-sp {
	margin-left: 55px !important;
	margin-right: 55px !important;
}

.my-55-sp {
	margin-top: 55px !important;
	margin-bottom: 55px !important;
}

/* 767px以下 */

.mt-60-sp {
	margin-top: 60px !important;
}

.mb-60-sp {
	margin-bottom: 60px !important;
}

.mr-60-sp {
	margin-right: 60px !important;
}

.ml-60-sp {
	margin-left: 60px !important;
}

.mx-60-sp {
	margin-left: 60px !important;
	margin-right: 60px !important;
}

.my-60-sp {
	margin-top: 60px !important;
	margin-bottom: 60px !important;
}

/* 767px以下 */

.mt-65-sp {
	margin-top: 65px !important;
}

.mb-65-sp {
	margin-bottom: 65px !important;
}

.mr-65-sp {
	margin-right: 65px !important;
}

.ml-65-sp {
	margin-left: 65px !important;
}

.mx-65-sp {
	margin-left: 65px !important;
	margin-right: 65px !important;
}

.my-65-sp {
	margin-top: 65px !important;
	margin-bottom: 65px !important;
}

/* 767px以下 */

.mt-70-sp {
	margin-top: 70px !important;
}

.mb-70-sp {
	margin-bottom: 70px !important;
}

.mr-70-sp {
	margin-right: 70px !important;
}

.ml-70-sp {
	margin-left: 70px !important;
}

.mx-70-sp {
	margin-left: 70px !important;
	margin-right: 70px !important;
}

.my-70-sp {
	margin-top: 70px !important;
	margin-bottom: 70px !important;
}

/* 767px以下 */

.mt-75-sp {
	margin-top: 75px !important;
}

.mb-75-sp {
	margin-bottom: 75px !important;
}

.mr-75-sp {
	margin-right: 75px !important;
}

.ml-75-sp {
	margin-left: 75px !important;
}

.mx-75-sp {
	margin-left: 75px !important;
	margin-right: 75px !important;
}

.my-75-sp {
	margin-top: 75px !important;
	margin-bottom: 75px !important;
}

/* 767px以下 */

.mt-80-sp {
	margin-top: 80px !important;
}

.mb-80-sp {
	margin-bottom: 80px !important;
}

.mr-80-sp {
	margin-right: 80px !important;
}

.ml-80-sp {
	margin-left: 80px !important;
}

.mx-80-sp {
	margin-left: 80px !important;
	margin-right: 80px !important;
}

.my-80-sp {
	margin-top: 80px !important;
	margin-bottom: 80px !important;
}

/* 767px以下 */

.mt-85-sp {
	margin-top: 85px !important;
}

.mb-85-sp {
	margin-bottom: 85px !important;
}

.mr-85-sp {
	margin-right: 85px !important;
}

.ml-85-sp {
	margin-left: 85px !important;
}

.mx-85-sp {
	margin-left: 85px !important;
	margin-right: 85px !important;
}

.my-85-sp {
	margin-top: 85px !important;
	margin-bottom: 85px !important;
}

/* 767px以下 */

.mt-90-sp {
	margin-top: 90px !important;
}

.mb-90-sp {
	margin-bottom: 90px !important;
}

.mr-90-sp {
	margin-right: 90px !important;
}

.ml-90-sp {
	margin-left: 90px !important;
}

.mx-90-sp {
	margin-left: 90px !important;
	margin-right: 90px !important;
}

.my-90-sp {
	margin-top: 90px !important;
	margin-bottom: 90px !important;
}

/* 767px以下 */

.mt-95-sp {
	margin-top: 95px !important;
}

.mb-95-sp {
	margin-bottom: 95px !important;
}

.mr-95-sp {
	margin-right: 95px !important;
}

.ml-95-sp {
	margin-left: 95px !important;
}

.mx-95-sp {
	margin-left: 95px !important;
	margin-right: 95px !important;
}

.my-95-sp {
	margin-top: 95px !important;
	margin-bottom: 95px !important;
}

/* 767px以下 */

.mt-100-sp {
	margin-top: 100px !important;
}

.mb-100-sp {
	margin-bottom: 100px !important;
}

.mr-100-sp {
	margin-right: 100px !important;
}

.ml-100-sp {
	margin-left: 100px !important;
}

.mx-100-sp {
	margin-left: 100px !important;
	margin-right: 100px !important;
}

.my-100-sp {
	margin-top: 100px !important;
	margin-bottom: 100px !important;
}

/* 767px以下 */

.mt-auto-sp {
	margin-top: auto !important;
}

.mb-auto-sp {
	margin-bottom: auto !important;
}

.mr-auto-sp {
	margin-right: auto !important;
}

.ml-auto-sp {
	margin-left: auto !important;
}

.mx-auto-sp {
	margin-left: auto !important;
	margin-right: auto !important;
}

.my-auto-sp {
	margin-top: auto !important;
	margin-bottom: auto !important;
}

/* 767px以下 */

.p-0-sp {
	padding: 0px !important;
}

.pt-0-sp {
	padding-top: 0px !important;
}

.pb-0-sp {
	padding-bottom: 0px !important;
}

.pr-0-sp {
	padding-right: 0px !important;
}

.pl-0-sp {
	padding-left: 0px !important;
}

.px-0-sp {
	padding-left: 0px !important;
	padding-right: 0px !important;
}

.py-0-sp {
	padding-top: 0px !important;
	padding-bottom: 0px !important;
}

/* 767px以下 */

.p-5-sp {
	padding: 5px !important;
}

.pt-5-sp {
	padding-top: 5px !important;
}

.pb-5-sp {
	padding-bottom: 5px !important;
}

.pr-5-sp {
	padding-right: 5px !important;
}

.pl-5-sp {
	padding-left: 5px !important;
}

.px-5-sp {
	padding-left: 5px !important;
	padding-right: 5px !important;
}

.py-5-sp {
	padding-top: 5px !important;
	padding-bottom: 5px !important;
}

/* 767px以下 */

.p-10-sp {
	padding: 10px !important;
}

.pt-10-sp {
	padding-top: 10px !important;
}

.pb-10-sp {
	padding-bottom: 10px !important;
}

.pr-10-sp {
	padding-right: 10px !important;
}

.pl-10-sp {
	padding-left: 10px !important;
}

.px-10-sp {
	padding-left: 10px !important;
	padding-right: 10px !important;
}

.py-10-sp {
	padding-top: 10px !important;
	padding-bottom: 10px !important;
}

/* 767px以下 */

.p-15-sp {
	padding: 15px !important;
}

.pt-15-sp {
	padding-top: 15px !important;
}

.pb-15-sp {
	padding-bottom: 15px !important;
}

.pr-15-sp {
	padding-right: 15px !important;
}

.pl-15-sp {
	padding-left: 15px !important;
}

.px-15-sp {
	padding-left: 15px !important;
	padding-right: 15px !important;
}

.py-15-sp {
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}

/* 767px以下 */

.p-20-sp {
	padding: 20px !important;
}

.pt-20-sp {
	padding-top: 20px !important;
}

.pb-20-sp {
	padding-bottom: 20px !important;
}

.pr-20-sp {
	padding-right: 20px !important;
}

.pl-20-sp {
	padding-left: 20px !important;
}

.px-20-sp {
	padding-left: 20px !important;
	padding-right: 20px !important;
}

.py-20-sp {
	padding-top: 20px !important;
	padding-bottom: 20px !important;
}

/* 767px以下 */

.p-25-sp {
	padding: 25px !important;
}

.pt-25-sp {
	padding-top: 25px !important;
}

.pb-25-sp {
	padding-bottom: 25px !important;
}

.pr-25-sp {
	padding-right: 25px !important;
}

.pl-25-sp {
	padding-left: 25px !important;
}

.px-25-sp {
	padding-left: 25px !important;
	padding-right: 25px !important;
}

.py-25-sp {
	padding-top: 25px !important;
	padding-bottom: 25px !important;
}

/* 767px以下 */

.p-30-sp {
	padding: 30px !important;
}

.pt-30-sp {
	padding-top: 30px !important;
}

.pb-30-sp {
	padding-bottom: 30px !important;
}

.pr-30-sp {
	padding-right: 30px !important;
}

.pl-30-sp {
	padding-left: 30px !important;
}

.px-30-sp {
	padding-left: 30px !important;
	padding-right: 30px !important;
}

.py-30-sp {
	padding-top: 30px !important;
	padding-bottom: 30px !important;
}

/* 767px以下 */

.p-35-sp {
	padding: 35px !important;
}

.pt-35-sp {
	padding-top: 35px !important;
}

.pb-35-sp {
	padding-bottom: 35px !important;
}

.pr-35-sp {
	padding-right: 35px !important;
}

.pl-35-sp {
	padding-left: 35px !important;
}

.px-35-sp {
	padding-left: 35px !important;
	padding-right: 35px !important;
}

.py-35-sp {
	padding-top: 35px !important;
	padding-bottom: 35px !important;
}

/* 767px以下 */

.p-40-sp {
	padding: 40px !important;
}

.pt-40-sp {
	padding-top: 40px !important;
}

.pb-40-sp {
	padding-bottom: 40px !important;
}

.pr-40-sp {
	padding-right: 40px !important;
}

.pl-40-sp {
	padding-left: 40px !important;
}

.px-40-sp {
	padding-left: 40px !important;
	padding-right: 40px !important;
}

.py-40-sp {
	padding-top: 40px !important;
	padding-bottom: 40px !important;
}

/* 767px以下 */

.p-45-sp {
	padding: 45px !important;
}

.pt-45-sp {
	padding-top: 45px !important;
}

.pb-45-sp {
	padding-bottom: 45px !important;
}

.pr-45-sp {
	padding-right: 45px !important;
}

.pl-45-sp {
	padding-left: 45px !important;
}

.px-45-sp {
	padding-left: 45px !important;
	padding-right: 45px !important;
}

.py-45-sp {
	padding-top: 45px !important;
	padding-bottom: 45px !important;
}

/* 767px以下 */

.p-50-sp {
	padding: 50px !important;
}

.pt-50-sp {
	padding-top: 50px !important;
}

.pb-50-sp {
	padding-bottom: 50px !important;
}

.pr-50-sp {
	padding-right: 50px !important;
}

.pl-50-sp {
	padding-left: 50px !important;
}

.px-50-sp {
	padding-left: 50px !important;
	padding-right: 50px !important;
}

.py-50-sp {
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}

/* 767px以下 */

.p-55-sp {
	padding: 55px !important;
}

.pt-55-sp {
	padding-top: 55px !important;
}

.pb-55-sp {
	padding-bottom: 55px !important;
}

.pr-55-sp {
	padding-right: 55px !important;
}

.pl-55-sp {
	padding-left: 55px !important;
}

.px-55-sp {
	padding-left: 55px !important;
	padding-right: 55px !important;
}

.py-55-sp {
	padding-top: 55px !important;
	padding-bottom: 55px !important;
}

/* 767px以下 */

.p-60-sp {
	padding: 60px !important;
}

.pt-60-sp {
	padding-top: 60px !important;
}

.pb-60-sp {
	padding-bottom: 60px !important;
}

.pr-60-sp {
	padding-right: 60px !important;
}

.pl-60-sp {
	padding-left: 60px !important;
}

.px-60-sp {
	padding-left: 60px !important;
	padding-right: 60px !important;
}

.py-60-sp {
	padding-top: 60px !important;
	padding-bottom: 60px !important;
}

/* 767px以下 */

.p-65-sp {
	padding: 65px !important;
}

.pt-65-sp {
	padding-top: 65px !important;
}

.pb-65-sp {
	padding-bottom: 65px !important;
}

.pr-65-sp {
	padding-right: 65px !important;
}

.pl-65-sp {
	padding-left: 65px !important;
}

.px-65-sp {
	padding-left: 65px !important;
	padding-right: 65px !important;
}

.py-65-sp {
	padding-top: 65px !important;
	padding-bottom: 65px !important;
}

/* 767px以下 */

.p-70-sp {
	padding: 70px !important;
}

.pt-70-sp {
	padding-top: 70px !important;
}

.pb-70-sp {
	padding-bottom: 70px !important;
}

.pr-70-sp {
	padding-right: 70px !important;
}

.pl-70-sp {
	padding-left: 70px !important;
}

.px-70-sp {
	padding-left: 70px !important;
	padding-right: 70px !important;
}

.py-70-sp {
	padding-top: 70px !important;
	padding-bottom: 70px !important;
}

/* 767px以下 */

.p-75-sp {
	padding: 75px !important;
}

.pt-75-sp {
	padding-top: 75px !important;
}

.pb-75-sp {
	padding-bottom: 75px !important;
}

.pr-75-sp {
	padding-right: 75px !important;
}

.pl-75-sp {
	padding-left: 75px !important;
}

.px-75-sp {
	padding-left: 75px !important;
	padding-right: 75px !important;
}

.py-75-sp {
	padding-top: 75px !important;
	padding-bottom: 75px !important;
}

/* 767px以下 */

.p-80-sp {
	padding: 80px !important;
}

.pt-80-sp {
	padding-top: 80px !important;
}

.pb-80-sp {
	padding-bottom: 80px !important;
}

.pr-80-sp {
	padding-right: 80px !important;
}

.pl-80-sp {
	padding-left: 80px !important;
}

.px-80-sp {
	padding-left: 80px !important;
	padding-right: 80px !important;
}

.py-80-sp {
	padding-top: 80px !important;
	padding-bottom: 80px !important;
}

/* 767px以下 */

.p-85-sp {
	padding: 85px !important;
}

.pt-85-sp {
	padding-top: 85px !important;
}

.pb-85-sp {
	padding-bottom: 85px !important;
}

.pr-85-sp {
	padding-right: 85px !important;
}

.pl-85-sp {
	padding-left: 85px !important;
}

.px-85-sp {
	padding-left: 85px !important;
	padding-right: 85px !important;
}

.py-85-sp {
	padding-top: 85px !important;
	padding-bottom: 85px !important;
}

/* 767px以下 */

.p-90-sp {
	padding: 90px !important;
}

.pt-90-sp {
	padding-top: 90px !important;
}

.pb-90-sp {
	padding-bottom: 90px !important;
}

.pr-90-sp {
	padding-right: 90px !important;
}

.pl-90-sp {
	padding-left: 90px !important;
}

.px-90-sp {
	padding-left: 90px !important;
	padding-right: 90px !important;
}

.py-90-sp {
	padding-top: 90px !important;
	padding-bottom: 90px !important;
}

/* 767px以下 */

.p-95-sp {
	padding: 95px !important;
}

.pt-95-sp {
	padding-top: 95px !important;
}

.pb-95-sp {
	padding-bottom: 95px !important;
}

.pr-95-sp {
	padding-right: 95px !important;
}

.pl-95-sp {
	padding-left: 95px !important;
}

.px-95-sp {
	padding-left: 95px !important;
	padding-right: 95px !important;
}

.py-95-sp {
	padding-top: 95px !important;
	padding-bottom: 95px !important;
}

/* 767px以下 */

.p-100-sp {
	padding: 100px !important;
}

.pt-100-sp {
	padding-top: 100px !important;
}

.pb-100-sp {
	padding-bottom: 100px !important;
}

.pr-100-sp {
	padding-right: 100px !important;
}

.pl-100-sp {
	padding-left: 100px !important;
}

.px-100-sp {
	padding-left: 100px !important;
	padding-right: 100px !important;
}

.py-100-sp {
	padding-top: 100px !important;
	padding-bottom: 100px !important;
}

/* 767px以下 */

.grid-1col-sp {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
}

.grid-2col-sp {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.grid-3col-sp {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.grid-4col-sp {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}

.l-navi { /* 767px以下 */
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #114170;
	color: #FFF;
	z-index: 100;
}

.button-primary { /* 767px以下 */
	width: 20.8rem;
	font-size: 1.3rem;
}

.firstview__catch { /* 767px以下 */
	width: 100%;
	height: 100vh;
	display: block;
}

.firstview__catch__inner { /* 767px以下 */
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 100%;
	height: 50vh;
	max-width: initial;
	padding: 10vh 25.5vw;
}

.firstview__catch__inner picture {
	width: 100%;
	height: 100%;
}

.firstview__catch__inner img {
	display: block;
	-o-object-fit: contain;
	object-fit: contain;
	width: 100%;
	height: 100%;
	max-width: initial;
	-webkit-transform: translateY(5%);
	transform: translateY(5%);
}

.firstview__main { /* 767px以下 */
	margin-top: -100vh;
}

.firstview__inner { /* 767px以下 */
	display: contents;
	height: auto;
}

.firstview__inner--1 { /* 767px以下 */
	margin-top: 0;
}

.firstview__col { /* 767px以下 */
	width: 100%;
	height: 50vh;
	position: sticky;
}

.firstview__col:nth-child(odd) {
	z-index: 5;
	top: 0;
}

.firstview__col:nth-child(even) {
	z-index: 10;
	top: 50vh;
}

.firstview__col--text { /* 767px以下 */
	background: #f0893a;
}

.firstview__col--head { /* 767px以下 */
	background: #004ea2;
	margin-top: -50vh;
}

.firstview__logo { /* 767px以下 */
	width: 52%;
	-webkit-transform: translateX(-10px);
	transform: translateX(-10px);
	padding-bottom: calc(100vh - 100svh);
}

.firstview__lead { /* 767px以下 */
	text-align: center;
	-webkit-writing-mode: horizontal-tb;
	-ms-writing-mode: lr-tb;
	writing-mode: horizontal-tb;
	font-size: 1.3rem;
	line-height: 1.5;
	letter-spacing: 0.02em;
	padding: 20px 0;
}

.firstview__lead p:not(:last-child) { /* 767px以下 */
	margin-left: 0;
	margin-bottom: 1.5em;
}

.catching-image { /* 767px以下 */
	height: calc(100vh + 300px);
}

.catching-image__inner { /* 767px以下 */
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.catching-image__col { /* 767px以下 */
	width: 100%;
	height: 50%;
}

.news__body { /* 767px以下 */
	width: 87.2%;
}

.news__label { /* 767px以下 */
	font-size: 1.6rem;
	margin-bottom: 26px;
}

.news__label::after { /* 767px以下 */
	height: 10px;
	margin: 8px auto 0;
}

.news__heading { /* 767px以下 */
	font-size: 2rem;
	line-height: 1.5;
	margin-bottom: 23px;
}

.news__text { /* 767px以下 */
	font-size: 1.3rem;
	line-height: 1.615384;
	text-align: justify;
}

.news__text p:not(:last-child) { /* 767px以下 */
	margin-bottom: 1.615384em;
}

.concept__bg { /* 767px以下 */
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.concept__bg__col { /* 767px以下 */
	width: 100%;
	height: 50%;
}

.concept__main-screen { /* 767px以下 */
	padding-top: 24px;
}

.concept__body { /* 767px以下 */
	width: 87.2%;
	height: calc(100vh - 48px);
	min-height: 580px;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.concept__head { /* 767px以下 */
	width: 100%;
	height: 50%;
	padding-bottom: 0;
	padding-right: 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.concept__main { /* 767px以下 */
	width: 100%;
	height: 50%;
	padding: 30px 9%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.concept__heading { /* 767px以下 */
	padding-bottom: 16px;
	margin-bottom: 11px;
}

.concept__heading__en { /* 767px以下 */
	font-size: 1.2rem;
	margin-bottom: 7px;
}

.concept__heading__jp { /* 767px以下 */
	font-size: 1.8rem;
}

.concept__text { /* 767px以下 */
	font-size: 1.3rem;
	line-height: 1.53;
}

.concept__footer { /* 767px以下 */
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.concept__footer__haze { /* 767px以下 */
	height: calc(50vh + 250px);
}

.concept__footer__col { /* 767px以下 */
	width: 100%;
}

.concept__footer__col--main { /* 767px以下 */
	height: auto;
	opacity: 1 !important;
	background: none;
}

.concept__footer__margin { /* 767px以下 */
	height: 0;
}

.footer { /* 767px以下 */
	height: 50vh;
	opacity: 1;
	margin-top: 100px;
}

.footer-logo { /* 767px以下 */
	width: 20rem;
	margin-bottom: 10px;
}

.sns-link { /* 767px以下 */
	margin-top: 25px;
	-webkit-transform: scale(0.87);
	transform: scale(0.87);
}

.copyright { /* 767px以下 */
	bottom: 10px;
}

}

@media screen and (max-width: 999px) and (max-aspect-ratio: 375/315) {

.firstview__lead {
	font-size: clamp(1.2rem, 2.05vh, 1.8rem);
}

}

