/* OVERTURE WEB SHOP 独自機能CSS(静的のみ・BASE変数を含む動的CSSはテーマ内に残す) */

/* 発売カウントダウン */
#dropCountdown { margin: 0 0 40px; background: var(--AccentColor); color: #fff; text-align: center; padding: 22px 15px; }
#dropCountdown a { color: inherit; text-decoration: none; display: block; }
#dropCountdown .cdTitle { font-size: .7em; letter-spacing: .25em; opacity: .7; text-transform: uppercase; }
#dropCountdown .cdLabel { font-size: 1.1em; font-weight: bold; letter-spacing: .08em; margin: 4px 0 12px; }
#dropCountdown .cdTimer { display: flex; justify-content: center; gap: 22px; font-weight: bold; }
#dropCountdown .cdTimer b { display: block; font-size: 1.9em; line-height: 1.1; font-variant-numeric: tabular-nums; }
#dropCountdown .cdTimer i { display: block; font-style: normal; font-size: .6em; letter-spacing: .15em; opacity: .6; margin-top: 4px; }
#dropCountdown .cdEnd { font-size: 1.3em; font-weight: bold; letter-spacing: .15em; display: none; }
#dropCountdown, #dropCountdown a, #dropCountdown .cdTitle, #dropCountdown .cdLabel, #dropCountdown .cdTimer b, #dropCountdown .cdTimer i, #dropCountdown .cdEnd { color: #fff !important; }
@media (max-width: 767px) {
#dropCountdown .cdTimer { gap: 16px; }
#dropCountdown .cdTimer b { font-size: 1.5em; }
}

/* 商品ラベル(COMING SOON / SOLD OUT)を同じ形に統一: COMING SOON=黒 / SOLD OUT=赤 */
.waitingForSale, p.comingSoon, .soldout { display: inline-block !important; width: auto !important; min-width: 0 !important; max-width: max-content !important; height: auto !important; min-height: 0 !important; padding: 2px 8px !important; font-size: 11px !important; line-height: 1.5 !important; letter-spacing: .06em !important; white-space: nowrap !important; color: #fff !important; }
.waitingForSale, p.comingSoon { background: #111 !important; }
.soldout { background: #cc0000 !important; }
.soldout > span { background: none !important; padding: 0 !important; margin: 0 !important; color: inherit !important; font: inherit !important; }

/* ドロワーBRAND一覧のA-Z頭文字アコーディオン(otws-brandnav.js) */
li.otwsAZ { list-style: none; }
.otwsAZchk { display: none !important; }
.otwsAZlabel { display: flex !important; justify-content: space-between; align-items: center; padding: 9px 6px; cursor: pointer; font-weight: bold; font-size: .95em; border-bottom: 1px solid rgba(0,0,0,.06); }
.otwsAZlabel::after { content: '+'; font-weight: 400; opacity: .55; }
.otwsAZchk:checked + .otwsAZlabel::after { content: '−'; }
.otwsAZlist { display: none; list-style: none; margin: 0; padding: 2px 0 8px 14px; }
.otwsAZchk:checked ~ .otwsAZlist { display: block; }
.otwsAZlist li a { display: block; padding: 6px 4px; text-decoration: none; color: inherit; font-size: .9em; }

/* カテゴリータイル */
#catGridNav { margin: 0 0 40px; }
#catGridNav .sHeading { margin-bottom: 18px; }
#catGridNav .sHeading h2 { font-size: 1.4em; line-height: 1.3; font-weight: bold; }
#catGridNav .catGridList { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px 12px; list-style: none; margin: 0; padding: 0; }
#catGridNav .catGridList li a { display: block; text-decoration: none; color: inherit; }
#catGridNav .catGridList figure { margin: 0; overflow: hidden; }
#catGridNav .catGridList img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; transition: transform .3s ease; }
#catGridNav .catGridList li a:hover img { transform: scale(1.05); }
#catGridNav .catGridList span { display: block; text-align: center; font-size: .8em; margin-top: 8px; letter-spacing: .05em; }
@media (max-width: 767px) {
#catGridNav .catGridList { grid-template-columns: repeat(3, 1fr); gap: 14px 8px; }
#catGridNav .catGridList span { font-size: .72em; margin-top: 6px; }
}

/* ブランドロゴ自動スクロール帯 */
#brandLogoBand { margin: 0 0 40px; }
#brandLogoBand .sHeading { margin-bottom: 18px; }
#brandLogoBand .sHeading h2 { font-size: 1.4em; line-height: 1.3; font-weight: bold; }
#brandLogoBand .brandMarquee { overflow: hidden; position: relative; }
#brandLogoBand .brandTrack { display: flex; align-items: center; width: max-content; margin: 0; padding: 10px 0; list-style: none; animation: brandScroll 35s linear infinite; }
#brandLogoBand .brandMarquee:hover .brandTrack { animation-play-state: paused; }
#brandLogoBand .brandTrack li { flex-shrink: 0; margin-right: 56px; }
#brandLogoBand .brandTrack img { height: 44px; width: auto; display: block; opacity: .85; transition: opacity .3s; }
#brandLogoBand .brandTrack li a:hover img { opacity: 1; }
@keyframes brandScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (max-width: 767px) {
#brandLogoBand .brandTrack li { margin-right: 36px; }
#brandLogoBand .brandTrack img { height: 32px; }
}

/* FEATURED ITEM */
#featuredItem { display: flex; align-items: center; gap: 36px; margin: 0 0 40px; }
#featuredItem .ftImg { width: 55%; flex-shrink: 0; }
#featuredItem .ftImg img { width: 100%; height: auto; display: block; }
#featuredItem .ftBody { flex: 1; }
#featuredItem .ftBody .sHeading { margin-bottom: 14px; }
#featuredItem .ftBody .sHeading h2 { font-size: 1.4em; line-height: 1.3; font-weight: bold; }
#featuredItem .ftName { font-size: 1.15em; font-weight: bold; letter-spacing: .05em; margin: 0 0 10px; }
#featuredItem .ftDesc { font-size: .88em; line-height: 1.9; letter-spacing: .02em; margin: 0 0 18px; }
#featuredItem .ftBtn { display: inline-block; background: var(--AccentColor); color: #fff !important; text-decoration: none; font-size: .8em; font-weight: bold; letter-spacing: .15em; padding: 13px 36px; transition: opacity .3s; }
#featuredItem .ftBtn:hover { opacity: .75; }
@media (max-width: 767px) {
#featuredItem { flex-direction: column; gap: 16px; }
#featuredItem .ftImg { width: 100%; }
#featuredItem .ftBody { width: 100%; }
}

/* スタッフコーデ 2タブ(ルージュ式・別データ) */
#staffStyleNav { margin: 0 0 40px; }
#staffStyleNav .sHeading { margin-bottom: 18px; }
#staffStyleNav .sHeading h2 { font-size: 1.4em; line-height: 1.3; font-weight: bold; }
.otwsTabs { display: flex; max-width: 420px; margin: 0 auto 24px; border: 1px solid #ddd; border-radius: 30px; overflow: hidden; }
.otwsTabs button { flex: 1; padding: 12px; border: none; background: #fff; color: #999; font-size: .82em; font-weight: bold; letter-spacing: .05em; cursor: pointer; transition: background .2s, color .2s; }
.otwsTabs button.on { background: #111; color: #fff; }
.otwsPanel { display: none; }
.otwsPanel.on { display: grid; }
/* Coordinationタブ: コーデ写真グリッド */
.otwsCrdGrid { grid-template-columns: repeat(4, 1fr); gap: 24px 16px; list-style: none; margin: 0; padding: 0; }
.otwsCrdGrid li a, .otwsCrdGrid li .noLink { display: block; text-decoration: none; color: inherit; }
.otwsCrdGrid figure { margin: 0; overflow: hidden; position: relative; }
.otwsCrdGrid img { width: 100%; aspect-ratio: 3 / 4; object-fit: cover; display: block; transition: transform .4s ease; }
.otwsCrdGrid li a:hover img { transform: scale(1.06); }
.otwsCrdGrid li a figure::after { content: 'VIEW STYLE'; position: absolute; left: 0; right: 0; bottom: 0; padding: 22px 10px 12px; font-size: .68em; letter-spacing: .18em; color: #fff; text-align: center; background: linear-gradient(transparent, rgba(0,0,0,.55)); opacity: 0; transition: opacity .3s; }
.otwsCrdGrid li a:hover figure::after { opacity: 1; }
.otwsCrdGrid .cpt { display: block; font-size: .78em; font-weight: bold; margin-top: 10px; letter-spacing: .03em; }
/* Staff profileタブ: 左顔写真+右テキストのリスト */
.otwsProfList { grid-template-columns: repeat(2, 1fr); gap: 0 40px; list-style: none; margin: 0 auto; padding: 0; max-width: 860px; }
.otwsProfList li { border-bottom: 1px solid rgba(0,0,0,.08); }
.otwsProfList .prfRow { display: flex; align-items: center; gap: 16px; padding: 12px 6px; color: inherit; transition: background .2s; }
.otwsProfList .prfRow.lnk { cursor: pointer; }
.otwsProfList .prfRow.lnk:hover { background: rgba(0,0,0,.03); }
.otwsProfList figure { margin: 0; width: 64px; flex-shrink: 0; overflow: hidden; }
.otwsProfList img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; border-radius: 50%; }
.otwsProfList .prfTxt { flex: 1; min-width: 0; }
.otwsProfList .nm { display: block; font-size: .9em; font-weight: bold; letter-spacing: .05em; }
.otwsProfList .ht { display: block; font-size: .74em; opacity: .65; margin-top: 2px; }
.otwsProfList .ig { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; color: #777; flex-shrink: 0; transition: color .2s; }
.otwsProfList .ig:hover { color: #111; }
.otwsProfList .prfRow.lnk::after { content: ''; width: 7px; height: 7px; border-top: 1px solid #999; border-right: 1px solid #999; transform: rotate(45deg); flex-shrink: 0; }
.otwsPanel li.hid { display: none; }
.otwsMore { display: block; margin: 28px auto 0; padding: 14px 64px; border: none; border-radius: 30px; background: #111; color: #fff; font-size: .8em; font-weight: bold; letter-spacing: .2em; cursor: pointer; transition: opacity .3s; }
.otwsMore:hover { opacity: .75; }

/* スタッフ別コーデまとめ(ブログ ?style= ページ) */
.otwsBlogMsg { text-align: center; padding: 50px 0; opacity: .6; font-size: .9em; }
.otwsBlogGrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px 18px; list-style: none; margin: 0; padding: 0; }
.otwsBlogGrid li a { display: block; text-decoration: none; color: inherit; }
.otwsBlogGrid figure { margin: 0 0 10px; overflow: hidden; }
.otwsBlogGrid img { width: 100%; aspect-ratio: 3 / 4; object-fit: cover; display: block; transition: transform .4s ease; }
.otwsBlogGrid li a:hover img { transform: scale(1.05); }
.otwsBlogGrid .bt { font-size: .82em; line-height: 1.5; font-weight: bold; letter-spacing: .02em; }
@media (max-width: 767px) {
.otwsBlogGrid { grid-template-columns: repeat(2, 1fr); gap: 20px 10px; }
}
@media (max-width: 767px) {
.otwsCrdGrid { grid-template-columns: repeat(2, 1fr); gap: 18px 10px; }
.otwsProfList { grid-template-columns: 1fr; }
}

/* ブランド紹介ボックス */
#brandInfoBox { display: flex; gap: 24px; align-items: center; margin: 0 0 30px; padding: 22px; border: 1px solid rgba(0,0,0,.1); }
#brandInfoBox .biImg { flex-shrink: 0; width: 240px; }
#brandInfoBox .biImg img { width: 100%; height: auto; display: block; }
#brandInfoBox .biText { font-size: .9em; line-height: 1.9; letter-spacing: .02em; }
@media (max-width: 767px) {
#brandInfoBox { flex-direction: column; gap: 14px; padding: 16px; }
#brandInfoBox .biImg { width: 100%; }
}

/* 店舗で見る/来店予約ボタン */
#otwsStoreVisit { margin: 10px 0 0; }
#otwsStoreVisit a { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 13px; border: 1px solid #111; background: #fff; color: #111; text-decoration: none; font-size: .85em; font-weight: bold; letter-spacing: .08em; transition: background .3s, color .3s; box-sizing: border-box; }
#otwsStoreVisit a:hover { background: #111; color: #fff; }
#otwsStoreVisit .svNote { font-size: .7em; opacity: .6; margin-top: 6px; text-align: center; }

/* 店舗ガイド(About) 5店舗カード */
#branchStores .otwsStoreLead { font-size: .85em; line-height: 1.85; margin: 0 0 22px; }
#branchStores .otwsStoreLead span { display: block; margin-top: 6px; font-size: .92em; color: #cc0000; }
.otwsStoreList { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; list-style: none; margin: 0; padding: 0; }
.otwsStore { border: 1px solid rgba(0,0,0,.12); border-radius: 8px; padding: 16px; display: flex; flex-direction: column; }
.otwsStore h4 { font-size: 1em; font-weight: bold; margin: 0 0 12px; letter-spacing: .02em; line-height: 1.4; }
.otwsStore h4 .otwsResvTag { display: inline-block; margin-left: 6px; font-size: 10px; font-weight: bold; color: #fff; background: #cc0000; padding: 2px 7px; border-radius: 3px; vertical-align: middle; letter-spacing: .04em; white-space: nowrap; }
.otwsStore dl { display: grid; grid-template-columns: max-content 1fr; gap: 3px 12px; margin: 0 0 16px; font-size: .8em; line-height: 1.6; }
.otwsStore dt { color: #999; white-space: nowrap; }
.otwsStore dd { margin: 0; }
.otwsStoreBtns { margin-top: auto; display: flex; gap: 8px; }
.otwsStoreBtns a { flex: 1; text-align: center; text-decoration: none; font-size: .8em; font-weight: bold; letter-spacing: .05em; padding: 12px 8px; border-radius: 6px; transition: opacity .2s; box-sizing: border-box; }
.otwsMapBtn { flex: 0 0 36% !important; border: 1px solid #111; color: #111 !important; background: #fff; }
.otwsResvBtn { background: #111; color: #fff !important; }
.otwsStoreBtns a:hover { opacity: .7; }
@media (max-width: 767px) { .otwsStoreList { grid-template-columns: 1fr; } }

/* お気に入り */
.item-thumb-wrap { position: relative; }
.otwsCardFav { position: absolute; right: 8px; bottom: 8px; z-index: 5; width: 34px; height: 34px; border-radius: 50%; border: none; background: rgba(255,255,255,.92); font-size: 17px; line-height: 34px; text-align: center; cursor: pointer; color: #222; padding: 0; box-shadow: 0 1px 4px rgba(0,0,0,.15); }
.otwsCardFav.on { color: #e8413f; }
#otwsFavWrap { margin: 12px 0 0; }
#otwsFavBtn { width: 100%; padding: 13px; border: 1px solid #ccc; background: #f4f4f4; color: #666; font-size: .85em; font-weight: bold; letter-spacing: .08em; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: background .2s, color .2s, border-color .2s; }
#otwsFavBtn .favHeart { font-size: 1.2em; line-height: 1; color: #aaa; transition: color .2s; }
#otwsFavBtn:hover { background: #ececec; }
#otwsFavBtn.on { background: #8a8a8a; color: #fff; border-color: #8a8a8a; }
#otwsFavBtn.on .favHeart { color: #ff5b6e; }
#otwsFavSection { margin: 0 0 40px; }
#otwsFavSection .sHeading { margin-bottom: 18px; }
#otwsFavSection .sHeading h2 { font-size: 1.4em; line-height: 1.3; font-weight: bold; }
#otwsFavList { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px 12px; list-style: none; margin: 0; padding: 0; }
#otwsFavList li { position: relative; }
#otwsFavList a { display: block; text-decoration: none; color: inherit; }
#otwsFavList figure { margin: 0; overflow: hidden; position: relative; }
#otwsFavList img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; display: block; }
#otwsFavList .favT { font-size: .78em; line-height: 1.5; margin-top: 6px; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
#otwsFavList .favP { font-size: .78em; font-weight: bold; margin-top: 2px; }
@media (max-width: 767px) {
#otwsFavList { grid-template-columns: repeat(3, 1fr); gap: 16px 8px; }
}

/* スマホ下固定ナビ(PCは非表示) */
#otwsBottomNav { display: none; }
@media (max-width: 767px) {
#otwsBottomNav { display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 9999; background: #fff; border-top: 1px solid #e5e5e5; box-shadow: 0 -1px 10px rgba(0,0,0,.07); padding-bottom: env(safe-area-inset-bottom, 0px); }
#otwsBottomNav a, #otwsBottomNav button, #otwsBottomNav label { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; background: none; border: none; padding: 11px 0 9px; color: #1a1a1a; font-size: 11px; line-height: 1; letter-spacing: .02em; text-decoration: none; cursor: pointer; font-family: inherit; -webkit-tap-highlight-color: transparent; }
#otwsBottomNav .material-symbols-outlined { font-size: 27px; }
#otwsBottomNav .lb { display: block; }
body.otwsHasBottomNav { padding-bottom: 68px; }
/* BASEチャットボタンを小さい丸+ボトムナビの上へ(ルージュ風) */




/* 検索オーバーレイをcheckboxで開く(JS非依存・確実) */
#otwsSearchChk:checked ~ #otwsSearchOv { display: flex; }
#x_message #x_startMessenger { bottom: 70px !important; right: 16px !important; left: auto !important; margin: 0 !important; width: 60px !important; height: 60px !important; min-width: 0 !important; padding: 0 !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; transform: none !important; overflow: hidden !important; }
#x_message #x_startMessenger .msg_startButton__text { display: none !important; }
#x_message #x_startMessenger .msg_startButton__icon { margin: 0 !important; padding: 0 !important; width: 100% !important; height: 100% !important; font-size: 31px !important; line-height: 1 !important; display: flex !important; align-items: center !important; justify-content: center !important; }
/* NUBIAN風ヘッダー: 検索ボックス/人気キーワード/MENUを非表示にしてロゴ中央(検索・メニューはボトムナビに集約済) */
#trendTagHeader { display: none !important; }
header .searchbar { display: none !important; }
label.open[for="drawer"] { display: none !important; }
header .headCatNav.menu { display: none !important; }
.otwsHeaderFavWrap { display: none !important; }
header .navIcons { margin-left: auto !important; justify-content: flex-end !important; transform: translateY(5px) !important; }
header #subNav { display: none !important; }
#shoplogo { justify-content: center !important; align-items: center !important; text-align: center !important; padding-top: 16px !important; padding-bottom: 16px !important; }
/* ヘッダーのテキストロゴを大きく(オーナー指定) */
header #shoplogo #logo { font-size: 22px !important; letter-spacing: .04em !important; white-space: nowrap !important; line-height: 1.15 !important; }
header #shoplogo #logo img { width: 180px !important; max-width: 56% !important; height: auto !important; max-height: none !important; }
/* NUBIAN型1段化: カート行(#headNavwrap)をロゴ行に重ねてヘッダーを薄く */
header { position: relative !important; }
#headNavwrap { position: absolute !important; top: 0 !important; right: 0 !important; height: 100% !important; width: auto !important; margin: 0 !important; display: flex !important; align-items: center !important; z-index: 5 !important; }
#headNavwrap .widthfix { margin: 0 !important; padding: 0 14px 0 0 !important; height: 100% !important; width: auto !important; align-items: center !important; }
/* カートアイコンの「カート」文字ラベル(::before生成)を消す(アイコン+数バッジは残す) */
header li.cart > a::before { display: none !important; content: "" !important; }
}
/* ボトムナビ検索オーバーレイ */
#otwsSearchOv { display: none; position: fixed; top: 0; left: 0; right: 0; z-index: 10001; background: #fff; padding: 12px 14px; box-shadow: 0 2px 10px rgba(0,0,0,.12); align-items: center; gap: 10px; }
#otwsSearchOv.open { display: flex; }
#otwsSearchOv form { flex: 1; display: flex; align-items: center; gap: 8px; border: 1px solid #ccc; border-radius: 8px; padding: 9px 13px; }
#otwsSearchOv .material-symbols-outlined { font-size: 20px; color: #888; }
#otwsSearchOv input { flex: 1; border: none; outline: none; font-size: 16px; background: none; color: #111; }
#otwsSearchClose { background: none; border: none; font-size: 20px; color: #555; cursor: pointer; padding: 4px 10px; line-height: 1; }
