@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Noto+Sans+JP:wght@100..900&display=swap');
html {
  font-size: 62.5%;
}
img, figure {
  width: 100%;
  height: auto;
}
a {
  text-decoration: none;
  color: #464646;
}
button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}
ruby rt {
  font-size: 0.4em;
  letter-spacing: 0.1em;
  text-align: center;
  position: relative;
  left: 0;
  bottom: -0.2em;
  line-height: 1;
}
em {
  font-style: normal;
  font-weight: 600;
}

sup, sub {
  font-size: 0.6em;
}

ol, ul, li {
  list-style: none;
  padding: 0;
  margin: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 400;
  font-style: normal;
}
* {
  min-width: 0;
  min-height: 0;
}
body {
  padding: 0;
  margin: 0;
  background: #fff;
  position: relative;
  color: #000;
  font-feature-settings: "palt" 1;
  letter-spacing: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  min-width: 100%;
  line-height: 1;
}

body#page::after {
  content: "";
  background-image: url("/images/common/bg.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position:center top;
	top:0;
	left: 0;
	position: fixed;
	width:100vw;
	height: 100vh;
	z-index: 1;
}

@media screen and (max-width:750px) {
body#page::after {
  content: "";
  background-image: url("/images/common/bg_sp.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position:center top;
	top:0;
	left: 0;
	position: fixed;
	width:100vw;
	height: 100vh;
	z-index: 1;
}
}
/*=================================
	common_setting
=================================*/
@media screen and (min-width:751px) {
  .pc_none {
    display: none !important;
  }
}
@media screen and (max-width:750px) {
  .sp_none {
    display: none !important;
  }
}

.clearfix:after {
  content: " ";
  display: block;
  clear: both;
}
.object-fit-img {
  object-fit: cover !important;
  width: 100% !important;
  height: 100% !important;
}
.object-fit-img.contain {
  object-fit: contain !important;
  width: 100% !important;
  height: 100% !important;
}

/*=================================
	font
=================================*/
.font-mont {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

/*=================================
	header
=================================*/

header{
	position: fixed;
	top:0;
	left: 0;
	height: 100px;
	width:100%;
	z-index: 101;
}

header .head_inbox{
	display: flex;
	justify-content: space-between;
	align-items: center;
	width:100%;
	height: 100px;
}

#page header .head_inbox{
	position: relative;
}

#page header .head_inbox::after{
	content: "";
	width:100%;
	height: 100%;
	position: absolute;
	top:0;
	left:0;
	background:rgba(255,255,255,0.5);
	z-index:1;
	backdrop-filter: blur(5px);
}

header .head_inbox .logo{
	position:relative;
	z-index: 2;
	margin-left: 2.5vw;
}

header .head_inbox .logo a{
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

header .head_inbox .logo figure{
	width:320px;
	position: relative;
}

header .head_inbox .logo figure .logo2{
	position: absolute;
	top:0;
	left:0;
	width:100%;
	opacity: 0;
}

#page header .head_inbox .logo figure img:nth-child(1){
	opacity: 0;
}

#page header .head_inbox .logo figure .logo2{
	opacity: 1;
}

header .head_inbox .logo span{
	font-size: 1.4rem;
	font-weight: 500;
	color:#fff;
	line-height: 1.4em;
	padding-left: 15px;
	margin-left: 15px;
	display: inline-block;
	border-left: 1px solid #fff;
	margin-bottom: 13px;
}

#page header .head_inbox .logo span{
	color:#000;
	border-left: 1px solid #000;
}

header nav{
	position: fixed;
	z-index: 3;
	top:0;
	right:-100vw;
	padding-top:20px;
	padding-bottom:20px;
	padding-right:150px;
	padding-left:max(2.5vw,100px);
	background:#005eae;
	height: 100dvh;
	max-width: 100vw;
	width:auto;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	transition: right 0.5s;
}

.overray{
	width:100vw;
	height: 100dvh;
	position: fixed;
	top:0;
	left:0;
	background:rgba(70,150,210,0.8);
	mix-blend-mode: multiply;
	transition:opacity 0.3s;
	pointer-events: none;
	opacity: 0;
	z-index: 100;
}

header nav.active{
	right: 0;
}

.overray.active{
	opacity: 1;
	pointer-events: auto;
	
}

header nav ul{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 2;
}

header nav ul li{
	height: auto;
	width:100%;
	border-bottom:1px dotted #4696d2;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	padding:20px 0;
}

header nav ul li a{
	font-size: 1.2rem;
	font-weight: 500;
	color:#fff;
	letter-spacing: 0.05em;
	padding-left: 30px;
	position: relative;
	display: inline-block;
}

header nav ul li a::before{
	content: "";
	width:10px;
	height: 10px;
	border:1px solid #a2cae8;
	border-radius: 50%;
	display: block;
	transform: scale(1);
	transition: all 0.3s;
	position: absolute;
	top:calc(50% - 5px);
	left:0;
}

header nav ul li a:hover::before{
	transform: scale(2);
	background:#a2cae8;
}

header nav ul li a span{
	font-size:1.6em;
	font-weight: 600;
	margin-right: 1em;
}

header nav ul li .acbox{
	position: relative;
	width:100%;
}

header nav ul li .acbox a{
	position: relative;
	z-index: 1;
}

header nav ul li .acbox button{
	position: absolute;
	z-index: 2;
	width:20px;
	height: 20px;
	background:url("/images/common/plus.svg");
	background-size: contain;
	background-repeat: no-repeat;
	right:0;
	top:calc(50% - 10px);
}

header nav ul li .acbox button.active{
	position: absolute;
	z-index: 2;
	width:20px;
	height: 20px;
	background:url("/images/common/minus.svg");
	background-size: contain;
	background-repeat: no-repeat;
	right:0;
	top:calc(50% - 10px);
}

header nav ul li .acbox .button{
	position: relative;
	z-index: 2;
	width:20px;
	height: 20px;
}

header nav ul li .accont{
	display: flex;
	flex-wrap: wrap;
	gap:10px;
	width:100%;
	padding-top:0;
	padding-left: 30px;
}

header nav ul li .accont .box{
	width:calc(50% - 10px);
}

header nav ul li .accont a{
	font-size: 1.4rem;
	padding-left: 20px;
}

header nav ul li .accont a span{
	font-size: 1.4rem;
}

header nav ul li .accont a::before{
	content: "";
	width:10px;
	height: 10px;
	border:1px solid #fff;
	background:#fff;
	border-radius: 50%;
	display: block;
	transform: scale(1);
	transition: all 0.3s;
	position: absolute;
	top:calc(50% - 5px);
	left:0;
}

header nav ul li .accont a:hover::before{
	transform: scale(1.5);
	background:#fff;
}


header nav ul li .accontainer{
	margin-top:0;
	padding:0;
	display: grid;
    transition: all 0.5s;
    grid-template-rows: 0fr;
	overflow: hidden;
	width:100%;
}

header nav ul li .accontainer.active{
	margin-top:15px;
	grid-template-rows: 1fr;
}

header nav .linkbtnbox{
	margin-top:20px;
}

header nav .linkbtnbox a{
	font-size: 1.4rem;
	color:#fff;
	font-weight: 400;
	letter-spacing: 0.1em;
}

header nav .linkbtnbox a::before{
	content: "";
	width:1em;
	height: 1em;
	background:url("/images/common/blank_icon.svg");
	background-size: contain;
	display: inline-block;
	margin-right: 0.5em;
	vertical-align: middle;
	position: relative;
	top:-0.1em;
}

header .entry_btn{
	position:fixed;
	top:120px;
	right:2.5vw;
	z-index: 11;
}

header .entry_btn a{
	width:60px;
	border-radius: 9999px;
	background:#fff;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	font-weight: 700;
	color:#005eae;
	font-size: 1.8rem;
	padding:30px 0;
	letter-spacing: 0.2em;
	transition: background 0.3s, color 0.3s;
}

header .entry_btn a p{
	writing-mode: vertical-rl;
}

#page header .entry_btn a{
	background:#005eae;
	color:#fff;
}

header .entry_btn a:hover{
	color:#fff;
	background:#005eae;
}

#page header .entry_btn a:hover,
header .entry_btn.active a{
	color:#005eae !important;
	background:#fff !important;
}

header .entry_btn a span{
	display: inline-block;
	width:14px;
	height: 20px;
	margin-bottom: 10px;
	right:2px;
	position: relative;
}

header .entry_btn a span svg{
	fill:#005eae;
	transition: all 0.1s;
}

#page header .entry_btn a span svg{
	fill:#fff;
}

header .entry_btn a:hover span svg{
	fill:#fff;
}

#page header .entry_btn a:hover span svg,
header .entry_btn.active a span svg{
	fill:#005eae !important;
}

header .entry_btn.active a{
	transition: opacity 0.1s;
}

header .entry_btn.active a:hover{
	opacity: 0.8;
}

@media screen and (max-width:750px) {
header{
	position: fixed;
	top:0;
	left: 0;
	height: 75px;
	width:100%;
	z-index: 101;
}

header .head_inbox{
	display: flex;
	justify-content: space-between;
	align-items: center;
	width:100%;
	height: 75px;
}

#page header .head_inbox{
	position: relative;
}

#page header .head_inbox::after{
	content: "";
	width:100%;
	height: 100%;
	position: absolute;
	top:0;
	left:0;
	background:rgba(255,255,255,0.5);
	z-index:1;
	backdrop-filter: blur(5px);
}

header .head_inbox .logo{
	position:relative;
	z-index: 2;
	margin-left: 2.5vw;
}

header .head_inbox .logo a{
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

header .head_inbox .logo figure{
	width:175px;
	position: relative;
}

header .head_inbox .logo figure .logo2{
	position: absolute;
	top:0;
	left:0;
	width:100%;
	opacity: 0;
}

#page header .head_inbox .logo figure img:nth-child(1){
	opacity: 0;
}

#page header .head_inbox .logo figure .logo2{
	opacity: 1;
}

header .head_inbox .logo span{
	font-size:0.9rem;
	font-weight: 500;
	color:#fff;
	line-height: 1.4em;
	padding-left: 10px;
	margin-left: 10px;
	display: inline-block;
	border-left: 1px solid #fff;
	margin-bottom: 13px;
}

#page header .head_inbox .logo span{
	color:#000;
	border-left: 1px solid #000;
}

header nav{
	position: fixed;
	z-index: 3;
	top:0;
	right:-100vw;
	padding-top:75px;
	padding-bottom:30px;
	padding-right:0;
	padding-left:0;
	background:#005eae;
	height: 100dvh;
	max-width: 100vw;
	width:100vw;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	transition: right 0.5s;
}

.overray{
	width:100vw;
	height: 100dvh;
	position: fixed;
	top:0;
	left:0;
	background:rgba(70,150,210,0.8);
	mix-blend-mode: multiply;
	transition:opacity 0.3s;
	pointer-events: none;
	opacity: 0;
	z-index: 100;
}

header nav.active{
	right: 0;
}
	
header nav .innav{
	height: calc(100dvh - 30px);
	overflow: auto;
	padding:0 5vw;
	width:100%;
}

.overray.active{
	opacity: 1;
	pointer-events: auto;
	
}

header nav ul{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 2;
	width:100%;
}

header nav ul li{
	height: auto;
	width:100%;
	border-bottom:1px dotted #4696d2;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	padding:20px 0;
}

header nav ul li a{
	font-size: 1.2rem;
	font-weight: 500;
	color:#fff;
	letter-spacing: 0.05em;
	padding-left: 30px;
	position: relative;
	display: inline-block;
}

header nav ul li a::before{
	content: "";
	width:10px;
	height: 10px;
	border:1px solid #a2cae8;
	border-radius: 50%;
	display: block;
	transform: scale(1);
	transition: all 0.3s;
	position: absolute;
	top:calc(50% - 5px);
	left:0;
}

header nav ul li a:hover::before{
	transform: scale(2);
	background:#a2cae8;
}

header nav ul li a span{
	font-size:1.6em;
	font-weight: 600;
	margin-right: 1em;
	display: block;
	margin-bottom: 0.3em;
}

header nav ul li .acbox{
	position: relative;
	width:100%;
}

header nav ul li .acbox a{
	position: relative;
	z-index: 1;
}

header nav ul li .acbox button{
	position: absolute;
	z-index: 2;
	width:20px;
	height: 20px;
	background:url("/images/common/plus.svg");
	background-size: contain;
	background-repeat: no-repeat;
	right:0;
	top:calc(50% - 10px);
}

header nav ul li .acbox button.active{
	position: absolute;
	z-index: 2;
	width:20px;
	height: 20px;
	background:url("/images/common/minus.svg");
	background-size: contain;
	background-repeat: no-repeat;
	right:0;
	top:calc(50% - 10px);
}

header nav ul li .acbox .button{
	position: relative;
	z-index: 2;
	width:20px;
	height: 20px;
}

header nav ul li .accont{
	display: flex;
	flex-wrap: wrap;
	gap:10px;
	width:100%;
	padding-top:0;
	padding-left: 30px;
}

header nav ul li .accont .box{
	width:100%;
}

header nav ul li .accont a{
	font-size: 1.4rem;
	padding-left: 20px;
}

header nav ul li .accont a span{
	font-size: 1.4rem;
}

header nav ul li .accont a::before{
	content: "";
	width:10px;
	height: 10px;
	border:1px solid #fff;
	background:#fff;
	border-radius: 50%;
	display: block;
	transform: scale(1);
	transition: all 0.3s;
	position: absolute;
	top:calc(50% - 5px);
	left:0;
}

header nav ul li .accont a:hover::before{
	transform: scale(1.5);
	background:#fff;
}


header nav ul li .accontainer{
	margin-top:0;
	padding:0;
	display: grid;
    transition: all 0.5s;
    grid-template-rows: 0fr;
	overflow: hidden;
	width:100%;
}

header nav ul li .accontainer.active{
	margin-top:15px;
	grid-template-rows: 1fr;
}

header nav .linkbtnbox{
	margin-top:20px;
}

header nav .linkbtnbox a{
	font-size: 1.4rem;
	color:#fff;
	font-weight: 400;
	letter-spacing: 0.1em;
}

header nav .linkbtnbox a::before{
	content: "";
	width:1em;
	height: 1em;
	background:url("/images/common/blank_icon.svg");
	background-size: contain;
	display: inline-block;
	margin-right: 0.5em;
	vertical-align: middle;
	position: relative;
	top:-0.1em;
}

header .entry_btn{
	position:relative;
	top:0;
	right:0;
	z-index: 11;
	width:100%;
	margin-top:40px;
}

header .entry_btn a{
	width:100%;
	height: 60px;
	border-radius: 9999px;
	background:#fff;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
	font-weight: 700;
	color:#005eae;
	font-size: 1.8rem;
	padding:30px 0;
	letter-spacing: 0.2em;
	transition: background 0.1s, color 0.1s;
}

header .entry_btn a p{
	writing-mode: horizontal-tb;
}

#page header .entry_btn a{
	background:#005eae;
	color:#fff;
}

header .entry_btn a:hover{
	color:#fff;
	background:#005eae;
}

#page header .entry_btn a:hover,
header .entry_btn.active a{
	color:#005eae !important;
	background:#fff !important;
}

header .entry_btn a span{
	display: inline-block;
	width:14px;
	height: 20px;
	margin-bottom: 0;
	margin-right: 10px;
	right:0;
	top:2px;
	position: relative;
}

header .entry_btn a span svg{
	fill:#005eae;
	transition: all 0.1s;
}

#page header .entry_btn a span svg{
	fill:#fff;
}

header .entry_btn a:hover span svg{
	fill:#fff;
}

#page header .entry_btn a:hover span svg,
header .entry_btn.active a span svg{
	fill:#005eae !important;
}

header .entry_btn.active a{
	transition: opacity 0.1s;
}

header .entry_btn.active a:hover{
	opacity: 0.8;
}
}

/*=================================
	menu-trigger
=================================*/
header .menu {
  height: 60px;
  width: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 0;
  border-radius:50%;
  font-weight: 600;
  background:#fff;
  line-height: 1.7em;
  text-align: center;
  letter-spacing: 0.05em;
  margin: 0 2.5vw 0 0;
  cursor: pointer;
  z-index: 11;
  position: relative;
	transition: 0.3s;
}

#page header .menu,
header .menu:hover{
  background:#005eae;
}

#page header .menu:hover{
  background:#fff;
}

header .menu figure{
  position: absolute;
  top:0;
  left:0;
  padding:19px;
  width:100%;
}

header .menu.active{
  background:#fff !important;
}

header .menu.active figure{
  opacity: 0;
}

header .menu figure svg{
  fill:#005eae;
}

#page header .menu figure svg,
header .menu:hover figure svg{
  fill:#fff;
}


#page header .menu:hover figure svg{
  fill:#005eae;
}

header .menu-trigger {
  position: relative;
  width: 25px;
  height: 25px;
  z-index: 5;
	opacity: 0;
}

header .menu.active .menu-trigger {
  opacity: 1;
}
header .menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #005eae;
  border-radius: 0px;
}
header .menu-trigger span:nth-of-type(1) {
  top: 0;
}
header .menu-trigger span:nth-of-type(2) {
  top: 7.5px;
  opacity: 0;
}
header .menu-trigger span:nth-of-type(3) {
  bottom: 0;
}
header .menu-trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(11.5px) rotate(45deg);
  transform: translateY(11.5px) rotate(45deg);
}
header .menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
header .menu-trigger.active span:nth-of-type(3) {
  -webkit-transform: translateY(-11.5px) rotate(-45deg);
  transform: translateY(-11.5px) rotate(-45deg);
  width: 100% !important;
  margin: 0 0 0 0;
}

@media screen and (max-width:750px) {
header .menu {
  height: 45px;
  width: 45px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 0;
  border-radius:50%;
  font-weight: 600;
  background:#fff;
  line-height: 1.7em;
  text-align: center;
  letter-spacing: 0.05em;
  margin: 0 2.5vw 0 0;
  cursor: pointer;
  z-index: 11;
  position: relative;
}

header .menu figure{
  position: absolute;
  top:0;
  left:0;
  padding:13px;
  width:100%;
}
}

/*=================================
	footer
=================================*/
footer{
	background:#000;
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 2;
}

footer .rightbox{
	width:50%;
	padding:70px 5vw 50px;
	display: flex;
	justify-content: center;
	flex-direction: column;
	align-items: center;
}

footer .rightbox .innerbox{
	display: flex;
	flex-direction: column;
	height: 100%;
}

footer .rightbox .innerbox .logo{
	margin-bottom: 40px;
}

footer .rightbox .innerbox .logo a{
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

footer .rightbox .innerbox .logo figure{
	width:300px;
	position: relative;
}

footer .rightbox .innerbox .logo span{
	font-size: 1.6rem;
	font-weight: 500;
	color:#fff;
	line-height: 1.4em;
	padding-left: 15px;
	margin-left: 15px;
	display: inline-block;
	border-left: 1px solid #fff;
	margin-bottom: 13px;
}

footer .rightbox .innerbox nav ul{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

footer .rightbox .innerbox nav ul li{
	height: auto;
	width:100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	margin-bottom: 30px;
}

footer .rightbox .innerbox nav ul li a{
	font-size: 1.6rem;
	font-weight: 500;
	color:#fff;
	letter-spacing: 0.05em;
	padding-left: 25px;
	position: relative;
	display: inline-block;
}

footer .rightbox .innerbox nav ul li a::before{
	content: "";
	width:10px;
	height: 10px;
	border:1px solid #4696d2;
	border-radius: 50%;
	display: block;
	transform: scale(1);
	transition: all 0.3s;
	position: absolute;
	top:calc(50% - 5px);
	left:0;
}

footer .rightbox .innerbox nav ul li a:hover::before{
	transform: scale(2);
	background:#4696d2;
}

footer .rightbox .innerbox .linkbtnbox{
	margin-top:auto;
}


footer .rightbox .innerbox .linkbtnbox .copy{
	font-size: 1rem;
	color:#fff;
	letter-spacing: 0.1em;
	margin-top:30px;
}

footer .leftbox{
	width:50%;
	border-left: 1px solid #fff;
	background-image:url("/images/common/footer_bg.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	display: flex;
	flex-wrap: wrap;
}

footer .leftbox a{
	width:50%;
	height: 280px;
	display: flex;
	align-items: center;
	padding:0 45px;
	position: relative;
	overflow: hidden;
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: 0.3em;
	color:#fff;
}

footer .leftbox a::after{
	content: "";
	width:100%;
	height: 100%;
	position: absolute;
	top:0;
	left:0;
	background:rgba(70,150,210,0.4);
	mix-blend-mode:multiply;
	z-index: 1;
}

footer .leftbox a::before{
	content: "";
	width:100%;
	padding-top: 100%;
	clip-path: polygon(100% calc(100% - 30px), calc(100% - 30px) 100%, 100% 100%);
	position: absolute;
	bottom:0;
	right:0;
	z-index: 1;
	background:rgba(70,150,210,0.5);
	mix-blend-mode:multiply;
	transform: scale(1);
	transform-origin: right bottom;
	transition: all 0.45s;
}

footer .leftbox a:hover::before{
	transform: scale(3);
	clip-path: polygon(100% 0, 0 100%, 100% 100%);
}

footer .leftbox a .inbox{
	display: flex;
	flex-direction: column;
	position: relative;
	z-index: 3;
}

footer .leftbox a:nth-child(2){
	border-left:1px solid #fff;
}

footer .leftbox a:nth-child(3){
	border-top:1px solid #fff;
	width:100%;
	height: 480px;
	font-size: 2rem;
}

footer .leftbox a span{
	font-size: 5rem;
	font-weight: 400;
	letter-spacing: 0;
	margin-bottom: 0.2em;
}

footer .leftbox a:nth-child(3) span{
	font-size: 8rem;
}

@media screen and (max-width:750px) {
footer{
	background:#000;
	display: flex;
	justify-content: space-between;
	position: relative;
	flex-direction: column;
	z-index: 2;
}

footer .rightbox{
	width:100%;
	padding:50px 5vw 30px;
	display: flex;
	justify-content: center;
	flex-direction: column;
	align-items: flex-start;
	order: 1;
}

footer .rightbox .innerbox{
	display: flex;
	flex-direction: column;
	height:auto;
	width:100%;
}

footer .rightbox .innerbox .logo{
	margin-bottom: 30px;
	width:100%;
	display: flex;
	justify-content: flex-start;
}

footer .rightbox .innerbox .logo a{
	display: flex;
	justify-content: center;
	align-items: flex-end;
}

footer .rightbox .innerbox .logo figure{
	width:200px;
	position: relative;
}

footer .rightbox .innerbox .logo span{
	font-size: 1rem;
	font-weight: 500;
	color:#fff;
	line-height: 1.4em;
	padding-left: 15px;
	margin-left: 15px;
	display: inline-block;
	border-left: 1px solid #fff;
	margin-bottom: 13px;
}

footer .rightbox .innerbox nav ul{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

footer .rightbox .innerbox nav ul li{
	height: auto;
	width:100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	margin-bottom: 30px;
}

footer .rightbox .innerbox nav ul li a{
	font-size: 1.6rem;
	font-weight: 500;
	color:#fff;
	letter-spacing: 0.05em;
	padding-left: 25px;
	position: relative;
	display: inline-block;
}

footer .rightbox .innerbox nav ul li a::before{
	content: "";
	width:10px;
	height: 10px;
	border:1px solid #4696d2;
	border-radius: 50%;
	display: block;
	transform: scale(1);
	transition: all 0.3s;
	position: absolute;
	top:calc(50% - 5px);
	left:0;
}

footer .rightbox .innerbox nav ul li a:hover::before{
	transform: scale(2);
	background:#4696d2;
}

footer .rightbox .innerbox .linkbtnbox{
	margin-top:20px;
}


footer .rightbox .innerbox .linkbtnbox .copy{
	font-size: 1rem;
	color:#fff;
	letter-spacing: 0.1em;
	margin-top:30px;
	text-align: center;
}

footer .leftbox{
	width:100%;
	border-left: none;
	background-image:url("/images/common/footer_bg.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	display: flex;
	flex-wrap: wrap;
}

footer .leftbox a{
	width:50%;
	height: 100px;
	display: flex;
	align-items: center;
	padding:0 7vw;
	position: relative;
	overflow: hidden;
	font-size: 1.4rem;
	font-weight: 600;
	letter-spacing: 0.3em;
	color:#fff;
}

footer .leftbox a::after{
	content: "";
	width:100%;
	height: 100%;
	position: absolute;
	top:0;
	left:0;
	background:rgba(70,150,210,0.4);
	mix-blend-mode:multiply;
	z-index: 1;
}

footer .leftbox a::before{
	content: "";
	width:100%;
	padding-top: 100%;
	clip-path: polygon(100% calc(100% - 30px), calc(100% - 30px) 100%, 100% 100%);
	position: absolute;
	bottom:0;
	right:0;
	z-index: 1;
	background:rgba(70,150,210,0.5);
	mix-blend-mode:multiply;
	transform: scale(1);
	transform-origin: right bottom;
	transition: all 0.45s;
}

footer .leftbox a:hover::before{
	transform: scale(3);
	clip-path: polygon(100% 0, 0 100%, 100% 100%);
}

footer .leftbox a .inbox{
	display: flex;
	flex-direction: column;
	position: relative;
	z-index: 3;
}

footer .leftbox a:nth-child(2){
	border-left:1px solid #fff;
}

footer .leftbox a:nth-child(3){
	border-top:1px solid #fff;
	width:100%;
	height: 150px;
	font-size: 1.4rem;
}

footer .leftbox a span{
	font-size: 3rem;
	font-weight: 400;
	letter-spacing: 0;
	margin-bottom: 0.2em;
}

footer .leftbox a:nth-child(3) span{
	font-size: 4rem;
}
}

/*=================================
	layout
=================================*/
#maincontainer {
  padding-top: 100px;
	position: relative;
	z-index: 2;
}

@media screen and (max-width:750px) {
#maincontainer {
  padding-top: 75px;
	position: relative;
	z-index: 2;
}
}

#page_common_content{
	width:95%;
	max-width: 1165px;
	margin:0 auto;
}

@media screen and (max-width:750px) {
#page_common_content{
	width:90%;
	max-width: 1165px;
	margin:0 auto;
}
}

#page_main{
	height: 500px;
	display: flex;
	align-items:center;
}

@media screen and (max-width:750px) {
#page_main{
	height: auto;
	display: flex;
	align-items:center;
	padding:40px 0;
}
}

#page_main .innerbox{
	width:95%;
	max-width: 1165px;
	margin:0 auto;
	display: flex;
	justify-content: flex-start;
}

@media screen and (max-width:750px) {
#page_main .innerbox{
	width:90%;
	max-width: 1165px;
	margin:0 auto;
	display: flex;
	justify-content: flex-start;
}
}

#page_main h1{
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	color:#231815;
	font-weight: 500;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
}

#page_main h1.active{
	animation: pagetitle 0.5s;
    animation-delay: 0.3s;
    animation-timing-function: ease-out;
    animation-fill-mode: forwards;
    position: relative;
}

#page_main h1 span{
	font-size: 8rem;
	letter-spacing: 0em;
	color:#fff;
	font-weight: 400;
	margin-bottom: 0.3em;
}

@media screen and (max-width:750px) {
#page_main h1 span{
	font-size: 4rem;
	letter-spacing: 0em;
	color:#fff;
	font-weight: 400;
	margin-bottom: 0.3em;
}
}

.common_tab_cont .tab_area{
	display: flex;
	justify-content: space-around;
	gap:min(4vw,40px);
	padding:0 min(4vw,40px);
}

.common_tab_cont .tab_area button{
	width:100%;
	border:2px solid #fff;
	border-bottom: 0;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
	min-height: 100px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	transition: background 0.2s;
}

.common_tab_cont .tab_area button .mtl{
	font-size: 3rem;
	font-weight: 400;
	color:#fff;
	margin-bottom: 0.3em;
	transition: color 0.2s;
}

.common_tab_cont .tab_area button .sub{
	font-size: 1.4rem;
	font-weight: 500;
	color:#fff;
	transition: color 0.2s;
}

.common_tab_cont .tab_area button.active{
	pointer-events: none;
}

.common_tab_cont .tab_area button.active,
.common_tab_cont .tab_area button:hover{
	background:#fff;
}

.common_tab_cont .tab_area button.active .mtl,
.common_tab_cont .tab_area button:hover .mtl{
	color:#4696d2;
}

.common_tab_cont .tab_area button.active .sub,
.common_tab_cont .tab_area button:hover .sub{
	color:#000;
}

.common_tab_cont .tab_cont{
	background:#fff;
	border-radius: 10px;
	padding:min(10vw,90px);
}

.common_tab_cont .tab_cont .inbox{
	display: none;
	clip-path: polygon(0 0, 100% 0, 100% 0, 0% 0);
}

.common_tab_cont .tab_cont .inbox.active{
	display: block;
	animation: tabcont 1s;
    animation-delay: 0.3s;
    animation-timing-function: ease-in-out;
    animation-fill-mode: forwards;
    position: relative;
}

@media screen and (max-width:750px) {
.common_tab_cont .tab_area{
	display: flex;
	justify-content: space-around;
	flex-direction: column;
	gap:min(5vw,50px);
	padding:0 0;
	margin-bottom: min(5vw,50px);
}

.common_tab_cont .tab_area button{
	width:100%;
	border:2px solid #fff;
	border-bottom: 2px solid #fff;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
	border-bottom-left-radius: 5px;
	border-bottom-right-radius: 5px;
	min-height: 75px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	transition: background 0.2s;
}

.common_tab_cont .tab_area button .mtl{
	font-size: 2.1rem;
	font-weight: 400;
	color:#fff;
	margin-bottom: 0.3em;
	transition: color 0.2s;
}

.common_tab_cont .tab_area button .sub{
	font-size: 1.2rem;
	font-weight: 500;
	color:#fff;
	transition: color 0.2s;
}

.common_tab_cont .tab_area button.active{
	pointer-events: none;
}

.common_tab_cont .tab_area button.active,
.common_tab_cont .tab_area button:hover{
	background:#fff;
}

.common_tab_cont .tab_area button.active .mtl,
.common_tab_cont .tab_area button:hover .mtl{
	color:#4696d2;
}

.common_tab_cont .tab_area button.active .sub,
.common_tab_cont .tab_area button:hover .sub{
	color:#000;
}

.common_tab_cont .tab_cont{
	background:#fff;
	border-radius: 5px;
	padding:40px 0;
}

.common_tab_cont .tab_cont .inbox{
	display: none;
	clip-path: polygon(0 0, 100% 0, 100% 0, 0% 0);
	padding:0 5vw;
}

.common_tab_cont .tab_cont .inbox.active{
	display: block;
	animation: tabcont 1s;
    animation-delay: 0.3s;
    animation-timing-function: ease-in-out;
    animation-fill-mode: forwards;
    position: relative;
}
}


/*=================================
	caption
=================================*/
.kome{
	font-size: 1.2rem;
	line-height: 1.75em;
	position: relative;
	padding-left: 1.1em;
	text-align: justify;
	font-weight: 300;
}

.kome::before{
	content: "※";
	width:1em;
	height: 1em;
	position: absolute;
	top:0;
	left:0;
}

/*=================================
	color
=================================*/
.co_red {
  color: #cc0000;
}
.co_white {
  color: #fff;
}
/*=================================
	pan
=================================*/
#pan {
  width: 100%;
  padding: 0 min(2.5vw, 60px);
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  background: #fff;
  line-height: 1.6em;
}
#pan a {
  color: #009691;
  transition: all 0.3s;
  margin: 0 10px 0 0;
  /*padding-bottom: 1px;*/
  /*border-bottom: 1px solid #000;*/
}
#pan a:hover {
  opacity: 0.7;
}
#pan span {
  margin: 0 10px 0 0;
  font-weight: 400;
  color: #000;
}
#pan span::after {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  margin: 0 0;
  border-radius: 50%;
  background: #009691;
  /*border-top: 1px solid #009691;
  		border-right: 1px solid #009691;
  		transform: rotate(45deg);*/
  position: relative;
  top: -0.2em;
}
#pan span:last-child::after {
  display: none;
}
/*=================================
	common_btn
=================================*/
.common_maskbtn{
	display: inline-block;
	position: relative;
	overflow: hidden;
}

.common_maskbtn span{
	width:100%;
	min-width: 250px;
	height: 60px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.4rem;
	letter-spacing: 0.2em;
	color:#000;
	border:1px solid #000;
	position: relative;
	z-index: 2;
	transition: color 0.2s;
}

.common_maskbtn.white span{
	color:#fff;
	border:1px solid #fff;
}

.common_maskbtn::after{
	content: "";
	width:100%;
	padding-top: 100%;
	clip-path: polygon(100% calc(100% - 20px), calc(100% - 20px) 100%, 100% 100%);
	position: absolute;
	bottom:0;
	right:0;
	z-index: 1;
	background:#4696d2;
	transform: scale(1);
	transform-origin: right bottom;
	transition: all 0.3s;
}

.common_maskbtn.white::after{
	background:#fff;
}

.common_maskbtn:hover span{
	color:#fff;
}

.common_maskbtn.white:hover span{
	color:#000;
}

.common_maskbtn:hover::after{
	transform: scale(2);
	clip-path: polygon(100% 0, 0 100%, 100% 100%);
}

@media screen and (max-width:750px) {
.common_maskbtn span{
	width:100%;
	min-width: 225px;
	height: 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.4rem;
	letter-spacing: 0.2em;
	color:#000;
	border:1px solid #000;
	position: relative;
	z-index: 2;
	transition: color 0.2s;
}
}
/*=================================
	common_hover
=================================*/
@media (any-hover: hover) {
	.hover_opacity{
		transition: all 0.3s;
	}	
	
	.hover_opacity:hover{
		opacity: 0.7;
	}	
	
}
/*=================================
	animation
=================================*/
.fadeTop, .fadeBottom, .fadeLeft, .fadeRight, .fadeIn {
  opacity: 0;
}
.fadeTop.active {
  animation: fadeTop 1s;
  animation-delay: 0s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  position: relative;
}
.fadeBottom.active {
  animation: fadeBottom 1s;
  animation-delay: 0s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  position: relative;
}
.fadeLeft.active {
  animation: fadeLeft 1s;
  animation-delay: 0s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  position: relative;
}
.fadeRight.active {
  animation: fadeRight 1s;
  animation-delay: 0s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  position: relative;
}
.fadeIn.active {
  animation: fadeIn 1s;
  animation-delay: 0s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  position: relative;
}
@keyframes fadeTop {
  0% {
    top: 20px;
    opacity: 0;
  }
  100% {
    top: 0;
    opacity: 1;
  }
}
@keyframes fadeBottom {
  0% {
    bottom: 20px;
    opacity: 0;
  }
  100% {
    bottom: 0;
    opacity: 1;
  }
}
@keyframes fadeLeft {
  0% {
    left: -20px;
    opacity: 0;
  }
  100% {
    left: 0;
    opacity: 1;
  }
}
@keyframes fadeRight {
  0% {
    right: -20px;
    opacity: 0;
  }
  100% {
    right: 0;
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes pagetitle {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
  }
}

@keyframes tabcont {
  0% {
   clip-path: polygon(0 0, 100% 0, 100% 0, 0% 0);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
  }
}