/*___________________________
Body
___________________________*/

html {
	scroll-behavior: smooth;
	scroll-padding-top: 74px;
}

body {
	background: #fff;
	font-family: var(--familyNotoSans);
}

p,
h5,
h4,
h3,
h2,
h1,
a,
dd,
dt,
li,
figcaption,
button {
	color: #424242;
	font-family: var(--familyInter);
	font-size: var(--fontMax16Min14);
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 2;
}

main a,
footer a {
	transition: opacity 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
}

main a:not(.paginationGroup a):hover,
footer a:hover {
	opacity: 0.7;
}

.decoratedUnderline {
	background: linear-gradient(to top, rgba(255, 213, 208, 1) 0%, rgba(255, 213, 208, 1) 45%, rgba(255, 255, 255, 1) 45%);
	padding-bottom: 2px;
}

.w-auto {
	height: revert-layer !important;
	width: auto !important;
}

span.has__notice {
	display: block;
	position: relative;
}

span.has__notice .pictureNotice {
	bottom: 1rem;
	color: #333;
	font-family: "Noto Sans JP", sans-serif;
	font-size: var(--fontMax12Min10);
	font-weight: 400;
	left: 1rem;
	letter-spacing: 0.1em;
	margin: 0;
	position: absolute;    
    text-shadow: -1px -1px 0px #fff, 1px -1px 0px #fff, -1px 1px 0px #fff, 1px 1px 0px #fff;
}

/*___________________________
Breadcrumbs
___________________________*/

.breadcrumbs {
	box-sizing: border-box;
	display: flex;
	gap: 24px;
	margin: 0 auto;
	max-width: 1280px;
	padding: 80px 16px 24px;
}

.breadcrumbLink,
.breadcrumbCurrent {
	font-size: 12px;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 2;
}

.breadcrumbLink {
	color: #ababab;
	min-width: fit-content;
	position: relative;
}

.breadcrumbLink::after {
	background: #ababab;
	content: "";
	height: 12px;
	position: absolute;
	right: -13px;
	top: 7px;
	transform: rotate(45deg);
	transform-origin: center;
	width: 1px;
}

@media screen and (max-width: 767px) {
	.breadcrumbs {
		padding-top: 40px;
	}
}

/*========================
  Header
========================*/

.header {
	align-items: center;
	background: #fff;
	border-bottom: 1px solid #e9e8e5;
	box-sizing: border-box;
	display: flex;
	height: 72px;
	justify-content: space-between;
	left: 0;
	padding: 0 24px;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 10;
}

.headerBar__nav {
	display: flex;
	gap: 28px;
	position: relative;
	top: -2px;
}

.headerBar__nav img {
	max-width: 21px;
}

.headerBar__shopIcon {
	max-width: 18px;
}

.headerBar__logo {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	left: -0.05vw;
}

.headerBar__logo img {
	max-width: 180px;
	width: 100%;
}

.sideBar {
	height: calc(100% - 70px);
	left: 0;
	max-width: 600px;
	opacity: 0;
	overflow-y: scroll;
	position: fixed;
	top: 72px;
	transform: translateX(-100%);
	visibility: hidden;
	width: calc(100% - 44px);
	z-index: 11;
}

/* width */
.sideBar::-webkit-scrollbar {
	width: 6px;
}

/* Track */
.sideBar::-webkit-scrollbar-track {
	background: transparent;
}

/* Handle */
.sideBar::-webkit-scrollbar-thumb {
	background: #b3b3b3;
}

/* Handle on hover */
.sideBar::-webkit-scrollbar-thumb:hover {
	background: #555;
}

.sideBar__list {
	display: grid;
	grid-template-columns: 1fr;
}

.sideBarDropdown__head {
	align-content: center;
	background: #fff;
	border-top: 1px solid #d8d8d8;
	box-sizing: border-box;
	display: grid;
	grid-template-columns: auto 20px;
	height: 60px;
	padding: 0 28px 0 24px;
	position: relative;
}

.sideBar__list .sideBar__item:first-child .sideBarDropdown__head {
	border-top: 0;
}

.sideBarDropdown__head p,
.sideBarDropdown__item p {
	color: var(--colorBlack);
	font-size: var(--fontMax16Min14);
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 1;
}

.sideBarDropdown__head p.hasGlobe {
	padding-left: 24px;
}

.sideBar__item--globe {
	left: 25px;
	max-width: 14px;
	position: absolute;
	top: 22px;
}

.sideBar__external {
	align-self: center;
	background: url(../images/common/icon-open_new.svg) no-repeat center / cover;
	height: 14px;
	width: 14px;
}

.sideBar__arrow {
	align-self: center;
	border-bottom: 1px solid var(--colorGray);
	border-right: 1px solid var(--colorGray);
	height: 8px;
	transform: rotate(-45deg);
	width: 8px;
}

.sideBarDropdown__list {
	display: grid;
	grid-template-columns: 1fr;
}

.sideBarDropdown__item {
	background: #ececec;
	border-top: 1px solid #d8d8d8;
	box-sizing: border-box;
	display: grid;
	grid-template-columns: auto 20px;
	height: 48px;
	padding: 0 28px 0 40px;
}

.sideBarDropdown__item span {
	align-items: center;
	display: flex;
	gap: 8px;
}

.sideBarDropdown__item img {
	max-width: 32px;
}

.hamburgerBtn {
	cursor: pointer;
	height: 100%;
	position: relative;
	width: 24px;
}

.hamburgerBtn span {
	background: #424242;
	height: 1px;
	position: absolute;
	transition: 0.4s cubic-bezier(0.175, 0.885, 0.52, 1);
	width: 100%;
}
.hamburgerBtn span:first-child {
	left: 0;
	top: 49%;
}

.hamburgerBtn span:last-child {
	bottom: 40%;
	left: 0;
}

.drawerOpen .hamburgerBtn span:first-child {
	transform: translateY(3px) rotate(45deg);
}

.drawerOpen .hamburgerBtn span:last-child {
	transform: translateY(-4px) rotate(-45deg);
}


@media screen and (max-width: 1024px) {
	.headerBar__logo {
		left: 0.1vw;
	}
	.headerBar__nav {
		top: 0;
		gap: 26px;
	}
	.headerBar__nav img {
		max-width: 19px;
	}
}

@media screen and (max-width: 767px) {
	.headerBar__logo img {
		max-width: 120px;
	}
	.headerBar__nav {
		gap: 16px;
	}
	.headerBar__nav img {
		max-width:18px;
	}
	.headerBar__userIcon {
		position: relative;
		left: -1px;
	}
	
	.headerBar__shopIcon img {
		max-height:15px;
	}
}

/*========================
  Navbar
========================*/

.navbar {
	align-items: center;
	box-sizing: border-box;
	display: flex;
	height: 120px;
	justify-content: center;
	left: 0;
	padding: 0 20px;
	position: fixed;
	top: 0;
	width: 100%;
}

.navbar__inner {
	display: grid;
	gap: 40px;
	grid-template-columns: 150px auto;
	max-width: 1080px;
	width: 100%;
}

.navbar__logo img {
	max-width: 200px;
}

.navbar__list {
	align-self: center;
	display: flex;
	gap: 30px;
	height: fit-content;
	justify-content: center;
	width: 100%;
}

.navbar__item {
	width: fit-content;
}

.navbar__item a {
	color: #000;
	font-family: var(--familyNotoSans);
	font-size: var(--fontMax18Min16);
	font-weight: 700;
	line-height: 1.38;
	transition: opacity 0.3s ease-out;
}

.navbar__item:hover a {
	opacity: 0.7;
}

.backdrop {
	background: rgba(0, 0, 0, 0.6);
	height: calc(100% - 72px);
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	top: 72px;
	transition: all 0.6s ease-in-out;
	visibility: hidden;
	width: 100%;
	z-index: 9;
}

.drawerOpen .backdrop {
	opacity: 1;
	pointer-events: all;
	visibility: visible;
}

/*========================
  Hamburger
========================*/

.navbar__hamburger {
	cursor: pointer;
	display: none;
	height: 25px;
	position: relative;
	width: 30px;
}

.navbar__hamburger span {
	background: #000;
	height: 2px;
	position: absolute;
	transition: all 0.3s ease-in-out, background-color 0.3s ease-in-out 0.3s;
	width: 100%;
}

.drawerOpen .navbar__hamburger span {
	background: #fff;
}

.navbar__hamburger span:nth-child(1) {
	left: 0;
	top: 0;
}

.drawerOpen .navbar__hamburger span:nth-child(1) {
	transform: translate(-1px, 12px) rotate(45deg);
}

.navbar__hamburger span:nth-child(2) {
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}

.drawerOpen .navbar__hamburger span:nth-child(2) {
	opacity: 0;
	transform: translateX(20px);
}

.navbar__hamburger span:nth-child(3) {
	bottom: 0;
	left: 0;
}

.drawerOpen .navbar__hamburger span:nth-child(3) {
	transform: translate(-1px, -11px) rotate(-45deg);
}

/*========================
  NavDrawer
========================*/

.navdrawer {
	align-items: center;
	background: rgba(0, 0, 0, 0.9);
	display: flex;
	flex-direction: column;
	gap: 18px;
	height: 100vh;
	justify-content: center;
	left: 0;
	position: fixed;
	top: 0;
	transform: translateX(100%);
	width: 100vw;
	z-index: -1;
}

.navdrawer__nav {
	display: grid;
	gap: 16px;
	grid-template-columns: 1fr;
	margin: 0 auto;
	width: fit-content;
}

.navdrawer__nav a {
	border-bottom: 1px solid rgba(255, 255, 255, 0.4);
	color: #fff;
	font-family: var(--familyNotoSans);
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 1.6;
	opacity: 0;
	transform: translateY(50px);
	visibility: hidden;
}

.navdrawer__nav a:last-child {
	border-bottom: none;
}

@media screen and (max-width: 1080px) {
	.navbar__logo img {
		max-width: 150px;
	}

	.navbar {
		height: 60px;
	}

	.navbar__list {
		display: none;
	}

	.navbar__hamburger {
		align-self: center;
		display: block;
	}

	.navbar__inner {
		display: flex;
		justify-content: space-between;
		max-width: 1230px;
		padding: 0 20px;
	}
}

@media screen and (max-width: 550px) {
	.navbar__logo img {
		max-width: 120px;
	}

	.navbar__inner {
		padding: 0;
	}
}

/*___________________________
Sidedrawer
___________________________*/

.sidedrawer {
	display: block;
}

/*___________________________
Footer
___________________________*/

.promotionBar {
	align-items: center;
	background: #545454;
	box-sizing: border-box;
	display: flex;
	gap: 52px;
	height: 83px;
	justify-content: center;
	padding: 0 20px;
}

.footerSocials {
	display: flex;
	gap: 40px;
}

.footerSocials nav {
	display: flex;
	gap: 4px;
}

.promotion {
	align-items: center;
	display: flex;
	gap: 16px;
}

.footerIcon__insta,
.footerIcon__x,
.footerIcon__yt {
	max-width: 51px;
}

.promotion .engText {
	color: #fff;
	font-family: var(--familyInter);
	font-size: var(--fontMax18Min16);
	font-weight: 300;
	letter-spacing: 0.38em;
	line-height: 1;
}

.promotion .jpText {
	color: #fff;
	font-size: 12px;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 2;
}

.footerBody {
	background: #424242;
	box-sizing: border-box;
	padding: 80px 20px;
}

.footerBody__container {
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1280px;
}

.footerLogo {
	max-width: 240px;
}

.footerAddress__textArea {
	margin-top: 40px;
}

.footerAddress__textArea p,
.footerNav a,
.globalLink p {
	color: #fff;
	font-size: var(--fontMax14Min12);
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 2;
}

.footerNav nav {
	display: grid;
	gap: 8px;
	grid-template-columns: 1fr;
}

.globalLink {
	align-items: center;
	display: grid;
	gap: 10px;
	grid-template-columns: 16px auto;
	height: fit-content;
	margin-top: 40px;
}

.globalLink img {
	max-width: 16px;
}

.globalLink p {
	font-family: var(--familyInter);
	font-weight: 300;
}

.copywrite {
	color: #fff;
	font-family: var(--familyInter);
	font-size: 10px;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1;
	margin: 80px auto 0;
	max-width: 1280px;
	width: 100%;
}

@media screen and (max-width: 767px) {
	.footerBody {
		padding: 64px 16px;
	}
	.promotionBar {
		display: none;
	}
	.footerBody__container {
		flex-direction: column;
		gap: 40px;
	}
	.footerAddress__textArea {
		display: none;
	}
	.copywrite {
		margin-top: 40px;
	}
}

/*___________________________
Container
___________________________*/
.container,
.singleColumn .columnHeadBanner .container {
	margin: 0 auto;
	max-width: 1080px;
}

.singleColumn .container {
	max-width: 1080px;
}

.download .container,
.model .container {
	padding-bottom: 40px;
	word-break: break-all;
}

.for-sp {
	display: none;
}

.for-pc {
	display: block;
}

@media screen and (max-width: 767px) {
	.for-sp {
		display: block;
	}

	.for-pc {
		display: none;
	}

	.download .container,
	.model .container {
		padding-inline: 16px;
	}
}

/*___________________________
Animation
___________________________*/

.js-fadeElement {
	opacity: 0;
	visibility: hidden;
}

/*___________________________
Link Buttons
___________________________*/

.whiteLink {
	align-items: center;
	border: 1px solid #fff;
	border-radius: 100px;
	color: #fff;
	display: flex;
	font-size: 14px;
	font-weight: 400;
	height: 48px;
	justify-content: center;
	letter-spacing: 0.1em;
	line-height: 1.4;
	margin: 0 auto;
	max-width: 350px;
	position: relative;
	width: calc(100% - 32px);
}

.whiteLink span {
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
	height: 6px;
	position: absolute;
	right: 26px;
	top: 50%;
	transform: translateY(-50%) rotate(-45deg);
	width: 6px;
}

.greyLink,
.walkLink,
.submitButton {
	align-items: center;
	background: #ececec;
	border: 1px solid #c9c9c9;
	border-radius: 100px;
	color: #424242;
	cursor: pointer;
	display: flex;
	font-size: var(--fontMax14Min12);
	font-weight: 400;
	height: 50px;
	justify-content: center;
	letter-spacing: 0.1em;
	line-height: 1.4;
	margin: 0 auto;
	max-width: 348px;
	position: relative;
	width: calc(100% - 32px);
}

.greyLink span,
.walkLink span {
	border-bottom: 1px solid #424242;
	border-right: 1px solid #424242;
	height: 7px;
	position: absolute;
	right: 26px;
	top: 50%;
	transform: translateY(-50%) rotate(-45deg);
	width: 7px;
}

.walkLink span {
	border-color: #fff;
}

.walkLink,
.submitButton {
	background: #424242;
}

.submitButton,
.walkLink {
	border: 1px solid #7c7c7c;
	gap: 12px;
}

.walkLink img {
	max-width: 13px;
}

.greyLink.leftArrow span {
	left: 26px;
	right: auto;
	transform: translateY(-50%) rotate(135deg);
}

.walkLink:has(font) {
	display: grid;
	grid-template-columns: 30px auto 30px;
}
.walkLink:has(font) p {
	font-size: 12px;
	text-align: center;
}
.walkLink:has(font) img {
	justify-self: center;
}

/* .shareLink {
  align-items: center;
  background: #ececec;
  border: 1px solid #c9c9c9;
  border-radius: 100px;
  cursor: pointer;
  display: flex;
  gap: 13px;
  height: 50px;
  justify-content: center;
  margin: 0 auto;
  max-width: 348px;
  position: relative;
  width: calc(100% - 32px);
} */

/* .shareLink p, */
.submitButton p {
	color: #424242;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 1.4;
}

.walkLink p,
.submitButton p {
	color: #fff;
}

/* .shareLink img, */
.submitButton img {
	max-width: 16px;
}

.shoppingLink {
	align-items: center;
	background: #ececec;
	border: 1px solid #c9c9c9;
	border-radius: 100px;
	cursor: pointer;
	display: flex;
	gap: 13px;
	height: 50px;
	justify-content: center;
	margin: 0 auto;
	max-width: 348px;
	position: relative;
	width: calc(100% - 32px);
	margin-top: 40px;
}

.shoppingLink p {
	color: #424242;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 1.4;
	text-align: center;
}

.shoppingLink img {
	max-width: 16px;
}

.shareLink__wrap {
	align-items: center;
	display: flex;
	margin: 70px auto 0;
	width: fit-content;
}

.shareLink__title {
	font-family: var(--familyInter);
	font-size: 24px;
	font-weight: 300;
	letter-spacing: 0.05em;
	padding-right: 40px;
	position: relative;
}

.shareLink__title::after {
	background: #ababab;
	content: "";
	height: 40px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
}

.shareLink__column {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	padding-left: 40px;
}

button.shareLink__item {
	appearance: none;
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
}

.shareLink__item img {
	display: block;
	margin-inline: auto;
	width: 44px;
}

.shareLink__item p {
	font-family: var(--familyInter);
	font-size: 14px;
	letter-spacing: 0.05em;
	text-align: center;
}

.sharePopup {
	align-items: center;
	display: flex;
	height: 100vh;
	justify-content: center;
	left: 0;
	opacity: 0;
	position: fixed;
	top: 0;
	transition: all 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
	visibility: hidden;
	width: 100%;
	z-index: 1;
}

.sharePopup.active {
	opacity: 1;
	visibility: visible;
}

.sharePopup__bg {
	background: rgba(0, 0, 0, 0.16);
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}

.sharePopup__contents {
	align-items: center;
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 4px 7px rgba(0, 0, 0, 0.2);
	display: flex;
	flex-direction: column;
	gap: 16px;
	height: 116px;
	justify-content: center;
	max-width: 315px;
	width: 100%;
}

.sharePopup__icon {
	max-width: 32px;
}

.sharePopup__contents p {
	color: #424242;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 1.4;
}

.walkLink::after {
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
	content: "";
	height: 6px;
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%) rotate(-45deg);
	width: 6px;
}

.cartLink {
	align-items: center;
	background: #424242;
	border: 1px solid #7c7c7c;
	border-radius: 100px;
	display: flex;
	gap: 12px;
	height: 50px;
	justify-content: center;
	margin: 0 auto;
	max-width: 327px;
	position: relative;
}

.cartLink::after {
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
	content: "";
	height: 7px;
	position: absolute;
	right: 26px;
	top: 50%;
	transform: translateY(-50%) rotate(-45deg);
	width: 7px;
}

.cartLink img {
	max-width: 18px;
}

.cartLink p {
	color: #fff;
	font-family: var(--familyInter);
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 2;
}

@media screen and (max-width: 767px) {
	.shareLink__wrap {
		margin-bottom: 20px;
	}

	.shareLink__title {
		padding-right: 20px;
	}

	.shareLink__column {
		padding-left: 20px;
	}

	.shareLink__item p {
		font-size: 12px;
	}
}

/*___________________________
404
___________________________*/
.notFound__head {
	font-size: 24px;
	letter-spacing: 0.01em;
	line-height: 2;
	text-align: center;
}

.notFound__head span {
	display: inline-block;
}

.notFound__body {
	font-size: 16px;
	line-height: 2;
	margin-top: 40px;
	text-align: center;
}

.notFound__button a {
	color: #fff;
	margin-top: 50px;
}

@media screen and (max-width: 767px) {
	.notFound {
		padding-inline: 20px;
	}

	.notFound__head {
		font-size: 20px;
	}

	.notFound__body {
		text-align: left;
	}
}
