@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
@media all and (-ms-high-contrast: none) {
	#container {
		overflow: hidden;
	}
  }
.mainVisual {
	position: relative;
	overflow: hidden;
}
.mainVisual .photo {
	height: 768px;
	background: url("/img/index/movie-pc01.mp4") no-repeat center top;
	background-size: cover;
}
/*
.mainVisual .photo01 {
	background-image: url("/img/index/img_fv02.jpg");
}
*/
.mainVisual .textBox {
	position: absolute;
	left: 0;
	bottom: 0;
	top: 0;
	width: 100%;
	z-index: 1;
}
.mainVisual .textBox .content {
	width: 74%;
	height: 100%;
	padding-top: 17px;
	display: flex;
	align-items: center;
	box-sizing: border-box;
}
.mainVisual .textBox p {
	font-size: 1.8rem;
	color: #fff;
	font-weight: 500;
	line-height: 2.61;
	letter-spacing: 0.25em;
}
.mainVisual .textBox .text {
	opacity: 1;
	transform-origin: 0 0;
	transition: all 1400ms ease 400ms;
}
.mainVisual.on .textBox .text {
	opacity: 0;
	transform: translate(20px, 0);
}
.mainVisual .textBox .name {
	margin: 35px 0 -35px;
	font-weight: 500;
	font-size: 4rem;
    letter-spacing: 0.13em;
	overflow: hidden;
}
.mainVisual .textBox .name span {
	display: block;
	opacity: 0;
	transform: translateY(100%);
	transition: transform 1.2s ease 0.6s,opacity 1.2s ease 0.6s;
}
.mainVisual.active .textBox .name span {
	opacity: 1;
	transform: translateY(0);
}
.mainVisual .textBox .en {
	font-size: 2.7rem;
	letter-spacing: 0.1em;
	font-weight: 700;
	overflow: hidden;
    margin-top: 10px;
}
.mainVisual .textBox .en span {
	display: block;
	opacity: 0;
	transform: translateY(100%);
	transition: transform 1.2s ease 1s,opacity 1.2s ease 1s;
}
.mainVisual.active .textBox .en span {
	opacity: 1;
	transform: translateY(0);
}
.mainVisual .enImg {
	width: 118px;
    position: absolute;
    top: 50%;
    right: 2%;
    z-index: 1;
    transform: translateY(-50%);
}
#english .mainVisual .enImg {
    right: 0;
    width: 146px;
}
.mainVisual .banner {
	position: absolute;
    bottom: 0;
    right: 0;
    width: 455px;
    opacity: 0;
    transform: translateX(100%);
    transition: transform 1s 1.5s, opacity .6s 1.7s;
    z-index: 1;
}
.mainVisual.active .banner {
	opacity: 1;
	transform: translateX(0);
}
.mainVisual .banner a:hover {
    opacity: .8;
}
.mainVisual .enImg a:hover {
	opacity: .8;
}
/*
.mainVisual .slide {
	overflow: hidden;
}
.mainVisual .slide img {
	transition: transform 12s;
	-moz-transition: -moz-transform 12s;
	-webkit-transition: -webkit-transform 12s;
	transition-timing-function: linear;
	-moz-transition-timing-function: linear;
	-webkit-transition-timing-function: linear;
	transform: scale(1.2) translate3d(0, 0, 0);
	-moz-transform: scale(1.2) translate3d(0, 0, 0);
	-webkit-transform: scale(1.2) translate3d(0, 0, 0);
}
.mainVisual .slide img.active {
	transform: scale(1.2) translate3d(90px, 0, 0);
	-moz-transform: scale(1.2) translate3d(90px, 0, 0);
	-webkit-transform: scale(1.2) translate3d(90px, 0, 0);
}
*/
#main .topBox {
    padding: 125px 0 113px;
	background-color: #EDF0F2;
}
#main .topBox .lBox {
	width: 580px;
	padding: 28px 0 0;
}
#main .topBox .lBox p {
	line-height: 2.07;
	letter-spacing: 0.12em;
}
#main .topBox .lBox .title {
	margin-bottom: 42px;
	color: #1C476A;
	font-size: 2.6rem;
	letter-spacing: 0.14em;
	line-height: 1.9;
}
#main .topBox .rBox {
	width: 348px;
    padding-top: 45px;
}
#main .topBox .rBox p {
	margin-top: 20px;
	font-size: 1.2rem;
	letter-spacing: 0.08em;
	line-height: 1.66;
	color: rgba(34,34,34,0.7)
}
#main .topBox .chart_container {
	display: -ms-grid;
	display: grid;
	-ms-grid-rows: 45px 45px 28px 124px 28px 90px;
	-ms-grid-columns: 150px 48px 150px;
	grid-template: 45px 45px 28px 124px 28px 0px / 150px 48px 150px;
}
#main .topBox .chart_item {
    background: #fff;
	position: relative;
	display: block;
}
#main .topBox .chart_item > span {
	position: absolute;
    left: 50%;
    transform: translateX(-43%);
    bottom: 10px;
    font-size: 12px;
    letter-spacing: 1.4px;
    font-weight: 500;
}
#main .topBox .chart_container a.chart_item:hover img,
#main .topBox .chart_container a.chart_item:hover > span {
	opacity: .6!important;
}
#main .topBox .chart_container img {
    position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
#main .topBox .chart_per {
    position: absolute;
    background: #6A9AC2;
    width: 32px;
    height: 32px;
    border-radius: 16px;
    font-size: 14px;
    color: #fff;
    line-height: 30px;
	text-align: center;
    box-sizing: border-box;
	font-weight: 500;;
}
#main .topBox .chart_per span {
	font-size: 1rem;
}
#main .topBox .chart_01 {
	-ms-grid-row: 1;
	-ms-grid-row-span: 2;
	-ms-grid-column: 1;
	-ms-grid-column-span: 3;
	grid-area: 1 / 1 / 3 / 4;
}
#main .topBox .chart_01 img {
	transform: translate(-51%, -64%);
    width: 66%;
}
#main .topBox .chart_01 > span {
	transform: translateX(-53%);
	bottom: 21px;
}
#main .topBox .chart_01 img {
	transform: translate(-51%, -86%);
    width: 30%;
}
#main .topBox .chart_02 {
	-ms-grid-row: 1;
	-ms-grid-row-span: 2;
	-ms-grid-column: 3;
	-ms-grid-column-span: 1;
	grid-area: 1 / 3 / 3 / 4;
}
#main .topBox .chart_02 img {
	width: 70%;
	transform: translate(-46%, -50%);
}
#main .topBox .chart_per_02 {
	left: -16px;
    top: 50%;
    transform: translateY(-50%);
}
#main .topBox .chart_03 {
	-ms-grid-row: 4;
	-ms-grid-row-span: 1;
	-ms-grid-column: 1;
	-ms-grid-column-span: 3;
	grid-area: 4 / 1 / 5 / 4;
}
#main .topBox .chart_03 img {
	transform: translate(-50%, -77%);
    width: 40%;
}
#main .topBox .chart_03 > span {
    bottom: 30px;
    left: 46%;
/*    color: #005EAE;*/
}
#main .topBox .chart_per_01,
#main .topBox .chart_per_03 {
	width: 48px;
    bottom: -16px;
    left: 50%;
    transform: translateX(-50%);
}
#main .topBox .chart_04 {
	-ms-grid-row: 6;
	-ms-grid-row-span: 1;
	-ms-grid-column: 1;
	-ms-grid-column-span: 3;
	grid-area: 6 / 1 / 7 / 4;
}
#main .topBox .chart_04 img {
	width: 49%;
	transform: translate(-50%, -78%);
}
#main .topBox .chart_04 > span {
	bottom: 18px;
    transform: translateX(-43%);
}
#main .topBox .chart_line_01 {
	height: 2px;
    background: #6A9AC2;
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    grid-area: 2 / 2 / 3 / 2;
	display: block;
}
#main .topBox .chart_line_02 {
	width: 2px;
    background: #6A9AC2;
    -ms-grid-row: 2;
    -ms-grid-row-span: 5;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 2 / 2 / 5 / 2;
    -ms-grid-column-align: center;
    justify-self: center;
	display: block;
}
#main .topBox .banner {
	max-width: 1210px;
    margin: 100px auto 20px;
    width: 95%;
}
#main .topBox .banner a:hover {
	opacity: 0.8;
}
#main .news {
	padding: 91px 0 105px;
}
#main .news .headLine01 {
	margin-bottom: 42px;
	text-align: center;
}
#main .news .comNewsUl {
	width: 700px;
	margin: 0 auto 34px;
}
#main .news .comNewsUl > li {
	padding: 20px 0 19px;
	overflow: hidden;
	border-bottom-width: 1px;
}
#main .news .comNewsUl .time {
	float: left;
	margin-bottom: 0;
	letter-spacing: 0.04em;
	font-size: 1.4rem;
}
#main .news .comNewsUl .txt {
	padding: 0 0 0 7em;
	font-size: 1.5rem;
}
#main .news .comNewsUl .txt.txt_content {
	padding: 0.5em 0 0 8.1em;
	font-size: 1.3rem;
}
#main .news .link {
	text-align: center;
}
#main .news .link a {
	padding-right: 20px;
	display: inline-block;
	color: #2C70A9;
	font-size: 1.4rem;
	letter-spacing: 0.08em;
	font-weight: 500;
	background: url("/img/common/icon01.png") no-repeat right center;
	background-size: 9px auto;
}
#main .news .link a:hover {
	opacity: 0.6;
}
#main .company {
	padding-bottom: 79px;
}
#main .company .content {
	width: 1036px;
}
#main .company .listUl > li {
	width: 481px;
}
#main .company .listUl > li:last-child {
	position: relative;
	padding-bottom: 50px;
}
#main .company dl {
	padding-top: 6px;
}
#main .company dt {
	padding-top: 12px;
	float: left;
	font-size: 1.5rem;
	letter-spacing: 0.2em;
}
#main .company dd {
	padding: 12px 0 11px 8.2em;
	font-size: 1.3rem;
	line-height: 1.84;
	letter-spacing: 0.08em;
	border-bottom: 1px solid #E2E2E2;
}
#main .company .textUl li {
	padding: 18px 0 11px;
	font-size: 1.3rem;
	line-height: 1.84;
	letter-spacing: 0.08em;
	border-bottom: 1px solid #E2E2E2;
}
#main .company .textUl li a {
    color: #2C70A9;
}
#main .company .textUl li a:hover {
	border-bottom: 1px solid #2C70A9;
}
#main .company .comLink01 {
	margin-top: 65px;
}
#main .company .btmLink .comLink {
	margin-top: 66px;
	padding-bottom: 8px;
}
#main .company .btmLink a {
	font-size: 1.7rem;
	padding-right: 27px;
}
#main .company .photo {
	margin: 0 0 76px;
}
#main .company .photo li {
	width: calc(100% / 3);
	position: relative;
}
@media all and (-ms-high-contrast: none) {
		#main .company .photo li {
			width: calc(100% / 3.001);
		}
  }
#main .company .photo li img {
	width: 100%;
}
#main .company .photo li span {
	position: absolute;
	left: 25px;
	bottom: 16px;
	color: #fff;
	letter-spacing: 0.08em;
	font-weight: 600;
    text-shadow: 0px 0px 8px rgb(0 0 0);
}
#main .product {
	padding: 122px 0 135px;
	background-color: #EDF0F2;
}
#main .product .content {
	width: 1100px;
}
#main .product .headLine01 {
	margin-bottom: 32px;
	text-align: center;
}
#main .product .whiteUl {
	background-color: #fff;
	margin: 0 0 2px;
}
#main .product .whiteUl .comLink {
	padding: 0;
	margin-bottom: 18px;
	border-bottom: none;
}
#main .product .whiteUl > li {
	width: 50%;
	box-sizing: border-box;
}
#main .product .whiteUl > li:first-child {
	padding: 35px 39px;
	border-right: 2px solid #EDF0F2;
}
#main .product .borList li {
	padding-left: 13px;
	position: relative;
	line-height: 2;
	font-size: 1.3rem;
	letter-spacing: 0.08em;
}
#main .product .borList li:before {
	position: absolute;
	left: 0;
	top: 12px;
	width: 7px;
	height: 1px;
	background-color: #95B7D4;
	content: "";
}
#main .product .listUl > li {
	width: 209px;
}
#main .product .listUl > li:last-child {
	width: 200px;
}
#main .product .listUl .liMargin {
	margin-bottom: 20px;
}
#main .product .whiteUl > li:last-child .comLink a {
	font-size: 1.8rem;
}
#main .product .whiteUl > li:last-child > ul > li {
	padding: 35px 20px 15px 30px;
	width: 50%;
	box-sizing: border-box;
}
#main .product .whiteUl > li:last-child > ul > li:first-child {
	border-right: 2px solid #EDF0F2;
}
#main .product .whiteUl > li:last-child > ul > li:last-child {
	padding: 25px 30px 27px;
	width: 100%;
	border-top: 2px solid #EDF0F2;
}
#main .product .whiteUl > li:last-child > ul > li:last-child .comLink {
	margin-bottom: 12px;
}
#main .product .whiteUl > li:last-child p {
	color: #6F6F6F;
	font-size: 1rem;
	line-height: 1.6;
	letter-spacing: 0.06em;
	text-indent: -1em;
	padding: 12px 0 0 1em;
}
#main .business {
	padding: 112px 0 116px;
	background-color: #2C70A9;
}
#main .business .content {
	width: 1018px;
}
#main .business .headLine01 {
	width: 400px;
	color: #fff;
	font-size: 3.3rem;
}
#main .business .textUl {
	margin-top: 7px;
	width: 517px;
}
#main .business .textUl > li {
	width: 231px;
}
#main .business .textUl > li:last-child {
	margin-top: 51px;
	width: 100%;
}
#main .business .comLink {
	border-bottom-color: #fff;
}
#main .business .comLink a {
	color: #fff;
	display: block;
	font-size: 1.8rem;
	letter-spacing: 0.12em;
	background-image: url("/img/common/icon03.png");
}
#main .business .textUl li ul {
	margin-top: 12px;
}
#main .business .textUl li li a {
	padding-left: 15px;
	display: inline-block;
	line-height: 2.2;
	color: #fff;
	position: relative;
	letter-spacing: 0.1em;
}
#main .business .textUl li li a:before {
	position: absolute;
	left: 0;
	top: 16px;
	width: 7px;
	height: 1px;
	background-color: #fff;
	content: "";
}
#main .business .textUl li li a:hover {
	opacity: 0.6;
}
#main .btmInfo {
	overflow: hidden;
	background: url("/img/index/photo03.jpg") no-repeat center top;
	background-size: cover;
}
#main .btmInfo .photoBox {
	width: 50%;
	text-align: center;
}
#main .btmInfo .photoBox a {
	display: block;
	height: 100%;
	padding: 86px 0 75px;
	box-sizing: border-box;
	position: relative;
}
#main .btmInfo .photoBox .bg {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 100%;
	background: linear-gradient(#2c70a9 0%, #1c476a 100%);
	opacity: 0.4;
	content: "";
	mix-blend-mode: multiply;
	-webkit-transition: width 0.7s,height 0.7s;
	-moz-transition: width 0.7s,height 0.7s;
	-ms-transition: width 0.7s,height 0.7s;
	-o-transition: width 0.7s,height 0.7s;
	transition: width 0.7s,height 0.7s;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
}
#main .btmInfo .photoBox:last-child .bg {
	background: #00203b;
	opacity: 0.65;
}
#main .btmInfo .textBox {
	position: relative;
	z-index: 1;
}
#main .btmInfo h2 {
	margin-bottom: 42px;
	position: relative;
	color: #fff;
	text-align: center;
	font-size: 2.8rem;
	font-weight: 500;
	letter-spacing: 0.13em;
}
#main .btmInfo h2:before {
	margin-left: -20px;
	position: absolute;
	left: 50%;
	bottom: -21px;
	width: 39px;
	height: 1px;
	content: "";
	background: rgba(255,255,255,0.6);
}
#main .btmInfo p,
#main .btmInfo dl {
	font-size: 1.3rem;
	line-height: 2;
	color: #fff;
	font-weight: 400;
	letter-spacing: 0.1em;
}
#main .btmInfo dl {
	display: inline-block;
	text-align: left;
}
#main .btmInfo dl dt {
	float: left;
}
#main .btmInfo dl dd {
	padding: 0 0 0 7.8em;
}
#main .btmInfo .link {
	margin-top: 34px;
	font-weight: 500;
	font-size: 1.4rem;
	letter-spacing: 0.08em;
}
#main .btmInfo .link span {
	padding-right: 15px;
	display: inline-block;
	background: url("/img/common/icon03.png") no-repeat right center;
	background-size: 9px auto;
}

@media all and (min-width: 768px) {
	#main .btmInfo .photoBox a:hover .bg {
		width: 80%;
		height: 80%;
	}
}

@media all and (max-width: 767px) {
	.mainVisual .photo {
		height: 667px;
		background-image: url("/img/index/sp_img_fv01.jpg");
	}
	.mainVisual .photo01 {
		background-image: url("/img/index/sp_img_fv02.jpg");
	}
	.mainVisual .textBox .content {
		padding: 0 20px 30px;
	}
	.mainVisual .textBox p {
		font-size: 1.4rem;
		font-weight: 400;
		line-height: 2;
		letter-spacing: 0.16em;
	}
	.mainVisual .textBox .name {
		margin: 42px 0 -5px;
		font-size: 2rem;
		letter-spacing: 0.1em;
        line-height: 1.5;
	}
	.mainVisual .textBox .en {
		font-size: 1.6rem;
        letter-spacing: 0.05em;
        margin-top: 20px;
	}
	.mainVisual .enImg {
		width: 40%;
		bottom: -2px;
		margin: 0;
		top: auto;
		right: 60%;
		padding: 0 34px;
		box-sizing: border-box;
	}
	#english .mainVisual .enImg {
		padding: 0;
		bottom: 0;
		transform: none;
		width: 120px;
	}
	.mainVisual .banner {
		width: 60%;
	}
	#main .topBox {
		padding: 45px 20px 60px;
	}
	#main .topBox .info {
		display: inherit;
	}
	#main .topBox .lBox {
		width: auto!important;
	}
	#main .topBox .lBox p {
		line-height: 2;
		letter-spacing: 0.05em;
	}
	#main .topBox .lBox .title {
		margin-bottom: 27px!important;
		font-size: 1.7rem;
		line-height: 1.94;
		letter-spacing: 0.08em;
	}
	#main .topBox .rBox {
		margin: 50px 0 0;
		width: auto!important;
        padding-top: 0;
	}
	#main .topBox .chart_container {
		-ms-grid-rows: 45px 45px 30px 122px 30px 90px;
		-ms-grid-columns: 42% 16% 42%;
		grid-template: 45px 45px 30px 122px 30px 0 / 42% 16% 42%;
	}
	#main .topBox .chart_per {
		width: 30px;
		height: 30px;
		font-size: 13px;
		line-height: 28px;
	}
	#main .topBox .chart_per_01,
	#main .topBox .chart_per_03 {
		width: 42px;
	}
	#main .topBox .chart_01 img {
		width: 34%;
		transform: translate(-51%, -84%);
	}
	#main .topBox .chart_01 > span {
		bottom: 20px;
	}
	#main .topBox .chart_02 img {
		width: 75%;
	}
	#main .topBox .chart_03 img {
		width: 42%;
		transform: translate(-50%, -77%);	
	}
	#main .topBox .chart_03 > span {
		bottom: 30px;
        left: 42%;
        transform: translateX(-36%);
	}
	#main .topBox .chart_04 img {
		width: 52%;
	}
	#main .topBox .rBox p {
		margin-top: 0;
	}
	#main .topBox .banner {
		margin: 80px 0 30px;
		width: 100%;
	}
	#main .news {
		padding: 67px 20px 91px;
	}
	#main .news .headLine01 {
		margin-bottom: 23px;
	}
	#main .news .comNewsUl {
		width: auto;
		margin: 0 auto 26px;
	}
	#main .news .comNewsUl > li {
		padding: 16px 0 21px;
		overflow: hidden;
		border-bottom-width: 1px;
	}
	#main .news .comNewsUl .time {
		font-size: 1.3rem;
		padding-top: 3px;
	}
	#main .news .comNewsUl .txt {
		padding: 0 0 0 6em;
		font-size: 1.4rem;
	}
	#main .news .comNewsUl .txt.txt_content {
		padding: 0.2em 0 0 7em;
		font-size: 1.2rem;
		line-height: 1.7;
	}
	#main .company {
		padding: 0 20px 60px;
	}
	#main .company .headLine01 {
		margin-bottom: 27px;
	}
	#main .company .listUl {
		display: inherit;
	}
	#main .company .listUl > li {
		width: auto;
	}
	#main .company .listUl > li:last-child {
		padding: 51px 0 0;
	}
	#main .company dl {
		padding-top: 4px;
	}
	#main .company dt {
		font-size: 1.4rem;
		letter-spacing: 0.18em;
	}
	#main .company dd {
		padding: 12px 0 11px 7.3em;
		line-height: 1.69;
		letter-spacing: 0.05em;
	}
	#main .company .textUl li {
		padding: 16px 0 13px;
		line-height: 1.69;
		letter-spacing: 0.05em;
	}
	#main .company .comLink01 {
		margin-top: 51px!important;
	}
	#main .company .btmLink .comLink {
		width: 47.8%;
		margin-top: 51px;
	}
	#main .company .btmLink .comLink:last-child {
		margin-top: 21px;
		width: 100%;
	}
	#main .company .btmLink a {
		padding-bottom: 8px;
		font-size: 1.4rem;
		padding-right: 13px;
	}
	#main .company .photo {
		margin: 0 -20px 50px;
	}
	#main .company .photo li span {
		left: 7px;
		bottom: 8px;
		font-size: 1.2rem;
		font-weight: 500;
		text-shadow: 0px 0px 8px rgb(0 0 0 / 40%);
		letter-spacing: 0.02em;
	}
	#main .company .photo img {
		width: 100%;
	}
	#main .product {
		padding: 67px 13px 69px;
	}
	#main .product .headLine01 {
		margin-bottom: 29px;
	}
	#main .product .whiteUl .comLink {
		margin-bottom: 8px;
	}
	#main .product .whiteUl .comLink a {
		display: inline-block;
		background-position: right top 6px;
	}
	#main .product .whiteUl > li {
		width: 100%;
	}
	#main .product .whiteUl > li:first-child {
		padding: 23px 20px;
		border-right: none;
		border-bottom: 1px solid #EDF0F2;
	}
	#main .product .borList li {
		padding-left: 15px;
		line-height: 1.84;
	}
	#main .product .borList li:before {
		left: 2px;
	}
	#main .product .listUl {
		justify-content: space-between;
	}
	#main .product .listUl > li {
		width: 50%;
	}
	#main .product .listUl > li:last-child {
		width: 46.5%;
	}
	#main .product .listUl .liMargin {
		margin-bottom: 15px;
	}
	#main .product .whiteUl > li:last-child .comLink a {
		font-size: 1.6rem;
	}
	#main .product .whiteUl > li:last-child > ul > li {
		padding: 26px 20px 12px;
		width: 100%;
	}
	#main .product .whiteUl > li:last-child > ul > li:first-child {
		padding-bottom: 24px;
		border-right: none;
		border-bottom: 1px solid #EDF0F2;
	}
	#main .product .whiteUl > li:last-child > ul > li:last-child {
		padding: 26px 20px 24px;
		border-top-width: 1px;
	}
	#main .product .whiteUl > li:last-child > ul > li:last-child .comLink {
		margin-bottom: 8px;
	}
	#main .product .whiteUl > li:last-child p {
		line-height: 1.7;
		padding: 8px 0 0 1em;
	}
	#main .business {
		padding: 72px 20px 83px;
	}
	#main .business .headLine01 {
		margin-bottom: 41px;
		width: 100%;
		text-align: center;
		font-size: 2.4rem;
	}
	#main .business .textUl {
		margin-top: 0;
		width: 100%;
	}
	#main .business .textUl > li {
		width: 100%!important;
	}
	#main .business .textUl > li:first-child {
		order: -2;
	}
	#main .business .textUl > li:last-child {
		margin: 36px 0 41px;
		order: -1;
	}
	#main .business .comLink a {
		padding-bottom: 7px;
		font-size: 1.5rem;
		letter-spacing: 0.08em;
	}
	#main .business .textUl li ul {
		margin-top: 11px;
	}
	#main .business .textUl li li a {
		padding-left: 17px;
		line-height: 2;
		font-weight: 500;
		letter-spacing: 0.05em;
	}
	#main .business .textUl li li a:before {
		top: 12px;
	}
	#main .btmInfo {
		display: inherit;
		background-image: url("/img/index/sp_photo02.jpg");
	}
	#main .btmInfo .photoBox {
		width: auto;
	}
	#main .btmInfo .photoBox a {
		padding: 69px 0 74px;
	}
	#main .btmInfo .photoBox .bg {
		opacity: 0.5;
	}
	#main .btmInfo .photoBox:last-child .bg {
		opacity: 0.7;
	}
	#main .btmInfo h2 {
		font-size: 2.6rem;
		font-weight: 400;
	}
	#main .btmInfo p,
	#main .btmInfo dl {
		font-size: 1.2rem;
	}
	#main .btmInfo dl dd {
		padding: 0 0 0 9.1em;
	}
	#main .btmInfo .link {
		font-size: 1.3rem;
		letter-spacing: 0.05em;
	}
	#main .btmInfo .link span {
		padding-right: 20px;
	}

}

@media all and (max-width: 340px) {
	.mainVisual .textBox .content {
		padding: 0 15px;
	}
}


@media all and (max-width: 374px){
    .mainVisual .textBox .name{
        font-size: 1.9rem;
        letter-spacing: 0.1em;
    }
}
    
/*------------------------------------------------------------
	index 英語版
------------------------------------------------------------*/
#english .topBox .content {
	width: 1070px;
}
#english .mainVisual .textBox p {
    letter-spacing: 0.06em;
    line-height: 1.8;
    margin: 0 0 22px;
    font-size: 1.8rem;
}
#english .mainVisual .textBox .name {
    font-size: 7.4rem;
    margin: 41px 0 -35px;
    letter-spacing: 0.08em;
}
#english #main .topBox .lBox {
    width: 622px;
}
#english #main .topBox .lBox .title {
	font-size: 2.3rem;
	margin-bottom: 53px;
	letter-spacing: 0.03em;
	line-height: 1.8;
}
#english #main .topBox .lBox p {
	line-height: 1.8;
    letter-spacing: 0.04em;
}
/* #english #main .topBox .rBox {
    width: 375px;
} */
#english #main .topBox .rBox p {
    letter-spacing: 0.04em;
    line-height: 1.4;
	width: 97%;
}
#english #main .topBox .chart_item > span {
	letter-spacing: .4px;
    width: 100%;
    text-align: center;
}
#english #main .topBox .chart_item.chart_03 span{
    left: 42.8%;
}
#english #main .topBox .chart_item > span{
    left: 49.5%;
}
#english #main .topBox .chart_per {
	left: 50%;
	right: auto;
    top: auto;
    bottom: -16px;
    transform: translateX(-50%);
}
#english .headLine01 {
    letter-spacing: 0.01em;
}
#english #main .product .borList li{
    letter-spacing: 0.05em;
}
#english #main .news .link a{
    letter-spacing: 0.05em;
}
#english #main .topBox .chart_01 > span {
	transform: translateX(-50%);
}
#main .topBox .chart_04 > span {
	transform: translateX(-47%);
}
#english #main .company dt {
    letter-spacing: 0.04em;
    font-weight: 500;
}
#english #main .company dd {
    padding: 12px 0 11px 15em;
	letter-spacing: 0.03em;
}
#english #main .company .btmLink .comLink {
    margin-top: 35px;
}
#english #main .company .btmLink .comLink:first-child,
#english #main .company .btmLink .comLink:nth-child(2){
	margin-top: 61px;
}
#english #main .company .btmLink .comLink:nth-child(3){
	width: 100%;
}
#english #main .company .comLink01 {
    margin-top: 70px;
}
#english #main .product .headLine01 {
    font-size: 4.6rem;
}
#english #main .product .whiteUl > li:last-child > ul > li:first-child {
    width: 100%;
	border: none;
}
#english #main .product .whiteUl > li:last-child > ul > li {
	padding: 35px 20px 35px 30px;
}
 #english #main .news .headLine01 {
    margin-bottom: 10px;
 }
#english #main .business .comLink a {
    letter-spacing: 0.02em;
}
#english #main .business .textUl li li a {
    letter-spacing: 0.03em;
}
#english #main .business .textUl {
    width: 540px;
}
#english #main .business .textUl > li {
    width: 245px;
}
#english #main .business .textUl > li:last-child {
    width: 100%;
}
#english #main .business .headLine01 {
    font-size: 3.6rem;
	line-height: 1.4;
}
#english #main .btmInfo dl {
    width: 280px;
	letter-spacing: 0.03em;
}
#english #main .btmInfo .photoBox {
    width: 100%;
}
#english #main .btmInfo h2 {
    letter-spacing: 0.01em;
    font-size: 3rem;
}
#english #main .btmInfo dl dd {
    padding: 0 0 0 11em;
}
@media all and (max-width: 767px) {
	#english .mainVisual .textBox p {
		font-size: 1.4rem;
		line-height: 1.6;
		letter-spacing: 0.04em;
	}
	#english .mainVisual .textBox .name {
		font-size: 3.2rem;
        letter-spacing: 0.03em;
        margin: 0;
        line-height: 1.3;
	}
	#english #main .topBox .news .newsDl > dd {
		padding: 0 0 0 4em;
	}
	#english #main .topBox .news .newsDl > dd dd {
		margin-left: -48px;
	}
	#english #main .topBox .lBox .title {
		line-height: 1.6;
		letter-spacing: 0.03em;
		font-size: 1.8rem;
	}
	#english #main .topBox .chart_01 > span {
		bottom: 20px;
	}
	#english #main .company dt {
		letter-spacing: 0.02em;
	}
	#english #main .company dd {
		padding: 12px 0 11px 13em;
	}
	#english #main .company .btmLink .comLink {
		width: 100%;
	}
	#english #main .company .btmLink .comLink {
		margin-top: 35px!important;
	}
	#english #main .product .headLine01 {
		font-size: 2.6rem;
	}
	#english #main .product .borList li {
		letter-spacing: 0.03em;
	}
	#english #main .product .whiteUl > li:last-child > ul > li {
		padding: 26px 20px 24px!important;
	}
	#english #main .business .headLine01 {
		font-size: 2.4rem;
		letter-spacing: 0.02em;
	}
	#english #main .btmInfo dl {
		width: auto;
	}
	#english #main .btmInfo dl dd {
		padding: 0px 0 0 11.1em;
	}
    #english #main .topBox .chart_item.chart_03 span{
        left: 35.5%;
    }
}

/*202411 追記*/
.topVideo{
    height: calc(100vh - 80px);
}
.topVideo video{
    object-fit: cover;
    width: 100%;
    height: 100%;
}   
#main .company .textUl li a:hover {
    opacity: 0.6;
}
#main .company .textUl li .blue{
    color: #2C70A9;
    border-bottom: 1px solid #2C70A9;
    display: inline-block;
    background: url(/img/common/icon02.png) no-repeat right center;
    background-size: 12px auto;
    padding: 0 15px 1px 0;
    margin: 0 4px;
}

@media all and (max-width: 767px) {
    .topVideo {
        width: 100%;
    }
    body {
        min-width: inherit;
    }
}
@media all and (min-width: 768px) and (max-width: 1024px){
    .topVideo .pc{
        display: none;
    }
    .topVideo .sp{
        display: block !important;
        width: 100%;
    }
}

#gHeader {
	position: fixed;
	background-color: #fff;
}
#container {
	padding-top: 80px;
}
.mainVisual::before {
	position: absolute;
	left: 0;
	top: 0;
	width: 10px;
	bottom: 0;
	background-color: #fff;
	content: "";
	z-index: 1;
}
.mainVisual::after {
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	background: url(/img/index/main_visual_bg.png) no-repeat;
	background-size: 100% 100%;
	content: "";
}
.mainVisual .textBox .content {
	padding: 0 0 40px;
}
@media all and (max-width: 767px) {
	#gHeader.sp {
		background-color: transparent;
	}
	#container {
		padding-top: 62px;
	}
	.topVideo{
		height: calc(100vh - 62px);
	}
	.mainVisual::before {
		width: 5px;
	}
	.mainVisual::after {
		left: 5px;
		background: url(/img/index/main_visual_bg_sp.png);
	}
	.mainVisual .banner {
		width: 67.5%;
	}
	.mainVisual .textBox .content {
		padding: 0 20px 50px;
	}
}