nav.navbar {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	left: 0;
	padding: 0;
	width: 100%;
	border-bottom: 1px solid #ddd;
	background-color: #fff;
	-webkit-transition: opacity 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: opacity 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
	z-index: 3;
}
nav.navbar ul.list-inline {
	display: inline-block;
	margin-bottom: 0;
}
nav.navbar ul.list-inline li a,
nav.navbar .menuFooter a {
	font-weight: bold;
	color: #21303d;
	text-decoration: none;
}
nav.navbar.hide {
	opacity: 0;
	pointer-events: none;
}
nav.navbar .navbar-toggler {
	padding-top: 0;
	padding-bottom: 0;
	height: 46px;
	border: none;
}
.navbar-toggler:focus {
	box-shadow: none;
}
nav.navbar .offcanvas-body .mobile {
	position: relative;
	margin: 0 auto 20px auto;
	color: #999;
	border-bottom: 1px solid #4b4b4b;
}
nav.navbar .offcanvas-body .header-lang {
	display: flex;
	padding: 0;
	list-style: none;
	justify-content: center;
}
nav.navbar .offcanvas-body .header-lang a {
	margin-right: 40px;
	font-size: 14px;
	color: #c5cedb;
	font-weight: bold;
	text-decoration: none;
}
nav.navbar .offcanvas-body .header-lang li:last-child a {
	margin-right: 0;
}
nav.navbar .offcanvas-body .header-lang a:hover {
	color: #2b73ba;
}
nav.navbar .offcanvas-body .header-lang a.active {
	color: #232933;
}
nav.navbar .navbar-nav {
	margin: 0 auto 40px auto;
}
nav.navbar .navbar-nav .nav-item {
	padding: 10px 14px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
nav.navbar .navbar-nav .nav-item .sp-btn {
	position: relative;
	width: 54px;
	height: 27px;
	border-left: solid 1px rgba(33, 48, 61, 0.2);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-transition: opacity 1s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: opacity 1s cubic-bezier(0.165, 0.84, 0.44, 1);
	-webkit-transition-delay: 0.2s;
	transition-delay: 0.2s;
	cursor: pointer;
}
nav.navbar .navbar-nav .nav-item .sp-btn:before,
nav.navbar .navbar-nav .nav-item .sp-btn:after {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	background-color: #3b1e87;
	border-radius: 0.5px;
	-webkit-transition: opacity 0.3s;
	transition: opacity 0.3s;
	content: '';
}
nav.navbar .navbar-nav .nav-item .sp-btn:before {
	width: 15px;
	height: 1px
}
nav.navbar .navbar-nav .nav-item .sp-btn:after {
	width: 1px;
	height: 15px;
}
nav.navbar .navbar-nav .nav-item.open > .sp-btn:after,
nav.navbar .header-mega-body ul li.open .sp-btn:after {
	opacity: 0;
}
nav.navbar .navbar-nav .nav-item > a,
nav.navbar .header-mega-body ul li p {
	position: relative;
	display: block;
	margin-left: 22px;
	padding: 0;
	width: calc(100% - 77px);
	color: #21303d;
	font-weight: bold;
	text-decoration: none;
}
nav.navbar .header-mega li a:hover {
	color: #00a0e9;
}
nav.navbar .offcanvas-header .bi-x-lg {
	font-size: 25px;
	border: 0;
	background: transparent var(--bs-btn-close-bg) center/1em auto no-repeat;
}
nav.navbar .menuFooter img {
	margin-bottom: 10px;
	height: 30px;
}
nav.navbar .menuFooterCopy {
	font-size: 14px;
	color: #868b8f;
	text-align: center;
}
nav .navbar-brand:focus {
	box-shadow: none;
}
nav .navbar-brand:focus-visible,
nav .navbar-brand img:focus-visible {
	outline: none;
}
nav.navbar .navbar-brand {
	display: block;
	margin: 0;
	padding: 0;
}
nav.navbar .navbar-brand img {
	height: 22px;
}
nav.navbar-expand-lg .navbar-nav .nav-link p {
	margin-bottom: 0;
}
nav.navbar .offcanvas-body .mobile {
	color: #999;
}
nav.navbar .header-mega {
	display: none;
	width: 100%;
}
nav.navbar .header-mega-body {
	padding: 5px 0 0 30px;
}
nav.navbar .header-mega-body ul li {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
nav.navbar .header-mega-body p a {
	color: inherit;
	text-decoration: none;
}
nav.navbar .header-mega-body ul li p {
	margin-bottom: 0;
}
nav.navbar .header-mega-body ul li,
nav.navbar .header-mega-body ol li {
	margin-top: 16px;
}
nav.navbar .header-mega-body ul li a {
	display: block;
	font-size: 14px;
	text-decoration: none;
	color: rgba(33, 48, 61, 0.7);
}
nav.navbar .header-mega-body ol {
	display: none;
}
nav.navbar .ai {
	background-color: #2593c9;
}
nav.navbar .ai a {
	height: 60px;
	font-size: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.banner-wrap {
	position: relative;
	display: flex;
	text-decoration: none;
	color: inherit;
}
.banner-wrap .content {
	margin-left: -100%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.banner-wrap .content,
.banner-wrap picture {
	-webkit-box-flex: 1;
	-webkit-flex: 1;
	-ms-flex: 1;
	flex: 1;
}
.banner-wrap picture {
	position: relative;
	-webkit-box-ordinal-group: 0;
	-webkit-order: -1;
	-ms-flex-order: -1;
	order: -1;
	z-index: -1;
}
.banner-wrap picture img {
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}
.banner .content .wrap {
	line-height: 1.4;
	text-shadow: 3px 3px 4px rgb(0 0 0 / 16%);
}
.banner-wrap .content .wrap h1 {
	margin-bottom: 1rem;
	font-weight: bold;
	letter-spacing: 2px;
}
.banner-wrap .content .wrap h1 strong {
	color: #2555f3;
}
.banner-wrap .footer {
	position: absolute;
	right: 0;
	bottom: 30px;
}
.banner-wrap .footer h2 {
	margin-bottom: 0;
	font-size: 4rem;
	font-weight: bold;
	text-align: right;
	background: -webkit-linear-gradient(transparent 0%, rgba(205, 215, 220, 0.8));
	background: -o-linear-gradient(transparent 0%, rgba(205, 215, 220, 0.8));
	background: -moz-linear-gradient(transparent 0%, rgba(205, 215, 220, 0.8));
	background: linear-gradient(transparent 0%, rgba(205, 215, 220, 0.8));

	/* テキストまで背景をクリップする */
	-webkit-background-clip: text;
	-moz-background-clip: text;
	background-clip: text;

	/* テキストの色を透明にして、背景を表示する */
	-webkit-text-fill-color: transparent;
	-moz-text-fill-color: transparent;
	-o-text-fill-color: transparent;
	text-fill-color: transparent;
}
.banner-wrap .wrap ul li img {
	margin-top: 10px;
	width: auto;
	height: 30px;
}
.property-floor {
	padding: 60px 0;
}
.property-floor .title {
	margin-bottom: 30px;
	color: #222;
	font-size: 32px;
	font-weight: bold;
}
.property-floor .number {
	grid-row-gap: 20px;
	grid-column-gap: 20px;
	-webkit-column-gap: 20px;
	column-gap: 20px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	row-gap: 20px;
}
.property-floor .item {
	position: relative;
	padding-left: 16px;
}
.property-floor .item::before {
	background-color: #ddd;
	-webkit-border-radius: 2px;
	border-radius: 2px;
	content: "";
	display: inline-block;
	height: 86%;
	left: 0;
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 4px;
}
.property-floor .item strong {
	color: #f60;
	font-size: 20px;
}
.property-floor .item p {
	margin-bottom: 0;
	color: #51200b;
	font-size: 16px;
}
.property-floor .item p small {
	color: rgba(33, 37, 41, 0.5);
}
.banner-item a {
	position: relative;
	display: block;
	overflow: hidden;
}
.banner-item a img {
	transition: all 0.5s;
}
.banner-item a:hover img {
	transform: scale(1.05);
}
.banner-item a .wrap {
	position: absolute;
	top: 64px;
	left: 50%;
	transform: translate(-50%);
	text-align: center;
	color: #fff;
}
.banner-item a .wrap p:last-child {
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: center;
}
.banner-item a .wrap p:last-child::after {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	border-top: 2px solid currentColor;
	border-right: 2px solid currentColor;
	transform: rotate(45deg);
	position: relative;
	margin-left: 6px;
}
section.newsroom .tab-content {
	padding: 16px 6.4vw 30px;
	background-color: #fff;
}
section.newsroom nav {
	display: flex;
	align-items: flex-end;
}
section.newsroom nav a {
	display: flex;
	align-items: center;
	flex-basis: 50%;
	justify-content: center;
	line-height: 1.125;
	font-weight: 500;
	height: 48px;
	text-decoration: none;
	color: inherit;
	background-color: #d3d2cf;
}
section.newsroom nav a.active {
	background-color: #fff;
	border-top: 2px solid #00a0e9;
	font-weight: 700;
	height: 54px;
}
section.newsroom .newswrap li {
	border-bottom: 1px solid #eee;
}
section.newsroom ul.newswrap li a,
section.newsroom ol.newswrap li a {
	line-height: 1.8;
}
section.newsroom .newswrap li a {
	display: block;
	padding: 16px 10px;
	text-decoration: none;
	color: inherit;
}
section.newsroom .newswrap li a time {
	display: inline-block;
	color: #9da2a6;
}
section.newsroom .newswrap li a p {
	margin-bottom: 0;
}
section.newsroom .newswrap li a p span {
	margin-right: 10px;
	font-weight: bold;
	color: #2b73ba;
}
section.newsroom .newswrap ul li a p {
	font-size: 12px;
}
section.newsroom ul,
section.newsroom ol {
	margin-bottom: 0;
	padding-left: 0;
	list-style: none;
}
section.newsroom .newswrap li a address {
	color: #9da2a6;
	margin-bottom: 0;
}
section.newsroom .newswrap li a address i {
	margin-right: 4px;
}
section.newsroom .btn-more a {
	position: relative;
	width: 170px;
	border-radius: 0.52083vw;
}
section.newsroom .btn-more a::after {
	content: "\F285";
	position: absolute;
	right: .5rem;
	margin-left: auto;
	font-weight: bold;
	font-family: "bootstrap-icons";
}
section.newsroom .btn-more a:hover {
	border: 1px solid #00a0e9;
	background-color: #00a0e9;
	color: #fff;
}
.item-gray {
	display: flex;
	flex-direction: column;
	height: 100%;
	background-color: #fafafa;
}
.item-gray h4 {
	margin-bottom: 16px;
	color: #333;
}
.item-gray p {
	color: #777;
}
.item-gray .text-wrap {
	padding: 32px 24px;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-flex: 1;
	-ms-flex: 1 1 auto;
	flex: 1 1 auto;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}
.item-gray .text-wrap p {
	margin-bottom: 30px;
	-webkit-box-flex: 1;
	-ms-flex: 1 1 auto;
	flex: 1 1 auto;
}
.item-gray .text-wrap a {
	display: inline-block;
	padding: 6px 10px;
	color: #111;
	border: 1px solid #111;
	text-decoration: none;
	-webkit-transition: .3s ease-out;
	transition: .3s ease-out;
}
.item-gray .text-wrap a:hover {
	border-color: #c7000b;
	background-color: #c7000b;
	color: #fff;
}

.info {
	padding: 0 0 48px 0;
}
.info .content {
	color: #666;
	line-height: 2;
}
.info a:not([class]) {
	padding-bottom: 3px;
	text-decoration: none;
	color: #00a9e0;
	background: linear-gradient(#00a9e0, #00a9e0) right bottom no-repeat;
	background-size: 0 1px;
	transition-property: background-size;
	transition-duration: 0.5s;
	transition-timing-function: cubic-bezier(0.87, 0, 0.13, 1);
	word-wrap: break-word;
}
.info a:not([class]):hover {
	background-size: 100% 1px;
	background-position: left bottom;
}
.info .frame {
	padding: 20px;
	border: 3px solid #e9e9e9;
}
.info .frame h5 {
	margin-bottom: 20px;
	font-weight: bold;
	color: #666;
	line-height: 1.7;
}
.info .frame p {
	margin-bottom: 0;
	font-size: 14px;
	line-height: 1.7;
}
.list-btn {
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	padding: 0 32px;
	min-height: 72px;
	height: 100%;
	color: inherit;
	font-weight: 700;
	font-size: 18px;
	line-height: 24px;
	text-decoration: none;
}
.list-btn::before,
.list-btn::after {
	display: block;
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #f2f2f2;
	z-index: -1;
}
.list-btn::after {
	background-color: #00a0e9;
	transform: scaleX(0);
	transform-origin: right;
	transition-property: transform;
	transition-duration: 0.5s;
	transition-timing-function: cubic-bezier(0.87,0,0.13,1);
}

.guideline-lists {
	display: flex;
	flex-wrap: wrap;
	margin: 0 auto;
}
.guideline-lists dt,
.guideline-lists dd {
	width: 100%;
}
.guideline-lists dt {
	padding: 20px;
	background-color: #DADADA;
	margin: 0 0 10px 0;
	border-top-left-radius: 3px;
	border-bottom-left-radius: 3px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.guideline-lists dd {
	padding: 20px;
	background-color: #F3F3F3;
	margin: 0 0 10px 0;
	border-top-right-radius: 3px;
	border-bottom-right-radius: 3px;
}
.guideline-lists dd p {
	margin: 0;
}
.guideline-lists dd ul {
	margin-left: 20px;
}
.guideline-lists dd img {
	width: auto;
}

a.product {
	text-decoration: none;
	color: inherit;
	transition: all .4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
a.product img {
	transition: opacity .4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
a.product dl,
a.product dd {
	margin-bottom: 0;
}
a.product dt {
	margin-bottom: 6px;
}
a.product dd {
	font-size: 12px;
}
a.product:hover {
	color: #018463;
	transition-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
}
a.product:hover img {
	opacity: .6;
	transition-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
}

header.banner-wrap {
	order: 2;
}
header.banner-wrap .content {
	justify-content: center;
}
header.banner-wrap .content .wrap  {
	margin-bottom: 200px;
	font-weight: bold;
	line-height: 1.4;
}
header.banner-wrap .content h1 {
	font-size: 24px;
	text-shadow: 1px 2px 4px rgb(0 0 0 / 24%);
}
.link-list {
	padding: 60px 0;
	background-color: #919295;
}
.link-list ul {
	margin-bottom: 0;
	padding-left: 0;
	list-style: none;
}
.link-list li a {
	display: block;
	padding: 13px 0;
	font-weight: bold;
	color: #fff;
	text-align: center;
	text-decoration: none;
	background: none;
	border: 1px solid #fff;
	border-radius: 6px;
}
.link-list li a:hover {
	color: #fff;
	background: #848484;
	border: 1px solid #BABABA;
	border-color: #fff;
}
.link-list li a.active {
	color: #888;
	background: #E8E8E8;
	border: 1px solid #999;
	pointer-events: none;
}
.product-info nav {
	display: flex;
	flex-wrap: wrap;
}
.product-info nav label {
	padding: .3em 0;
	color: #6e6e73;
	font-size: 3.7333333333vw;
	font-weight: bold;
	text-align: center;
	border-bottom: 2px solid #d2d2d7;
	cursor: pointer;
	flex: 1;
	transition: .5s;
}
.product-info nav label.active {
	color: #1d1d1f;
	border-bottom: 3px solid #1d1d1f;
}
.product-info nav.link-area {
	padding: .55556vw;
	background-color: #e8e8e8;
	border-radius: 5.83333vw;
}
.product-info nav.link-area a {
	flex: 1;
	padding: 2.1vw;
	font-size: 2.9vw;
	font-weight: bold;
	text-decoration: none;
	color: inherit;
	border-radius: 5.27778vw;
}
.product-info nav.link-area a.active {
	background-color: #fff;
}
.product-info thead tr th {
	background-color: #f8f8f8;
}
.product-info th,
.product-info td {
	padding: 20px;
}
.product-info tbody th,
.product-info tbody td {
	font-size: 14px;
}
.product-info tbody td {
	color: #666;
}

.process-items {
	padding: 40px 0;
}
.process-wrap {
	display: flex;
	flex-direction: column;
	text-align: center;
	color: #20364c;
}
.process-wrap p {
	font-size: 14px;
}
.process-wrap h1 {
	font-size: 45px;
}
.process-wrap i {
	font-size: 18px;
}

.equi-process {
	margin-bottom: 0;
	padding-left: 0;
}
.equi-process li {
	position: relative;
	display: inline-block;
	width: 100%;
	height: 38px;
	background: #f1f4f7;
	vertical-align: top;
}
.equi-process li:not(:first-child) {
	margin-top: 2px;
}
.equi-process li:before,
.equi-process li:after {
	display: none;
}
.equi-process li a,
.equi-process li span {
	font-weight: bold;
	color: #333;
}
.equi-process li a,
.equi-process li span {
	position: relative;
	text-decoration: none;
	line-height: 1;
	transition: all 0.2s ease-out;
}
.equi-process li a br,
.equi-process li span br {
	display: none;
}
.equi-process li a:after {
	position: absolute;
	content: '';
	width: 0;
	height: 0;
	right: 16px;
	bottom: 16px;
	border-style: solid;
	border-width: 4px 5px 0 5px;
	border-color: #2593c9 transparent transparent transparent;
	transition: all 0.2s ease-out;
}
.equi-process li a:hover:after {
	bottom: 4px;
}
.equi-process li i {
	position: absolute;
	top: 7px;
	left: 10px;
	display: block;
	padding: 5px 6px 3px 6px;
	background-color: #2593c9;
	color: #fff;
	font-size: 18px;
	font-family: Bahnschrift;
	font-style: normal;
	line-height: 1;
}
.equi-process li a,
.equi-process li span {
	display: flex;
	height: 100%;
	font-size: 14px;
	text-align: center;
	align-items: center;
	padding: 0 27px 0 52px;
}
.equi-contents dl {
	margin-bottom: 0;
}
.equi-contents dl {
	margin-top: -56px;
	padding-top: 56px;
}
.equi-contents dt {
	font-size: 4rem;
	line-height: 1;
}
.equi-contents dd {
	margin-bottom: 0;
}
.equi-contents dt,
.equi-contents dd p {
	color: #2593c9;
	font-family: 'Open Sans', sans-serif;
}
.equi-contents dd p {
	margin-bottom: 12px;
	padding-bottom: 2px;
	font-weight: bold;
	border-bottom: 1px solid #2593c9;
}
.equi-contents dd h4 {
	margin-bottom: 20px;
	font-weight: bold;
	font-size: 18px;
}
.equi-contents dd h5 {
	margin-bottom: 0;
	font-size: 14px;
}

.section-hero {
	position: relative;
	min-height: auto;
}
.section-content {
	margin: 0 auto;
	width: auto;
}
.section-hero .image-hero-container {
	position: static;
	top: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	margin-bottom: 40px;
	overflow: hidden;
	background: -webkit-gradient(linear, left top, left bottom, from(#eaeaea), to(#fafafa));
	background: -webkit-linear-gradient(top, #eaeaea 0%, #fafafa 100%);
	background: linear-gradient(to bottom, #eaeaea 0%, #fafafa 100%);
}
.section-hero .image-hero-container .image-hero {
	position: static;
	width: auto;
	height: 220px;
	margin: 0 auto;
	background-image: url(../images/company/hqm.png);
	background-size: 292px 220px;
	background-repeat: no-repeat;
	background-position: 50% 100%;
	-webkit-transform: none;
	transform: none;
}
.section-hero .headlines {
	position: relative;
	margin: 0 auto;
	width: 87.5%;
}
.section-hero .headlines h1 small {
	margin-left: 10px;
}
.section-hero .headlines h1,
.section-hero .headlines h2 {
	margin: 0;
}
.section-hero .headlines h1 {
	margin-bottom: 10px;
	font-size: 28px;
}
.section-hero .headlines h2 {
	margin-bottom: 24px;
	font-size: 24px;
	font-weight: 300;
}

.company-info dt {
	padding-top: 23px;
}
.company-info dd {
	margin-bottom: 0;
	padding: 15px 0 25px;
	width: 100%;
	font-size: 14px;
	border-bottom: 1px solid #00a0e9;
	line-height: 2;
}
.company-info dd a {
	text-decoration: none;
}
.company-info dd figure iframe {
	min-height: 230px;
}

.contact {
	margin-bottom: 60px;
}
.contact section {
	margin: 0 20px;
}
.stepInfo {
	margin-right: auto;
	margin-left: auto;
	max-width: 900px;
}
.stepInfo ol {
	display: flex;
	position: relative;
	margin-bottom: 60px;
	padding-left: 0;
	list-style: none;
	justify-content: space-between;
}
.stepInfo ol::before {
	content: "";
	display: block;
	position: absolute;
	z-index: 1;
	top: 24px;
	right: 0;
	left: 0;
	height: 2px;
	background-color: #d0d0d0;
}
.stepInfo li {
	position: relative;
	text-align: center;
	flex: 1;
	z-index: 2;
}
.stepInfo li::before,
.stepInfo li::after {
	content: "";
	display: block;
	position: absolute;
	top: 24px;
	width: 50%;
	height: 2px;
	background-color: #d0d0d0;
	z-index: -1;
}
.stepInfo li::before {
	right: 50%;
}
.stepInfo li::after {
	left: 50%;
}
.stepInfo li:first-child::before,
.stepInfo li:last-child::after {
	background-color: #fff;
}
.stepInfo dl {
	margin-bottom: 0;
}
.stepInfo dt {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	border-radius: 50%;
	width: 50px;
	height: 50px;
	background-color: #d0d0d0;
	color: #fff;
	font-weight: bold;
	line-height: 1;
}
.stepInfo .is-active dt,
.stepInfo .is-completed dt,
.stepInfo .is-active::before,
.stepInfo .is-completed::before,
.stepInfo .is-completed::after {
	background-color: #333334;
}
.stepInfo .is-active dd,
.stepInfo .is-completed dd {
	color: #333334;
}
.stepInfo dd {
	margin: 14px 0 0;
	font-size: 14px;
	font-weight: bold;
	color: #d0d0d0;
}
.contact .stepInfo + h4 + p {
	font-size: 14px;
	line-height: 2;
}
.contact .content {
	padding: 32px 16px;
	border: 1px solid #eaeaea;
}
.contact .content dl {
	margin-bottom: 0;
	font-size: 14px;
}
.contact .content dt {
	padding-bottom: 24px;
}
.contact .content dd {
	margin-bottom: 0;
	padding-bottom: 56px;
}
.contact .content .form-col:last-child {
	margin-top: 32px;
}
.contact .content dd:last-of-type {
	padding-bottom: 0;
}
.contact .content input[type=text],
.contact .content select,
.contact .content textarea {
	border: 1px solid #d3d3d0;
	outline: none;
}
.contact .content input[type=text],
.contact .content select {
	height: 42px;
}
.contact .content input[type=text],
.contact .content textarea {
	padding: 6px;
	width: 100%;
/*	background-color: #f1f1f1;*/
}
.contact .content select {
	padding: 0 20px;
	width: 100%;
	background: #fff url(../images/common/input-select-arrow-down.svg) no-repeat right 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	box-sizing: border-box;
}
.contact input[type=button],
.contact input[type=submit] {
	font-weight: bold;
	color: #2d2d2d;
	text-align: inherit;
	padding: 16px;
	width: 100%;
	border: 0;
	transition-property: color, background-color, background-image;
	transition-duration: 0.5s;
}
.contact .btn-right {
	background: #f2f2f2 url(../images/common/chevron-right.svg) no-repeat right 20px top 50%;
}
.contact input.btn-left {
	text-align: right;
	background: #f2f2f2 url(../images/common/chevron-left.svg) no-repeat left 20px top 50%;
}
.contact .btn-right:hover,
.contact input.btn-left:hover {
	color: #fff;
}
.contact .btn-right:hover {
	background: #00a0e9 url(../images/common/chevron-right-white.svg) no-repeat right 20px top 50%;
}
.contact input.btn-left:hover {
	background: #00a0e9 url(../images/common/chevron-left-white.svg) no-repeat left 20px top 50%;
}
.contact .is-error input[type=text],
.contact .is-error select,
.contact .is-error textarea {
	color: #fff;
	background-color: #ffaaaa;
}
.error {
	margin-top: .25rem;
	margin-bottom: 0;
	font-size: 14px;
	color: #e71f19;
}

footer {
	position: relative;
	padding: 0 0 1rem;
	background-color: #f2f2f2;
}
footer > ul {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: distribute;
	margin: 0 auto;
	padding: 30px 13px;
	max-width: 400px;
	list-style: none;
	justify-content: space-around;
}
footer a {
	transition-timing-function: ease;
	transition-duration: .3s;
	transition-property: color;
}
footer ul a {
	position: relative;
	display: block;
	color: #fff;
	text-decoration: none;
}
footer .wrap a {
	text-decoration: none;
	color: #666;
}
footer ul a:hover,
footer ul a:focus,
footer .wrap a:hover {
	text-decoration: none;
	-webkit-tap-highlight-color: transparent;
}
footer .wrap {
	padding: 48px 0 0 0;
}
footer .wrap:first-of-type {
	padding: 30px 0 20px 0;
}
footer .wrap:last-child {
	padding-top: 20px;
}
footer .wrap .logo {
	display: block;
	margin: 0 auto;
	margin-bottom: 1rem;
	width: 65%;
}
footer .wrap .copy-text {
	font-size: 12px;
}
footer .wrap .copyright {
	margin-bottom: 0;
	font-family: "Open Sans",sans-serif;
	color: #666;
}
footer .wrap ul {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 14px;
}
footer .wrap ul a {
	padding: 0 16px;
}

@media (min-width: 992px) {
	nav.navbar::before {
		position: fixed;
		top: 106px;
		left: 0;
		width: 100%;
		height: 100%;
		background-color: rgba(33, 37, 41, 0.45);
		-webkit-transition: 0.25s ease-out;
		transition: 0.25s ease-out;
		visibility: hidden;
		opacity: 0;
		content: '';
	}
	nav.navbar.is-active::before {
		visibility: visible;
		opacity: 1;
	}
	nav.navbar .navbar-brand img {
		height: 30px;
	}
	nav.navbar .navbar-nav {
		margin: 0;
		width: auto;
	}
	nav.navbar .navbar-nav,
	nav.navbar .navbar-nav .nav-item {
		position: static;
	}
	nav.navbar .navbar-nav .nav-item {
		padding: 0 15px;
	}
	nav.navbar .navbar-nav .nav-item .nav-link {
		position: relative;
		padding: 1.5rem 0;
	}
	nav.navbar .navbar-nav .nav-item .nav-link .bi {
		margin-left: 6px;
		color: #00a0e9;
		transform: rotate(0);
		transition: transform 0.25s ease;
	}
	nav.navbar .navbar-nav .nav-item .nav-link.open .bi {
		transform: rotate(180deg);
	}
	nav.navbar .navbar-nav .nav-item.active .nav-link::after {
		position: absolute;
		top: 50%;
		left: 50%;
		width: min(64px, 5vw);
		height: min(64px, 5vw);
		content: "";
		background: radial-gradient(farthest-side, rgba(0, 160, 233, .2), transparent);
		transform: translate(-50%, -50%);
	}
	nav.navbar .navbar-nav .nav-item:last-child {
		margin-right: 0;
	}
	nav.navbar .navbar-nav .nav-item > a {
		position: relative;
		margin-left: 0;
		width: auto;
		font-size: 15px;
		text-align: center;
		line-height: 1.1;
	}
	nav.navbar .navbar-nav .nav-item > a::before {
		position: absolute;
		right: calc(100% + 3px);
		bottom: -3px;
		left: 0;
		z-index: 2;
		display: block;
		content: "";
		height: 6px;
		background: linear-gradient(to left, #01a1eb 0%, #0066bd 100%);
		border-radius: 3px;
		transition: right 0.3s ease-in-out;
	}
	nav.navbar .navbar-nav .nav-item > a.open::before,
	nav.navbar .navbar-nav .nav-item > a:hover::before {
		right: 0;
	} 
	nav.navbar .offcanvas-body .wrap {
		display: flex;
		width: 100%;
	}
	nav.navbar .offcanvas-body .header-lang {
		margin-top: 0.5rem;
		margin-bottom: 0;
		justify-content: flex-end;
	}
	nav.navbar .offcanvas-body .header-lang a,
	nav.navbar .offcanvas-body .header-lang li:last-child a {
		margin-right: 24px;
	}
	nav.navbar .offcanvas-body .mobile {
		margin: 0;
		border-bottom: none;
	}
	nav.navbar .header-mega {
		position: absolute;
		top: 100%;
		left: 0;
		display: block;
		background-color: #fff;
		opacity: 0;
		visibility: hidden;
		-webkit-transform: translateY(20px);
		transform: translateY(20px);
		-webkit-transition: 0.25s ease-out;
		transition: 0.25s ease-out;
		pointer-events: none;
		z-index: 1;
	}
	nav.navbar .header-mega.visible {
		border-top: 1px solid #ddd;
		opacity: 1;
		visibility: visible;
		-webkit-transform: translateY(0);
		transform: translateY(0);
		pointer-events: auto;
	}
	nav.navbar .header-mega-container {
		margin: 0 auto;
		padding: 60px 0;
		max-width: 1100px;
	}
	nav.navbar .header-mega-container.en {
		max-width: 1400px;
	}

	nav.navbar .header-mega-head p {
		font-size: 14px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
	}
	nav.navbar .header-mega-head h1 {
		margin-bottom: 0;
		color: #2b73ba;
		font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
		font-weight: 400;
		line-height: 1.1;
	}
	nav.navbar .header-mega-body {
		padding: 0;
	}
	nav.navbar .header-mega-body h5 {
		margin-bottom: 0;
		padding-bottom: 20px;
		border-bottom: solid 1px #c0b3d2;
	}
	nav.navbar .header-mega-body h5 a {
		font-weight: bold;
		color: inherit;
		text-decoration: none;
	}
	nav.navbar .header-mega-body h5 a .bi {
		margin-left: 20px;
		color: #2b73ba;
	}
	nav.navbar .header-mega-body h5 a .bi::before {
		transition: .6s ease;
	}
	nav.navbar .header-mega-body h5 a:hover .bi::before {
		transform: translateX(4px);
	}
	nav.navbar .header-mega-body ul li {
		display: block;
	}
	nav.navbar .header-mega-body ul li p {
		width: 100%;
	}
	nav.navbar .header-mega-body ul > li > a {
		font-size: inherit;
		color: inherit;
	}
	nav.navbar .header-mega-body ol {
		display: block;
		margin-top: 7.5px;
		margin-left: 2px;
		padding: 4.5px 0 4.5px 22px;
		border-left: solid 1px #c0b3d2;
	}
	nav.navbar .header-mega-body ol li {
		margin-top: 6px;
	}
	nav.navbar .header-mega-body li h5 {
		margin-bottom: 0;
		padding-bottom: 21px;
		font-weight: bold;
		color: #e71f19;
		border-bottom: solid 1px #c0b3d2;
	}
	nav.navbar .header-mega-body > ul > li {
		margin-top: 0;
	}
	nav.navbar .header-mega-body > ul li li > a {
		width: 100%;
		color: inherit;
		text-decoration: none;
		letter-spacing: normal;
		-webkit-transition: color 0.3s;
		transition: color 0.3s;
	}
	nav.navbar .ai a {
		width: 100px;
		height: 100%;
	}
	.banner-wrap .content .wrap h1 strong {
		font-size: 150px;
		line-height: 1;
	}
	.property-floor .title {
		font-size: 44px;
		line-height: 52px;
	}
	.property-floor .item strong {
		font-size: 36px;
		line-height: 44px;
	}
	.property-floor .item p {
		font-size: 20px;
		line-height: 26px;
	}
	section.newsroom .tab-content {
		padding: 40px 80px;
	}
	section.newsroom .newswrap li a {
		position: relative;
		padding: 24px 0;
		font-size: inherit;
		line-height: inherit;
		-webkit-transition: all 0.6s cubic-bezier(0.24, 0.12, 0, 1);
		transition: all 0.6s cubic-bezier(0.24, 0.12, 0, 1);
	}
	section.newsroom .newswrap li a::before {
		position: absolute;
		top: -1px;
		left: 0;
		width: calc(100% + 20px);
		height: calc(100% + 2px);
		margin-left: -10px;
		display: block;
		background-color: #ebecee;
		border-radius: 5px;
		opacity: 0;
		-webkit-transition: opacity 0.6s cubic-bezier(0.24, 0.12, 0, 1), -webkit-transform 0.6s cubic-bezier(0.36, 0.14, 0, 1);
		transition: opacity 0.6s cubic-bezier(0.24, 0.12, 0, 1), -webkit-transform 0.6s cubic-bezier(0.36, 0.14, 0, 1);
		transition: opacity 0.6s cubic-bezier(0.24, 0.12, 0, 1), transform 0.6s cubic-bezier(0.36, 0.14, 0, 1);
		transition: opacity 0.6s cubic-bezier(0.24, 0.12, 0, 1), transform 0.6s cubic-bezier(0.36, 0.14, 0, 1), -webkit-transform 0.6s cubic-bezier(0.36, 0.14, 0, 1);
		-webkit-transform-origin: 0% 50%;
		transform-origin: 0% 50%;
		-webkit-transform: scale(0.98, 1);
		transform: scale(0.98, 1);
		content: '';
	}
	section.newsroom .newswrap li a:hover::before {
		-webkit-transform: scale(1, 1);
		transform: scale(1, 1);
		opacity: 1;
	}
	section.newsroom .newswrap li a .wrap {
		display: flex;
		align-items: center;
		-webkit-transition: -webkit-transform 0.8s cubic-bezier(0.36, 0.14, 0, 1);
		transition: -webkit-transform 0.8s cubic-bezier(0.36, 0.14, 0, 1);
		transition: transform 0.8s cubic-bezier(0.36, 0.14, 0, 1);
		transition: transform 0.8s cubic-bezier(0.36, 0.14, 0, 1), -webkit-transform 0.8s cubic-bezier(0.36, 0.14, 0, 1);
	}
	section.newsroom .newswrap li a:hover .wrap {
		-webkit-transform: translate(20px, 0);
		transform: translate(20px, 0);
	}
	section.newsroom .newswrap li a p {
		padding: 4px 20px;
		font-size: initial;
		border-left: 1px solid #dcdcdc;
	}
	section.newsroom .newswrap li a:hover p {
		color: #2593c9;
	}
	section.newsroom .newswrap li a time {
		margin-bottom: 0;
		white-space: nowrap;
	}
	section.newsroom .newswrap li a p span {
		margin-right: 20px;
	}
	section.newsroom .newswrap li a time,
	section.newsroom .newswrap li a address {
		position: relative;
		margin: 0 20px;
	}
	section.newsroom .newswrap li a address i + br + i {
		margin-left: 20px;
	}
	section.newsroom .btn-more a {
		width: 15.625vw;
	}
	section.newsroom .btn-more a:hover::after {
		border-color: #fff;
	}
	.item-gray .img-wrap {
		overflow: hidden;
	}
	.item-gray .text-wrap a {
		padding: 6px 20px;
	}
	.bg-gray ul.nav a {
		font-size: 26px;
	}

	.info {
		padding: 0 0 100px 0;
	}
	.info .container {
		padding: 0 100px;
	}
	.info .content .wrap {
		margin: 60px auto 0 auto;
		max-width: 860px;
	}
	.info .frame {
		padding: 40px;
	}
	.list-btn {
		font-size: 24px;
		line-height: 1.3em;
		min-height: 96px;
		transition-property: color;
		transition-duration: 0.5s;
		transition-timing-function: cubic-bezier(0.87,0,0.13,1);
	}
	.list-btn:hover {
		color: #fff;
		transition-timing-function: cubic-bezier(0.16,1,0.3,1);
	}
	.list-btn:hover:after {
		transform: scaleX(1);
		transform-origin: left;
		transition-timing-function: cubic-bezier(0.16,1,0.3,1);
	}
	.giftinner {
		margin: 40px 0 0 0;
	}
	.giftinner p {
		margin-bottom: 20px;
	}
	.guideline-lists dt {
		width: 30%;
	}
	.guideline-lists dd {
		width: 70%;
	}

	a.product dd {
		font-size: 14px;
	}

	header.banner-wrap {
		order: 1;
	}
	.affix-placeholder {  
		order: 2;
	}
	header.banner-wrap .content {
		justify-content: start;
	}
	header.banner-wrap .content .wrap {
		margin-bottom: 0;
		padding-left: 250px;
	}
	header.banner-wrap .content h1 {
		padding-left: 0;
		font-size: 2.5rem;
	}
	.link-list {
		padding: 80px 0;
	}
	.product-info nav label {
		font-size: 20px;
	}
	.product-info nav label {
		padding: .5em 0;
	}
	.product-info nav label.active {
		border-bottom: 6px solid #1d1d1f;
	}
	.product-info nav.link-area {
		display: inline-flex;
		justify-content: center;
		padding: 4px;
	}
	.product-info nav.link-area a {
		flex: auto;
		padding: 10px 40px;
		font-size: 20px;
	}

	.textblock {
		padding-right: 130px;
		padding-left: 130px;
	}
	.process-items {
		padding: 80px 0;
	}
	.process-wrap p {
		font-size: 18px;
	}
	.process-wrap h1 {
		font-size: 60px;
	}
	.process-wrap i {
		font-size: 24px;
	}

	.equi-contents dt {
		font-size: 4.8rem;
	}
	.equi-contents dd p {
		margin-bottom: 1rem;
		padding-bottom: 6px;
	}
	.equi-contents dd h4 {
		margin-bottom: 30px;
		font-size: 1.5rem;
	}
	.equi-contents dd h5 {
		font-size: 18px;
	}
	.equi-process {
		position: relative;
		display: inline-block;
		font-size: 0;
	}
	.equi-process:last-child:after {
		display: none;
	}
	.equi-process:after {
		position: absolute;
		content: '';
		display: block;
		top: 0;
		right: 0;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 33px 0 33px 18px;
		border-color: #fff transparent #fff #f1f4f7;
	}
	.equi-process li {
		width: auto;
		height: 66px;
	}
	.equi-process li:not(:first-child) {
		margin-top: 0;
	}
	.equi-process li:before,
	.equi-process li:after {
		position: absolute;
		content: '';
		display: block;
		top: 0;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 33px 0 33px 18px;
		border-color: transparent transparent transparent #fff;
	}
	.equi-process li:first-child:before {
		display: none;
	}
	.equi-process li:before {
		left: 0;
	}
	.equi-process li:after {
		left: -3px;
		border-left-color: #f1f4f7;
	}
	.equi-process li:first-child:after {
		content: none;
	}
	.equi-process li a,
	.equi-process li span {	
		padding: 0 30px;
	}
	.equi-process.en li a,
	.equi-process.en li span {	
		padding: 0 20px;
	}
	.equi-process li:not(:first-child) a,
	.equi-process li:not(:last-child) span {
		position: relative;
		left: 10px;
	}
	.equi-process li a br,
	.equi-process li span br {
		display: block;
	}
	.equi-process li:first-child i {
		left: 44%;
	}
	.equi-process li i {
		top: -17px;
		left: 46%;
	}
	.equi-process li a:after {
		bottom: 8px;
		left: 48%;
	}

	.section-content,
	.section-hero .image-hero-container .image-hero {
		width: 980px;
	}
	.section-hero {
		position: relative;
		min-height: 360px;
	}
	.section-hero .image-hero-container {
		position: absolute;
		margin-bottom: 0;
	}
	.section-hero .image-hero-container .image-hero {
		position: absolute;
		bottom: 0;
		left: 60%;
		height: 336px;
		background-size: auto 336px;
		background-position: 381px 100%;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
	}
	.section-hero .headlines {
		margin: 0;
		width: 50%;
		padding-top: 94px;
	}
	.section-hero .headlines h1 {
		font-size: 40px;
	}
	.section-hero .headlines h2 {
		margin-bottom: 0;
		font-size: 32px;
	}

	.company-info {
		display: flex;
		flex-wrap: wrap;
	}
	.company-info dt,
	.company-info dd {
		padding: 25px 0 25px 13px;
	}
	.company-info dt {
		width: 255px;
		border-bottom: 1px solid #00a0e9;
		line-height: 2;
	}
	.company-info dd {
		margin-left: 32px;
		font-size: inherit;
		width: calc(100% - 255px - 32px);
		border-color: #e0e0e0;
	}
	.company-info dd figure iframe {
		min-height: 450px;
	}

	.stepInfo ol {
		margin-bottom: 80px;
	}
	.contact {
		margin-bottom: 100px;
	}
	.stepInfo dd,
	.contact .stepInfo + h4 + p {
		font-size: inherit;
	}
	.contact section {
		margin: 0 auto;
		width: 58.623%;
	}
	.contact .content {
		padding: 80px 60px;
	}
	.contact .content dl {
		display: flex;
		flex-wrap: wrap;
		font-size: inherit;
	}
	.contact .content dt {
		width: 290px;
		padding-bottom: 56px;
		line-height: 1.5;
	}
	.contact .content dd {
		width: calc(100% - 290px);
	}
	.contact .content dt:last-of-type,
	.contact .content dd:last-of-type {
		padding-bottom: 0;
	}
	.contact .content .form-row {
		display: flex;
		justify-content: space-between;
	}
	.contact .content .form-col {
		width: calc(50% - 32px);
	}
	.contact .content .form-col:last-child {
		margin-top: 0;
	}
	.contact .content select,
	.contact .content input[type=text].form-input--s {
		width: 224px;
	}
	.contact input[type=button] {
		padding: 16px 32px;
	}

	footer {
		padding-bottom: 0;
	}
	footer > ul {
		padding: 40px 0;
		-ms-flex-pack: center;
		max-width: 100%;
		justify-content: center;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	footer > ul a {
		padding: 0 1.5rem 0 calc(1.5rem + 1.5rem + 40px);
	}
	footer ul a span.i {
		position: absolute;
		top: 50%;
		left: 1.5rem;
		width: 44px;
		height: 44px;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
	}
	footer ul a span.icon {
		font-size: 18px;
	}
	footer ul a span.lbl {
		padding: 10px 0;
		font-size: 14px;
		line-height: 1.5714;
	}
	footer ul a span.lbl br {
		display: none;
	}
	footer .wrap {
		padding: 40px 0 32px 0;
		font-size: 14px;
	}
	footer .wrap:last-child {
		padding: 20px 0;
	}
	footer .wrap .logo {
		width: 100%;
		text-align: center;
	}
	footer .wrap .logo img {
		display: inline-block;
		width: auto;
		height: 50px;
	}
	footer .wrap .copy-text {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		font-size: 14px;
	}
	footer .wrap a + .copyright {
		display: inline-block;
		margin: 0 0 0 20px;
	}
	footer .wechat-qrcode {
		position: absolute;
		top: 60px;
		left: -60px;
	}
}