@charset "UTF-8";
html {
	font-size: 62.5%;
	scroll-behavior: smooth;
}
body {
	font-size: 1.4rem;
	font-family: 'Noto Sans JP', 'Hiragino Sans', 'ヒラギノ角ゴシック', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', 'Helvetica', 'メイリオ', 'Meiryo', 'ＭＳ ゴシック', 'MS PGothic', Osaka, sans-serif;
	background-color: #FFF;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	position: relative;
	font-feature-settings: "palt";
	letter-spacing: 1px;
	color: #1C1C1C;
}
*,
*::before,
*::after {
	box-sizing: border-box;
}
.clearfix::after {
	content: '';
	display: block;
	clear: both;
}
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary {
	display: block;
}
.flex {
	-js-display: flex;
	display: -webkit-box;
	display: -moz-box;
	display: -ms-box;
	display: -webkit-flexbox;
	display: -moz-flexbox;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-box-lines: multiple;
	-moz-box-lines: multiple;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.j-start {
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.j-between {
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.j-center {
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.j-around {
	-webkit-justify-content: space-around;
	-ms-flex-pack: justify;
	justify-content: space-around;
}
.j-end {
	-webkit-justify-content: flex-end;
	-ms-flex-pack: end;
	justify-content: flex-end;
}
.a-center {
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
}
.a-start {
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
}
.a-end {
	-webkit-align-items: flex-end;
	-ms-flex-align: end;
	align-items: flex-end;
}
.a-stretch {
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.ac-center {
	-webkit-align-content: center;
	-ms-flex-line-pack: center;
	align-content: center;
}
.ac-start {
	-webkit-align-content: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
}
.ac-space-between {
	-webkit-align-content: space-between;
	-ms-flex-line-pack: justify;
	align-content: space-between;
}
.ac-space-around {
	-webkit-align-content: space-around;
	-ms-flex-line-pack: justify;
	align-content: space-around;
}
.f-nowrap {
	-webkit-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
}
.w5 {
	width: 5%;
}
.w10 {
	width: 10%;
}
.w15 {
	width: 15%;
}
.w20 {
	width: 20%;
}
.w25 {
	width: 25%;
}
.w30 {
	width: 30%;
}
.w35 {
	width: 35%;
}
.w40 {
	width: 40%;
}
.w45 {
	width: 45%;
}
.w50 {
	width: 50%;
}
.w55 {
	width: 55%;
}
.w60 {
	width: 60%;
}
.w65 {
	width: 65%;
}
.w70 {
	width: 70%;
}
.w75 {
	width: 75%;
}
.w80 {
	width: 80%;
}
.w85 {
	width: 85%;
}
.w90 {
	width: 90%;
}
.w95 {
	width: 95%;
}
.w100 {
	width: 100%;
}
.red {
	color: red;
}
.pc {
	display: block;
}
.sp {
	display: none;
}
img {
	width: 100%;
	vertical-align: bottom;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}
div,
p,
section,
article {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
:root {
	--navy: #0C1B36;
	--navy2: #4B5971;
	--gray: #efefef;
	--white: #ffffff;
	--bg: #f2f2f2;
	--line: #d9dde4;
	--text: #0C1B36;
	--muted: #6b7789;
	--radius: 10px;
	--shadow: 0 10px 28px rgba(15, 33, 56, .08);
}
.wpw_c_white {
	color: var(--white);
}
.wpw_c_navy {
	color: var(--navy);
}
.wpw_section {
	margin: 0;
	padding: 5vw 0;
}
.wpw_title {
	margin: 0 auto 3em;
	padding: 0;
	width: 100%;
	height: 8vw;
	max-height: 150px;
}
.wpw_subcatch_works {
	display: none;
}
// -------------------------------------------------------------
// data-scroll
[data-scroll=in] .char:after {
	opacity: 1;
	transform: translateY(0);
}
[data-scroll] {
	opacity: 0;
	will-change: transform, scale, opacity;
	transform: translateY(6rem) scale(0.93);
	transition: all 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.splitting .char {
	color: transparent;
}
[data-scroll=in] {
	opacity: 1;
	transform: translateY(0) scale(1);
}
.splitting .char:after {
	visibility: visible;
	color: #204754;
	opacity: 0;
	transform: translateY(30%);
	transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	transition-delay: calc(.2s + (.04s * var(--char-index)));
}
/*----------------------------------

下部ナビゲーション

------------------------------------*/
/* ===== 下部追従ナビ（Dock） ===== */
.dockNav {
	position: fixed;
	left: 50%;
	bottom: calc(0px + env(safe-area-inset-bottom, 0px));
	transform: translateX(-50%) translateY(120%);
	/* 初期：下に隠す */
	opacity: 0;
	pointer-events: none;
	z-index: 9999;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
	padding: 0px;
	background: var(--navy);
	border: 1px solid rgba(255, 255, 255, .18);
	box-shadow: 0 16px 40px rgba(0, 0, 0, .22);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	transition: transform .28s cubic-bezier(.2, .9, .2, 1), opacity .22s ease;
}
/* 表示状態（にょきっ） */
.dockNav.is-show {
	transform: translateX(-50%) translateY(0);
	opacity: 1;
	pointer-events: auto;
}
.dockNav__item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 7px 12px;
	color: #fff;
	text-decoration: none;
	font-weight: 700;
	font-size: 1.2rem;
	letter-spacing: .04em;
	transition: transform .08s ease, background .15s ease, border-color .15s ease;
	white-space: nowrap;
}
.dockNav__item:hover {
	background: rgba(255, 255, 255, .10);
	border-color: rgba(255, 255, 255, .28);
}
.dockNav__item:active {
	transform: translateY(1px);
}
/* 動きが苦手な人には無効化 */
@media (prefers-reduced-motion: reduce) {
	.dockNav {
		transition: none !important;
		transform: translateX(-50%) translateY(0);
		opacity: 1;
	}
}
/*----------------------------------

トップビジュアル

------------------------------------*/
.wpw_sec_tv {
	position: relative;
	width: 100%;
	height: 56vw;
}
.hero__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .35);
}
.hero__video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
/* 読みやすさ用のうっすら暗幕（不要なら削除） */
.hero__overlay {
	position: absolute;
	inset: 0;
	background: radial-gradient(900px 500px at 50% 30%, rgba(0, 0, 0, .10), rgba(0, 0, 0, .15));
	pointer-events: none;
}
/* ====== ナビ（動画の上に重ねる） ====== */
.heroNav {
	position: absolute;
	left: 50%;
	top: 40vw;
	transform: translateX(-50%);
	width: 90%;
	max-width: 600px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
	z-index: 3;
	/* video/overlayより上 */
}
.heroNav__item {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-width: 160px;
	padding: 12px 14px;
	background: var(--navy);
	color: var(--white);
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	text-decoration: none;
	font-weight: 700;
	font-size: 11px;
	font-size: clamp(1.1rem, 1vw, 1.6rem);
	letter-spacing: .3em;
	box-shadow: var(--shadow);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	transition: transform .08s ease, background .18s ease, border-color .18s ease;
	user-select: none;
	white-space: nowrap;
}
.heroNav__item:hover {
	background: var(--navy2);
	opacity: 1;
}
.heroNav__item:active {
	transform: translateY(1px);
}
.heroNav__icon {
	width: 20px;
	height: 20px;
	display: inline-block;
	flex: 0 0 20px;
}
.hero__content {
	position: relative;
	z-index: 1;
	margin: 0 auto;
	padding: 0;
	width: 30%;
	top: 14vw;
}
.wpw_h1 {
	font-size: clamp(2rem, 3.3vw, 7rem);
	font-weight: 900;
	color: var(--white);
	text-align: center;
	margin: 0;
	line-height: 1.3;
}
.wpw_nav {
	margin: 0;
	padding: 0;
	width: 0;
	padding: 0;
	width: 40%;
	position: absolute;
	top: 35vw;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	z-index: 10;
}
.wpw_nav_wrap {
	margin: 1em 0.5em;
	padding: 0.5em;
	font-size: 1.2rem;
	font-weight: 500;
	letter-spacing: 1px;
	background-color: var(--navy);
	color: var(--white);
	width: 14em;
	text-align: center;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
}
.wpw_nav_wrap a {
	color: var(--white);
}
/*----------------------------------

トップビジュアルここまで

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

選ばれる理由ここから

------------------------------------*/
.wpw_sec_works {
	margin: 0;
	padding: 3em 0;
	width: 100%;
	background: var(--white);
}
.wpw_wrap_works {
	margin: 5% auto 0;
	padding: 0;
	width: 90%;
	max-width: 1000px;
}
.wpw_sec_works .wpw_title {
	background: url(../images/title_works.png) no-repeat top center;
	background-size: contain;
}
.wpw_art_works {
	margin: 0 0 7vw;
	padding: 0;
	width: 100%;
	position: relative;
}
.wpw_box_works01 {
	margin: 0 0 0;
	padding: 0;
	width: 50%;
	position: relative;
	z-index: 10;
}
.wpw_box_works01 img {
	position: relative;
	z-index: 10;
}
.wpw_art_works01 .wpw_box_works01::before {
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	background: var(--navy);
	position: absolute;
	top: -20px;
	left: -24px;
	z-index: 1;
}
.wpw_art_works02 .wpw_box_works01::before {
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	background: #884242;
	position: absolute;
	top: -20px;
	right: -24px;
	z-index: 1;
}
.wpw_art_works03 .wpw_box_works01::before {
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	background: #F2F2E7;
	position: absolute;
	top: -20px;
	left: -24px;
	z-index: 1;
}
.wpw_box_works02 {
	margin: 0 10%;
	padding: 0;
	width: 30%;
}
.wpw_works_num {
	margin: 0 auto 1em;
	padding: 0;
	width: 100%;
	border-bottom: solid 1px var(--navy);
}
.wpw_catch_works {
	margin: 0;
	padding: 0 0 0.3em;
	font-size: 4rem;
	font-size: clamp(2rem, 3vw, 4rem);
	font-weight: 500;
	line-height: 1.3;
	color: var(--navy);
	text-align: center;
	letter-spacing: 1px;
}
.wpw_read_works {
	margin: 0;
	padding: 0;
	font-size: 1.4rem;
	font-weight: 500;
	color: var(--navy);
	line-height: 1.8em;
}
/*----------------------------------

選ばれる理由ここまで

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

黄金のバランスここから

------------------------------------*/
.wpw_sec_PF {
	margin: 0;
	padding: 5vw 0;
	background: #E5E5E5;
}
.wpw_wrap_PF {
	margin: 0 auto;
	padding: 0;
	width: 90%;
	max-width: 700px;
	text-align: center;
}
.wpw_sec_PF .wpw_title {
	background: url(../images/title_perfectfit.png) no-repeat top center;
	background-size: contain;
}
.wpw_box_PF {
	margin: 0 0 5%;
	padding: 0;
	width: 100%;
	height: 100vw!important;
	background: url(../images/img_pf.jpg) no-repeat center center;
	background-size: contain;
	position: relative;
	max-height: 878px;
	min-height: 874px;
}
.wpw_text_pf {
	margin: 0;
	padding: 0;
	width: 25%;
	position: absolute;
}
.wpw_text_pf01 {
	top: 37%;
	left: 67%;
}
.wpw_text_pf02 {
	top: 50%;
	left: 9%;
}
.wpw_text_pf03 {
	top: 80%;
	left: 59%;
}
.wpw_cta02 {
	border: 1px solid rgba(255, 255, 255, .65);
	background: var(--navy);
	color: var(--white);
	padding: 0.5em 2em 0.8em 2em;
	border-radius: 999px;
	letter-spacing: .06em;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 5px;
	text-decoration: none;
	transition: transform .06s ease, opacity .18s ease;
}
/*----------------------------------

黄金のバランスここまで

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

サイズここから

------------------------------------*/
.wpw_sec_size {
	background: var(--navy);
}
.wpw_wrap_size {
	width: 90%;
	max-width: 780px;
	margin: 0 auto;
	padding: 0;
}
.wpw_sec_size .wpw_title {
	background: url(../images/title_size.png) no-repeat top center;
	background-size: contain;
}
.wpw_container_size {
	margin: 0 0 50px;
	padding: 0;
}
.sectionHead {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 18px;
}
.sectionHead .no {
	font-size: 12px;
	letter-spacing: .14em;
	opacity: .9;
	min-width: 100px;
	color: var(--white);
}
.sectionHead .hr {
	height: 1px;
	background: var(--line);
	flex: 1;
}
.btnGrid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
}
.pickBtn {
	appearance: none;
	border: 1px solid var(--line);
	background: transparent;
	color: var(--white);
	padding: 18px 14px;
	border-radius: 6px;
	cursor: pointer;
	letter-spacing: .08em;
	font-weight: 700;
	box-shadow: inset 0 0 0 0 rgba(255, 255, 255, 0);
	transition: background .18s ease, border-color .18s ease, transform .06s ease;
	user-select: none;
}
.pickBtn:hover {
	border-color: rgba(255, 255, 255, .35);
	background: rgba(255, 255, 255, .04);
}
.pickBtn:active {
	transform: translateY(1px);
}
.pickBtn.is-active {
	background: var(--white);
	color: #0a1d3a;
	border-color: rgba(255, 255, 255, .9);
}
.wpw_resultWrap {
	margin-top: 44px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
}
.wpw_resultCard {
	width: auto;
	border: 1px solid var(--line);
	background: var(--white);
	border-radius: 6px;
	padding: 1em 3em;
	box-shadow: var(--shadow);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.wpw_resultCard .wpw_left {
	font-size: 1.2rem;
	color: var(--navy);
	letter-spacing: .3em;
	line-height: 1.8;
	font-weight: 700;
}
.wpw_resultCard .wpw_size {
	font-size: 7rem;
	font-weight: 900;
	letter-spacing: .06em;
	color: var(--navy);
}
.wpw_cta {
	border: 1px solid rgba(255, 255, 255, .65);
	background: rgba(255, 255, 255, .92);
	color: #0a1d3a;
	padding: 0.5em 2em 0.8em 2em;
	border-radius: 999px;
	letter-spacing: .06em;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 5px;
	text-decoration: none;
	transition: transform .06s ease, opacity .18s ease;
}
.wpw_ctaText {
	font-size: 1.2rem;
	font-weight: 500;
}
.wpw_ctaText::after {
	font-family: 'Material Icons';
	content: "\e5cc";
	color: #5c5f82;
	position: relative;
	top: 3px;
	left: 1em;
	font-size: 1.5rem;
}
.wpw_cta:active {
	transform: translateY(1px);
}
.wpw_cta[aria-disabled="true"] {
	opacity: .55;
	pointer-events: none;
}
.wpw_cta .wpw_arrow {
	width: 18px;
	height: 18px;
	display: inline-grid;
	place-items: center center;
	font-size: 2rem;
}
.wpw_hint {
	color: rgba(255, 255, 255, .58);
	font-size: 12px;
	letter-spacing: .08em;
	text-align: center;
}
.wpw_txt_notice {
	margin: 0;
	padding: 0;
	font-size: 1rem;
	font-weight: 500;
	color: var(--white);
	text-align: center;
}
/*----------------------------------

サイズここまで

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

着こなしここから

------------------------------------*/
.wpw_sec_styling {
	background: #E5E5E5;
}
.wpw_wrap_styling {
	width: 90%;
	margin: 0 auto;
	padding: 0;
}
.wpw_sec_styling .wpw_title {
	background: url(../images/title_styling.png) no-repeat top center;
	background-size: contain;
}
.stylingSlider .slick-slide img {
	display: block;
	vertical-align: bottom;
}
.stylingSlider .slick-slide {
	line-height: 0;
}
/*----------------------------------

着こなしここまで

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

商品一覧ここから

------------------------------------*/
/* ===== 商品一覧セクション ===== */
.wpw_sec_item .wpw_title {
	background: url(../images/title_item.png) no-repeat top center;
	background-size: contain;
}
.wpw_wrap_item {
	width: 90%;
	max-width: 1200px;
	margin: 0 auto;
}
.sectionTitle {
	text-align: center;
	font-size: 20px;
	letter-spacing: .04em;
	margin: 0 0 12px;
	font-weight: 700;
}
.titleRule {
	width: 120px;
	height: 1px;
	background: var(--line);
	margin: 0 auto 18px;
}
/* ===== 絞り込み（カンプ風） ===== */
.filterBlock {
	display: flex;
	justify-content: center;
	margin-bottom: 18px;
}
.filterInner {
	width: min(920px, 100%);
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
}
.btnAll {
	border: 1px solid var(--navy);
	background: var(--navy);
	color: var(--white);
	border-radius: 999px;
	padding: 10px 14px;
	font-size: 12px;
	letter-spacing: .04em;
	cursor: pointer;
	line-height: 1;
	user-select: none;
	transition: background .15s ease, transform .06s ease, box-shadow .2s ease;
	box-shadow: 0 8px 18px rgba(15, 33, 56, .12);
}
.btnAll:hover {
	background: var(--navy2);
}
.btnAll:active {
	transform: translateY(1px);
}
.btnAll:focus-visible {
	outline: 2px solid rgba(16, 40, 69, .45);
	outline-offset: 2px;
}
.selectWrap {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
}
/* selectを“さりげなく良い”感じに */
.select {
	position: relative;
	display: inline-flex;
	align-items: center;
	border-bottom: 1px solid var(--line);
	overflow: hidden;
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
	will-change: transform;
}
.select:hover {
	border-color: rgba(15, 33, 56, .22);
	box-shadow: 0 10px 22px rgba(15, 33, 56, .10);
	transform: translateY(-1px);
}
.select:focus-within {
	border-color: rgba(15, 33, 56, .35);
	box-shadow: 0 14px 26px rgba(15, 33, 56, .12);
}
.select select {
	border: 0;
	background: transparent;
	color: var(--text);
	padding: 12px 38px 12px 14px;
	font-size: 13px;
	appearance: none;
	outline: none;
	min-width: 180px;
	cursor: pointer;
}
.chev {
	position: absolute;
	right: 12px;
	width: 14px;
	height: 14px;
	pointer-events: none;
	opacity: .75;
	transform: translateY(1px);
}
.select.is-active {
	border-color: rgba(15, 33, 56, .26);
}
.select.is-active::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(15, 33, 56, .06), transparent 55%);
	pointer-events: none;
	opacity: .85;
}
@media (max-width: 520px) {
	.select {
		width: 100%;
	}
	.select select {
		min-width: 100%;
		width: 100%;
	}
	.filterInner {
		justify-content: stretch;
	}
	.btnAll {
		width: 100%;
	}
	.selectWrap {
		width: 100%;
	}
}
/* ===== 商品グリッド ===== */
.wpw_grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px 14px;
}
@media (min-width: 640px) {
	.wpw_grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}
@media (min-width: 1024px) {
	.wpw_grid {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}
}
/* ===== 商品カード（画像→濃紺バー→テキスト） ===== */
.card {
	border: 1px solid var(--line);
	border-radius: 6px;
	overflow: hidden;
	background: var(--white);
	box-shadow: var(--shadow);
	transform: translateY(0);
	transition: transform .18s ease, box-shadow .18s ease;
	will-change: transform, opacity;
	opacity: 1;
}
.card:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 34px rgba(15, 33, 56, .10);
}
.wpw_thumb {
	aspect-ratio: 3/4;
	background: #f6f7f9;
}
.wpw_thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.wpw_bar {
	background: var(--gray);
	color: var(--navy2);
	font-size: 10px;
	padding: 5px 10px;
	letter-spacing: .02em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.wpw_info {
	padding: 10px 10px 12px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-height: 58px;
	webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	position: relative;
}
.wpw_item_name {
	font-size: 1.3rem;
	line-height: 1.35;
	font-weight: 600;
	color: var(--navy);
}
.wpw_item_id {
	font-size: 1rem;
	line-height: 1.35;
	font-weight: 500;
	color: var(--navy2);
}
.wpw_item_price {
	font-size: 1.8rem;
	font-weight: 700;
	color: var(--navy);
}
.wpw_item_price .tax {
	font-size: 1rem;
	font-weight: 700;
	color: #caccd2;
	padding-left: 0.5em;
}
.wpw_btn_check {
	margin: 0 auto;
	padding: 0;
	width: 100%;
	font-size: 1.2rem;
	font-weight: 500;
	background: var(--navy);
	color: var(--white);
	text-align: center;
	line-height: 2em;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
}
.wpw_btn_check a {
	display: block;
	width: 100%;
	height: 100%;
	color: var(--white);
}
.wpw_empty {
	margin-top: 18px;
	text-align: center;
	color: var(--muted);
	font-size: 13px;
	display: none;
	padding: 16px;
	border: 1px dashed var(--line);
	border-radius: var(--radius);
}
/* ===== カードのフェード（初期表示/絞り込み共通） ===== */
.card {
	opacity: 1;
	transform: none;
}
/* 初期ロード：全体をふわっと */
.card.init-hidden {
	opacity: 0;
	transform: translateY(6px);
}
.card.init-show {
	opacity: 1;
	transform: translateY(0);
	transition: opacity .35s ease, transform .35s ease;
}
/* 絞り込み：消える/出る（フェードのみ） */
.card.is-hidden {
	display: none !important;
}
.card[hidden]{ display:none !important; }
.card.is-fading-out {
	opacity: 0;
	transition: opacity .18s ease;
	pointer-events: none;
}
.card.is-fading-in {
	opacity: 0;
}
.card.is-visible {
	opacity: 1;
	transition: opacity .22s ease;
}
@media (prefers-reduced-motion: reduce) {
	.card.init-show,
	.card.is-fading-out,
	.card.is-visible {
		transition: none !important;
	}
	.card.init-hidden {
		opacity: 1;
		transform: none;
	}
}
/* フェードしながら消える（消えた後はJSでhidden化） */
.card.is-fade-out{
	opacity: 0;
	transition: opacity .18s ease;
	pointer-events:none;
}

/* 表示される時はフェードイン */
.card.is-fade-in{
	opacity: 0;
}
.card.is-fade-in.is-on{
	opacity: 1;
	transition: opacity .22s ease;
}

/* hidden属性は display:none になるのでグリッドが詰まる */
.card[hidden]{ display:none !important; }

@media (prefers-reduced-motion: reduce){
	.card.is-fade-out,
	.card.is-fade-in.is-on{ transition:none !important; }
}
/*----------------------------------

商品一覧ここまで

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

フッターここから

------------------------------------*/
.wpw_sec_footer {
	background: var(--navy);
	text-align: center;
}
.wpw_cta03 {
	border: 1px solid rgba(255, 255, 255, .65);
	background: var(--white);
	color: var(--navy);
	padding: 0.5em 2em 0.8em 2em;
	border-radius: 999px;
	letter-spacing: .06em;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 5px;
	text-decoration: none;
	transition: transform .06s ease, opacity .18s ease;
}
/*----------------------------------

フッターここまで

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

@media (max-width: 1024px) {}
@media (max-width: 786px) {
	.wpw_box_PF {
		height: 110vw!important;
		min-height: auto;
	}
	.wpw_sec_tv {
		position: relative;
		width: 100%;
		height: 100vw;
	}
	.heroNav {
		top: 77vw;
	}
	.hero__content {
		width: 45%;
		top: 32vw;
	}
	.wpw_h1 {
		font-size: 5vw;
	}
	.wpw_title {
		height: 13vw;
	}
	.btnGrid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (max-width: 550px) {
	.heroNav__item {
		gap: 10px;
		min-width: 100px;
		padding: 9px 14px;
		font-size: 10px;
	}
	.wpw_sec_tv {
		position: relative;
		width: 100%;
		height: 130vw;
	}
	.hero__content {
		width: 63%;
		top: 41vw;
	}
	.heroNav {
		top: 107vw;
	}
	.wpw_h1 {
		font-size: 8vw;
	}
	.wpw_box_works01 {
		width: 100%;
	}
	.wpw_box_works02 {
		margin: 0px;
		padding: 4em;
		width: 100%;
		text-align: left;
		position: relative;
	}
	.wpw_read_works {
		font-size: 1.4rem;
		color: var(--white);
		position: relative;
		z-index: 5;
	}
	.wpw_art_works {
		margin: 0 0 10vw;
		color: var(--white);
		position: relative;
		z-index: 5;
	}
	.wpw_catch_works {
		font-size: 4rem;
		color: var(--white);
		text-align: left;
		letter-spacing: 5px;
		position: relative;
		z-index: 5;
	}
	.wpw_subcatch_works {
		display: block;
		margin: 0;
		padding: 0;
		font-size: 2.3rem;
		font-weight: 500;
		letter-spacing: 9px;
		color: var(--white);
		position: relative;
		z-index: 5;
	}
	.select select {
		min-width: 120px;
	}
	.dockNav {
		display: none;
	}
	.wpw_wrap_works {
		width: 90%;
	}
	.wpw_art_works01 .wpw_box_works01::before,
	.wpw_art_works02 .wpw_box_works01::before,
	.wpw_art_works03 .wpw_box_works01::before {
		display: none;
	}
	.wpw_order_01 {
		order: 1;
	}
	.wpw_order_02 {
		order: 2;
	}
	.wpw_works_num {
		display: none;
	}
	.wpw_art_works01 .wpw_box_works02 {
		background-color: var(--navy);
	}
	.wpw_art_works02 .wpw_box_works02 {
		background-color: #884242;
	}
	.wpw_art_works03 .wpw_box_works02 {
		background-color: #F2F2E7;
		color: var(--navy);
	}
	.wpw_art_works01 .wpw_box_works02::after {
		display: inline-block;
		content: "";
		width: 100%;
		height: 63vw;
		background: url(../images/works_num01.png) no-repeat;
		background-size: contain;
		position: absolute;
		top: calc(50% - 33vw);
		left: 0;
	}
	.wpw_art_works02 .wpw_box_works02::after {
		display: inline-block;
		content: "";
		width: 100%;
		height: 63vw;
		background: url(../images/works_num02.png) no-repeat;
		background-size: contain;
		position: absolute;
		top: calc(50% - 33vw);
		left: 0;
	}
	.wpw_art_works03 .wpw_box_works02::after {
		display: inline-block;
		content: "";
		width: 100%;
		height: 63vw;
		background: url(../images/works_num03.png) no-repeat;
		background-size: contain;
		position: absolute;
		top: calc(50% - 33vw);
		left: 0;
	}
	.wpw_art_works03 .wpw_box_works02 .wpw_subcatch_works {
		color: #CCCCCC;
	}
	.wpw_art_works03 .wpw_box_works02 .wpw_read_works {
		color: var(--navy);
	}
	.wpw_art_works03 .wpw_box_works02 .wpw_art_works {
		color: var(--navy);
	}
	.wpw_art_works03 .wpw_box_works02 .wpw_catch_works {
		color: var(--navy);
	}
}
@media (max-width: 414px) {
	.heroNav {
		top: auto;
		bottom: 18px;
		gap: 8px;
		width: 100%;
	}
	.wpw_sec_tv {
		position: relative;
		width: 100%;
		height: 180vw;
	}
	.hero__content {
		width: 63%;
		top: 59vw;
	}
	.wpw_title {
		height: 15vw;
		margin: 0 auto 1em;
	}
	.wpw_catch_works {
		font-size: 3rem;
	}
	.wpw_box_works02 {
		margin: 0px;
		padding: 3em;
	}
	.wpw_sec_works {
		margin: 0;
		padding: 1em 0 0;
	}
	.wpw_sec_PF {
		padding: 8vw 0;
	}
	.wpw_wrap_PF {
		width: 100%;
	}
	.wpw_box_PF {
		height: 125vw!important;
		min-height: auto;
	}
	.wpw_container_size {
		margin: 0 0 30px;
		padding: 0;
	}
	.wpw_wrap_styling {
		width: 100%;
	}
	.slick-next {
		right: 3%;
	}
	.slick-prev {
		left: 3%;
	}
	.slick-slide {
		padding: 0;
	}
}
@media (max-width: 375px) {}
@media (max-width: 320px) {}