@charset "UTF-8";

.footer-wrap {
	background-color: #2E2E2E;
	padding: 90px 0 80px 0;
}
@media only screen and (max-width: 767px) {
	.footer-wrap {
		padding: 60px 0 40px 0;
	}
}

.footer-container {
  margin: 0 auto;
  max-width: calc( 1157px + 80px);
  padding: 0 calc( 80px / 2);
}
@media only screen and (max-width: 767px) {
  .footer-container {
    max-width: calc(100%);
  	padding: 0 calc( 40px / 2);
  }
}

.footer-inner {
	display: flex;
}
@media only screen and (max-width: 767px) {
	.footer-inner {
		flex-wrap: wrap;
	}
}

.footer-logo-anchor {
	padding: 10px 0;
}
.footer-logo-anchor img {
	transition: .2s ease-out;
	width: 223px;
}
@media (hover: hover) {
	.footer-logo-anchor:hover img {
		opacity: 0.8;
	}
}
@media only screen and (max-width: 1150px) {
	.footer-logo-anchor img {
		width: clamp(125px, 16vw, 217px);
	}
}
@media only screen and (max-width: 767px) {
	.footer-logo-anchor {
		margin: 0 auto;
	}
	.footer-logo-anchor img {
		width: clamp(125px, 54vw, 217px);
	}
}

.footer-info-box {
	width: 100%;
	padding: 10px 0 10px 5%;
	margin-left: 5%;
	border-left: 1px solid #fff;
}
@media only screen and (max-width: 1150px) {
	.footer-info-box {
		padding: 10px 0 10px 4%;
		margin-left: 4%;
	}
}
@media only screen and (max-width: 870px) {
	.footer-info-box {
		padding: 10px 0 10px 3%;
		margin-left: 3%;
	}
}
@media only screen and (max-width: 767px) {
	.footer-info-box {
		border-left: none;
		padding: 0;
		margin-left: 0;
		margin-top: 20px;
	}
}

.footer-info-list {
	display: flex;
	justify-content: space-between;
	gap: 4%;
	width: 100%;
}
@media only screen and (max-width: 767px) {
	.footer-info-list {
		flex-wrap: wrap;
		justify-content: space-between;
		gap: 0;
	}
	.footer-info-list-item {
		width: calc(50% - 12px);
	}
	.footer-info-list-item + .footer-info-list-item {
		margin-bottom: 25px;
	}
}

@media only screen and (max-width: 767px) {
	.footer-info-list-item-box {
		margin-top: 40px;
	}
}

.footer-info-page-anchor-box + .footer-info-page-anchor-box {
	margin-top: 30px;
}

.footer-info-page-anchor {
	color: #fff;
  transition: .3s ease-out;
}
@media (hover: hover) {
	.footer-info-page-anchor:hover {
		color: #E60012;
	}
}
.footer-info-page-anchor .text-en {
	position: relative;
	display: block;
	font-size: clamp(14px, 5vw, 18px);
	letter-spacing: 0.1px;
}
.footer-info-page-anchor .text-jp {
	display: inline-block;
	font-size: 10px;
	padding-top: 3px;
}
@media only screen and (max-width: 1150px) {
	.footer-info-page-anchor .text-en {
		font-size: clamp(14px, 1.8vw, 18px);
	}
}
@media only screen and (max-width: 767px) {
	.footer-info-page-anchor {
		display: block;
	}
	.text-en-box {
		display: flex;
		align-items: center;
  	width: 100%;
	}
	.text-en-box::after {
	  content: "";
	  flex: 1;
	  height: 1px;
	  background-color: #fff;
	}
	.footer-info-page-anchor .text-en {
		font-size: clamp(14px, 5vw, 18px);
		white-space: nowrap;
		margin-right: 10px;
	}
	.footer-info-page-anchor .text-en .sp-line {
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		bottom: 0;
		margin: auto;
		width: 100%;
		background-color: #fff;
		height: 1.5px;
	}
}

.footer-info-section-anchor:nth-of-type(1) {
	margin-top: 30px;
}
.footer-info-section-anchor + .footer-info-section-anchor {
	margin-top: 12px;
}
.footer-info-section-anchor a {
	color: #fff;
	font-size: 14px;
	font-weight: 400;
	border-bottom: 1px solid #fff;
  transition: .15s ease;
}
@media (hover: hover) {
	.footer-info-section-anchor a:hover {
		opacity: 0.8;
		border-bottom: 1px solid transparent;
	}
}
@media only screen and (max-width: 1150px) {
	.footer-info-section-anchor a {
		font-size: clamp(10px, 1.4vw, 14px);
	}
}
@media only screen and (max-width: 767px) {
	.footer-info-section-anchor a {
		font-size: clamp(12px, 3.9vw, 14px);
	}
	.footer-info-section-anchor:nth-of-type(1) {
		margin-top: 20px;
	}
}

.footer-copy-wrap {
	background-color: #E60012;
	text-align: right;
	padding: 10px 0;
	font-size: 13px;
	@media only screen and (max-width: 1150px) {
		font-size: clamp(10px, 1.5vw, 13px);
	}
	@media only screen and (max-width: 767px) {
		font-size: 12px
	}
	@media only screen and (max-width: 380px) {
		font-size: 11px
	}
	@media only screen and (max-width: 374px) {
		font-size: 10px
	}
}

.footer-copy-privacypolicy {
	display: inline-block;
	color: #fff;
	font-weight: 400;
	margin-right: 15px;
	border-bottom: 1px solid #fff;
  transition: .15s ease;
  @media only screen and (max-width:767px){
  	margin-bottom:7px;
  	margin-right: 8px;
  }
}
@media (hover: hover) {
	.footer-copy-privacypolicy:hover {
		opacity: 0.8;
		border-bottom: 1px solid transparent;
	}
}
.footer-copy {
	display: inline-block;
	color: #fff;
	font-weight: 400;

	.theta-accent {
	  position: relative;
	  display: inline-block;
		&::before {
		  content: "ˆ";
		  position: absolute;
		  top: -0.4em;
		  left: 50%;
		  transform: translateX(-50%);
		  font-size: 0.6em;
		}
	}
}

