@charset "utf-8";
/*------------------------------------------------------------
	company
------------------------------------------------------------*/
#company .future {
	margin-bottom: 10rem;
}
#company .future .textBox {
	margin-bottom: 7.5rem;
}
#company .future .textBox p {
	margin-bottom: 4rem;
	font-size: 2rem;
	line-height: 2;
	letter-spacing: 0.05em;
}
#company .future .textBox p:last-child {
	margin-bottom: 0 !important;
}
#company .future .txtList {
	padding-top: 8rem;
	border-top: 1px solid #DDD;
}
#company .future .txtList li:first-child {
	border-right: 1px solid #DDD;
}
#company .future .txtList li {
	width: 50%;
	padding: 0 5rem;
}
#company .future .txtList .headLine02 .jp {
	margin-bottom: 1rem;
	font-size: 1.8rem;
}
#company .future .txtList .headLine02 .en {
	font-size: 1rem;
}
#company .future .txtList p {
	margin-top: 2rem;
	font-size: 3rem;
	font-weight: 700;
}
#company .message {
	margin-bottom: 14.5rem;
}
#company .message .pho {
	margin-bottom: 2.5rem;
}
#company .message .pho img {
	width: 100%;
	border-radius: 1rem;
}
#company .message p {
	margin-bottom: 2rem;
	line-height: 2;
	letter-spacing: 0.05em;
}
#company .message .name {
	margin: 3rem -0.1rem 0;
	text-align: right;
}
#company .message .name span {
	margin: -1.5rem 0 0 2rem;
	display: inline-block;
	vertical-align: middle;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
#company .outline {
	margin-bottom: 15rem;
}
#company .office {
	margin-bottom: 15rem;
}
#company .office .ttl {
	margin-bottom: 3rem;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
#company .office .comTab + .ttl {
	margin-top: 8rem;
}
@media all and (min-width: 897px) {
	#company .mainBox {
		padding-bottom: 15rem;
	}
}
@media all and (max-width: 896px) {
	#company .future {
		margin-bottom: 8rem;
	}
	#company .future .textBox {
		margin-bottom: 4rem;
	}
	#company .future .textBox p {
		margin-bottom: 1.5rem;
		font-size: 1.6rem;
		line-height: 2.5;
		letter-spacing: 0;
	}
	#company .future .txtList {
		padding-top: 0;
		display: block;
	}
	#company .future .txtList li:first-child {
		margin-bottom: 1rem;
		border-right: none;
	}
	#company .future .txtList li {
		width: auto;
		padding: 3rem;
		border-bottom: 1px solid #DDD;
	}
	#company .future .txtList .headLine02 {
		margin-bottom: 0;
	}
	#company .future .txtList p {
		font-size: 2.4rem;
	}
	#company .message {
		margin-bottom: 7.5rem;
	}
	#company .message p {
		letter-spacing: 0;
	}
	#company .message .name {
		letter-spacing: 0.05em;
	}
	#company .outline {
		margin-bottom: 8rem;
	}
	#company .office {
		margin-bottom: 8rem;
	}
	#company .office .ttl {
		margin-bottom: 3rem;
		font-size: 1.8rem;
		letter-spacing: 0;
	}
	#company .office .comTab + .ttl {
		margin-top: 5rem;
	}
}
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#index {
	overflow: hidden;
}
#index .mainVisual {
	position: relative;
	z-index: 1;
	height: 83.7rem;
}
#index .mainVisual .video {
	position: absolute;
	left: 2rem;
	top: 2rem;
	right: 2rem;
	bottom: 2rem;
	overflow: hidden;
	border-radius: 1rem;
}
#index .mainVisual .video::before {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	height: 20rem;
	background: linear-gradient(rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0) 100%);
	content: "";
}
#index .mainVisual video {
	position: absolute;
	left: 50%;
	top: 50%;
	width: 130%;
	height: 130%;
	transform: translate(-50%,-50%);
}
#index .about {
	margin: -9rem 0 10rem;
	position: relative;
	z-index: 2;
}
#index .about .imgBox {
	margin: 9.5rem 0 0 5rem;
}
#index .about .ttl {
	width: 37rem;
	color: #005DAC;
}
#index .about .ttl .jp {
	margin-bottom: 1.5rem;
	display: block;
	font-size: 8rem;
	font-weight: 500;
	letter-spacing: 0.1em;
}
#index .about .ttl .en {
	margin-bottom: 5rem;
	display: block;
	font-size: 1.8rem;
	font-weight: 700;
}
#index .about .ttl .ico {
	display: block;
	width: 10rem;
}
#index .about .textBox {
	width: calc(100% - 50rem);
	margin: 4rem -2rem 0 0;
}
#index .about .textBox p {
	margin-bottom: 3rem;
	line-height: 2.5;
	font-size: 2rem;
	font-weight: 500;
}
#index .domain {
	margin-bottom: 15rem;
}
#index .domain .imgBox {
	width: 65rem;
	margin: -1.5rem auto 0;
	position: relative;
}
#index .domain .line {
	position: absolute;
	width: 25.2rem;
}
#index .domain .line01 {
	top: 30.9rem;
	right: -17.1rem;
}
#index .domain .line02 {
	top: 2.9rem;
	right: -2.1rem;
}
#index .domain .line03 {
	top: 30.9rem;
	left: -17.1rem;
}
#index .domain .textList {
	width: 20rem;
	position: absolute;
	font-size: 1.4rem;
	font-weight: 500;
}
#index .domain .textList li {
	position: relative;
	padding: 0 0 0.4rem 1.6rem;
}
#index .domain .textList li::before {
	position: absolute;
	left: 0;
	top: 0.7rem;
	width: 0.8rem;
	height: 0.8rem;
	background-color: #EE243A;
	border-radius: 100%;
	content: "";
}
#index .domain .textList01 {
	top: -5.1rem;
	right: -3rem;
}
#index .domain .textList02 {
	top: 25.4rem;
	right: -18rem;
}
#index .domain .textList03 {
	top: 22.9rem;
	left: -16rem;
}
#index .business {
	padding: 9rem 0 14.5rem;
	background-color: #005DAC;
	border-radius: 5rem;
}
#index .business .headLine04 {
	margin-bottom: 5rem;
}
#index .business .headLine04 .en {
	color: #FEFEFE;
}
#index .business .headLine04 .jp {
	color: #FEFEFE;
}
#index .business .listUl a {
	display: block;
	position: relative;
}
#index .business .listUl .pho {
	overflow: hidden;
	border-radius: 1rem;
}
#index .business .listUl img {
	width: 100%;
}
#index .business .listUl p {
	position: absolute;
	left: 0;
	right: 8rem;
	top: calc(100% - 3rem);
	padding: 1.4rem 1rem 0;
	color: #FEFEFE;
	font-size: 2.4rem;
	font-weight: 700;
	background-color: #005DAC;
	border-top-right-radius: 1rem;
}
#index .business .listUl p::before {
	position: absolute;
	right: -0.9rem;
	top: 2.1rem;
	background: url(../img/index/business_icon01.png) no-repeat;
	background-size: 100% 100%;
	width: 0.9rem;
	height: 0.9rem;
	content: "";
}
#index .business .listUl p::after {
	position: absolute;
	left: 0;
	top: -0.9rem;
	background: url(../img/index/business_icon01.png) no-repeat;
	background-size: 100% 100%;
	width: 0.9rem;
	height: 0.9rem;
	content: "";
}
#index .business .listUl p span {
	margin-top: 0.8rem;
	display: block;
	font-size: 1.2rem;
}
#index .case {
	padding: 14rem 0;
	position: relative;
}
#index .case::before {
	position: absolute;
	right: 0;
	top: 15rem;
	bottom: -10rem;
	width: calc(50% + 18rem);
	background-color: #005DAC;
	border-radius: 50rem 0 0 50rem;
	content: "";
	z-index: 1;
}
#index .case .textInfo {
	width: 31rem;
}
#index .case .textInfo p {
	margin-top: 4.5rem;
	line-height: 2;
	letter-spacing: 0.05em;
}
#index .case .prev,
#index .case .next {
	margin-top: -3.5rem;
	position: absolute;
	top: 50%;
	cursor: pointer;
	width: 6rem;
	height: 3rem;
}
#index .case .comArrowBg {
	right: 0;
	bottom: 0;
	border: 1px solid #fff;
}
#index .case .prev {
	left: -8rem;
}
#index .case .next {
	right: -8rem;
}
#index .news {
	padding: 9rem 0 10rem;
	background-color: #F5F5F5;
	border-radius: 5rem;
}
#index .news .headLine04 {
	margin-bottom: 5rem;
}
#index .products {
	padding: 9rem 0 10rem;
	position: relative;
}
#index .products .comEnText {
	position: absolute;
	left: 0;
	top: 50%;
	width: 100%;
	margin-top: 1rem;
}
#index .products .headLine04 {
	margin-bottom: 5rem;
}
#index .products .comProductsList {
	position: relative;
	z-index: 2;
}
@media all and (min-width: 897px) {
	#index .mainBox {
		padding: 0;
		width: auto;
	}
	#index .content {
		width: 114rem;
		margin-right: auto;
	}
	#index .business .listUl {
		margin-top: -9.5rem;
		position: relative;
	}
	#index .business .listUl::after {
		content: "";
		width: 36rem;
	}
	#index .business .listUl li {
		margin-top: 9.5rem;
		width: 36rem;
	}
	#index .case .content {
		position: relative;
	}
	#index .case .slideBox {
		width: 40rem;
		position: absolute;
		right: 9rem;
		top: 6rem;
		z-index: 2;
	}
	#index .products .content {
		position: relative;
	}
	#index .products .comLink {
		position: absolute;
		right: 0;
		top: 9.6rem;
	}
}
@media all and (max-width: 896px) {
	#index .mainVisual {
		height: 84.4rem;
	}
	#index .mainVisual .video {
		left: 1rem;
		top: 1rem;
		right: 1rem;
		bottom: 1rem;
	}
	#index .about {
		margin: -13rem -3rem 7rem;
	}
	#index .about .imgBox {
		margin: -1rem 3rem 0;
		display: block;
	}
	#index .about .ttl {
		width: auto;
		position: relative;
	}
	#index .about .ttl .jp {
		margin-bottom: 2.5rem;
		font-size: 5rem;
		letter-spacing: 0.05em;
	}
	#index .about .ttl .en {
		margin-bottom: 0;
		font-size: 1.4rem;
	}
	#index .about .ttl .ico {
		position: absolute;
		right: 0;
		top: 2.2rem;
	}
	#index .about .textBox {
		width: auto;
		margin: 4.5rem 0 0;
	}
	#index .about .textBox p {
		margin-bottom:3.5rem;
		font-size: 1.6rem;
	}
	#index .domain {
		margin-bottom: 19rem;
	}
	#index .domain .imgBox {
		width: 33rem;
		margin: -1.5rem auto 0;
	}
	#index .domain .imgBox .img {
		margin: 0 -7.5rem;
	}
	#index .domain .line {
		width: 20.2rem;
	}
	#index .domain .line01 {
		top: 42.9rem;
		right: -1.2rem;
		width: 14rem;
	}
	#index .domain .line02 {
		top: -2.1rem;
		right: -1.1rem;
	}
	#index .domain .line03 {
		top: 42.9rem;
		left: -1.5rem;
	}
	#index .domain .textList li {
		padding-bottom: 0.7rem;
		line-height: 1.28;
	}
	#index .domain .textList li::before {
		top: 0.6rem;
	}
	#index .domain .textList01 {
		top: -9.9rem;
		right: -2rem;
	}
	#index .domain .textList02 {
		top: 47.1rem;
		right: -8.2rem;
	}
	#index .domain .textList03 {
		top: 47.1rem;
		left: -0.4rem;
	}
	#index .business {
		margin: 0 -3rem;
		padding: 7.5rem 2rem 11rem;
		border-radius: 3rem;
	}
	#index .business .headLine04 {
		margin: 0 1rem 5rem;
	}
	#index .business .listUl {
		display: block;
	}
	#index .business .listUl li:not(:last-child) {
		margin-bottom: 6rem;
	}
	#index .business .listUl p {
		padding-top: 1rem;
		font-size: 1.8rem;
	}
	#index .case {
		padding: 7.5rem 0 0;
	}
	#index .case::before {
		display: none;
	}
	#index .case .textInfo {
		margin-bottom: 4.5rem;
		width: auto;
	}
	#index .case .headLine04 {
		margin-bottom: 0;
	}
	#index .case .slideBox {
		position: relative;
		z-index: 2;
		padding: 7.5rem 0 4rem;
	}
	#index .case .slideBox::before {
		position: absolute;
		right: -3rem;
		top: 0;
		bottom: -9rem;
		left: -12rem;
		content: "";
		background-color: #005DAC;
		border-radius: 25rem 0 0 25rem;
	}
	#index .case .comCaseList {
		margin: 0 -1rem;
		position: relative;
		z-index: 2;
	}
	#index .case .prev,
	#index .case .next {
		margin-top: 0;
		position: absolute;
		top: auto;
		bottom: -1.6rem;
		z-index: 3;
	}
	#index .case .prev {
		left: auto;
		right: 6rem;
	}
	#index .case .next {
		right: -1rem;
	}
	#index .news {
		margin: 0 -3rem;
		padding: 13.5rem 3rem 8rem;
		border-radius: 3rem;
	}
	#index .products {
		padding: 7.5rem 0 1.5rem;
	}
	#index .products .comEnText {
		display: none !important;
	}
	#index .products .headLine04 {
		margin-bottom: 5rem;
	}
	#index .products .comProductsList {
		margin: 0 -3rem 2.5rem;
		display: block;
	}
}
/*------------------------------------------------------------
	case
------------------------------------------------------------*/
#case .topText {
	margin-bottom: 4.5rem;
	line-height: 2;
	letter-spacing: 0.05em;
	font-size: 2rem;
}
#case .comCaseList {
	margin-bottom: 8rem;
}
#case .detail .txt {
	margin-bottom: 4.5rem;
	text-align: right;
	font-size: 1.2rem;
}
#case .detail .txt .sort {
	padding-left: 2.8rem;
	font-weight: 500;
	background: url(../img/common/icon20.png) no-repeat left 1rem top 0.6rem;
	background-size: 0.8rem auto;
}
#case .detailBox {
	margin-bottom: 4.5rem;
}
#case .detailBox p {
	margin-bottom: 3rem;
	line-height: 1.875;
	word-break: break-all;
}
#case .detailBox p a {
	color: #005DAC;
	text-decoration: underline;
}
#case #conts .images {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
	margin: 50px 0;
}
#case #conts .images li {
	border-radius: 1rem;
	overflow: hidden;
}
@media all and (max-width: 896px) {
	#case .topText {
		margin-bottom: 2rem;
		font-size: 1.6rem;
	}
	#case .comCaseList {
		margin-bottom: 4rem;
	}
}
/*------------------------------------------------------------
	products
------------------------------------------------------------*/
#products .topText {
	margin-bottom: 4.5rem;
	line-height: 2;
	letter-spacing: 0.05em;
	font-size: 2rem;
}
@media all and (min-width: 897px) {
	#products .comProductsList {
		width: auto;
	}
	#products .comProductsList::after {
		width: 26rem;
	}
	#products .comProductsList li {
		margin-top: 3rem;
		width: 26rem;
	}
}
@media all and (max-width: 896px) {
	#products .topText {
		margin-bottom: 2rem;
		font-size: 1.6rem;
	}
	#products .comProductsList {
		margin: 0 -3rem;
		display: block;
	}
}
/*------------------------------------------------------------
	products-info
------------------------------------------------------------*/
#products .detail .ttl {
	margin-bottom: 3rem;
	color: #005DAC;
	font-size: 4rem;
}
#products .detail figure {
	margin: 0 0 2.5rem;
}
#products .detail figure img {
	width: 100%;
	border-radius: 1rem;
}
#products .detail p {
	margin-bottom: 2.5rem;
	font-size: 2rem;
	line-height: 2;
	letter-spacing: 0.05em;
	word-break: break-all;
}
#products .detail p a {
	color: #005DAC;
	text-decoration: underline;
}
#products .detail .movie {
	margin-bottom: 3rem;
}
#products .detail .movie img {
	width: 100%;
}
@media all and (min-width: 897px) {
	#products .detail {
		margin: 0.5rem 0 -3rem;
	}
	#products .detail p a:hover {
		text-decoration: none;
	}
}
@media all and (max-width: 896px) {
	#products .detail .ttl {
		margin-bottom: 1.5rem;
		font-size: 2.6rem;
	}
	#products .detail figure {
		margin: 0 0 1.5rem;
	}
	#products .detail p {
		margin-bottom: 2rem;
		font-size: 1.6rem;
	}
	#products .detail .movie {
		margin-bottom: 2rem;
	}
}
/*------------------------------------------------------------
	news
------------------------------------------------------------*/
#news .comNewsList .txt {
	color: #221E1F;
	text-decoration: none;
}
@media all and (min-width: 897px) {
	#news #conts {
		margin-top: 0;
	}
}
/*------------------------------------------------------------
	news-info
------------------------------------------------------------*/
#news .detail .txt {
	margin-bottom: 4.5rem;
	text-align: right;
	font-size: 1.2rem;
}
#news .detail .txt .sort {
	padding-left: 2.8rem;
	font-weight: 500;
	background: url(../img/common/icon20.png) no-repeat left 1rem top 0.6rem;
	background-size: 0.8rem auto;
}
#news .detailBox {
	margin-bottom: 4.5rem;
}
#news .detailBox p {
	margin-bottom: 3rem;
	line-height: 1.875;
	word-break: break-all;
}
#news .detailBox p a {
	color: #005DAC;
	text-decoration: underline;
}
@media all and (min-width: 897px) {
	#news .detailBox p a:hover {
		text-decoration: none;
	}
}
@media all and (max-width: 896px) {
	#news .detail .txt {
		margin-bottom: 3rem;
	}
	#news .detailBox {
		margin-bottom: 4rem;
	}
	#news .detailBox p {
		margin-bottom: 2rem;
	}
}
/*------------------------------------------------------------
	business
------------------------------------------------------------*/
#business .connecting {
	margin-bottom: 8rem;
}
#business .connecting .content {
	padding-bottom: 7.5rem;
	border-bottom: 1px solid #DDD;
}
#business .connecting .textBox p {
	margin-bottom: 4rem;
	font-size: 2rem;
	line-height: 2;
	letter-spacing: 0.05em;
}
#business .connecting .textBox p:last-child {
	margin-bottom: 0 !important;
}
#business .trading {
	margin-bottom: 8rem;
}
#business .trading .content {
	padding-bottom: 8rem;
	border-bottom: 1px solid #DDD;
}
#business .trading .imgInfo {
	margin: 5rem 0 3rem;
}
#business .trading .textList {
	margin: 0 3rem 8rem;
}
#business .trading .textList li {
	width: 38rem;
	text-align: center;
}
#business .trading .textList .ttl {
	padding: 1.6rem 0 1.7rem;
	margin-bottom: 1rem;
	color: #FEFEFE;
	font-size: 1.8rem;
	font-weight: 500;
	background-color: #005DAC;
	border-radius: 3rem;
}
#business .trading .textList p {
	letter-spacing: -0.05em;
}
#business .trading .listUl {
	margin-top: -2rem;
}
#business .trading .listUl li {
	width: 41rem;
	margin-top: 2rem;
	padding: 2.5rem 3rem;
	position: relative;
	background-color: #F5F5F5;
	border-radius: 1rem;
}
#business .trading .listUl .img {
	position: absolute;
	right: 3rem;
	top: 3rem;
	width: 27rem;
}
#business .trading .listUl .title {
	margin-bottom: 10rem;
	font-size: 2.4rem;
	color: #EE243A;
}
#business .trading .listUl .num {
	display: block;
}
#business .trading .listUl .jp {
	margin: 0.6rem 0 0.3rem;
	display: block;
	color: #005DAC;
}
#business .trading .listUl li:not(:first-child) .jp {
	letter-spacing: -0.1em;
}
#business .trading .listUl .en {
	display: block;
	font-size: 1.2rem;
}
#business .trading .listUl p {
	line-height: 1.8;
	letter-spacing: 0.05em;
}
#business .promotion {
	margin-bottom: 7.5rem;
}
#business .promotion .content {
	padding-bottom: 8rem;
	border-bottom: 1px solid #DDD;
}
#business .promotion .comImgBox {
	margin-bottom: 5rem;
}
#business .promotion .listUl li {
	padding: 2.5rem 1rem 2.5rem 8rem;
	margin-top: 2rem;
	position: relative;
	background-color: #F5F5F5;
	border-radius: 5rem;
}
#business .promotion .listUl .ico {
	width: 4.2rem;
	position: absolute;
	left: 2.4rem;
	top: 50%;
	transform: translateY(-50%);
}
#business .promotion .listUl p {
	color: #005DAC;
	font-size: 1.8rem;
}
#business .promotion .listUl .sml01 {
	letter-spacing: -0.1em;
}
#business .promotion .listUl .sml02 {
	letter-spacing: -0.05em;
}
#business .promotion .listUl .en {
	margin-top: 0.3rem;
	display: block;
	color: #EE243A;
	font-size: 1.2rem;
	letter-spacing: 0;
}
#business .management {
	margin-bottom: 7.5rem;
}
#business .management .content {
	padding-bottom: 8rem;
	border-bottom: 1px solid #DDD;
}
#business .management .comLink {
	margin: 4.5rem 0 0;
}
#business .management .comLink a {
	font-family: "Zen Kaku Gothic New", sans-serif;
}
#business .store {
	margin-bottom: 7.5rem;
}
#business .store .content {
	padding-bottom: 8rem;
	border-bottom: 1px solid #DDD;
}
#business .store .comImgBox {
	margin-bottom: 5rem;
}
@media all and (min-width: 897px) {
	#business .trading .comSticky {
		top: 1.8rem;
	}
	#business .headLine03 + .comImgBox .pho {
		margin-top: -2.5rem;
	}
	#business .promotion .listUl {
		margin-top: -2rem;
		position: relative;
	}
	#business .promotion .listUl::after {
		content: "";
		width: 27rem;
	}
	#business .promotion .listUl li {
		width: 27rem;
	}
	#business .management .comSticky {
		top: 0.4rem;
	}
	#business .store .comSticky {
		top: 0.4rem;
	}
	#business .parking .comSticky {
		top: 0.4rem;
	}
}
@media all and (max-width: 896px) {
	#business .connecting {
		margin-bottom: 4rem;
	}
	#business .connecting .content {
		padding-bottom: 4rem;
	}
	#business .connecting .textBox p {
		margin-bottom: 2rem;
		font-size: 1.6rem;
	}
	#business .trading {
		margin-bottom: 4rem;
	}
	#business .trading .content {
		padding-bottom: 4rem;
	}
	#business .trading .imgInfo {
		margin: 3rem 0;
	}
	#business .trading .textList {
		margin: 0 0 4rem;
		display: block;
	}
	#business .trading .textList li {
		padding-bottom: 2rem;
		width: auto;
	}
	#business .trading .textList .ttl {
		margin-bottom: 0.5rem;
		padding: 1rem 0;
		font-size: 1.6rem;
	}
	#business .trading .textList p {
		font-size: 1.5rem;
	}
	#business .trading .listUl {
		margin-top: 0;
		display: block;
	}
	#business .trading .listUl li {
		width: auto;
		margin: 0 0 2rem;
		padding: 2rem;
	}
	#business .trading .listUl li:last-child {
		margin-bottom: 0;
	}
	#business .trading .listUl .img {
		right: 1rem;
		top: 1rem;
		width: 20rem;
	}
	#business .trading .listUl .title {
		margin-bottom: 4rem;
	}
	#business .promotion {
		margin-bottom: 4rem;
	}
	#business .promotion .content {
		padding-bottom: 4rem;
	}
	#business .promotion .comImgBox {
		margin-bottom: 3rem;
	}
	#business .promotion .listUl {
		display: block;
		width: 27rem;
		margin: 0 auto;
	}
	#business .promotion .listUl li {
		margin: 0 0 1rem;
	}
	#business .promotion .listUl li:last-child {
		margin-bottom: 0;
	}
	#business .management {
		margin-bottom: 4rem;
	}
	#business .management .content {
		padding-bottom: 4rem;
	}
	#business .management .comLink {
		margin: 2rem 0 0;
	}
	#business .store {
		margin-bottom: 4rem;
	}
	#business .store .content {
		padding-bottom: 4rem;
	}
	#business .store .comImgBox {
		margin-bottom: 3rem;
	}
}
/*------------------------------------------------------------
	mrtmicc
------------------------------------------------------------*/
#mrtmicc .about {
	margin: -0.5rem 0 7.5rem;
}
#mrtmicc .about .content {
	padding-bottom: 8rem;
	border-bottom: 1px solid #DDD;
}
#mrtmicc .topText {
	margin-bottom: 2.5rem;
	line-height: 2;
	font-size: 2rem;
	letter-spacing: 0.05em;
}
#mrtmicc .about .comLinkList.flexC {
	margin-bottom: 8rem;
}
#mrtmicc .about .comListUl {
	margin-bottom: 5rem;
}
#mrtmicc .party .topPho {
	margin: 0 0 5rem;
	overflow: hidden;
	border-radius: 1rem;
}
#mrtmicc .party .topPho img {
	width: 100%;
}
#mrtmicc .party .comTable th,
#mrtmicc .party .comTable td {
	width: auto;
}
#mrtmicc .party .comTable td {
	width: 37.5%;
}
#mrtmicc .party .noteList {
	margin: -1.5rem 0 4.5rem;
	font-size: 1.4rem;
}
#mrtmicc .party .noteList li {
	text-indent: -1em;
	padding: 0 0 0.4rem 1em;
}
#mrtmicc .party .comCaseList {
	margin-bottom: 5rem;
}
#mrtmicc .party .comLinkList {
	gap: 20px;
	margin-bottom: 0 !important;
}
@media all and (min-width: 897px) {
	#mrtmicc .comSticky {
		top: 0.5rem;
	}
}
@media all and (max-width: 896px) {
	#mrtmicc .about {
		margin: 0 0 4rem;
	}
	#mrtmicc .about .content {
		padding-bottom: 4rem;
	}
	#mrtmicc .topText {
		margin-bottom: 2rem;
		font-size: 1.6rem;
	}
	#mrtmicc .about .comLinkList.flexC {
		margin-bottom: 4rem;
	}
	#mrtmicc .about .comListUl {
		margin-bottom: 3rem;
	}
	#mrtmicc .party .topPho {
		margin: 0 0 2.5rem;
	}
	#mrtmicc .party .noteList {
		margin: -1rem 0 2rem;
	}
	#mrtmicc .party .comCaseList {
		margin-bottom: 3rem;
	}
}
/*------------------------------------------------------------
	hall
------------------------------------------------------------*/
#hall {
	overflow: hidden;
}
#hall .topText {
	margin: 0 0 2.5rem;
	line-height: 2;
	font-size: 2rem;
	letter-spacing: 0.05em;
}
#hall .infiniteslide_wrap {
	margin: 0 calc(-50vw + 62rem) 3rem 0;
}
#hall .phoList {
	display: flex;
}
#hall .phoList li {
	margin: 0 1rem;
	width: 41rem;
	flex-shrink: 0;
	overflow: hidden;
	border-radius: 1rem;
}
#hall .comTab {
	margin-bottom: 5rem;
}
#hall .comTab th, 
#hall .comTab td {
	letter-spacing: 0;
	font-family: "Zen Kaku Gothic Antique", sans-serif;
}
#hall .comTab td .sml {
	margin-top: 1.5rem;
	display: block;
	font-size: 1.4rem;
}
#hall .comDotBox {
	margin-bottom: 8rem;
}
#hall .faqList {
	margin-top: 5rem;
	border-bottom: 1px solid #DDD;
}
#hall .faqList li {
	padding: 2rem 0;
	border-top: 1px solid #DDD;
}
#hall .faqList .ttl,
#hall .faqList .aBox {
	padding: 0 5.6rem 1rem;
	position: relative;
	font-weight: 500;
}
#hall .faqList .ttl {
	padding-top: 1rem;
	background: url(../img/common/icon23.png) no-repeat right 3rem center;
	background-size: 2.4rem auto;
	cursor: pointer;
}
#hall .faqList .ttl.on {
	background-image: url(../img/common/icon23_on.png);
}
#hall .faqList .aBox {
	display: none;
}
#hall .faqList .aBox p {
	word-break: break-all;
}
#hall .faqList .aBox a {
	color: #005DAC;
}
#hall .faqList .ttl::before,
#hall .faqList .aBox::before {
	position: absolute;
	left: 3rem;
	top: 1rem;
	color: #EE243A;
	font-weight: 700;
	content: "Q.";
}
#hall .faqList .aBox::before {
	top: 0;
	color: #005DAC;
	content: "A.";
}
@media all and (min-width: 897px) {
	#hall #conts {
		margin-top: 0;
	}
	#hall .comLinkList {
		margin-top: -2rem;
	}
	#hall .comLinkList li {
		margin: 2rem 0.5rem 0;
	}
	#hall .comTab th {
		width: 16.6%;
	}
	#hall .faqList .ttl:hover {
		opacity: 0.7;
	}
	#hall .faqList .aBox a:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#hall .topText {
		margin: 0 0 2.5rem;
		font-size: 1.6rem;
	}
	#hall .infiniteslide_wrap {
		margin: 0 -3rem 3rem;
	}
	#hall .phoList li {
		width: 30rem;
	}
	#hall .comTab {
		margin-bottom: 4rem;
	}
	#hall .comTab td .sml {
		margin-top: 1rem;
	}
	#hall .comDotBox {
		margin-bottom: 5rem;
	}
	#hall .faqList {
		margin-top: -2rem;
	}
	#hall .faqList li {
		padding: 1rem 0;
	}
	#hall .faqList .ttl,
	#hall .faqList .aBox {
		padding-left: 3.5rem;
		padding-right: 3.5rem;
	}
	#hall .faqList .ttl {
		background-position: right 1rem center;
	}
	#hall .faqList .ttl::before,
	#hall .faqList .aBox::before {
		left: 1rem;
	}
}
/*------------------------------------------------------------
	access
------------------------------------------------------------*/
#access .imgBox .pho {
	width: 30rem;
}
#access .imgBox .pho img {
	width: 100%;
	border-radius: 1rem;
}
#access .imgBox .textBox {
	width: 49rem;
}
#access .headLine07 {
	margin-bottom: 2rem;
	font-size: 2.4rem;
}
#access .imgBox .text {
	line-height: 1.8;
}
#access .access {
	margin-bottom: 8rem;
}
#access .access .content {
	padding-bottom: 8rem;
	border-bottom: 1px solid #DDD;
}
#access .access .comDotList {
	margin-top: 2rem;
	padding: 1.8rem 0 0 1rem;
	border-top: 1px solid #CCC;
}
#access .access .comDotList li {
	padding-bottom: 0.6rem;
	font-size: 1.4rem;
	line-height: 1.71;
}
#access .floor {
	margin-bottom: 8rem;
}
#access .floor .content {
	padding-bottom: 8rem;
	border-bottom: 1px solid #DDD;
}
#access .floor .tabUl {
	margin-bottom: 5rem;
}
#access .floor .tabUl li {
	width: 12rem;
}
#access .floor .tabUl a {
	height: 5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-color: #F5F5F5;
	border-radius: 1rem 1rem 0 0;
}
#access .floor .tabUl .on a {
	color: #FEFEFE;
	background-color: #005DAC;
}
#access .parking {
	margin-bottom: 8rem;
}
#access .parking .content {
	padding-bottom: 8rem;
	border-bottom: 1px solid #DDD;
}
#access .parking .imgBox {
	margin-bottom: 5rem;
}
#access .parking .comTab {
	margin-top: 1.5rem;
}
#access .parking .comTab th,
#access .parking .comTab td {
	letter-spacing: 0;
}
#access .parking .ttl {
	margin-bottom: 1rem;
	font-weight: 700;
}
#access .parking .comTab .comDotList {
	margin: 0 0 1.7rem 0.9rem;
}
#access .parking .comTab .comDotList:last-child {
	margin-bottom: 0 !important;
}
#access .parking .comTab .comDotList li {
	padding-bottom: 0 !important;
	line-height: 1.5;
}
#access .service .pho {
	text-align: center;
}
#access .service p {
	line-height: 1.8;
	font-family: "Zen Kaku Gothic New", sans-serif;
}
#access .service .topText {
	margin-bottom: 2.5rem;
}
#access .service .topText span {
	margin-top: 1.5rem;
	display: block;
}
#access .service .textList > li {
	padding: 3rem 0;
	border-top: 1px solid #CCC;
}
#access .service .sml {
	margin-top: 1.5rem;
	display: block;
	font-size: 1.4rem;
}
#access .service .comLink {
	margin: 2rem 0 2.5rem;
}
#access .service .comLink a {
	font-family: "Zen Kaku Gothic New", sans-serif;
}
#access .service .text01 {
	margin-bottom: 3rem;
}
#access .service .text02 {
	margin-bottom: 2.5rem;
}
#access .service .comDotList {
	margin: 1.5rem 0 0 1rem;
}
#access .service .pho img {
	width: 22.2rem !important;
}
@media all and (min-width: 897px) {
	#access .mainBox {
		padding-bottom: 14rem;
	}
	#access .floor .tabUl a:hover {
		color: #FEFEFE;
		background-color: #005DAC;
	}
	#access .parking .comTab th,
	#access .parking .comTab td {
		padding: 1.8rem 1rem;
	}
	#access .parking .comTab th {
		padding-left: 2rem;
	}
	#access .service .headLine07 {
		margin-bottom: 1.5rem;
	}
}
@media all and (max-width: 896px) {
	#access .imgBox {
		display: block;
	}
	#access .imgBox .pho {
		width: auto;
	}
	#access .imgBox .textBox {
		width: auto;
		margin-top: 2rem;
	}
	#access .headLine07 {
		margin-bottom: 1rem;
	}
	#access .access {
		margin-bottom: 4rem;
	}
	#access .access .content {
		padding-bottom: 4rem;
	}
	#access .access .comDotList {
		margin-top: 1rem;
		padding: 1rem 0 0;
	}
	#access .floor {
		margin-bottom: 4rem;
	}
	#access .floor .content {
		padding-bottom: 4rem;
	}
	#access .floor .tabUl {
		margin-bottom: 2rem;
	}
	#access .floor .tabUl li {
		width: 8rem;
	}
	#access .floor .tabUl a {
		height: 4rem;
	}
	#access .floor .tabBox img {
		width: 100%;
	}
	#access .parking {
		margin-bottom: 4rem;
	}
	#access .parking .content {
		padding-bottom: 4rem;
	}
	#access .parking .imgBox {
		margin-bottom: 3rem;
	}
	#access .parking .ttl {
		margin-bottom: 0;
	}
	#access .parking .comTab .comDotList {
		margin: 0 0 1rem 0.5rem;
	}
	#access .service p {
		font-size: 1.5rem;
	}
	#access .service .headLine07 {
		font-size: 2rem;
	}
	#access .service .topText {
		margin-bottom: 2rem;
	}
	#access .service .topText span {
		margin-top: 1.5rem;
	}
	#access .service .textList > li {
		padding: 2rem 0;
	}
	#access .service .sml {
		margin-top: 1rem;
		font-size: 1.3rem;
	}
	#access .service .comLink {
		margin: 1.5rem 0;
	}
	#access .service .text01 {
		margin-bottom: 1.5rem;
	}
	#access .service .text02 {
		margin-bottom: 1.5rem;
	}
	#access .service .comDotList {
		margin-top: 1.5rem;
	}
}
/*------------------------------------------------------------
	contact
------------------------------------------------------------*/
#contact .comContactList{
 display: grid;
 gap: 8.5rem;
}
#contact .comContactList li .title{
 font-size: 1.6rem;
 font-weight: bold;
 line-height: 1.8;
 margin-bottom: 1.5rem;
 padding-bottom: 0.5rem;
 border-bottom: solid 1px #ccc;
}
#contact .comContactList li .tel{
 position: relative;
 padding: 0 0 0 4rem;
 margin: 0 0 1.5rem;
}
#contact .comContactList li .tel:before{
 position: absolute;
 content: "";
 width: 17px;
 height: 17px;
 background: url("../img/common/icon24.png") no-repeat center center;
 background-size: cover;
 top: 0;
 bottom: 0;
 left: 0;
 margin: auto;
}
#contact .comContactList li .tel a{
 font-size: 27px;
 font-weight: 600;
 line-height: 1.2;
}
#contact .comContactList li .text{
 font-size: 1.6rem;
 font-weight: 500;
 line-height: 1.8;
}
@media all and (max-width: 896px) {
 #contact .comContactList{
  gap: 4rem;
 }
 #contact .comContactList li .tel{
  padding: 0 0 0 3rem;
  margin: 0 0 0.5rem;
 }
}