@charset "utf-8";


/* reset
-------------------------------------------------- */

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,
main,
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%;
	vertical-align: baseline;
}

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

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

sup {
	font-size: 75%;
	vertical-align: middle;
}

img {
	vertical-align: bottom;
}

html,
body {
	overflow-x: hidden;
}

*,
*:before,
*:after {
	box-sizing: border-box;
}

a:link,
a:visited {
	text-decoration: none;
}

main {
	background: #f3f3f3;
}

main,
main h1,
main h2,
main h3,
main h4,
main h5 {
	/* font-family: "font_name_W3", "FP-ヒラギノUD角ゴ StdN W3", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif; */
	font-weight: normal;
	color: #333;
	line-height: 1;
}

@media (min-width: 768px) {
	a {
		transition: opacity .5s;
	}

	a:hover:not(.tmb-list li a) {
		opacity: .7;
	}

	.pcHidden {
		display: none !important;
	}
}

@media (max-width: 768px) {
	img {
		max-width: 100%;
	}

	.spHidden {
		display: none !important;
	}
}


/* common
-------------------------------------------------- */

.mFooter__sitemap-container {
	background-color: #fff;
}

.mFooter__bottom {
	background-color: #f5f5f5;
}

.cg-wrap .navbar {
	display: none;
}

.section-container {
	position: relative;
	max-width: 1240px;
	margin: -150px auto 0;
	padding: 0 65px 80px;
	background: #f3f3f3;
}

.section-container::before {
	content: '';
	position: absolute;
	right: -100%;
	width: 100%;
	height: 100%;
	background: #f3f3f3;
}

section>.inner {
	max-width: 1000px;
	margin: 0 auto;
}

.hind,
.hind-mid,
.hind-small {
	color: #004180;
	/* font-family: 'Hind', sans-serif; */
	line-height: 1;
}

.hind-mid {
	font-size: 20px;
	color: #004180;
}

.sec-ttl-type1 {
	position: relative;
	font-size: 30px;
	line-height: 1.5;
}

.sec-ttl-type2 {
	position: relative;
	font-size: 25px;
	line-height: 1.5;
}

.sec-ttl-line1,
.sec-ttl-line2 {
	position: relative;
	padding-left: 80px;
	font-size: 18px;
	color: #004180;
}

.sec-ttl-line2 {
	margin-top: 50px;
}

.sec-ttl-line1::before,
.sec-ttl-line1::before,
.sec-ttl-line2::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	width: 70px;
	height: 2px;
	background: #004180;
	transform: translateY(-50%);
}

.body-copy {
	font-size: 18px;
	line-height: 2;
	font-weight: normal;
}

.body-copy.wh {
	color: #fff;
}

.under-line {
	padding: 0 0 20px;
	border-bottom: 1px solid #808080;
}

.under-line img {
	padding-top: .5em;
}

.link-type1 {
	position: relative;
	display: inline-block;
	padding-right: 30px;
	font-size: 14px;
	font-weight: bold;
	color: #005f9b !important;
	line-height: 1;
}

@media (min-width: 768px) {
	.link-type1.wh {
		color: #fff !important;
	}
}

.link-type1.window {
	padding-right: 20px;
	background: url(../img/common/icon-window.png) no-repeat right bottom;
}

.link-type1::before,
.link-type3::before {
	content: '';
	position: absolute;
	right: 0;
	bottom: 0px;
	width: 19px;
	height: 9px;
	background: url(../img/common/icon-arrow.png) no-repeat 0 0;
}

.link-type2 {
	position: relative;
}

.link-type2::before {
	content: '';
	position: absolute;
	right: 0;
	bottom: 0px;
	width: 100%;
	border-bottom: 1px solid #333;
}

.link-type1.window::before {
	right: -30px;
}

.table-type1 {
	border-collapse: collapse;
	table-layout: fixed;
	font-size: 14px;
	word-wrap: break-word;
}

.table-type1 th {
	padding: 10px;
	border: 1px solid #cdcdcd;
	vertical-align: middle;
}

.table-type1 td {
	padding: 10px;
	border: 1px solid #cdcdcd;
	vertical-align: middle;
	line-height: 1.3;
}

.table-type1 thead th {
	background: #b8b8b8;
	color: #fff;
	text-align: center;
	vertical-align: middle;
}

.table-type1 tbody th {
	background: #dcdcdc;
	text-align: center;
}

.table-type1 tbody .canon {
	color: #004180;
	font-weight: bold;
}

.btn-detail {
	cursor: pointer;
}

.btn-detail .detail-text,
.page-detail .detail-text  {
	position: relative;
	display: block;
	font-size: 18px;
	font-weight: bold;
	color: #005f98;
	line-height: 1;
}

.btn-detail .detail-text::before {
	content: '';
	position: absolute;
	right: 25px;
	top: 20%;
	width: 20px;
	height: 11px;
	background: url(../img/common/btn-arrow3.png) no-repeat;
	background-size: 100%;
	transition: transform .25s;
	transform-origin: center center;
	transform: rotate(180deg) translate(0, -50%);
}

.btn-detail .detail-text.show::before {
	top: 50%;
	transform: rotate(0deg) translate(0, -50%);
}

.note-list {
	margin-left: 1.5em;
	margin-top: 15px;
	font-size: 12px;
	text-indent: -1.5em;
	line-height: 1.4;
}

.note-list.num {
	margin-left: 2em;
	text-indent: -2em;
}

.text-shadow.wh {
	text-shadow: 2px 2px 2px rgb(0 0 0 / 80%);
}

@media (min-width: 1024px) {
	.section-container {
		padding: 0 65px 150px;
	}
}

@media (min-width: 768px) {
	.flex-wrap {
		display: flex;
	}

	.btn-detail {
		transition: opacity .5s;
	}

	.btn-detail:hover {
		opacity: 0.7;
	}

	.link-type1.wh::before {
		background: url(../img/common/icon-arrow-wh.png) no-repeat 0 0;
	}

	.flex-wrap>figure {
		margin-left: 30px;
	}

	.body-img figcaption {
		padding-top: .5em;
		font-size: 80%;
		text-align: right;
		line-height: 1.5em;
	}

	.body-copy+.body-copy {
		margin-top: 30px;
	}

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

	.under-line+.under-line {
		margin-top: 0;
	}
}

@media (max-width: 767px) {
	.section-container {
		padding: 0 30px 80px;
	}
}

@media (max-width: 768px) {
	.section-container {
		margin-top: 0;
		padding: 0 30px 13.3333vw;
	}

	.sec-ttl-line1,
	.sec-ttl-line2 {
		padding-left: 10vw;
		font-size: 4.2vw;
	}

	.sec-ttl-line1::before,
	.sec-ttl-line2::before {
		width: 8vw;
		height: 1px;
	}

	.body-copy {
		font-size: 3.8vw;
	}

	.body-copy+.body-copy {
		margin-top: 6.6666vw;
	}

	.link-type1 {
		padding-right: 6vw;
		padding-bottom: 2vw;
		font-size: 3.2vw;
		line-height: 1.4;
		letter-spacing: 0.05em;
		color: #005f9b !important;
	}

	.link-type1::before {
		top: auto;
		bottom: 2.5vw;
		width: 4vw;
		height: 2vw;
		background-size: 100%;
	}

	.link-type1.window {
		padding-right: 5vw;
		background-position: right 2.5% bottom 3vw;
		background-size: 2.8vw;
	}

	.link-type1.window::before {
		right: -5.5vw;
	}

	.btn-detail .detail-text,
	.page-detail .detail-text {
		padding-bottom: 3.2vw;
		font-size: 3.4vw;
	}

	#anti-counterfeit .btn-detail .detail-text {
		padding-bottom: 3.2vw;
		font-size: 3.4vw;
	}

	.btn-detail .detail-text::before {
		right: 2.6666vw;
		top: -0.5vw;
		width: 4.4444vw;
		height: 2.6666vw;
	}

	.btn-detail .detail-text.show::before {
		top: 2vw;
	}

	.table-wrap-scroll {
		overflow-x: scroll;
	}

	.table-type1 {
		font-size: 2.4vw;
	}

	.table-type1 tbody tr {
		border-bottom: #cdcdcd 1px solid;
	}

	.table-type1 tbody td+td {
		border-left: #cdcdcd 1px solid;
	}

	.table-type1 thead th,
	.table-type1 tbody th,
	.table-type1 tbody td {
		padding: 1.3333vw;
	}

	.note-list {
		margin-top: 4vw;
		font-size: 2.4vw;
	}

	.text-shadow {
		text-shadow: 2px 2px 2px rgba(255 255 255 / 70%);
	}

	.text-shadow.wh {
		text-shadow: 2px 2px 2px rgba(0 0 0 / 50%);
	}

	.under-line {
		padding: 0 0 1.3333vw;
	}

	.flex-wrap>figure {
		margin: 5vw auto 0;
		width: 80.33333vw;
	}

	.body-img {
		margin: 0 auto;
	}

	.body-img figcaption {
		padding-top: .5em;
		font-size: 80%;
		text-align: right;
	}

	.new-2lines {
		margin: .8em 0;
	}

	.section-container {
		padding: 0 15px 13.3333vw;
	}
}


/* ip__header
-------------------------------------------------- */

.ip__header {
	background: #fff;
}

.ip__header .site-nav-list li {
	padding: 20px 0;
}

.ip__header .site-nav-list li a {
	position: relative;
	display: inline-block;
	white-space: nowrap;
}

/* current */
[data-category="top"] .site-nav-list li.top,
[data-category="news"] .site-nav-list li.news,
[data-category="message"] .site-nav-list li.message,
[data-category="about"] .site-nav-list li.about,
[data-category="future"] .site-nav-list li.future,
[data-category="initiatives"] .site-nav-list li.initiatives,
[data-category="collaboration"] .site-nav-list li.collaboration,
[data-category="sword-shield"] .site-nav-list li.sword-shield,
[data-category="partnership"] .site-nav-list li.partnership,
[data-category="hr"] .site-nav-list li.hr,
[data-category="history"] .site-nav-list li.history {
	font-weight: bold;
}

[data-category="top"] .site-nav-list li.top a::before,
[data-category="news"] .site-nav-list li.news a::before,
[data-category="message"] .site-nav-list li.message a::before,
[data-category="about"] .site-nav-list li.about a::before,
[data-category="future"] .site-nav-list li.future a::before,
[data-category="initiatives"] .site-nav-list li.initiatives a::before,
[data-category="collaboration"] .site-nav-list li.collaboration a::before,
[data-category="sword-shield"] .site-nav-list li.sword-shield a::before,
[data-category="partnership"] .site-nav-list li.partnership a::before,
[data-category="hr"] .site-nav-list li.hr a::before,
[data-category="history"] .site-nav-list li.history a::before {
	content: '';
	position: absolute;
	left: 0;
	bottom: -5px;
	width: 100%;
	height: 2px;
	background: #004180;
}

.ip__header .btn-drawer {
	cursor: pointer;
}

.nav-fixed .ip__header .btn-drawer {
	z-index: 15;
}

@media (min-width: 768px) {
	.ip__header .inner {
		display: flex;
		align-items: center;
	}

	.ip__header .site-nav-list {
		display: flex;
		flex-wrap: wrap;
		column-gap: 3em;
		width: 100%;
		margin-top: 0px;
	}

	.ip__header .site-nav-list li {
		margin-top: 0px;
		font-size: 15px;
	}

	.ip__header .site-nav-list li:nth-child(2) {
		display: none;
	}

	.ip__header .dropdown li:nth-child(2) {
		display: block;
	}

	.subli a::before {
		content: none !important;
	}

	.subli a {
		line-height: 1.3em;
	}

	.subli a:hover {
		text-decoration: underline solid #004180 2px;
		text-underline-offset: .5em;
	}

	.globalnav-wrap {
		font-size: 16px;
		display: flex;
		justify-content: space-between;
	}

	.dropdown-btn {
		position: relative;
		display: inline-block;
	}

	.dropdown-btn:hover::before {
		content: '';
		position: absolute;
		left: -7px;
		top: 20px;
		width: 2px;
		height: 14px;
		background: #eb0000;
	}

	.dropdown {
		z-index: 100;
		background: #fff;
		position: absolute;
		left: -.8em;
		top: calc(-250% + 33px);
		width: fit-content;
		padding: 10px 10px 10px 10px;
		display: none;
		opacity: 0;
		font-weight: normal;
	}

	.dropdown li {
		display: block;
		margin-top: 0 !important;
		padding: 0 !important;
	}

	.dropdown li+li {
		margin-top: 10px !important;
	}

	.nav-button-wrap,
	.open {
		top: 38px;
		display: block;
		opacity: 1;
		animation: fade-in .4s;
	}

	@keyframes fade-in {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	.close {
		display: block;
	}

	.nav-fixed .ip__header .inner {
		display: flex;
		justify-content: space-between;
		align-items: center;
		transition: opacity 1s, z-index 1s;
		z-index: -1;
		visibility: hidden;
	}

	.nav-fixed .ip__header.show .inner {
		justify-content: center;
		position: fixed;
		left: 50%;
		top: 0;
		width: 100%;
		height: 100vh;
		max-width: initial;
		max-width: auto;
		background: url(../img/common/bg-nav.png) no-repeat center top;
		background-size: cover;
		opacity: 1;
		transform: translateX(-50%);
		z-index: 100;
		visibility: visible;
	}

	.nav-fixed .ip__header.show .site-ttl {
		display: none;
	}

	.nav-fixed .ip__header .site-nav {
		width: 0;
		height: 0;
		margin: 0 auto;
		padding: 20px 0 20px 4vw;
		border-left: 1px solid #333;
		opacity: 0;
	}

	.nav-fixed .ip__header.show .site-nav {
		width: 70%;
		height: auto;
		transition: opacity 1.5s, z-index 1.5s;
		opacity: 1;
		background: none;
	}

	.nav-fixed .ip__header .site-nav-list {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.nav-fixed .ip__header .site-nav-list li {
		width: 45%;
		font-size: 20px;
	}

	.nav-fixed .ip__header .site-nav-list .site-top {
		display: none;
	}

	.nav-fixed .ip__header .site-nav-list .news {
		display: block;
	}

	.nav-fixed .ip__header .site-nav-list li {
		margin-top: 40px;
	}

	.nav-fixed .ip__header .site-nav-list li:first-child,
	.nav-fixed .ip__header .site-nav-list li:nth-child(2) {
		margin-top: 0px;
	}

	.nav-fixed .ip__header .site-nav-list li .en-ttl {
		display: block;
		margin-top: 10px;
		font-size: 12px;
		color: #004180;
	}

	.nav-fixed .ip__header .site-nav-list .top,
	.nav-fixed .ip__header .site-nav-list li .en-ttl {
		display: block;
	}

	.nav-fixed .ip__header .site-nav-list .dropdown-btn::before {
		content: none;
		display: none;
	}

	.nav-fixed .ip__header .site-nav-list li .dropdown {
		display: none;
	}

	.ip__header .btn-drawer {
		transition: opacity .5s ease-in-out;
		opacity: 0;
	}

	.ip__header .btn-drawer {
		position: fixed;
		right: 0;
		top: 110.5px;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 50px;
		height: 50px;
		background: #004180;
		font-size: 12px;
		color: #fff;
		cursor: pointer;
		opacity: 0;
		visibility: hidden;
	}

	.nav-fixed .ip__header .btn-drawer {
		visibility: visible;
		opacity: 1;
	}

	.nav-fixed .ip__header.show .btn-drawer {
		position: fixed;
		right: 25px;
		top: 116px;
		background: none;
	}

	.nav-fixed .ip__header.show .btn-drawer span {
		display: none;
	}

	.nav-fixed .ip__header.show .btn-drawer::before,
	.nav-fixed .ip__header.show .btn-drawer::after {
		content: '';
		position: absolute;
		left: 0;
		top: 50%;
		width: 100%;
		height: 2px;
		background: #333;
		transform: translateY(-50%);
	}

	.nav-fixed .ip__header.show .btn-drawer::before {
		transform: rotate(45deg);
	}

	.nav-fixed .ip__header.show .btn-drawer::after {
		transform: rotate(-45deg);
	}

	.nav-fixed .ip__header .site-nav .nav-ttl,
	.nav-fixed .ip__header .site-nav a {
		color: #333;
	}
}

@media (max-width: 767px) {
	.ip__header .inner {
		display: flex;
		justify-content: space-between;
		align-items: center;
		transition: opacity 1s, z-index 1s;
		z-index: -1;
	}

	.ip__header.show .inner {
		justify-content: center;
		position: fixed;
		left: 0;
		top: 0;
		width: 100%;
		height: 100vh;
		background: url(../img/common/bg-nav.png) no-repeat center top;
		background-size: cover;
		opacity: 1;
		z-index: 100;
	}

	.ip__header.show .site-ttl {
		display: none;
	}

	.ip__header .site-nav {
		width: 0;
		height: 0;
		margin: 0 auto;
		transition: opacity 1.5s, z-index 1.5s;
		visibility: hidden;
		opacity: 0;
	}

	.ip__header.show .site-nav {
		padding: 20px 0 20px 4vw;
		border-left: 1px solid #333;
		width: 70%;
		height: auto;
		visibility: visible;
		opacity: 1;
	}

	.ip__header .site-nav-list {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.ip__header .site-nav-list li {
		width: 50%;
		font-size: 20px;
	}

	.ip__header .site-nav-list li:nth-child(n+3) {
		margin-top: 40px;
	}

	.ip__header .site-nav-list li .en-ttl {
		display: block;
		margin-top: 10px;
		font-size: 12px;
		color: #004180;
	}

	.ip__header .btn-drawer {
		position: fixed;
		right: 0;
		top: 85.5px;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 50px;
		height: 50px;
		background: #004180;
		font-size: 12px;
		color: #fff;
		z-index: 15;
	}

	.ip__header.show .btn-drawer {
		position: fixed;
		background: none;
	}

	.ip__header.show .btn-drawer span {
		display: none;
	}

	.ip__header.show .btn-drawer::before,
	.ip__header.show .btn-drawer::after {
		content: '';
		position: absolute;
		left: 0;
		top: 50%;
		width: 100%;
		height: 2px;
		background: #333;
		transform: translateY(-50%);
	}

	.ip__header.show .btn-drawer::before {
		transform: rotate(45deg);
	}

	.ip__header.show .btn-drawer::after {
		transform: rotate(-45deg);
	}

	.ip__header .site-nav .nav-ttl,
	.ip__header .site-nav a {
		color: #333;
	}

	.ip__header .site-nav-list li .dropdown {
		display: none;
	}
}

@media (min-width: 768px) {
	.ip__header .inner {
		padding: 0 30px;
	}

	.ip__header .inner {
		max-width: 1260px;
		margin: 0 auto;
	}

	.ip__header .site-nav {
		width: 100%;
	}

	.ip__header .btn-drawer {
		right: 0;
	}
}

@media (max-width: 767px) {
	.ip__header .btn-drawer {
		top: 75.5px;
	}
}

@media (max-width: 768px) {
	.ip__header {
		position: relative;
		padding: 15px 30px;
		z-index: 5;
	}

	.ip__header .inner.show {
		background: url(../img/common/bg-nav-sp.png) no-repeat center top;
		background-size: cover;
	}

	.ip__header .site-ttl {
		font-size: 4.8vw;
	}

	.ip__header .site-nav {
		display: flex;
		flex-direction: column;
		justify-content: center;
		margin-top: -30vw;
		padding: 2.6666vw 0 2.6666vw 2vw;
	}

	.ip__header.show .site-nav {
		width: 81vw;
	}

	.ip__header .site-nav .nav-ttl {
		font-size: 3.7333vw;
	}

	.ip__header .site-nav .nav-ttl .en-ttl {
		margin-top: 2.6666vw;
		font-size: 2.6666vw;
	}

	.ip__header .site-nav-list li {
		font-size: 4.188888vw;
	}

	.ip__header .site-nav-list .news {
		margin-top: 0;
	}

	.ip__header .site-nav-list li:nth-child(n+3) {
		margin-top: 6vw;
	}

	.ip__header .site-nav-list li .en-ttl {
		margin-top: 1.3333vw;
		font-size: 2.6666vw;
		line-height: 1.4;
	}

	.ip__header .btn-drawer {
		right: 0;
		top: 67.5px;
		max-width: 50px;
		max-height: 50px;
		background: #004180;
		font-size: 12px;
	}

	.ip__header.show .btn-drawer {
		background: none;
	}
}

.ip__header .btn-drawer {
	right: 0;
}

@media (max-width: 428px) {
	.ip__header {
		position: relative;
		padding: 3.5vw 15px;
		z-index: 5;
	}

	.ip__header .btn-drawer {
		right: 0;
		top: 95px;
		width: 10.6666vw;
		height: 10.6666vw;
		font-size: 2.6666vw;
	}

	.ip__header.show .btn-drawer {
		right: 4vw;
		top: calc(60px + 0.66665vw);
	}
}

.ip__header {
	padding: 0;
}

@media (max-width: 375px) {
	.ip__header .site-nav {
		margin-top: -20vw;
	}
}


/* key-visual
-------------------------------------------------- */

.key-visual.lower .inner {
	max-width: 1240px;
	margin: 0 auto;
	padding: 90px 30px 0;
}

.key-visual.lower .kv-ttl {
	font-size: 30px;
}

.key-visual.lower .kv-ttl.wh {
	color: #fff;
}

.key-visual .kv-txt {
	margin-top: 20px;
	font-size: 14px;
}

.key-visual .kv-txt.wh {
	color: #fff;
}

@media (min-width: 1024px) {
	.key-visual.lower .inner {
		max-width: 1330px;
		margin: 0 auto;
		padding: 90px 65px 0;
	}
}

@media (min-width: 768px) {
	.key-visual.lower {
		width: 100%;
		height: 360px;
	}
}

@media (max-width: 768px) {
	.key-visual.lower .inner {
		padding: 10.6666vw 6.66666vw 10.6666vw;
	}

	.key-visual.lower .kv-ttl {
		font-size: 4.8vw;
	}
}


/* main
-------------------------------------------------- */

.main .heading {
	padding-top: 50px;
}

.main .heading .sec-ttl-type1 {
	margin-top: 20px;
	line-height: 1;
}

.main .heading .en-ttl {
	margin-top: 20px;
}

.main .heading .index-text {
	font-size: 18px;
	line-height: 1.65;
}

@media (max-width: 768px) {
	.main .heading {
		padding-top: 9.3333vw;
	}

	.main .heading .sec-ttl-type1 {
		margin-top: 0;
		line-height: 1.4;
	}

	.main .heading .en-ttl {
		margin-top: 2.6666vw;
	}

	.main .heading .index-text {
		font-size: 3.8vw;
	}
}


/* news
-------------------------------------------------- */

.news-list li {
	position: relative;
	background: #fff;
	box-shadow: 0px 0px 11px -2px rgba(0, 0, 0, 0.45);
	display: none;
}

.news-list li .news-tag {
	position: absolute;
	top: 0;
	left: 0;
	background: url(../img/common/icon-new.png) no-repeat center center;
	background-size: cover;
	width: 62px;
	height: 48px;
	z-index: 1;
}

.news-list li a {
	display: block;
	height: 100%;
}

.news-list li .img-photo {
	position: relative;
}

.news-list li img {
	width: 100%;
}

.news-list li .text-wrap {
	padding: 20px 15px 50px 20px;
}

.news-list li .date {
	font-size: 18px;
	color: #004180;
	font-weight: bold;
}

.news-list li .copy {
	margin-top: 10px;
	font-size: 16px;
	line-height: 1.5;
}

.news-list li .read-more {
	position: absolute;
	right: 15px;
	bottom: 15px;
	padding-right: 30px;
	font-size: 16px;
	font-weight: bold;
	color: #004180;
	text-align: right;
}

.news-list li .read-more::before {
	content: '';
	position: absolute;
	right: 0;
	bottom: 0;
	width: 19px;
	height: 9px;
	background: url(../img/common/icon-arrow.png) no-repeat 0 0;
}

.news-list li .read-more i {
	display: inline-block;
	font-style: normal;
	transform: translateY(1.5px);
}

.btn-read-more {
	margin-top: 70px;
	font-size: 18px;
	font-weight: bold;
	color: #004180;
	text-align: center;
}

.btn-read-more span {
	position: relative;
	display: inline-block;
}

.btn-read-more span::before {
	content: '';
	position: absolute;
	right: -20px;
	top: 50%;
	width: 15px;
	height: 13px;
	background: url(../img/common/icon-arrow-blue1.png) no-repeat 0 0;
	transform: translateY(-50%);
}

@media (min-width: 768px) {
	.other-news {
		margin-top: 100px;
	}

	.news-list {
		width: 102%;
		margin-top: 70px;
	}

	.news-list {
		width: 102%;
		margin-top: 70px;
	}

	.news-list {
		display: flex;
		flex-wrap: wrap;
		margin: 20px 0 0 -2%;
	}

	.news-list li {
		width: 31.3333%;
		margin: 2.5% 0 0 2%;
	}
}

@media (max-width: 768px) {
	#news .sec-ttl-type1 {
		font-size: 4.26666vw;
	}

	.other-news {
		margin-top: 13.3333vw;
	}

	.news-list {
		display: flex;
		flex-direction: column;
		margin-top: 8vw;
	}

	.news-list li+li {
		margin-top: 4vw;
	}

	.news-list li a {
		display: flex;
		flex-wrap: wrap;
	}

	.news-list li .img-photo {
		position: relative;
		display: flex;
		justify-content: center;
		align-items: flex-start;
		width: 38%;
		overflow: hidden;
	}

	.news-list li .img-photo img {
		width: 100%;
		height: 33vw;
		max-width: initial;
		object-fit: cover;
		/* font-family: 'object-fit: cover; object-position: bottom;'; */
	}

	.news-list li .text-wrap {
		width: 62%;
		padding: 2.6666vw 3.2vw 6vw;
	}

	.news-list li .date {
		font-size: 3.7333vw;
	}

	.news-list li .copy {
		margin-top: 1.6vw;
		font-size: 3.2vw;
	}

	.news-list li .read-more {
		right: 4vw;
		bottom: 2vw;
		padding-right: 6vw;
		font-size: 3.2vw;
	}

	.news-list li .read-more::before {
		top: auto;
		bottom: 0;
		width: 4vw;
		height: 2vw;
		background-size: 100%;
	}

	.news-list li .read-more i {
		display: inline-block;
		font-style: normal;
		transform: translateY(1.5px);
	}

	.btn-read-more {
		margin-top: 70px;
		font-size: 18px;
		font-weight: bold;
		color: #004180;
		text-align: center;
	}

	.btn-read-more span {
		position: relative;
		display: inline-block;
	}

	.btn-read-more span::before {
		content: '';
		position: absolute;
		right: -20px;
		top: 50%;
		width: 15px;
		height: 13px;
		background: url(../img/common/icon-arrow-blue1.png) no-repeat 0 0;
		transform: translateY(-50%);
	}

	.news-list li .news-tag {
		position: absolute;
		top: 0;
		left: 0;
		background: url(../img/common/icon-new-sp.png) no-repeat center center;
		background-size: cover;
		width: 14.4vw;
		height: 10.4vw;
		z-index: 1;
	}
}


/* profile
-------------------------------------------------- */

.profile+.profile {
	margin-top: 60px;
}

.profile .heading {
	display: flex;
	/* align-items: center; */
	flex-wrap: wrap;
	/* padding-top: 80px; */
}

.profile .heading .elem-wrap {
	width: 50%;
	display: flex;
	flex-direction: column;
}

.profile .heading .elem-wrap .btm {
	flex-grow: 1;
}

.profile .heading .sec-ttl-type1 {
	line-height: 1.65;
}

.profile .heading .position {
	margin-top: 30px;
	font-size: 18px;
	line-height: 1.65;
}

.profile .heading .profile-date {
	margin-top: auto;
	font-size: 18px;
	line-height: 1.65;
	text-align: right;
}

.profile .heading .name {
	margin-top: 10px;
	font-size: 28px;
	line-height: 1em;
}

.profile .heading .profile-photo {
	width: 45%;
	margin-left: auto;
}

.profile .heading .profile-photo img {
	width: 100%;
}

@media (max-width: 768px) {
	.profile+.profile {
		margin-top: 0;
	}

	.profile .heading {
		position: relative;
		display: block;
		padding-top: 9.3333vw;
		align-items: center;
	}



	.profile .heading .sec-ttl-type1 {
		width: 100%;
		margin-top: 0;
		font-size: 5.3333vw;
		line-height: 1.4;
	}

	.profile .heading .elem-wrap {
		width: 100%;
	}

	.profile .heading .position {
		margin-top: 24vw;
		font-size: 2.6666vw;
	}
	
	#honma .heading .position {
		margin-top: 24vw;
		font-size: 2.6666vw;
	}
	
	#sanatake .heading .position {
		margin-top: 19vw;
		font-size: 2.6666vw;
	}
	
	.profile .heading .profile-date {
		margin-top: 1em;
		font-size: 2.6666vw;
		text-align: left;
	}

	.profile .heading .name {
		margin-top: 1.5vw;
		font-size: 3.7333vw;
	}

	.profile .heading .profile-photo {
		position: absolute;
		right: 0;
		bottom: 0;
		width: 57.14285%;
	}

	.profile .heading .text-wrap {
		width: 35vw;
		margin-top: 24vw;
	}
	
	.sanadake .heading .text-wrap {
		width: 35vw;
		margin-top: 17.5vw;
	}

	.profile .detail .body-copy {
		text-align: justify;
	}

	.sec-ttl-type1 {
		font-size: 5.3333vw;
	}
}


/* history
-------------------------------------------------- */

.history {
	margin-top: 80px;
}

.history .history-list {
	margin-top: 80px;
}

.history .history-list>li {
	position: relative;
	padding-bottom: 50px;
}

.history .history-list>li.show {
	padding-bottom: 15px;
}

.history .history-list>li::before {
	content: '';
	position: absolute;
	left: 40px;
	top: 0;
	width: 1px;
	height: 100%;
	background: #333;
}


.history .history-list li .history-ttl {
	position: relative;
	padding: 0 50px 15px 10px;
	border-bottom: 1px solid #848484;
	color: #333;
	font-size: 2vw;
	line-height: 1.4;
	text-decoration: none;
	cursor: pointer;
	background-color: #f3f3f3;
	display: flex;
}

.history .history-list li .history-ttl::after {
	content: '';
	position: absolute;
	right: 5px;
	top: 5%;
	width: 20px;
	height: 11px;
	background: url(../img/common/btn-arrow3.png) no-repeat;
	background-size: 100%;
	transition: transform .25s;
	transform-origin: center center;
	transform: rotate(180deg) translate(0, -50%);
}

.history .history-list li.show .history-ttl::after {
	top: 22.5%;
	transform: rotate(0deg) translate(0, -50%);
}

.history .history-list li .history-ttl span {
	display: inline-block;
	font-weight: bold;
}

.history .history-list li .history-ttl .year {
	font-style: italic;
	white-space: nowrap;
}

.history .history-list li .history-ttl .title {
	margin-left: 25px;
}

.history .history-list li .detail {
	display: none;
	padding: 25px 0 25px 70px;
	transition: opacity .5s;
	opacity: 0;
}

.history .history-list li .detail.show {
	opacity: 1;
}

.note,
.detail-figure figcaption,
.history-figure figcaption {
	margin-top: 5px;
	font-size: 13px;
	line-height: 1.4;
}


@media (min-width: 1001px) {
	.history .history-list li .history-ttl {
		font-size: 20px;
	}
}

@media (min-width: 768px) {
	.history .history-list li .history-ttl::before {
		content: '';
		position: absolute;
		left: 0;
		bottom: -1px;
		width: 0;
		height: 4px;
		background: #004180;
		transition: width .5s;
	}

	.history .history-list li .history-ttl:hover::before {
		width: 100%;
	}

	.detail .right-col {
		margin-left: 30px;
	}

	.history .history-figure.mt {
		margin-top: 30px;
	}

	.detail-figure+.detail-figure,
	.history-figure+.history-figure {
		margin-top: 20px;
	}
}

@media (max-width: 768px) {

	.history,
	.history .history-list {
		margin-top: 10.6666vw;
	}

	.history .history-list>li {
		padding-bottom: 12vw;
	}

	.history .history-list>li.show {
		padding-bottom: 4vw;
	}

	.history .history-list>li::before {
		left: 3.2vw;
		width: 1px;
	}

	.history .history-list>li.multi-line.show::before {
		height: calc(100% - 21vw);
	}

	.history .history-list li .history-ttl {
		position: relative;
		padding: 0 6.5vw 2vw 1.3333vw;
		font-size: 3.4666vw;
	}

	.history .history-list li .history-ttl span {
		display: block;
	}

	.history .history-list li .history-ttl::after {
		right: 1.25vw;
		top: auto;
		bottom: 4.5vw;
		width: 4vw;
		height: 2vw;
	}

	.history .history-list li.show .history-ttl::after {
		top: auto;
		bottom: 3vw;
	}

	.history .history-list li .history-ttl .title {
		margin-left: 1em;
		margin-top: 1.3333vw;
		font-size: 3.6vw;
	}

	.history .history-list li .history-ttl .year {
		margin-top: 1.3333vw;
		font-size: 3.6vw;
	}

	.history .history-list li .detail {
		padding: 3.3333vw 0 3.3333vw 9.3333vw;
	}

	.history .history-list li .right-col {
		display: flex;
	}

	.history-figure+.history-figure {
		margin-left: 6vw !important;
	}

	.detail .elem-wrap {
		width: 100%;
	}

	.detail .detail-figure,
	.detail .history-figure {
		max-width: 45%;
		margin-top: 6vw;
		margin-left: 0;
	}

	.detail .detail-figure.width100,
	.detail .history-figure.width100 {
		width: 100%;
		max-width: initial;
	}

	.detail-figure figcaption,
	.history-figure figcaption {
		margin-top: 1.3333vw;
		font-size: 2.6666vw;
	}

	.detail-figure .horizontal {
		width: 42.5vw;
	}

	.history-figure .horizontal {
		width: 38vw;
	}

	.history-figure .vertical {
		width: 26.6666vw;
	}
}


/* sec-detail-type1
-------------------------------------------------- */

.sec-detail-type1 {
	margin-top: 60px;
}

.sec-detail-type1 .detail {
	position: relative;
	display: none;
	padding-top: 40px;
	padding-bottom: 100px;
	transition: opacity .5s;
	opacity: 0;
}

.sec-detail-type1 .detail::before {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 125px;
	height: 2px;
	background: #004180;
}

.sec-detail-type1 .detail.show {
	opacity: 1;
}

@media (max-width: 768px) {
	.sec-detail-type1 {
		margin-top: 13.3333vw;
	}

	.sec-detail-type1 .detail {
		padding-top: 5.33333vw;
		padding-bottom: 13.3333vw;
		margin-bottom: 13.33333vw;
	}
}


/* sec-detail-type2
-------------------------------------------------- */

.sec-detail-type2 {
	margin-top: 60px;
}

.sec-detail-type2 .sec-ttl {
	position: relative;
	display: inline-block;
	padding-bottom: 15px;
	font-size: 18px;
}

.sec-detail-type2 .detail {
	margin-top: 20px;
}

@media (min-width: 768px) {
	.sec-detail-type2 .sec-ttl::before {
		content: '';
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
		height: 1px;
		background: #808080;
	}
}

@media (max-width: 768px) {
	.sec-detail-type2 {
		margin-top: 13.3333vw;
	}

	.sec-detail-type2 .detail {
		margin-top: 2.6666vw;
	}

	.sec-detail-type2 .sec-ttl {
		padding-bottom: 2vw;
		border-bottom: 1px solid #808080;
		font-size: 3.4666vw;
		line-height: 1.4;
	}
}

#lang-chng {
	z-index: 1;
}

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

.file-date {
	font-size: 16px;
	margin-top: 50px;
	text-align: right;
}
@media (max-width: 767px){
	.mt-30 {
		margin-top: 4vw !important;
	}
	.mt-50 {
		margin-top: 6.6666vw !important;
	}
}