
.adidas-sis {
	width: 100%;
	overflow: hidden;
	font-family: source-han-sans-japanese, sans-serif;
}

.ftw-warp {
	max-width: 1200px;
	margin: 0 auto;
}


.schedule{
	text-align: center;
    margin: 20px 0 30px;
    color: #111;
    font-weight: 700;
    line-height: 1.8;
}

.schedule span{
    background: #fff;
    color: #63b1d8;
    display: inline-block;
    padding: 5px 10px;
    font-weight: bold;
    font-size: 21px;
}

.feature-navi{
    display: flex;
    max-width: 1200px;
    margin: 0 auto;
    justify-content: space-between;
}

.feature-navi .item{
    width: 48.5%;
}

.feature-navi .item a{
    font-family: "adineuePRO", 'Poppins', sans-serif;
    display: block;
    border: 1px solid #fff;
    color: #fff;
    padding: 10px;
    line-height: 1;
    font-size: 16px;
}

.feature-navi .item a:hover{
    background: #fff;
    color: #63b1d8;
}

.selection {
	padding: 80px 0;
}

.selec-ttl {
	font-size: 28px;
	text-align: center;
	font-weight: 600;
	margin: 0 0 40px 0;
}

.view-all {
	background: #646464;
	padding: 50px 0;
	font-size: 1rem;
}

.view-all .row {
	max-width: 960px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.other-btn {
	max-width: 570px;
	width: 47%;
}

.other-btn a {
	border: 1px solid #fff;
	padding: 15px 0;
	text-align: center;
	display: block;
	font-size: 1.28em;
	color: #fff;
	transition: .3s;
}

.other-btn .arrow:before,
.other-btn .arrow:after {
	background: #ffffff;
	right: 50px;
}

.arrow {
	position: relative;
}

.arrow:before,
.arrow:after {
	content: '';
	display: block;
	position: absolute;
	top: 48%;
	height: 1px;
	transition: .3s;
}

.arrow:before {
	width: 30px;
	transform: translate(30px, 0px);
}

.arrow:after {
	width: 10px;
	transform-origin: right center;
	transform: translate(30px, 0px) rotate(25deg);
}

.other-btn a:hover {
	background: #fff;
	color: #646464;
}

.other-btn a:hover::before,
.other-btn a:hover::after {
	background: #646464;
}


.adidas-fede2022_list {
	display: flex;
	flex-wrap: wrap;
	position: relative;
	justify-content: space-between;
	padding: 40px 0 20px;
	margin: 0 auto;
	max-width: 1200px;
	box-sizing: border-box;
}

.adidas-fede2022_list .item {
	margin: 0 auto;
	width: 30%;
}

.adidas-fede2022_list .item a {
	display: block;
	border: 1px solid #fff;
	padding: 10px;
	font-size: 16px;
	color: #fff;
	box-sizing: border-box;
	font-weight: bold;
    transition: .3s;
}

.adidas-fede2022_list .item a:hover{
    background: #fff;
    color: #63b1d8;
}


/*------▼GALLERY01--------*/
.club1920_photoarea {
	padding: 20px 0 40px;
	max-width: 1200px;
	margin: 0 auto;
}

ul.club1920_photo {
	list-style-type: none;
	margin: 20px auto;
	padding: 0;
	position: relative;
	display: flex;
	flex-wrap: wrap;
}

ul.club1920_photo li {
	padding: 0;
	position: relative;
	width: 33.33%;
	overflow: hidden;
	height: auto;
}

ul.club1920_photo li img:hover {
	transform: scale(1.1, 1.1);
}


ul.club1920_photo li img {
	width: 100%;
	display: block;
	transition: 0.5s;
}

.reprica-list_home {
	display: flex;
    flex-wrap: wrap;
    position: relative;
    justify-content: space-evenly;
    margin: 40px auto 80px;
    max-width: 450px;
    padding: 0px;
    background-color: #ffffff;
}

.reprica-list {
	display: flex;
	flex-wrap: wrap;
	position: relative;
	justify-content: space-evenly;
	margin: 0 auto;
	max-width: 1200px;
	padding: 80px 0;
	background-color: #ffffff;
}

.reprica-list div {
	/* width:36%; */
	background-color: #fff;
}

.fede-team-main {
	max-width: 1200px;
	margin: 0 auto 50px;
}



.catchArea {
	background: #63b1d8;
	padding: 100px 50px 50px 0;
}

.catchArea_germany {
	background: #333333;
	padding: 100px 50px 50px 0;
}

.catchArea_italy {
	background: #1860aa;
	padding: 100px 50px 50px 0;
}

.catchArea_spain {
	background: #ad272f;
	padding: 100px 50px 50px 0;
}

.catchArea_mexico {
	background: #0d6355;
	padding: 100px 50px 50px 0;
}

.catchArea_other {
	background: #121212;
	padding: 100px 50px 50px 0;
}

.catchArea_jamaica {
	background: #e3b400;
	padding: 100px 50px 50px 0;
}



.maintitle {
	font-family: "adineuePRO", 'Poppins', sans-serif;
	font-size: 4em;
	color: #fff;
	text-align: center;
	margin: 0 0 0;
    line-height: 1.2;
}

.maincatch {
	color: #fff;
	text-align: center;
	font-size: 15px;
	line-height: 1.6;
}

.spslideimg {
	display: none !important;
}

img.pcslideimg {
	display: block;
}

.fede-ttl span,
.ftw-warp .cate-ttl span {
	font-weight: normal;
}


.contents {
	text-align: center;
	background: #63b1d8;
}

.contents_germany {
	text-align: center;
	background: #333333;
}

.contents_italy {
	text-align: center;
	background: #1860aa;
}

.contents_spain {
	text-align: center;
	background: #ad272f;
}

.contents_mexico {
	text-align: center;
	background: #0d6355;
}

.contents_other {
	text-align: center;
	background: #121212;
}

.contents_jamaica {
	text-align: center;
	background: #e3b400;
}

.contents .fede-ttl {
	font-family: "adineuePRO", 'Poppins', sans-serif;
	font-size: 3.6em;
	text-align: center;
	line-height: 1.2;
	margin: 0 0 40px 0;
	color: #fff;
}

.contents .fede-ttl span {
	font-size: 14px;
	font-weight: bold;
	display: block;
}

.view-all {
	background: #333333 !important;
	padding: 30px 0;
	margin: 0 auto;
}

.view-all .view-all-btn a:hover {
	background: #fff !important;
	border: 1px solid #333333 !important;
	color: #333333 !important;
}

.view-all .view-all-btn a {
	border: 1px solid #fff !important;
	padding: 15px 0;
	text-align: center;
	display: block;
	font-size: 1.4em;
	color: #fff;
	transition: .3s;
}

.view-all .view-all-btn .arrow:before,
.view-all .view-all-btn .arrow:after {
	content: '';
	display: block;
	position: absolute;
	top: 48%;
	height: 2px;
	transition: .3s;
	background: #ffffff;
	right: 40px;
}

.view-all .view-all-btn .arrow:before {
	width: 14px;
	transform: translate(20px, 0px) rotate(315deg);
	transform-origin: right center;
}

.view-all .view-all-btn .arrow:after {
	width: 14px;
	transform-origin: right center;
	transform: translate(20px, 0px) rotate(45deg);
}

.view-all .view-all-btn .arrow:hover:before,
.view-all .view-all-btn .arrow:hover:after {
	background: #333333;
}



/*購入はこちら*/
/*ホームレプリカ用*/
/*黒ボタン*/
.buybtn a {
	position: relative;
	display: block;
	max-width: 400px;
	padding: 16px 20px;
	box-sizing: border-box;
	margin: 20px auto 30px;
	font-size: 16px;
	line-height: 1;
	transition: .3s;
	background-color: #121212;
	color: #ffffff;
	text-align: center;
	border: solid 1px #121212;
}

.buybtn a::after {
	content: "";
	position: absolute;
	right: 20px;
	width: 5px;
	height: 5px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.buybtn a:hover {
	background: #fff;
	color: #121212;
}

.buybtn a:hover::after {
	border-top: 1px solid #121212;
	border-right: 1px solid #121212;
}

/*//黒ボタン*/

.buybtn_big a {
	position: relative;
	display: block;
	max-width: 400px;
	padding: 16px 20px;
	box-sizing: border-box;
	margin: 20px auto 30px;
	font-size: 18px;
	line-height: 1;
	transition: .3s;
	background-color: #121212;
	color: #ffffff;
	text-align: center;
	border: solid 1px #121212;
}

.buybtn_big a::after {
	content: "";
	position: absolute;
	right: 20px;
	width: 5px;
	height: 5px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.buybtn_big a:hover {
	background: #fff;
	color: #121212;
}

.buybtn_big a:hover::after {
	border-top: 1px solid #121212;
	border-right: 1px solid #121212;
}


.hr_itemimg, .hr_itemimg2 {
	margin-bottom: 20px;
}

.hr_name, .hr_name2 {
	margin-bottom: 10px;
	font-weight: normal;
	font-size: 16px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
}

.hr_name3 span, .i-name span {
	display: block;
	background-color: #4fffa1;
	padding: 5px;
	font-size: 0.9em;
	margin-right: 5px;
    color: #121212;
	max-width: 60%;
	margin: 10px auto;
    font-weight: bold;
}

.hr_price, .hr_price2 {
	margin-bottom: 20px;
	font-size: 22px;
	line-height: 1.2em;
	letter-spacing: 0.02em;
}

.hr_name3 {
	margin-bottom: 20px;
	font-weight: 500;
	font-size: 18px;
	line-height: 1.5;
	letter-spacing: 0.02em;
	color: #000000;
}

.hr_price3 {
	margin-bottom: 30px;
	font-size: 14px;
	line-height: 1.2em;
	letter-spacing: 0.02em;
	color: #000000;
}

.hr_price3 span {
	font-size: 60%;
}

.hr_sale {
	margin-bottom: 20px;
	font-size: 22px;
	line-height: 1.2em;
	letter-spacing: 0.02em;
	color: #FF0004;
}



.fede-bx {
	padding: 30px 0 0 0;
    border-top: 3px solid #fff;
	margin-top:40px;
}


/*　ピックアップ商品　*/

.other .selection {
	padding: 0 0 80px;
}

.selection {
	padding: 80px 0;
}

.selection .ftw-warp {
	max-width: 1200px;
	margin: 0 auto;
	background: #fff;
	padding: 80px 0 60px;
}

.cate-ttl {
	font-family: "adineuePRO", 'Poppins', sans-serif;
	font-size: 2.875em;
	text-align: center;
	line-height: 1.2;
	margin: 0 0 60px 0;
}

.cate-ttl span {
	font-size: 14px;
	display: block;
}

.chart_unit {
	position: relative;
	width: 100%;
	max-width: 1200px;
	/*padding-top: 40px;*/
	box-sizing: border-box;
}

/*　//ピックアップ商品　*/



/*スクロールダウン全体の場所*/
.scrolldown2 {
	/*描画位置※位置は適宜調整してください*/
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
    z-index: 5;
}

/*Scrollテキストの描写*/
.scrolldown2 span {
	/*描画位置*/
	position: absolute;
	left: -35px;
	bottom: 10px;
	/*テキストの形状*/
	color: #8f8f8f;
	font-size: 1rem;
	letter-spacing: 0.05em;
	font-family: "adineuePRO", 'Poppins', sans-serif;
}

/* 丸の描写 */
.scrolldown2:before {
	content: "";
	/*描画位置*/
	position: absolute;
	bottom: -4px;
	left: 0;
	/*丸の形状*/
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #8f8f8f;
	/*丸の動き1.6秒かけて透過し、永遠にループ*/
	animation:
		circlemove 2.6s ease-in-out infinite,
		cirlemovehide 2.6s ease-out infinite;
}


.maincatch span{
	font-size:20px;
	margin-bottom:15px;
	display:block;
}

.italia-awey_coming-txt{
    font-size: 30px;
    color: #fff;
    padding-bottom: 100px;
    letter-spacing: 3px;
    margin-top: -15px;
}

.italia-awey_coming-txt span{
    display:block;
	font-size:18px;
	margin-top:5px;
}


/*下からの距離が変化して丸の全体が上から下に動く*/
@keyframes circlemove {
	0% {
		left: 90px;
	}

	100% {
		left: -90px;
	}
}

/*上から下にかけて丸が透過→不透明→透過する*/
@keyframes cirlemovehide {
	0% {
		opacity: 0
	}

	50% {
		opacity: 1;
	}

	80% {
		opacity: 0.9;
	}

	100% {
		opacity: 0;
	}
}

/* 線の描写 */
.scrolldown2:after {
	content: "";
	/*描画位置*/
	position: absolute;
	bottom: 0;
	left: -90px;
	/*線の形状*/
	width: 180px;
	height: 2px;
	background: #8f8f8f;
}


.of-bx>.scrolldown2 {
	/*SPのみ*/
	display: none;
}

.chart_list {
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	padding: 0 0 20px;
}

.chart_list .item {
	width: 28%;
	max-width: 400px;
	margin: auto auto 60px auto;
}

.other .chart_list {
	padding: 0 20px 20px;
}

.other .chart_list .item {
	width: 30%;
	max-width: 400px;
	margin: auto auto 40px auto;
}

.chart_list .i-price {
	font-weight: bold;
	font-size: 22px;
	margin-bottom: 20px;
}

.chart_list .i-price span {
	font-size: 60%;
}


.chart_list .i-sale {
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 20px;
	color:#FF0004;
}

.chart_list .i-sale span {
	font-size: 60%;
}


.chart_list .c-model {
	position: relative;
}

.chart_list .c-model .ico-genre {
	position: absolute;
	top: 0;
	left: 0;
	color: #fff;
	font-weight: bold;
	display: inline-block;
	padding: 5px;
	line-height: 1;
}

.chart_list .c-model .kidtag {
	background: #019f4b;
}

.chart_list .c-model .womentag {
	background: #e2219c;
}

.footer .contlist01 ul li a, .footer .contlist02 ul li a{
	text-align:left;
}
.footer .f_navi h4{
	text-align:left;
}


/*----RWD----*/

.pc_none {
    display: none;
}


@media screen and (max-width:820px) {
	.ftw-warp {
		width: 85%;
	}

	.other_federation_list {
		justify-content: space-between;
		width: 94%;
		margin: 0 auto;
	}

	.other_federation_list li {
		width: 48%;
		margin: 0 0 60px 0;
	}

    .pc_none {
        display: block;
    }

}

@media screen and (max-width:768px) {

    .sp_none {
		display: none;
	}

	.club1920_photoarea {
		padding: 0;
	}

	ul.club1920_photo {
		margin: 0 0 45px;
		display: block;
		white-space: nowrap;
		/*    padding-left: 10px;*/
		overflow-x: auto;
	}

    ul.club1920_photo li {
		width: 30%;
		white-space: nowrap;
		display: inline-block;
	}

	.reprica-list div {
		width: 95%;
        margin: 0 auto 0px;
	}

    .feature-navi{
        margin: 0 10px;
    }

    .hr_name3 span, .i-name span{
        max-width: 80%;
    }


	.ftw-warp {
		width: 95%;
	}

	.chart_unit {
		overflow-x: auto;
		padding: 0;
	}

	.other .chart_list,
	.chart_list {
		white-space: nowrap;
		padding: 40px 0 20px 0;
		display: block;
	}

	.other .chart_list .item,
	.chart_list .item {
		width: 240px;
		display: inline-block;
	}

	.chart_list::-webkit-scrollbar {
		height: 5px;
	}

	.chart_list::-webkit-scrollbar-thumb {
		background-color: #cccccc;
		border-radius: 2.5px;
		padding-top: 40px;
	}


	.chart_unit .item:first-child {
		margin: 0 40px 0 20px;
	}

	.chart_unit .item {
		margin: 0 40px 0 0;
	}

    .catchArea,.catchArea_germany,.catchArea_italy,.catchArea_spain,.catchArea_mexico,.catchArea_other{
        padding: 60px 0 40px;
    }

    .maintitle{
        font-size: 3.4em;
    }

/*    .maincatch{
        text-align: left;
    }*/

	.pcslideimg {
		display: none !important;
	}

	.spslideimg {
		display: block !important;
	}

	.slide {
		width: 100% !important;
		margin: 0 auto;
	}

	.slide .item img {
		width: 100% !important;
	}


	.slide .slick-dots {
		bottom: 20px !important;
	}

	.slide .slick-dots li button:before {
		font-size: 20px !important;
	}

	.slide .item {
		width: 100% !important;
	}

	.slide-navi-bg {
		display: none !important;
	}

	.slick-dotted.slick-slider {
		margin-bottom: 0 !important;
	}

	/*---------------------------------------*/

	.view-all {
		padding: 30px 0;
	}

	.view-all .view-all-btn {
		padding: 0 20px;
	}

	.view-all .view-all-btn a {
		font-size: 14px;
		margin: 0 auto;
	}

	.view-all-btn .arrow:before,
	.view-all-btn .arrow:after {
		right: 80px;
	}

	.selection {
		padding: 0 0 6vh;
	}

	.fede-bx {
		padding: 5vh 0;
		margin-top: -5px;
	}


	.hr_itemimg {
		margin: 0 auto 20px;
		width: 100%;
	}

	.hr_price, .hr_price2, .hr_price3, .hr_sale {
		font-size: 18px;
	}


    .cate-ttl {
		font-size: 1.8rem;
	}

	.cate-ttl span {
		font-size: 12px;
	}

	.chart_list .i-name {
		font-size: 0.8rem;
		margin-bottom: 1vh;
	}

	.chart_list .i-price {
		font-size: 1rem;
		margin-bottom: 20px;
	}

	.chart_list .i-sale {
		font-size: 1rem;
		margin-bottom: 20px;
	}

	.chart_list .c-spec {
		margin-bottom: 1vh;
		font-size: 12px;
	}

	.chart_list .w-spec, .chart_list .m-spec {
		margin-bottom: 1vh;
		font-size: 12px;
	}

	.chart_list .j-spec {
		margin-bottom: 1vh;
		font-size: 12px;
	}

	.chart_unit .item .item-view a {
		padding: 13px 20px;
		font-size: 1em;
	}

	.other_federation {
		padding-top: 8%;
	}

	.of-bx {
		width: 90%;
		max-width: none;
		margin: 0 auto;
		position: relative;
	}

	.of-bx>.scrolldown2 {
		/*描画位置※位置は適宜調整してください*/
		position: absolute;
		top: 10px;
		left: 50%;
		margin: 0;
		display: block;
	}


	.hr_itemimg2 {
		margin: 0 auto 10px auto;
		width: none !important;
	}


	.hr_name2 {
		line-height: 1.6em;
		letter-spacing: 0.02em;
		font-size: 0.8rem;
		margin-bottom: 0.5vh;
	}

	.hr_price2 {
		margin-bottom: 20px;
		font-size: 1rem;
		line-height: 1.2em;
		letter-spacing: 0.02em;
	}
	
.maincatch span{
	font-size:16px;
	text-align:center;
	letter-spacing:0;
}

.italia-awey_coming-txt{
    font-size: 23px;
    letter-spacing: 0;
}

.italia-awey_coming-txt span{
    font-size: 13px;
}

.schedule span{
    font-size: 18px;
	letter-spacing:0;
}

}


@media screen and (max-width:480px) {

    ul.club1920_photo li {
        width: 80%;
    }
}









/*----スクロールアニメ----*/
:root {
	--animate-duration: 1s;
	--animate-delay: 1s;
	--animate-repeat: 1;
}

.wow {
	-webkit-animation-duration: 1s;
	animation-duration: 1s;
	-webkit-animation-duration: var(--animate-duration);
	animation-duration: var(--animate-duration);
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
}

@-webkit-keyframes slideInLeft {
	from {
		-webkit-transform: translate3d(-100%, 0, 0);
		transform: translate3d(-100%, 0, 0);
		visibility: visible;
	}

	to {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
}

@keyframes slideInLeft {
	from {
		-webkit-transform: translate3d(-100%, 0, 0);
		transform: translate3d(-100%, 0, 0);
		visibility: visible;
	}

	to {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
}

.slideInLeft {
	-webkit-animation-name: slideInLeft;
	animation-name: slideInLeft;
}

@-webkit-keyframes slideInRight {
	from {
		-webkit-transform: translate3d(100%, 0, 0);
		transform: translate3d(100%, 0, 0);
		visibility: visible;
	}

	to {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
}

@keyframes slideInRight {
	from {
		-webkit-transform: translate3d(100%, 0, 0);
		transform: translate3d(100%, 0, 0);
		visibility: visible;
	}

	to {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
}

.slideInRight {
	-webkit-animation-name: slideInRight;
	animation-name: slideInRight;
}

@-webkit-keyframes slideInUp {
	from {
		-webkit-transform: translate3d(0, 100%, 0);
		transform: translate3d(0, 100%, 0);
		visibility: visible;
	}

	to {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
}

@keyframes slideInUp {
	from {
		-webkit-transform: translate3d(0, 100%, 0);
		transform: translate3d(0, 100%, 0);
		visibility: visible;
	}

	to {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
}

.slideInUp {
	-webkit-animation-name: slideInUp;
	animation-name: slideInUp;
}

@-webkit-keyframes slideInDown {
	from {
		-webkit-transform: translate3d(0, -100%, 0);
		transform: translate3d(0, -100%, 0);
		visibility: visible;
	}

	to {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
}

@keyframes slideInDown {
	from {
		-webkit-transform: translate3d(0, -100%, 0);
		transform: translate3d(0, -100%, 0);
		visibility: visible;
	}

	to {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
}

.slideInDown {
	-webkit-animation-name: slideInDown;
	animation-name: slideInDown;
}

/*----//スクロールアニメ----*/


/* 251029追記 */

.country_jp{
	margin: 0 auto;
	text-align: center;
	font-size: 16px;
	color: #ffffff;
	margin-top: 10px;
}

.image-slider {
  width: auto;
  height: 500px;
  position: relative;
}

.slider-track {
  display: flex;
  width: max-content;
  animation: slide-loop 30s linear infinite;
}

.slider-track img {
  width: auto;
  height: 500px;
  object-fit: cover;
  flex-shrink: 0;
}

.image-slider:hover .slider-track {
  animation-play-state: paused;
}


@keyframes slide-loop {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.home_title,.home_title_germany,.home_title_germany,.home_title_italy,.home_title_spain,.home_title_mexico,.home_title_jamaica,.home_title_other{
	font-size: 38px;
	font-weight: bold;
	color: #000000;
	padding: 80px 0 0px;
	background-color: #ffffff;
	max-width: 1080px;
	margin: 0 auto;
	font-weight: bold;
}

.home_title p{
	font-size: 14px;
	color: #000000;
	background-color: #ffffff;
	max-width: 1200px;
	margin: 0 auto;
}

.home_title_germany p{
	font-size: 14px;
	color: #000000;
	background-color: #ffffff;
	max-width: 1200px;
	margin: 0 auto;
}

.home_title_italy p{
	font-size: 14px;
	color: #000000;
	background-color: #ffffff;
	max-width: 1200px;
	margin: 0 auto;
}

.home_title_spain p{
	font-size: 14px;
	color: #000000;
	background-color: #ffffff;
	max-width: 1200px;
	margin: 0 auto;
}

.home_title_jamaica p{
	font-size: 14px;
	color: #000000;
	background-color: #ffffff;
	max-width: 1200px;
	margin: 0 auto;
}

.home_title_mexico p{
	font-size: 14px;
	color: #000000;
	background-color: #ffffff;
	max-width: 1200px;
	margin: 0 auto;
}

.home_title_other p{
	font-size: 14px;
	color: #000000;
	background-color: #ffffff;
	max-width: 1200px;
	margin: 0 auto;
}


.adidas-italy_main {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  position: relative;
  overflow: hidden;
}

.adidas-italy_main img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* ===== SELECT ナビセクション ===== */

.bgcolor{
	background-color: #ffffff;
	padding:100px 0 0 0;
	max-width: 100%;
	margin: 0 auto;
}

.bgcolor_germany{
	background-color: #333333;
	padding:100px 0 0 0;
	max-width: 100%;
	margin: 0 auto;
}

.bgcolor_italy{
	background-color: #1860aa;
	padding:100px 0 0 0;
	max-width: 100%;
	margin: 0 auto;
}

.bgcolor_spain{
	background-color: #ad272f;
	padding:100px 0 0 0;
	max-width: 100%;
	margin: 0 auto;
}

.bgcolor_mexico{
	background-color: #0d6355;
	padding:100px 0 0 0;
	max-width: 100%;
	margin: 0 auto;
}

.bgcolor_other{
	background-color: #121212;
	padding:100px 0 0 0;
	max-width: 100%;
	margin: 0 auto;
}

.slect {
  background: #fff;
  padding: 40px 0;
  text-align: center;
}

.slecttitle {
  font-size: 28px;
  font-weight: 700;
  font-family: "adineuePRO", 'Poppins', sans-serif;
  margin-bottom: 40px;
  color: #111;
  background-color: #ffffff;
  margin-bottom: 30px;
}

.select-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr); /* PCでは3カラム */
  gap:20px 40px;;
  justify-content: center;
  max-width: 1000px;
  margin: 0 auto;
  list-style: none;
  padding: 0;
}

.select-grid li {
  background: #f9f9f9;
  border: 1px solid #000000;
  transition: all 0.3s ease;
}

.select-grid li a {
  display: block;
  padding: 15px 0px;
  font-size: 20px;
  font-weight: bold;
  font-family: "adineuePRO", 'Poppins', sans-serif;
  color: #000000;
  text-decoration: none;
}

.select-grid li a span {
  display: block;
  font-size: 13px;
  color: #000000;
}

.select-grid li:hover {
  background-color: #000;   /* 背景を黒に */
}

.select-grid li:hover a {
  color: #fff;              /* 文字を白に */
}

.select-grid li:hover a span {
  color: #fff;              /* サブテキストも白に */
}

/* --- SP（スマホ）--- */
@media screen and (max-width: 768px) {
  .select-grid {
    grid-template-columns: repeat(2, 1fr); /* 2カラム固定 */
    gap: 20px;
    justify-content: start; /* 左寄せ */
    max-width: 95%;
	margin-bottom: 0px;
  }

  .select-grid li a {
    padding: 15px 10px;
    font-size: 18px;
  }

  .country_jp {
	margin-top: 0	;
  }

  .buybtn a {
    position: relative;
    display: block;
    max-width: 400px;
    padding: 15px 10px;
    box-sizing: border-box;
    margin: 0px 10px 20px;
    font-size: 12px;
    line-height: 1;
    transition: .3s;
    background-color: #121212;
    color: #ffffff;
    text-align: center;
    border: solid 1px #121212;
}

.slect {
    background: #fff;
    padding: 50px 0 80px;
    text-align: center;
}

.home_title,.home_title_germany,.home_title_italy,.home_title_spain,.home_title_jamaica,.home_title_mexico,.home_title_other {
    padding: 0;
	font-size: 42px;
    font-weight: bold;
    color: #ffffff;
    max-width: 1080px;
    padding-left: 40px;
    padding-right: 40px;
    box-sizing: border-box;
    margin: 0 auto;
}

.home_title {
    background-color: #63b1d8;
}

.home_title_germany {
    background-color: #333333;
}

.home_title_italy {
    background-color: #1860aa;
}

.home_title_spain {
    background-color: #ad272f;
}

.home_title_mexico {
    background-color: #0d6355;
}

.home_title_jamaica {
    background-color: #e3b400;
}

.home_title_other {
    background-color: #121212;
}

.home_title p {
    font-size: 12px;
	font-weight: normal;
    color: #ffffff;
    background-color: #63b1d8;
    max-width: 100%;
    margin: 0 auto;
}


.home_title_germany p {
    font-size: 12px;
	font-weight: normal;
    color: #ffffff;
    background-color: #333333;
    max-width: 100%;
    margin: 0 auto;
}

.home_title_italy p {
    font-size: 12px;
	font-weight: normal;
    color: #ffffff;
    background-color: #1860aa;
    max-width: 100%;
    margin: 0 auto;
}

.home_title_spain p {
    font-size: 12px;
	font-weight: normal;
    color: #ffffff;
    background-color: #ad272f;
    max-width: 100%;
    margin: 0 auto;
}

.home_title_jamaica p {
    font-size: 12px;
	font-weight: normal;
    color: #ffffff;
    background-color: #e3b400;
    max-width: 100%;
    margin: 0 auto;
}

.home_title_mexico p {
    font-size: 12px;
	font-weight: normal;
    color: #ffffff;
    background-color: #0d6355;
    max-width: 100%;
    margin: 0 auto;
}

.home_title_other p {
    font-size: 12px;
	font-weight: normal;
    color: #ffffff;
    background-color: #121212;
    max-width: 100%;
    margin: 0 auto;
}

.select-grid li a span {
    font-size: 12px;
	font-family: normal;
}

.bgcolor,.bgcolor_germany,.bgcolor_italy,.bgcolor_spain,.bgcolor_mexico,.bgcolor_other{
	padding:0 0 0 0;
}

.buybtn_big a {
	position: relative;
	display: block;
	max-width: 400px;
	padding: 16px 20px;
	box-sizing: border-box;
	margin: 0px 10px 20px;
	font-size: 18px;
	line-height: 1;
	transition: .3s;
	background-color: #121212;
	color: #ffffff;
	text-align: center;
	border: solid 1px #121212;
}

}

   /* REPRICA LIST（共通レイアウト） */

.reprica-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 60px;
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 0 50px;
	background-color: #ffffff;
  }
  
  .reprica-list .home_reprica {
	width: 400px;
	background-color: #fff;
	box-sizing: border-box;
	padding: 20px 20px 0;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .reprica-list .home_reprica:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  }
  
  .reprica-list .hr_itemimg {
	margin-bottom: 10px;
  }
  
  .reprica-list .hr_name3 {
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 1.6;
	color: #000;
  }
  
  .reprica-list .hr_price3 {
	margin-bottom: 30px;
	font-size: 14px;
	color: #111;
  }

  @media screen and (max-width: 768px) {
	.reprica-list {
	  display: grid;
	  grid-template-columns: repeat(2, 1fr);
	  gap: 30px 10px;
	  justify-content: center;
	  max-width: 95%;
	  margin: 0 auto;
	  padding: 40px 0 60px;
	  background-color: var(--theme-color, #63b1d8);
	}
  
	.reprica-list .home_reprica {
	  width: 100%;
	  max-width: none;
	  background-color: #fff;
	  padding: 0;
	}
  
	.reprica-list .hr_name3 {
	  font-size: 12px;
	  padding: 0 10px;
	  margin-bottom: 15px;
	  line-height: 1.4;
	}
  
	.reprica-list .hr_price3 {
	  font-size: 13px;
	  margin-bottom: 20px;
	}
  }

  /* ドイツ */
  .reprica-list_germany {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 60px;
	max-width: 1200px;
	margin: 0 auto;
	padding: 60px 0 50px;
	background-color: #ffffff;
  }
  
  .reprica-list_germany .home_reprica {
	width: 400px;
	background-color: #fff;
	box-sizing: border-box;
	padding: 20px 20px 0;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .reprica-list_germany .home_reprica:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  }
  
  .reprica-list_germany .hr_itemimg {
	margin-bottom: 10px;
  }
  
  .reprica-list_germany .hr_name3 {
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 1.6;
	color: #000;
  }
  
  .reprica-list_germany .hr_price3 {
	margin-bottom: 30px;
	font-size: 14px;
	color: #111;
  }

  @media screen and (max-width: 768px) {
	.reprica-list_germany {
	  display: grid;
	  grid-template-columns: repeat(2, 1fr);
	  gap: 30px 10px;
	  justify-content: center;
	  max-width: 95%;
	  margin: 0 auto;
	  padding: 40px 0 60px;
	  background-color: var(--theme-color, #333333);
	}
  
	.reprica-list_germany .home_reprica {
	  width: 100%;
	  max-width: none;
	  background-color: #fff;
	  padding: 0;
	}
  
	.reprica-list_germany .hr_name3 {
	  font-size: 12px;
	  padding: 0 10px;
	  margin-bottom: 15px;
	  line-height: 1.4;
	}
  
	.reprica-list_germany .hr_price3 {
	  font-size: 13px;
	  margin-bottom: 20px;
	}

	.reprica-list_home {
	 width: 95%;
	}
  }

  /* イタリア */
  .reprica-list_italy {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 60px;
	max-width: 1200px;
	margin: 0 auto;
	padding: 60px 0 50px;
	background-color: #ffffff;
  }
  
  .reprica-list_italy .home_reprica {
	width: 400px;
	background-color: #fff;
	box-sizing: border-box;
	padding: 20px 20px 0;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .reprica-list_italy .home_reprica:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  }
  
  .reprica-list_italy .hr_itemimg {
	margin-bottom: 10px;
  }
  
  .reprica-list_italy .hr_name3 {
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 1.6;
	color: #000;
  }
  
  .reprica-list_italy .hr_price3 {
	margin-bottom: 30px;
	font-size: 14px;
	color: #111;
  }

  @media screen and (max-width: 768px) {
	.reprica-list_italy {
	  display: grid;
	  grid-template-columns: repeat(2, 1fr);
	  gap: 30px 10px;
	  justify-content: center;
	  max-width: 95%;
	  margin: 0 auto;
	  padding: 40px 0 60px;
	  background-color: var(--theme-color, #1860aa);
	}
  
	.reprica-list_italy .home_reprica {
	  width: 100%;
	  max-width: none;
	  background-color: #fff;
	  padding: 0;
	}
  
	.reprica-list_italy .hr_name3 {
	  font-size: 12px;
	  padding: 0 10px;
	  margin-bottom: 15px;
	  line-height: 1.4;
	}
  
	.reprica-list_italy .hr_price3 {
	  font-size: 13px;
	  margin-bottom: 20px;
	}

	.reprica-list_home {
	 width: 95%;
	}

.schedule{
	font-size:12px;
}

  }

  /* スペイン */
  .reprica-list_spain {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 60px;
	max-width: 1200px;
	margin: 0 auto;
	padding: 60px 0 50px;
	background-color: #ffffff;
  }
  
  .reprica-list_spain .home_reprica {
	width: 400px;
	background-color: #fff;
	box-sizing: border-box;
	padding: 20px 20px 0;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .reprica-list_spain .home_reprica:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  }
  
  .reprica-list_spain .hr_itemimg {
	margin-bottom: 10px;
  }
  
  .reprica-list_spain .hr_name3 {
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 1.6;
	color: #000;
  }
  
  .reprica-list_spain .hr_price3 {
	margin-bottom: 30px;
	font-size: 14px;
	color: #111;
  }

  @media screen and (max-width: 768px) {
	.reprica-list_spain {
	  display: grid;
	  grid-template-columns: repeat(2, 1fr);
	  gap: 30px 10px;
	  justify-content: center;
	  max-width: 95%;
	  margin: 0 auto;
	  padding: 40px 0 60px;
	  background-color: var(--theme-color, #ad272f);
	}
  
	.reprica-list_spain .home_reprica {
	  width: 100%;
	  max-width: none;
	  background-color: #fff;
	  padding: 0;
	}
  
	.reprica-list_spain .hr_name3 {
	  font-size: 12px;
	  padding: 0 10px;
	  margin-bottom: 15px;
	  line-height: 1.4;
	}
  
	.reprica-list_spain .hr_price3 {
	  font-size: 13px;
	  margin-bottom: 20px;
	}

	.reprica-list_home {
	 width: 95%;
	}
  }

    /* メキシコ */
	.reprica-list_mexico {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 60px;
		max-width: 1200px;
		margin: 0 auto;
		padding: 60px 0 50px;
		background-color: #ffffff;
	  }
	  
	  .reprica-list_mexico .home_reprica {
		width: 400px;
		background-color: #fff;
		box-sizing: border-box;
		padding: 20px 20px 0;
		transition: transform 0.3s ease, box-shadow 0.3s ease;
	  }
	  
	  .reprica-list_mexico .home_reprica:hover {
		transform: translateY(-4px);
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	  }
	  
	  .reprica-list_mexico .hr_itemimg {
		margin-bottom: 10px;
	  }
	  
	  .reprica-list_mexico .hr_name3 {
		margin-bottom: 20px;
		font-size: 16px;
		line-height: 1.6;
		color: #000;
	  }
	  
	  .reprica-list_mexico .hr_price3 {
		margin-bottom: 30px;
		font-size: 14px;
		color: #111;
	  }
	
	  @media screen and (max-width: 768px) {
		.reprica-list_mexico {
		  display: grid;
		  grid-template-columns: repeat(2, 1fr);
		  gap: 30px 10px;
		  justify-content: center;
		  max-width: 95%;
		  margin: 0 auto;
		  padding: 40px 0 60px;
		  background-color: var(--theme-color, #0d6355);
		}
	  
		.reprica-list_mexico .home_reprica {
		  width: 100%;
		  max-width: none;
		  background-color: #fff;
		  padding: 0;
		}
	  
		.reprica-list_mexico .hr_name3 {
		  font-size: 12px;
		  padding: 0 10px;
		  margin-bottom: 15px;
		  line-height: 1.4;
		}
	  
		.reprica-list_mexico .hr_price3 {
		  font-size: 13px;
		  margin-bottom: 20px;
		}
	
		.reprica-list_home {
		 width: 95%;
		}
	}
		

	     /* その他各国 */
	.reprica-list_other {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 60px;
		max-width: 1200px;
		margin: 0 auto;
		padding: 60px 0 50px;
		background-color: #ffffff;
	  }
	  
	  .reprica-list_other .home_reprica {
		width: 400px;
		background-color: #fff;
		box-sizing: border-box;
		padding: 20px 20px 0;
		transition: transform 0.3s ease, box-shadow 0.3s ease;
	  }
	  
	  .reprica-list_other .home_reprica:hover {
		transform: translateY(-4px);
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	  }
	  
	  .reprica-list_other .hr_itemimg {
		margin-bottom: 10px;
	  }
	  
	  .reprica-list_other .hr_name3 {
		margin-bottom: 20px;
		font-size: 16px;
		line-height: 1.6;
		color: #000;
	  }
	  
	  .reprica-list_other .hr_price3 {
		margin-bottom: 30px;
		font-size: 14px;
		color: #111;
	  }
	
	  @media screen and (max-width: 768px) {
		.reprica-list_other {
		  display: grid;
		  grid-template-columns: repeat(2, 1fr);
		  gap: 30px 10px;
		  justify-content: center;
		  max-width: 95%;
		  margin: 0 auto;
		  padding: 40px 0 60px;
		  background-color: var(--theme-color, #121212);
		}
	  
		.reprica-list_other .home_reprica {
		  width: 100%;
		  max-width: none;
		  background-color: #fff;
		  padding: 0;
		}
	  
		.reprica-list_other .hr_name3 {
		  font-size: 12px;
		  padding: 0 10px;
		  margin-bottom: 15px;
		  line-height: 1.4;
		}
	  
		.reprica-list_mexico .hr_price3 {
		  font-size: 13px;
		  margin-bottom: 20px;
		}
	
		.reprica-list_home {
		 width: 95%;
		}
	}

	/* ジャマイカ */

	.reprica-list_jamaica {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 60px;
		max-width: 1200px;
		margin: 0 auto;
		padding: 60px 0 50px;
		background-color: #ffffff;
	  }
	  
	  .reprica-list_jamaica .home_reprica {
		width: 400px;
		background-color: #fff;
		box-sizing: border-box;
		padding: 20px 20px 0;
		transition: transform 0.3s ease, box-shadow 0.3s ease;
	  }
	  
	  .reprica-list_jamaica .home_reprica:hover {
		transform: translateY(-4px);
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	  }
	  
	  .reprica-list_jamaica .hr_itemimg {
		margin-bottom: 10px;
	  }
	  
	  .reprica-list_jamaica .hr_name3 {
		margin-bottom: 20px;
		font-size: 16px;
		line-height: 1.6;
		color: #000;
	  }
	  
.reprica-list_jamaica .hr_price3 {
		margin-bottom: 30px;
		font-size: 14px;
		color: #111;
	  }

@media screen and (min-width: 769px) {
	.reprica-list,
	.reprica-list_germany,
	.reprica-list_italy,
	.reprica-list_spain,
	.reprica-list_mexico,
	.reprica-list_other,
	.reprica-list_jamaica {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 60px 24px;
		max-width: 1080px;
	}

	.reprica-list .home_reprica,
	.reprica-list_germany .home_reprica,
	.reprica-list_italy .home_reprica,
	.reprica-list_spain .home_reprica,
	.reprica-list_mexico .home_reprica,
	.reprica-list_other .home_reprica,
	.reprica-list_jamaica .home_reprica {
		width: 320px;
		max-width: none;
	}
}
	
	  @media screen and (max-width: 768px) {
		.reprica-list_jamaica {
		  display: grid;
		  grid-template-columns: repeat(2, 1fr);
		  gap: 30px 10px;
		  justify-content: center;
		  max-width: 95%;
		  margin: 0 auto;
		  padding: 40px 0 60px;
		  background-color: var(--theme-color, #e3b400);
		}
	  
		.reprica-list_jamaica .home_reprica {
		  width: 100%;
		  max-width: none;
		  background-color: #fff;
		  padding: 0;
		}
	  
		.reprica-list_jamaica .hr_name3 {
		  font-size: 12px;
		  padding: 0 10px;
		  margin-bottom: 15px;
		  line-height: 1.4;
		}
	  
		.reprica-list_mexico .hr_price3 {
		  font-size: 13px;
		  margin-bottom: 20px;
		}
	
		.reprica-list_home {
		 width: 95%;
		}
	}

	/* =============================
   固定ナビ（PC）
============================= */
.side-nav {
	position: fixed;
	top: 50%;
	left: 20px;
	transform: translateY(-50%);
	z-index: 9999;
  }
  .side-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
  }
  .side-nav li {
	margin-bottom: 10px;
  }
  .side-nav a {
	display: flex;
	align-items: center;
	gap: 8px;
	color: #fff;
	font-size: 14px;
	font-weight: bold;
	padding: 6px 10px;
	border-radius: 4px;
	text-decoration: none;
	transition: background 0.3s;
  }
  .side-nav a:hover {
	color: #000000;
  }
  .side-nav img {
	width: 28px;
	height: 28px;
	border-radius: 3px;
  }
  
  /* =============================
	 SPナビ
  ============================= */
  .sp-nav-tab {
	position: fixed;
	bottom: 488px;
	right: 20px;
	background: #63b1d8;
	color: #fff;
	padding: 10px 16px;
	border-radius: 50px;
	font-weight: bold;
	cursor: pointer;
	z-index: 10000;
  }
  .sp-nav-menu {
	display: none;
	position: fixed;
	top: 0;
	right: 0;
	width: 80%;
	height: 100vh;
	background: #fff;
	z-index: 10001;
	overflow-y: auto;
	box-shadow: -2px 0 10px rgba(0,0,0,0.3);
  }
  .sp-nav-menu.active {
	display: block;
  }
  .sp-nav-menu ul {
	list-style: none;
	padding: 80px 20px;
  }
  .sp-nav-menu li {
	margin-bottom: 20px;
  }
  .sp-nav-menu a {
	color: #111;
	text-decoration: none;
	font-size: 18px;
	font-weight: bold;
	display: flex;
	align-items: center;
	gap: 10px;
  }
  .sp-nav-close {
	position: absolute;
	top: 15px;
	right: 20px;
	font-size: 28px;
	cursor: pointer;
  }
  @media screen and (max-width: 768px) {
	.side-nav {
	  display: none;
	}
  }

  /* ========== 固定ナビ（PC版）indexと同デザイン ========== */
.side-nav {
	position: fixed;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	z-index: 1000;
	background: #fff;
	padding: 20px 10px 15px 10px;
	box-shadow: 2px 2px 6px rgba(0,0,0,0.1);
  }
  .side-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
  }
  .side-nav li {
	margin-bottom: 8px;
  }
  .side-nav a {
	display: flex;
	align-items: center;
	font-size: 13px;
	font-weight: 500;
	color: #999999;
	text-decoration: none;
	letter-spacing: 0.05em;
	transition: 0.3s;
  }
  .side-nav a:hover {
	opacity: 0.7;
  }
  .side-nav img {
	width: 26px;
	height: 26px;
	margin-right: 6px;
  }
  
  /* ========== SPナビ ========== */
  .sp-nav-tab {
	position: fixed;
    right: 0;
    transform: translateY(100%);
    background: #000;
    color: #fff;
    padding: 35px 12px;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-weight: bold;
    letter-spacing: 0.1em;
    border-radius: 6px 0 0 6px;
    cursor: pointer;
    z-index: 1001;
  }
  .sp-nav-menu {
	display: none;
    position: fixed;
    top: 10%;
    right: 0px;
    width: 52%;
    height: 52vh;
    background: #fff;
    z-index: 999;
    padding-top: 70px;
    overflow-y: auto;
  }
  .sp-nav-menu.active {
	display: block;
  }
  .sp-nav-close {
	position: absolute;
	top: 12px;
	right: 15px;
	font-size: 26px;
	font-weight: bold;
	cursor: pointer;
  }
  .sp-nav-menu ul {
	list-style: none;
	padding: 0 20px;
  }
  .sp-nav-menu li {
	margin-bottom: 20px;
  }
  .sp-nav-menu a {
	display: flex;
	align-items: center;
	gap: 8px;
	color: #111;
	font-size: 15px;
	font-weight: bold;
	text-decoration: none;
  }
  .sp-nav-menu a img {
	width: 32px;
	height: 32px;
  }

  /* ナビの表示・非表示アニメーション */
.side-nav,
.sp-nav-tab {
  transition: opacity 0.4s ease;
}

.pcnone{
	display: none;
  }
/* PCではSPナビ非表示 */
@media screen and (min-width: 769px) {
  .sp-nav-tab {
    display: none;
  }
}

/* SPではPCナビ非表示 */
@media screen and (max-width: 768px) {
  .side-nav {
    display: none;
  }
  .pcnone{
	display: block;
  }
}

.side-nav,
.sp-nav-tab {
  transition: opacity 0.4s ease;
}

.image-slider {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.slider-track {
  display: flex;
  gap: 0;
  will-change: transform;
}

.slider-track img {
  width: auto;
  height: 500px;
  object-fit: cover;
  flex-shrink: 0;
}
/* JS制御に切り替えるためCSSアニメを無効化 */
.slider-track {
  animation: none !important;
}



/* ▼ 商品タグ（KIDS・WOMEN） */
.home_reprica {
  position: relative;
}

.home_reprica .tag {
  position: absolute;
  top: 10px;
  left: 10px;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  padding: 4px 8px;
  z-index: 3;
  letter-spacing: 0.5px;
}

.home_reprica .tag.kids {
  background-color: #e09900;
}

.home_reprica .tag.women {
  background-color: #e4007f;
}

/* SP調整 */
@media screen and (max-width: 768px) {
  .home_reprica .tag {
    font-size: 10px;
    top: 0;
    left: 0;
    padding: 3px 6px;
  }
}

.side-nav span{
	font-size: 12px;
}

@media screen and (max-width: 768px) {

.sp-nav-menu span{
  font-size: 12px;
}
}



.kv-wrap { position: relative; width: 100%; overflow: hidden; }
.kv-slider { width: 100%; margin: 0 auto; box-sizing: border-box; }
.kv-slider > div { display: block; width: 100%; }
.kv-slider img { width: 100%; height: auto; display: block; object-fit: cover; }

.pc-only { display: block !important; }
.sp-only { display: none !important; }
@media screen and (max-width: 768px) {
  .pc-only { display: none !important; }
  .sp-only { display: block !important; }
}

.slick-slide { display: block; }
.slick-list, .slick-track { box-sizing: border-box; }

.kv-wrap {
  line-height: 0;
  overflow: hidden;
}

.kv-slider {
  margin-bottom: 0 !important;
}

.kv-slider img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: bottom; 
}

.titletxt{
	font-size: 40px;
	font-weight: bold;
	text-align: center;
	color: white;
}


.japan-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 1200px;
  margin: 20px auto 80px;
}

.japan-header {
  max-width: 1200px;
  text-align: center;
}

.japan-header .japan-title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 38px;
  font-weight: bold;
  margin: 0 auto 40px;
}

.japan-title .tag-year {
  background: #000274;
  color: #fff;
  padding: 5px 15px;
  font-size: 24px;
}

.japan-photos {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 10px;
  max-width: 1200px;
}

.japan-photos img {
  max-width: 100%;
  width: 1200px;
  height: auto;
  display: block;
  margin: 0 auto;
}

.japan-link {
  text-align: center;
}

.japan-section p{
 font-size: 18px;
 font-weight: 700;
 margin: 30px auto;
 
 line-height: 1.5;
 letter-spacing: 1.5px;
}

.btn-japan {
  display: inline-block;
  background-color: #000;
  border: 1px solid #121212;
  color: #fff;
  padding: 18px 40px;
  text-decoration: none;
  font-weight: 700;
  border-radius: 2px;
  font-size: 16px;
  transition: 0.3s;
}

.btn-japan:hover {
  background-color: #121212;
  border: 1px solid #121212;
  background-color: #fff;
  color: #121212;
}

.goodbg{
	margin-bottom: 120px;
}

.away-section {
	background: #63b1d8;
	padding: 0 0 80px;
}

.away-section_germany {
	background: #333333;
}

.away-section_italy {
	background: #1860aa;
}

.away-section_spain {
	background: #ad272f;
}

.away-section_mexico {
	background: #0d6355;
}

.away-section_jamaica {
	background: #e3b400;
}

.away-section_other {
	background: #121212;
}

.away-kv,
.away-gallery {
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}


.away-kv-image {
	display: block;
	width: 100%;
	height: auto;
}

.away-kv-image-sp {
	display: none;
}

.away-gallery {
	margin-top: 80px;
}

.away-image-slider {
	width: 100%;
	height: 500px;
}

.away-content {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 0 20px;
}

.away-content .home_title,
.away-content .goods_title,
.away-content .reprica-list {
	background: #ffffff;
}


@media screen and (max-width: 768px) {
.titletxt{
	font-size: 34px;
}

.slider-track img {
  width: auto;
  height: 375px;
  object-fit: cover;
  flex-shrink: 0;
}

.image-slider {
  width: auto;
  height: 375px;
  position: relative;
}

.away-section {
	padding: 0 0 50px;
}

.away-image-slider {
	height: 375px;
}

.away-kv-image-pc {
	display: none;
}

.away-kv-image-sp {
	display: block;
}

.away-content {
	padding-bottom: 10px;
}

.japan-photos{
        padding: 0 ;
    }

.japan-section p {
      font-size: 18px;
      font-weight: 700;
      margin:20px 0 30px 0;
      letter-spacing: 1.2px;
      text-align: center;
  }

.japan-link {
      margin: 0;
  }

.japan-section {
    background-color: #fff;
    text-align: center;
    padding: 60px 0 0px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }


  .japan-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0 30px;
  }

.japan-title {
    display: block;
    text-align: center;
    font-size: 22px;
    line-height: 1.3;
  }

.japan-title .tag-year {
    display: block;
    margin: 0 0 10px;
    font-size: 18px;
    width: 60px;
  }

.japan-photos {
    order: 2;
    width: 100%;
    margin: 0 auto;
  }

.japan-section p {
    order: 3;
    font-size: 16px;
    line-height: 1.8;
    padding: 0px;
    font-weight: 500;
  }

.japan-link {
    order: 4;
    margin-top: 0px;
    padding-bottom: 30px;
  }

.btn-japan {
    display: inline-block;
    background: #121212;
    color: #fff;
    padding: 12px 25px;
    text-decoration: none;
    font-weight: bold;
  }

.japan-header .japan-title {
  display: block;
  padding: 5px 0;
  font-size: 36px;
  text-align: center;
  margin: 0 auto 0px;
}

.japan-header{
  margin-bottom: 20px;
}

.goodbg {
    margin-bottom: 10px;
}

.catchArea_jamaica {
    background: #e3b400;
    padding: 60px 0 40px;
}
}


.movie {
    max-width: 100%;
    background: #e3b400;
    margin: 80px 0 0;
}

@media screen and (max-width: 768px) {
.movie {
    background: #e3b400;
    padding: 0 0 0px;
	margin: 40px 0 0px;
}
.hacobune-unit-video-outline[data-v-2a6c6f09] {
    padding: 0 0;
}
}

.hacobune-app-container[data-v-84392b72] {
  background: transparent !important;
}

.hacobune-app-container[data-v-84392b72] * {
  background: transparent !important;
}

@media (max-width: 719px) {
    .hacobune-app-container[data-v-84392b72] {
        width: 100% !important;
    }
}

/* Federation shared nav */
.side-nav {
  position: fixed;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  z-index: 1000;
  width: 160px;
  background: rgba(0, 0, 0, 0.84);
  backdrop-filter: blur(12px);
  border-radius: 0 12px 12px 0;
  padding: 12px 8px 12px 10px;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.2);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.side-nav-title {
  margin: 0 0 10px !important;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
}

.side-nav ul,
.sp-nav-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.side-nav li {
  margin-bottom: 7px;
}

.side-nav a {
  display: flex;
  align-items: center;
  gap: 7px;
  margin: 0;
  padding: 6px 7px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  color: #000000;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: 0.03em;
  text-decoration: none;
  transition: background 0.3s, transform 0.3s, border-color 0.3s;
}

.side-nav a:hover {
  background: linear-gradient(180deg, #ffffff 0%, #f3f6fb 100%);
  border-color: rgba(29, 74, 162, 0.22);
  color: #111111;
  transform: translateX(2px) scale(1.02);
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.1);
}

.side-nav img {
  width: 24px;
  height: 24px;
  margin-right: 0;
  border-radius: 4px;
  object-fit: cover;
}

.side-nav p,
.sp-nav-menu p {
  margin: 0;
}

.side-nav span,
.sp-nav-menu span {
  display: inline-block;
  margin-top: 2px;
  font-size: 10px;
  letter-spacing: 0.04em;
}

.sp-nav-tab {
  position: fixed;
  right: 0;
  top: 30%;
  transform: translateY(-50%);
  background: #000;
  color: #fff;
  padding: 24px 10px 20px;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  border: 0;
  border-radius: 14px 0 0 14px;
  cursor: pointer;
  z-index: 1001;
  text-align: center;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.24);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
}

.side-nav.is-visible,
.sp-nav-tab.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.sp-nav-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: min(82vw, 320px);
  height: 100vh;
  background: #fff;
  z-index: 1003;
  padding: 20px 18px 28px;
  overflow-y: auto;
  box-shadow: -12px 0 30px rgba(0, 0, 0, 0.18);
  transform: translateX(100%);
  transition: transform 0.35s ease;
}

.sp-nav-menu.active {
  transform: translateX(0);
}

.sp-nav-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.42);
  z-index: 1002;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

.sp-nav-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

.sp-nav-menu-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid #d9d9d9;
}

.sp-nav-menu-title {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.18em;
}

.sp-nav-close {
  border: 0;
  background: transparent;
  color: inherit;
  font-size: 30px;
  line-height: 1;
  font-weight: 400;
  cursor: pointer;
}

.sp-nav-menu li {
  margin-bottom: 12px;
}

.sp-nav-menu a {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  padding: 10px 8px;
  border-bottom: 1px solid #ececec;
  color: #111;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  text-decoration: none;
}

.sp-nav-menu a img {
  width: 36px;
  height: 36px;
  border-radius: 6px;
  object-fit: cover;
}

.goods_title{
	font-size: 30px;
    font-weight: bold;
    color: #000000;
    padding: 40px 0 0px;
    background-color: #ffffff;
    max-width: 1080px;
    margin: 0 auto;
}

.goods_title p {
    font-size: 14px;
    color: #000000;
    background-color: #ffffff;
    max-width: 1200px;
    margin: 0 auto;
}

@media screen and (min-width: 769px) {
  .sp-nav-tab,
  .sp-nav-menu,
  .sp-nav-overlay {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  body.sp-nav-open {
    overflow: hidden;
  }

  body {
    --sp-section-color: #ffffff;
    --sp-section-text-color: #000000;
  }

  .away-content,
  .away-content .home_title,
  .away-content .goods_title,
  .away-content .reprica-list,
  .goods_title,
  .goods_title p,
  .home_title,
  .home_title p,
  .reprica-list {
    background-color: var(--sp-section-color) !important;
    color: var(--sp-section-text-color) !important;
  }
}

.section-mode-nav {
  width: 100%;
  margin: -5px auto 0;
  padding: 50px 0;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  background: #000;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 0;
  box-shadow: none;
}

.section-mode-label {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.18em;
}

.section-mode-head {
  width: min(1000px, 100%);
  margin: 0 auto 15px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding-top: 18px;
}

.section-mode-switch {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  width: min(1000px, 100%);
  margin: 0 auto;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%);
  border-radius: 999px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), inset 0 -1px 0 rgba(255, 255, 255, 0.04);
}

.section-mode-button {
  min-width: 0;
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  position: relative;
  overflow: hidden;
  min-height: 44px;
  padding: 9px 32px 10px 24px;
  border: 1px solid transparent;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.88);
  text-decoration: none;
  transition: background 0.28s ease, color 0.28s ease, box-shadow 0.28s ease, transform 0.28s ease, border-color 0.28s ease;
  opacity: 1;
  cursor: pointer;
}

.section-mode-button::before {
  content: none;
}

.section-mode-button::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 50%;
  width: 6px;
  height: 6px;
  margin-top: -4px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  background: transparent;
  opacity: 0.78;
  transform: rotate(45deg);
  transition: transform 0.28s ease, opacity 0.28s ease;
}

.section-mode-eyebrow,
.section-mode-name {
  position: relative;
  z-index: 1;
  text-align: center;
}

.section-mode-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1;
  color: rgba(255, 255, 255, 0.58);
}

.section-mode-name {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.16em;
  line-height: 1.1;
}

.section-mode-button:hover,
.section-mode-button:focus-visible {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.18);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.section-mode-button:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

.section-mode-button[href="#home-top"],
.section-mode-button[href="#away-top"] {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%);
}

.section-mode-button.is-current {
  background: linear-gradient(135deg, #ffffff 0%, #f7f7f7 48%, #eceff2 100%);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06);
}

.section-mode-button:not(.is-current) {
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.section-mode-button[href="#home-top"].is-current {
  color: #1c4fb6;
}

.section-mode-button[href="#away-top"].is-current {
  color: #eb2b2b;
}

.section-mode-button.is-current::after {
  opacity: 0.72;
}

.section-mode-button:hover .section-mode-eyebrow,
.section-mode-button:focus-visible .section-mode-eyebrow,
.section-mode-button.is-current .section-mode-eyebrow {
  color: rgba(255, 255, 255, 0.52);
}

.section-mode-button[href="#home-top"].is-current .section-mode-eyebrow {
  color: rgba(28, 79, 182, 0.52);
}

.section-mode-button[href="#away-top"].is-current .section-mode-eyebrow {
  color: rgba(182, 56, 70, 0.52);
}

.section-mode-button:hover::after,
.section-mode-button:focus-visible::after,
.section-mode-button.is-current::after {
  opacity: 1;
  transform: translateY(1px) rotate(45deg);
}

.section-mode-button:not(.is-current) span,
.section-mode-button:not(.is-current)::before {
  pointer-events: none;
}

@media screen and (min-width: 769px) and (max-width: 1024px) {
  .section-mode-nav {
    padding: 28px 0 34px;
  }

  .section-mode-head,
  .section-mode-switch {
    width: calc(100% - 48px);
  }

  .section-mode-label {
    font-size: 24px;
  }

  .section-mode-button {
    min-height: 52px;
    padding: 10px 34px 11px 24px;
  }

  .section-mode-eyebrow {
    font-size: 9px;
  }

  .section-mode-name {
    font-size: 16px;
  }
}

@media screen and (max-width: 768px) {
  .section-mode-nav {
    padding: 30px 0;
  }

  .section-mode-head {
    width: calc(100% - 30px);
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 12px;
    align-items: center;
    gap: 0;
    padding-top: 0;
  }

  .section-mode-label {
    font-size: 20px;
    letter-spacing: 0.14em;
  }

  .section-mode-switch {
    width: calc(100% - 30px);
    margin-left: auto;
    margin-right: auto;
    gap: 6px;
    padding: 5px;
  }

  .section-mode-button {
    min-height: 54px;
    padding: 9px 16px 11px 16px;
    gap: 3px;
    border-radius: 999px;
  }

  .section-mode-eyebrow {
    font-size: 10px;
    letter-spacing: 0.12em;
  }

  .section-mode-name {
    font-size: 16px;
    letter-spacing: 0.12em;
  }

  .section-mode-button::after {
    right: 13px;
    top: 50%;
    width: 5px;
    height: 5px;
    margin-top: -3px;
  }
}
/* Federation shared nav */
.side-nav {
  position: fixed;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
  z-index: 1000;
  width: 188px;
  max-height: calc(100vh - 140px);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(17, 17, 17, 0.08);
  border-radius: 20px;
  padding: 14px 10px 12px;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.14);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  overflow-y: auto;
  transition: opacity 0.3s ease, visibility 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}

.side-nav.is-away {
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(17, 17, 17, 0.08);
}

.side-nav-title {
  margin: 0 0 10px !important;
  color: #111111;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2em;
}

.side-nav-groups,
.sp-nav-groups {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.nav-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.nav-group-japan {
  padding: 10px;
  border-radius: 16px;
  background:
    linear-gradient(135deg, rgba(29, 74, 162, 0.12) 0%, rgba(255, 255, 255, 0.88) 48%, rgba(202, 34, 54, 0.12) 100%),
    #ffffff;
  border: 1px solid rgba(17, 17, 17, 0.08);
}

.side-nav.is-away .nav-group-japan,
.sp-nav-menu.is-away .nav-group-japan {
  background:
    linear-gradient(135deg, rgba(29, 74, 162, 0.12) 0%, rgba(255, 255, 255, 0.88) 48%, rgba(202, 34, 54, 0.12) 100%),
    #ffffff;
  border-color: rgba(17, 17, 17, 0.08);
}

.nav-group-federation {
  padding: 10px;
  border-radius: 16px;
  background: #f7f7f7;
  border: 1px solid rgba(17, 17, 17, 0.06);
}

.nav-group-title {
  margin: 0;
  color: #111111;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
}

.nav-group-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.nav-group-grid-japan {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nav-group-grid-federation {
  grid-template-columns: 1fr;
}

.side-nav ul {
  margin: 0;
  padding: 0;
}

.side-nav li {
  margin-bottom: 0;
}

.nav-card {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 600;
  color: #111111;
  text-decoration: none;
  letter-spacing: 0.03em;
  line-height: 1.25;
  min-height: 48px;
  padding: 9px 10px;
  border: 1px solid rgba(17, 17, 17, 0.08);
  border-radius: 12px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfbfb 100%);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.04);
  transition: background 0.22s ease, transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
  position: relative;
  overflow: hidden;
}

.nav-card::after {
  content: "";
  position: absolute;
  right: 10px;
  top: 50%;
  width: 6px;
  height: 6px;
  border-top: 1.5px solid currentColor;
  border-right: 1.5px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
  opacity: 0.45;
  transition: transform 0.22s ease, opacity 0.22s ease;
}

.nav-card:hover,
.nav-card:focus-visible {
  background: linear-gradient(180deg, #ffffff 0%, #f3f6fb 100%);
  border-color: rgba(29, 74, 162, 0.22);
  transform: translateX(2px) scale(1.02);
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.1);
}

.nav-card:focus-visible {
  outline: 2px solid #111111;
  outline-offset: 3px;
}

.nav-card:hover::after,
.nav-card:focus-visible::after {
  opacity: 0.9;
  transform: translateY(-50%) translateX(2px) rotate(45deg);
}

.nav-card-japan {
  flex-direction: column;
  justify-content: center;
  text-align: center;
  gap: 7px;
  min-height: 82px;
  padding: 10px 8px;
}

.nav-card-japan:hover,
.nav-card-japan:focus-visible {
  transform: translateY(-2px) scale(1.02);
}

.nav-card-japan::after {
  content: none;
}

.nav-card-japan p,
.nav-card-japan span {
  text-align: center;
}

.nav-card img {
  width: 30px;
  height: 30px;
  margin-right: 0;
  border-radius: 7px;
  object-fit: cover;
}

.nav-card span {
  color: rgba(17, 17, 17, 0.62);
}

.side-nav .nav-card-japan {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(246, 248, 251, 0.98) 100%);
}

.side-nav .nav-card-japan:hover,
.side-nav .nav-card-japan:focus-visible {
  border-color: rgba(29, 74, 162, 0.24);
  box-shadow: 0 12px 24px rgba(29, 74, 162, 0.1);
}

/* ========== SPナビ ========== */
.sp-nav-tab {
  position: fixed;
  right: 0;
  top: 30%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.96);
  color: #111111;
  padding: 20px 12px 16px;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-weight: bold;
  letter-spacing: 0.14em;
  border-radius: 18px 0 0 18px;
  border: 1px solid rgba(17, 17, 17, 0.08);
  cursor: pointer;
  z-index: 1001;
  text-align: center;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.16);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.22s ease, box-shadow 0.22s ease;
}

.sp-nav-tab::before {
  content: "";
  display: block;
  width: 20px;
  height: 2px;
  margin: 0 auto 10px;
  background: currentColor;
  box-shadow: 0 6px 0 currentColor, 0 12px 0 currentColor;
}

.side-nav.is-visible,
.sp-nav-tab.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.sp-nav-tab.is-visible {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sp-nav-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: min(82vw, 320px);
  height: 100vh;
  height: 100dvh;
  max-height: 100dvh;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 0.98);
  z-index: 1003;
  padding: 20px 18px 28px;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
  box-shadow: -12px 0 30px rgba(0, 0, 0, 0.18);
  transform: translateX(100%);
  transition: transform 0.35s ease;
}

.sp-nav-menu.active {
  transform: translateX(0);
}

.sp-nav-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.42);
  z-index: 1002;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

.sp-nav-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

.sp-nav-menu-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid #d9d9d9;
}

.sp-nav-menu-title {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.18em;
}

.sp-nav-close {
  border: 0;
  background: transparent;
  font-size: 30px;
  line-height: 1;
  font-weight: 400;
  cursor: pointer;
}

.sp-nav-menu ul {
  padding: 0;
}

.sp-nav-menu li {
  margin-bottom: 0;
}

.sp-nav-menu .nav-group {
  gap: 12px;
}

.sp-nav-menu .nav-group-japan {
  background:
    linear-gradient(135deg, rgba(29, 74, 162, 0.12) 0%, rgba(255, 255, 255, 0.88) 48%, rgba(202, 34, 54, 0.12) 100%),
    #ffffff;
  border-color: rgba(17, 17, 17, 0.08);
}

.sp-nav-menu .nav-group-federation {
  background: #f7f7f7;
  border-color: rgba(17, 17, 17, 0.06);
}

.sp-nav-menu .nav-group-title {
  color: #111111;
}

.sp-nav-menu .nav-group-grid-japan {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.sp-nav-menu .nav-card {
  color: #111;
  background: #ffffff;
  border-color: rgba(17, 17, 17, 0.08);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
}

.sp-nav-menu .nav-card:hover,
.sp-nav-menu .nav-card:focus-visible {
  background: #ffffff;
  border-color: rgba(17, 17, 17, 0.18);
}

.sp-nav-menu .nav-card-japan {
  min-height: 110px;
}

.sp-nav-menu .nav-card img {
  width: 42px;
  height: 42px;
}

.page-top-button {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 1004;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
  width: 72px;
  height: 72px;
  padding: 0;
  border: 1px solid rgba(60, 60, 60, 0.14);
  border-radius: 999px;
  background: rgba(116, 116, 116, 0.9);
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.18);
  color: #ffffff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  cursor: pointer;
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease, border-color 0.22s ease;
}

.page-top-button::before {
  content: "";
  width: 10px;
  height: 10px;
  margin-top: 4px;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
  transform: rotate(45deg);
}

.page-top-button.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.page-top-button:hover,
.page-top-button:focus-visible {
  background: rgba(92, 92, 92, 0.96);
  border-color: rgba(60, 60, 60, 0.22);
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.22);
}

.page-top-button:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}

.side-nav p,
.sp-nav-menu p {
  margin: 0;
}

@media screen and (min-width: 769px) {
  .sp-nav-tab {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    top: 12%;
    right: 25px;
    transform: none;
    min-width: 128px;
    height: 45px;
    box-sizing: border-box;
    justify-content: center;
    padding: 14px 28px;
    writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 0.12em;
    border-radius: 999px;
    border: 1px solid rgba(17, 17, 17, 0.08);
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(12px);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.14);
    pointer-events: auto;
  }

  .sp-nav-tab.is-visible {
    top: 12%;
    right: 25px;
    transform: none;
    min-width: 128px;
    height: 45px;
    padding: 14px 28px;
  }

  .sp-nav-tab::before {
    content: "";
    width: 16px;
    height: 2px;
    margin-bottom: 0;
    margin-right: 2px;
    padding: 0;
    border-radius: 0;
    background: currentColor;
    color: inherit;
    box-shadow: 0 6px 0 currentColor, 0 -6px 0 currentColor;
    flex: 0 0 auto;
  }

  .sp-nav-tab::after {
    content: "";
    width: 5px;
    height: 5px;
    border-top: 1.5px solid currentColor;
    border-right: 1.5px solid currentColor;
    transform: rotate(45deg);
    margin-top: -1px;
    opacity: 0.9;
  }

  .sp-nav-tab:hover,
  .sp-nav-tab:focus-visible {
    background: #ffffff;
    border-color: rgba(29, 74, 162, 0.22);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18);
    transform: translateY(-1px);
  }

  .sp-nav-tab:focus-visible {
    outline: 2px solid #111111;
    outline-offset: 3px;
  }

  .sp-nav-tab[aria-expanded="true"]::after {
    transform: rotate(135deg);
  }

  .sp-nav-menu {
    width: min(420px, 36vw);
    padding: 24px 20px 32px;
    background: rgba(255, 255, 255, 0.98);
    color: #111111;
    box-shadow: -16px 0 40px rgba(0, 0, 0, 0.16);
  }

  .sp-nav-menu-head {
    margin-bottom: 20px;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(17, 17, 17, 0.1);
  }

  .sp-nav-menu-title,
  .sp-nav-close {
    color: #111111;
  }

  .sp-nav-menu .nav-group-grid-federation {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .sp-nav-menu .nav-group-japan {
    background:
      linear-gradient(135deg, rgba(29, 74, 162, 0.12) 0%, rgba(255, 255, 255, 0.88) 48%, rgba(202, 34, 54, 0.12) 100%),
      #ffffff;
    border-color: rgba(17, 17, 17, 0.08);
  }

  .sp-nav-menu .nav-group-federation {
    background: #f7f7f7;
    border-color: rgba(17, 17, 17, 0.06);
  }

  .sp-nav-menu .nav-group-title,
  .sp-nav-menu .nav-card {
    color: #111111;
  }

  .sp-nav-menu .nav-card {
    gap: 12px;
    font-size: 13px;
    border-color: rgba(17, 17, 17, 0.08);
    background: #ffffff;
  }

  .sp-nav-menu .nav-card-japan {
    min-height: 104px;
  }

  .sp-nav-menu span {
    color: rgba(17, 17, 17, 0.62);
  }

  .sp-nav-overlay {
    background: rgba(0, 0, 0, 0.56);
  }
}

@media screen and (min-width: 1025px) and (max-width: 1366px) {
  .side-nav {
    display: none !important;
  }

  .sp-nav-tab,
  .sp-nav-menu,
  .sp-nav-overlay {
    display: block !important;
  }

  .sp-nav-tab {
    display: inline-flex !important;
  }
}

@media screen and (min-width: 1367px) {
  .side-nav {
    display: none !important;
  }

  .sp-nav-tab,
  .sp-nav-menu,
  .sp-nav-overlay {
    display: block !important;
  }

  .sp-nav-tab {
    display: inline-flex !important;
  }
}

@media screen and (max-width: 1024px) {
  .side-nav {
    display: none;
  }

  body.sp-nav-open {
    overflow: hidden;
  }
}

@media screen and (max-width: 768px) {
  .sp-nav-menu {
    width: min(84vw, 350px);
    height: 100vh;
    height: 100dvh;
    max-height: 100dvh;
    padding: 12px 12px calc(108px + env(safe-area-inset-bottom));
  }

  .sp-nav-menu-head {
    gap: 8px;
    margin-bottom: 12px;
    padding-bottom: 10px;
  }

  .sp-nav-menu-title {
    font-size: 12px;
    letter-spacing: 0.12em;
  }

  .sp-nav-close {
    font-size: 24px;
  }

  .sp-nav-menu .nav-group-japan,
  .sp-nav-menu .nav-group-federation {
    padding: 8px;
    border-radius: 12px;
  }

  .sp-nav-menu .nav-group {
    gap: 8px;
  }

  .sp-nav-menu .nav-group-title {
    font-size: 10px;
    letter-spacing: 0.1em;
  }

  .sp-nav-tab {
    top: 92px;
    bottom: auto;
    right: 0;
    transform: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    min-width: 110px;
    min-height: 56px;
    padding: 16px 12px;
    font-size: 17px;
    font-weight: 700;
    writing-mode: horizontal-tb;
    text-orientation: initial;
    line-height: 1;
    letter-spacing: 0.08em;
    border-radius: 20px 0 0 20px;
  }

  .page-top-button {
    right: 14px;
    bottom: 14px;
    width: 64px;
    height: 64px;
    gap: 5px;
    font-size: 9px;
    letter-spacing: 0.1em;
  }

  .sp-nav-tab::before {
    width: 16px;
    height: 2px;
    margin: 0 -4px 0 0;
    box-shadow: 0 5px 0 currentColor, 0 -5px 0 currentColor;
  }

  .sp-nav-menu .nav-group-grid-japan {
    gap: 6px;
  }

  .sp-nav-menu .nav-card {
    gap: 6px;
    font-size: 12px;
    min-height: 52px;
    padding: 8px 8px;
  }

  .sp-nav-menu .nav-card img {
    width: 30px;
    height: 30px;
  }

.sp-nav-menu .nav-card-japan {
  min-height: 74px;
  padding: 8px 6px;
  }
}

.home_reprica .hr_itemimg.is-fade-switch {
  position: relative;
  overflow: hidden;
}

.home_reprica .hr_itemimg.is-fade-switch img {
  display: block;
  width: 100%;
  height: auto;
  transition: opacity 0.35s ease;
}

.home_reprica .hr_itemimg.is-fade-switch .fade-switch-sub {
  position: absolute;
  inset: 0;
  opacity: 0;
}

.home_reprica:hover .hr_itemimg.is-fade-switch .fade-switch-main,
.home_reprica:focus-within .hr_itemimg.is-fade-switch .fade-switch-main {
  opacity: 0;
}

.home_reprica:hover .hr_itemimg.is-fade-switch .fade-switch-sub,
.home_reprica:focus-within .hr_itemimg.is-fade-switch .fade-switch-sub {
  opacity: 1;
}


        .section-mode-nav {
            width: 100%;
            margin: -5px auto 0;
            padding: 50px 0;
            box-sizing: border-box;
            position: relative;
            overflow: hidden;
            background: #000;
            border-top: 1px solid rgba(255, 255, 255, 0.08);
            border-bottom: 1px solid rgba(255, 255, 255, 0.08);
            border-radius: 0;
            box-shadow: none;
        }

        .section-mode-label {
            margin: 0;
            color: rgba(255, 255, 255, 0.92);
            font-size: 28px;
            font-weight: 700;
            letter-spacing: 0.18em;
        }

        .section-mode-head {
            width: min(1000px, 100%);
            margin: 0 auto 15px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 12px;
            padding-top: 18px;
        }

        .section-mode-switch {
            position: relative;
            z-index: 1;
            display: flex;
            align-items: center;
            gap: 8px;
            width: min(1000px, 100%);
            margin: 0 auto;
            padding: 6px;
            border: 1px solid rgba(255, 255, 255, 0.12);
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%);
            border-radius: 999px;
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), inset 0 -1px 0 rgba(255, 255, 255, 0.04);
        }

        .section-mode-button {
            min-width: 0;
            flex: 1 1 50%;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 2px;
            position: relative;
            overflow: hidden;
            min-height: 44px;
            padding: 9px 32px 10px 24px;
            border: 1px solid transparent;
            border-radius: 999px;
            color: rgba(255, 255, 255, 0.88);
            text-decoration: none;
            transition: background 0.28s ease, color 0.28s ease, box-shadow 0.28s ease, transform 0.28s ease, border-color 0.28s ease;
            opacity: 1;
            cursor: pointer;
        }

        .section-mode-button::before {
            content: none;
        }

        .section-mode-button::after {
            content: "";
            position: absolute;
            right: 18px;
            top: 50%;
            width: 6px;
            height: 6px;
            margin-top: -4px;
            border-right: 1.5px solid currentColor;
            border-bottom: 1.5px solid currentColor;
            background: transparent;
            opacity: 0.78;
            transform: rotate(45deg);
            transition: transform 0.28s ease, opacity 0.28s ease;
        }

        .section-mode-eyebrow,
        .section-mode-name {
            position: relative;
            z-index: 1;
            text-align: center;
        }

        .section-mode-eyebrow {
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.14em;
            line-height: 1;
            color: rgba(255, 255, 255, 0.58);
        }

        .section-mode-name {
            font-size: 18px;
            font-weight: 700;
            letter-spacing: 0.16em;
            line-height: 1.1;
        }

        .section-mode-button:hover,
        .section-mode-button:focus-visible {
            color: #ffffff;
            background: rgba(255, 255, 255, 0.14);
            border-color: rgba(255, 255, 255, 0.18);
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
        }

        .section-mode-button:focus-visible {
            outline: 2px solid #fff;
            outline-offset: 3px;
        }

        .section-mode-button[href="#home-top"],
        .section-mode-button[href="#away-top"] {
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%);
        }

        .section-mode-button.is-current {
            background: linear-gradient(135deg, #ffffff 0%, #f7f7f7 48%, #eceff2 100%);
            box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06);
        }

        .section-mode-button:not(.is-current) {
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.04);
        }

        .section-mode-button[href="#home-top"].is-current {
            color: #1c4fb6;
        }

        .section-mode-button[href="#away-top"].is-current {
            color: #eb2b2b;
        }

        .section-mode-button.is-current::after {
            opacity: 0.72;
        }

        .section-mode-button:hover .section-mode-eyebrow,
        .section-mode-button:focus-visible .section-mode-eyebrow,
        .section-mode-button.is-current .section-mode-eyebrow {
            color: rgba(255, 255, 255, 0.52);
        }

        .section-mode-button[href="#home-top"].is-current .section-mode-eyebrow {
            color: rgba(28, 79, 182, 0.52);
        }

        .section-mode-button[href="#away-top"].is-current .section-mode-eyebrow {
            color: rgba(182, 56, 70, 0.52);
        }

        .section-mode-button:hover::after,
        .section-mode-button:focus-visible::after,
        .section-mode-button.is-current::after {
            opacity: 1;
            transform: translateY(1px) rotate(45deg);
        }

        .section-mode-button:not(.is-current) span,
        .section-mode-button:not(.is-current)::before {
            pointer-events: none;
        }

        @media screen and (min-width: 769px) and (max-width: 1024px) {
            .section-mode-nav {
                padding: 28px 0 34px;
            }

            .section-mode-head,
            .section-mode-switch {
                width: calc(100% - 48px);
            }

            .section-mode-label {
                font-size: 24px;
            }

            .section-mode-button {
                min-height: 52px;
                padding: 10px 34px 11px 24px;
            }

            .section-mode-eyebrow {
                font-size: 9px;
            }

            .section-mode-name {
                font-size: 16px;
            }
        }

        @media screen and (max-width: 768px) {
            .section-mode-nav {
                padding: 30px 0;
            }

            .section-mode-head {
                width: calc(100% - 30px);
                margin-left: auto;
                margin-right: auto;
                margin-bottom: 12px;
                align-items: center;
                gap: 0;
                padding-top: 0;
            }

            .section-mode-label {
                font-size: 20px;
                letter-spacing: 0.14em;
            }

            .section-mode-switch {
                width: calc(100% - 30px);
                margin-left: auto;
                margin-right: auto;
                gap: 6px;
                padding: 5px;
            }

            .section-mode-button {
                min-height: 54px;
                padding: 9px 16px 11px 16px;
                gap: 3px;
                border-radius: 999px;
            }

            .section-mode-eyebrow {
                font-size: 10px;
                letter-spacing: 0.12em;
            }

            .section-mode-name {
                font-size: 16px;
                letter-spacing: 0.12em;
            }

            .section-mode-button::after {
                right: 13px;
                top: 50%;
                width: 5px;
                height: 5px;
                margin-top: -3px;
            }
        }

        .page-top-button {
            position: fixed;
            right: 25px;
            bottom: 25px;
            z-index: 1004;
            display: inline-flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            gap: 6px;
            width: 72px;
            height: 72px;
            padding: 0;
            border-radius: 999px;
            background: #ffffff;
            backdrop-filter: blur(12px);
            box-shadow: 0 14px 30px rgba(0, 0, 0, 0.18);
            color: #242424;
            font-size: 12px;
            font-weight: 700;
            letter-spacing: 0.12em;
            line-height: 1;
            opacity: 0;
            visibility: hidden;
            pointer-events: none;
            cursor: pointer;
            transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease, border-color 0.22s ease;
        }

        .page-top-button::before {
            content: "";
            width: 10px;
            height: 10px;
            margin-top: 4px;
            border-top: 2px solid currentColor;
            border-left: 2px solid currentColor;
            transform: rotate(45deg);
            color:#000000;
        }

        .page-top-button.is-visible {
            opacity: 1;
            visibility: visible;
            pointer-events: auto;
        }

        .page-top-button:hover,
        .page-top-button:focus-visible {
            background: rgba(92, 92, 92, 0.96);
            border-color: rgba(60, 60, 60, 0.22);
            transform: translateY(-2px);
            box-shadow: 0 18px 36px rgba(0, 0, 0, 0.22);
        }

        .page-top-button:focus-visible {
            outline: 2px solid #ffffff;
            outline-offset: 3px;
        }

        @media screen and (min-width: 1025px) and (max-width: 1366px) {
            .side-nav {
                display: none !important;
            }

            .sp-nav-tab,
            .sp-nav-menu,
            .sp-nav-overlay {
                display: block !important;
            }

            .sp-nav-tab {
                display: inline-flex !important;
            }
        }

        @media screen and (max-width: 768px) {
            .page-top-button {
                right: 14px;
                bottom: 14px;
                width: 64px;
                height: 64px;
                gap: 5px;
                font-size: 9px;
                letter-spacing: 0.1em;
            }
        }
