@charset "utf-8";

/***************************************************
	common.css
	共通レイアウトスタイル定義
***************************************************/

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Oswald:wght@500;700&display=swap');

/* Base
------------------------------------------------------------ */
html {
	font-size: 62.5%;
}

@media only screen and (min-width: 768px) {
	html {
		font-size: 100%;
	}
}

body {
	line-height: 2;
	color: #212121;
	margin: 0;
	padding: 0;
	min-width: 1020px;
	background: #ffffff;
	font-family: 'Noto Sans JP', sans-serif;
	word-wrap: break-word;
}

@media only screen and (max-width: 767px) {
	body {
		min-width: inherit;
	}
}

img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
	image-rendering: -webkit-optimize-contrast;
}

.innerBox {
	max-width: 750px;
	margin: 0 auto;
}

@media only screen and (max-width: 767px) {
	.innerBox {
		padding: 0 30px;
	}
}

@media only screen and (max-width: 374px) {
	.innerBox {
		padding: 0 15px;
	}
}


/* Link
------------------------------------------------------------ */
a {
	outline: none;
}

a:link {
	color: #212121;
	text-decoration: none;
}

a:visited {
	color: #212121;
	text-decoration: none;
}

a:hover {
	color: #212121;
	text-decoration: none;
}

a img {
	transition: 0.2s;
}

a:hover img {
	opacity: 0.7;
	filter: alpha(opacity=70);
}

a em {
	font-style: normal;
	text-decoration: underline;
}

/* wrapper
-------------------------------------------------------------------*/
.wrapper {}

/* header
-------------------------------------------------------------------*/
.header {
	margin: 0;
	padding: 0;
	position: sticky;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
	background: #ffffff;
}

@media only screen and (min-width: 768px) {
	.header {
		height: 90px;
	}
}

.header .headerRow01 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 15px;
}

.header .logo {
	width: 122px;
	margin: 0;
}

@media only screen and (min-width: 768px) {
	.header .logo {
		width: 200px;
	}
}

@media only screen and (max-width: 374px) {
	.header .logo {
		width: 90px;
	}
}

.header .btnList {
	margin: 0;
	padding: 0;
	list-style-type: none;
	display: flex;
	column-gap: 10px;
}

.header .btnList>li {
	margin: 0;
	font-size: 1.1rem;
	width: 7.5em;
}

.header .btnList>li a {
	display: flex;
	justify-content: center;
	align-items: center;
	column-gap: 0.3em;
	font-weight: 500;
	text-align: center;
	line-height: 1;
	padding: 0.7em;
	border: 1px solid #212121;
	position: relative;
	transition: 0.2s;
}

.header .btnList>li a:hover {
	opacity: 0.7;
}

.header .btnList>li a::after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	border-right: 1px solid #212121;
	border-bottom: 1px solid #212121;
	position: absolute;
	top: 3px;
	left: 3px;
}

.header .btnList>li a i {
	display: flex;
	justify-content: center;
	align-items: center;
}

.header .btnList>li.document a {
	background: #F37447;
}

.header .btnList>li.document a i {
	width: 0.75em;
}

.header .btnList>li.visit a {
	background: #D9AB33;
}

.header .btnList>li.visit a i {
	width: 0.83em;
}

@media only screen and (min-width: 768px) {
	.header .btnList>li a {
		border-width: 2px;
	}

	.header .btnList>li a::after {
		border-width: 2px;
		top: 4px;
		left: 4px;
	}
}


/* main
-------------------------------------------------------------------*/
.main {
	display: block;
	clear: both;
	font-size: 1.2rem;
	margin: 0 auto;
	padding: 0;
	overflow: hidden;
}

@media only screen and (min-width: 768px) {
	.main {
		font-size: 1.6rem;
	}
}


/* footer
-------------------------------------------------------------------*/
.footer {
	padding: 30px 0;
}

.footer .logo {
	width: 235px;
	margin: 0 auto;
}

.footer .cr {
	color: #666666;
	font-size: 1rem;
	text-align: center;
	margin: 1em 0 0 0;
}




/*UPDATE 20240918*/
.header .btnList>li.oc {
	width: 12em;
}

.header .btnList>li.oc a {
	background: #8d79e8;
}

.header .btnList>li.oc a i {
	width: 0.83em;
}

@media only screen and (max-width: 767px) {
	.header .headerRow01 {
		flex-direction: column;
		gap: 6px;
	}
}

.header .btnList>li.document {
	width: 11em;
}




/* START OF UPDATE 250402*/
/* .mainBox {
	position: relative;
	height: auto!important;
}
.mainBox img {
	width: 100%;
}
.mv__cvarea {
	position: absolute;
	width: fit-content;
	left: 50%;
	bottom: 20px;
	transform: translateX(-50%);
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
  	max-width: inherit;
}
.mv__cvbtn {
	width: 300px;
	margin: 0 auto;
	padding-top: 0;
}
.mv__cvbtn .btn {
	width: 100%;
	display: block;
	padding: 10px 16px;
	max-width: 265px;
	border: 3px solid #252525;
	position: relative;
	border-radius: 50px;
	text-align: center;
	background-color: #FFF;
	font-weight: 700;
	font-size: 20px;
 	color: #333;
	transition: 0.3s all;
}
.mv__cvbtn .btn:hover {
	opacity: 0.8;
}
.mv__cvbtn .btn::before {
	content: "";
	display: inline-block;
	width: 20px;
	height: 20px;
	background-image: url(../img/icon_materials.svg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	position: absolute;
	top: 50%;
	left: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.mv__cvbtn .btn::after {
	content: "";
	display: inline-block;
	width: 20px;
	height: 20px;
	background-image: url(../img/arrow-black.svg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	position: absolute;
	top: 50%;
	right: 18px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.mv__cvbtn .btn.anime {
	background-color: #D91C3E;
	color: white;
}
.mv__cvbtn .btn.anime:before {
	content: none;
}
.mv__cvbtn .btn.anime:after {
	background-image: url(../img/arrow-white.svg);
}
@media (min-width: 768px) and (max-width: 1000px) {
	.mv__cvarea {
		left: inherit;
		transform: none;
		right: 10px;
		bottom: 30px;
		gap: 10px;
	}
}
@media (max-width: 767px) {
	.mv__cvarea {
		position: absolute;
		grid-template-columns: 1fr;
		gap: 3px;
		bottom: 2%;
		width: 100%;
		margin-bottom: 0;
		padding-bottom: 0;
	}
	.mv__cvbtn {
		display: flex;
		justify-content: center;
		width: 100%;
	}
	.mv__cvbtn .btn {
		width: 100%;
		min-width: inherit;
		margin: 0;
		padding: 7px 16px;
	}
} */
/* END OF UPDATE 250402*/