@charset "utf-8";
:root {--main-color: #007CC5;}
:root {--sub-color: ;}
:root {--text-color: #333333;}

:root {--text-font: "Zen Kaku Gothic New", "MSゴシック" , "メイリオ" , "遊ゴシック";}

section{
	width: 100%;
    padding: 80px 0;
	position: relative;
	overflow: hidden;
}
.inner{
	width: 90%;
	max-width: 1188px;
	margin: 0 auto;
    position: relative;
}
h1,h2,h3,h4,h5,h6{
	font-weight: bold;
	line-height: 2;
	letter-spacing: 0.05em;
}
p{
	font-size: 15px;
	line-height: 2;
    letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
	section{
	    padding: 40px 0;
	}
}
/*==================================================================================================*/
/*共通記述*/
.title{
	font-size: 30px;
	line-height: 1.4;
}
.title span{
	display: block;
	font-family: "Bebas Neue", sans-serif;
	font-size: 18px;
	color: var(--main-color);
	margin: 0 0 15px;
}
.btn{
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 120px;
	height: 32px;
	font-size: 10px !important;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 0.15em;
	color: #FFF !important;
	background: #333333;
	padding: 0 12px;
	transition: .5s;
	opacity: 1;
}
.btn:hover{
	opacity: .7;
}
.btn.color{
	background: linear-gradient(to right, #0071BD, #1D257A);
}
.btn.white{
	color: var(--text-color) !important;
	background: #FFF;
}
.btn span{
	display: block;
	content: "";
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
	border-left: 7px solid #FFF;
	position: relative;
}
.btn.white span{
	border-left: 7px solid var(--text-color);
}
.btn span::before{
	display: inline-block;
	content: "";
	width: 0;
	height: 10px;
	border-right: dotted 1px #FFF;
	position: absolute;
	top: -5px;
    left: -19px;
}
.btn.white span::before{
	border-right: dotted 1px var(--text-color);
}
@media screen and (max-width: 768px) {
}
/*==================================================================================================*/
/*-*/
header{
	width: 100%;
	height: 60px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 24px;
	position: fixed;
	z-index: 1000;
}
header h1,
header div{
	width: fit-content;
	position: relative;
	top: -3px;
	z-index: 100;
	transition: .5s;
	opacity: 1;
}
header h1:hover,
header div:hover{
	opacity: .7;
}
header h1 a,
header div a{
	display: flex;
	align-items: center;
}
header h1 a img,
header div a img{
	width: 183px;
}
nav{
	width: fit-content;
}
.nav{
	width: 100%;
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
.nav li{
	display: flex;
	width: fit-content;
	margin-left: 30px;
}
.nav li:last-child{
	margin-left: 12px;
}
.nav li a{
	font-family: var(--text-font);
	font-size: 11px;
	font-weight: bold;
	letter-spacing: 0.15em;
	color: var(--text-color);
	transition: .5s;
}
.nav li a:hover{
	color: var(--main-color);
}
@media screen and (max-width: 768px) {
	nav{
		width: 100%;
		height: 100vh;
		background:rgba(255,255,255,0.80);
		padding-top: 120px;
		position: fixed;
		top: -100vh;
		left: 0;
		transition: .5s;
	}
	.pcNav nav{
		top: 0;
	}
	nav .nav{
		flex-wrap: wrap;
	}
	nav .nav li{
		justify-content: center;
		width: 100%;
		margin-left: 0;
		margin-bottom: 20px;
	}
	nav .nav li:last-child{
		margin-left: 0;
	}
	nav .nav li a{
		font-size: 20px;
	}
}
.openbtn1{
	display: none;
}
@media screen and (max-width: 768px) {
	.openbtn1{
		display: block;
		cursor: pointer;
		width: 55px;
		height: 55px;
		position: fixed;
		top: 0;
		right: 0;
		z-index: 1;
		background: #007CC5;
	}
	.openbtn1 span:nth-of-type(1),
	.openbtn1 span:nth-of-type(2),
	.openbtn1 span:nth-of-type(3){
		display: inline-block;
		transition: all .4s;
		width: 27px;
		height: 3px;
		background: #FFF;
		position: absolute;
		left: 15px;
	}
	.openbtn1 span:nth-of-type(1) { top:15px;}
	.openbtn1 span:nth-of-type(2) { top:26px;}
	.openbtn1 span:nth-of-type(3) { top:37px;}
	
	.openbtn1.active span:nth-of-type(1) {
		top: 25px;
		transform: rotate(-45deg);
	}
	.openbtn1.active span:nth-of-type(2){
		opacity: 0;
	}
	.openbtn1.active span:nth-of-type(3){
		top: 25px;
		transform: rotate(45deg);
	}
}
/*==================================================================================================*/
/*-*/
	/***************************************************
     * Generated by SVG Artista on 5/20/2025, 4:12:24 PM
     * MIT license (https://opensource.org/licenses/MIT)
     * W. https://svgartista.net
     **************************************************/

    @-webkit-keyframes animate-svg-stroke-1 {
      0% {
        stroke-dashoffset: 5068px;
        stroke-dasharray: 5068px;
      }
      100% {
        stroke-dashoffset: 0;
        stroke-dasharray: 5068px;
      }
    }
    @keyframes animate-svg-stroke-1 {
      0% {
        stroke-dashoffset: 5068px;
        stroke-dasharray: 5068px;
      }
      100% {
        stroke-dashoffset: 0;
        stroke-dasharray: 5068px;
      }
    }
    @-webkit-keyframes animate-svg-fill-1 {
      0% { fill: transparent; }
      100% { fill: rgb(255, 255, 255); }
    }
    @keyframes animate-svg-fill-1 {
      0% { fill: transparent; }
      100% { fill: rgb(255, 255, 255); }
    }
    .svg-elem-1 {
      -webkit-animation: animate-svg-stroke-1 1s ease 0s both,
                         animate-svg-fill-1 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s both;
              animation: animate-svg-stroke-1 1s ease 0s both,
                         animate-svg-fill-1 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s both;
    }

    @-webkit-keyframes animate-svg-stroke-2 {
      0% {
        stroke-dashoffset: 2754.7548828125px;
        stroke-dasharray: 2754.7548828125px;
      }
      100% {
        stroke-dashoffset: 0;
        stroke-dasharray: 2754.7548828125px;
      }
    }
    @keyframes animate-svg-stroke-2 {
      0% {
        stroke-dashoffset: 2754.7548828125px;
        stroke-dasharray: 2754.7548828125px;
      }
      100% {
        stroke-dashoffset: 0;
        stroke-dasharray: 2754.7548828125px;
      }
    }
    .svg-elem-2 {
      -webkit-animation: animate-svg-stroke-2 1s ease 0.12s both,
                         animate-svg-fill-2 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s both;
              animation: animate-svg-stroke-2 1s ease 0.12s both,
                         animate-svg-fill-2 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s both;
    }

    @-webkit-keyframes animate-svg-stroke-3 {
      0% {
        stroke-dashoffset: 5068px;
        stroke-dasharray: 5068px;
      }
      100% {
        stroke-dashoffset: 0;
        stroke-dasharray: 5068px;
      }
    }
    @keyframes animate-svg-stroke-3 {
      0% {
        stroke-dashoffset: 5068px;
        stroke-dasharray: 5068px;
      }
      100% {
        stroke-dashoffset: 0;
        stroke-dasharray: 5068px;
      }
    }
    @-webkit-keyframes animate-svg-fill-3 {
      0% { fill: transparent; }
      100% { fill: rgb(255, 255, 255); }
    }
    @keyframes animate-svg-fill-3 {
      0% { fill: transparent; }
      100% { fill: rgb(255, 255, 255); }
    }
    .svg-elem-3 {
      -webkit-animation: animate-svg-stroke-3 1s ease 0.24s both,
                         animate-svg-fill-3 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1s both;
              animation: animate-svg-stroke-3 1s ease 0.24s both,
                         animate-svg-fill-3 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1s both;
    }

.fv{
	padding: 0;
	max-height: 768px;
	overflow: inherit;
	margin-bottom: 100px;
}
.fv .inner{
	align-content: center;
	max-width: 1080px;
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.fv .inner h2 img{
	width: 481px;
}
.fv .inner p{
	font-family: "Noto Serif JP", serif;
	font-size: 15px;
	letter-spacing: 0.5em;
	color: #FFF;
	padding-left: 20px;
	margin-top: 10px;
}
@media screen and (max-width: 768px) {
	.fv{
		overflow: hidden;
		margin-bottom: 0;
	}
	.fv svg{
		width: 1000px;
	}
	.fv .inner h2 img{
		width: 296px;
	}
	.fv .inner p{
		font-size: 13px;
		margin-bottom: 60px;
	}
}
.topic{
	width: 370px;
	height: 102px;
	border-radius: 7px;
	background: #FFF;
	box-shadow: 0 4px 4px 0 rgba(0,0,0,0.25);
	padding: 11px 13px;
	position: fixed;
	bottom: 0;
	right: 20px;
	z-index: 1;
	opacity: 0;
	transition: .5s;
}
.movement .topic{
	opacity: 1;
	bottom: 30px;
}
.topic.closenews{
	display: none;
}
.topic .img{
	width: 130px;
	padding-top: 23%;
}
.topic .img + div{
	justify-content: flex-start;
	width: calc( 100% - 140px );
}
.topic p:nth-child(1){
	width: 75px;
	font-size: 11px;
    line-height: 1.4;
	letter-spacing: 0;
	color: #898989;
}
.topic p:nth-child(2){
	width: fit-content;
	font-size: 11px;
	line-height: 1.4;
	color: #044A9A;
}
.topic h3{
	font-size: 16px;
	font-weight: normal;
	line-height: 1.4;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.topic p:nth-child(4){
	font-size: 12px;
	line-height: 1.4;
	display: -webkit-box;             
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	-webkit-line-clamp: 2;
}
.close{
	display: block;
	content: "";
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: #B0B0B0;
	position: absolute;
	top: -10px;
	right: -10px;
	cursor: pointer;
}
.close::before,
.close::after{
	display: block;
	content: "";
	width: 10px;
	height: 1px;
	background: #FFF;
	transform: rotate(45deg);
	position: absolute;
	top: 11px;
	left: 6px;
}
.close::after{
	transform: rotate(-45deg);
}
@media screen and (max-width: 768px) {
	.topic{
		right: auto;
		left: 50%;
		transform: translateX(-50%);
	}
}
/*==================================================================================================*/
/*company-*/
.block .inner{
	max-width: 1080px;
}
.company .title + p{
	font-size: 10px !important;
	margin-top: 5px !important;
}
.block .imgBox{
	max-width: 495px;
	width: 46%;
}
.block .imgBox img{
	display: block;
	max-width: 337px;
	width: 68%;
	box-shadow: 0 4px 4px 0 rgba(0,0,0,0.25);
	position: relative;
	z-index: 1;
}
.block .imgBox img:nth-child(2){
	margin-left:auto;
	top: -20px;
	z-index: 0;
}
.block .textBox{
	max-width: 528px;
	width: 49%;
}
.block .textBox p{
	font-size: 14px;
	line-height: 2.5;
	margin-top: 40px;
}
.more{
	display: flex;
	align-items: center;
	font-size: 12px;
	transition: .5s;
	position: relative;
	left: 0;
}
.block .more{
	margin-top: 40px;
}
.more:hover{
	color: var(--main-color);
	left: 5px;
}
.more::before{
	display: block;
	content: "";
	width: 30px;
	height: 1px;
	background: #333333;
	margin-right: 15px;
	transition: .5s;
}
.more:hover::before{
	background: var(--main-color);
}
@media screen and (max-width: 768px) {
	.company{
		padding-bottom: 0;
	}
	.block .imgBox{
		max-width: 495px;
		width: 100%;
		margin-bottom: 20px;
	}
	.block .textBox{
		max-width: 528px;
		width: 100%;
	}
}
/*==================================================================================================*/
/*works-*/
.works .inner{
	flex-direction: row-reverse;
}

/*==================================================================================================*/
/*works-*//*
.works .title{
	width: 94%;
	max-width: 1188px;
	padding: 0 0 20px;
	border-bottom: solid 1px #AEAEAE;
	margin: 0 auto 25px;
}
.works div{
	width: 96.5%;
	margin-left: auto;
	overflow: scroll;
}
.works ul{
	width: fit-content;
	flex-wrap: nowrap;
	padding-right: 4%;
	margin-bottom: 20px;
}
.works ul li{
	width: 283px;
}
.works ul li .img{
	width: 100%;
}
.works ul li h3{
	font-family: "Noto Serif JP", serif;
	font-size: 12px;
	font-weight: normal;
}
@media screen and (max-width: 768px) {
	.works .title{
		width: 90%;
	}
	.works div{
		width: 95%;
	}
	.works ul{
		padding-right: 5%;
	}
}
/*==================================================================================================*/
/*news-*/
.news{
	max-width: 1122px;
	border-top: solid 1px #D9D9D9;
	border-bottom: solid 1px #D9D9D9;
	padding: 80px 0 20px;
	margin: 0 auto 90px;
}
.news .inner{
	max-width: 768px;
}
.news .inner div{
	max-width: 122px;
}
.news .title{
	margin-bottom: 20px;
}
.news .inner ul{
	max-width: 537px;
	width: calc( 100% - 200px);
}
.news .inner ul li{
	border-top: solid 1px #DCDCDC;
	margin: 0 0 20px;
}
.newsList li a{
	justify-content: flex-start;
	color: var(--text-color) ;
	padding: 15px 0;
	transition: .5s;
	opacity: 1;
}
.newsList li a:hover{
	opacity: .6;
}
/*テキストブロック*/
.newsList div{
	max-width: 100% !important;
	justify-content: flex-start;
}
.newsList p:nth-child(1){
	width: 100px;
	font-size: 13px;
	line-height: 1;
	letter-spacing: 0;
	padding-right: 15px;
	border-right: solid 1px #DCDCDC;
}
.newsList p:nth-child(2){
	width: fit-content;
	font-size: 13px;
	line-height: 1;
	color: #044A9A;
	padding: 0 15px;
}
.newsList h3{
	font-size: 15px;
	font-weight: normal;
	margin-top: 5px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.newsList p:nth-child(4){
	font-size: 12px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
@media screen and (max-width: 768px) {
	.news{
		padding: 40px 0 20px;
	}
	.news .inner div{
		max-width: 100%;
		margin-bottom: 40px;
	}
	.news .inner ul{
		max-width: 537px;
		width: 100%;
	}
	.news .inner .newsList div{
		margin-bottom: 0;
	}
}
/*==================================================================================================*/
/*-*/
iframe{
	width: 100%;
	height: 283px;
	margin-bottom: -20px;
}
footer{
	color: #FFF;
	background: #333333;
	padding: 40px 0 20px;
}
footer .inner div{
	width: fit-content;
}
footer .inner div h2{
	width: 272px;
	margin-bottom: 40px;
	transition: .5s;
	opacity: 1;
}
footer .inner div h2:hover{
	opacity: .7;
}
footer .inner div h2 a{
	display: block;
}
footer .inner div .nav{
	justify-content: flex-start;
	margin-bottom: 20px;
}
footer .inner div .nav li{
    margin-left: 0;
}
footer .inner div ul:nth-child(2) li{
	display: flex;
    align-items: center;
	padding-right: 15px;
	border-right: solid 1px #FFF;
	margin-right: 15px;
}
footer .inner div ul:nth-child(2) li:last-child{
	border-right: none;
}
footer .inner div ul:nth-child(2) li a{
	font-size: 12px;
	color: #FFF;
	line-height: 1;
	letter-spacing: 0.4em;
}
footer .inner div ul:nth-child(2) li a:hover{
	color: var(--main-color);
}
footer .inner div ul:nth-child(3) li a{
	margin-right: 10px;
}
footer .inner div ul + a {
	font-size: 12px;
	letter-spacing: 0.2em;
	color: #FFF;
	transition: .5s;
}
footer .inner div ul + a:hover{
	color: var(--main-color);
}
footer .inner dl{
	width: 430px;
	font-size: 12px;
	letter-spacing: 0.1em;
}
footer .inner dt{
	display: flex;
	align-items: center;
	width: 110px;
	margin: 0 0 10px;
}
footer .inner dt::after{
	display: block;
	content: "";
	width: 10px;
	height: 10px;
	background: center / contain no-repeat url("../img/icon-map.svg");
	padding: 0 5px;
}
footer .inner dd{
	width: calc( 100% - 110px );
	margin: 0 0 10px;
}

footer small{
	display: block;
	font-size: 10px;
	text-align: center;
	color: #FFF;
	margin: 40px auto 0;
}
.re footer{
	background: none;
}
@media screen and (max-width: 768px) {
}