/* 商品ページ標準スタイル(試作3号の型を踏襲・編集/閲覧 共用) */
/* 無印ふうの本文書体: Zen Kaku Gothic New(OFL・自前ホスト / JIS第1・2水準サブセット woff2) */
@font-face{font-family:"Zen Kaku Gothic New";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/zenkaku-400.woff2") format("woff2")}
@font-face{font-family:"Zen Kaku Gothic New";font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/zenkaku-700.woff2") format("woff2")}
:root{
  --ink:#1d1d1b; --sub:#6f6b64; --line:#e8e5df; --bg:#faf9f6;
  --accent:#e8590c; --accent-dark:#cf4d08; --good:#1d7a4f;
  --night:#241a36; --nightInk:#efe9f8; --gold:#fcba28; --marker:#fff3a8;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Yu Gothic Medium","Yu Gothic",sans-serif;
     color:var(--ink);background:var(--bg);font-size:16px;line-height:1.78}
/* 実ショップ(viewer)では横はみ出し(100vw全幅要素 vs スクロールバー差)を消す。
   → 全幅の色帯(ブロック背景/ABOUT/フッター)が左右の端までぴったり届く(右に白帯が残らない)。
   ルート(html)にも適用しないと8px残るため :has でビューア時のみ。エディタには影響させない。 */
html:has(body.shopView){overflow-x:clip}
/* 実ショップは左右の余白も中央(.page=白)と同じ白に統一(クリーム#faf9f6の左右帯を解消) */
html:has(body.shopView){background:#fff}
body.shopView{overflow-x:clip;background:#fff}

/* ===== ページ(スマホ幅) ===== */
.page{max-width:430px;margin:0 auto;background:#fff;min-height:100vh;padding-bottom:96px}
.pHeader{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;
         background:#faf8f7;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.pHeader.noLogo{justify-content:flex-end;border-bottom:none}
/* 実ショップ(viewer)はヘッダーの地色を左右いっぱいに伸ばす(中央カラム外の白余白に色が届かず段差が出るのを解消)。
   中身(ロゴ・アイコン)はそのまま上に乗る。擬似要素で背面に全幅の同色帯を敷く方式=sticky を壊さない。 */
body.shopView .pHeader{position:sticky}
body.shopView .pHeader::before{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:100vw;background:#faf8f7;z-index:-1}
.pLogo{display:flex;align-items:center;text-decoration:none;color:var(--ink)}
.pLogo img{height:38px;width:auto;display:block}
.pLogoTxt{font-weight:800;letter-spacing:.12em;font-size:14.5px}
.pLogoTxt b{font-weight:400;color:var(--sub);font-size:11px;margin-left:5px}
.pNav{display:flex;align-items:center;gap:15px}
.pNav a{color:var(--ink);text-decoration:none;line-height:1}
.pIcon{display:flex;align-items:center;justify-content:center;color:var(--ink);position:relative}
.pIcon svg{width:30px;height:30px;display:block}
@media(min-width:768px){.pNav .pIcon svg{width:23px;height:23px}}
.cartDot{position:absolute;top:-5px;right:-7px;background:#e8200f;color:#fff;font-size:9.5px;font-weight:700;min-width:15px;height:15px;border-radius:99px;display:none;align-items:center;justify-content:center;padding:0 3px;line-height:1}
.pMenu{position:absolute;top:100%;right:14px;margin-top:6px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 6px 24px rgba(0,0,0,.12);padding:6px;display:none;z-index:50;min-width:170px}
.pMenu.on{display:block}
.pMenu a{display:block;padding:9px 12px;font-size:13px;color:var(--ink);border-radius:7px;white-space:nowrap}
.pMenu a:hover{background:#f5f2ec}

/* ===== フッター(赤・波トップ・白ロゴ・SNS・メニュー) ===== */
.pFooter{margin-top:40px;margin-bottom:-96px;margin-left:calc(50% - 50vw);width:100vw;max-width:100vw;background:transparent;overflow:hidden}
.pfWave{line-height:0;font-size:0;position:relative;z-index:1}
.pfWaveImg{width:100%;height:auto;display:block}
.pfWaveSp{display:block}.pfWavePc{display:none}
.pfBody{background:#D80309;color:#fff;margin-top:-2px;position:relative;z-index:2;padding:38px 22px 34px}
.pfInner{display:flex;flex-direction:column;gap:26px;max-width:1040px;margin:0 auto}
.pfBrand{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:16px}
.pfBrandMain{display:flex;flex-direction:column;align-items:flex-start}
.pfLogo{width:150px;height:auto;display:block;margin-bottom:14px}
.pfCozy{font-size:13px;letter-spacing:.08em;color:#fff;opacity:.95}
.pfCozyLine{display:block;width:34px;height:2px;background:#fff;opacity:.8;margin:13px 0 2px}
.pfSns{display:flex;flex-direction:column;gap:13px}
.pfSns .snsIcon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1.5px solid rgba(255,255,255,.85);color:#fff;text-decoration:none;transition:background .15s,color .15s}
.pfSns .snsIcon:hover{background:#fff;color:#D80309}
.pfMenu{display:flex;flex-direction:column}
.pfMenu a{display:flex;align-items:center;justify-content:space-between;gap:20px;color:#fff;text-decoration:none;font-size:15px;letter-spacing:.04em;padding:14px 2px;border-bottom:1px solid rgba(255,255,255,.2)}
.pfMenu a:first-child{border-top:1px solid rgba(255,255,255,.2)}
.pfArr{font-style:normal;opacity:.85;font-size:16px}
.pfCopy{text-align:center;color:rgba(255,255,255,.85);font-size:11px;letter-spacing:.08em;max-width:1040px;margin:24px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.22)}
@media(min-width:768px){
  .pfWaveSp{display:none}.pfWavePc{display:block}
  .pFooter{margin-bottom:-130px}
  .pfBody{padding:40px 40px 44px}
  .pfInner{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:60px;padding-top:18px}
  .pfBrand{flex:0 0 auto;flex-direction:column;align-items:flex-start;gap:18px}
  .pfSns{flex-direction:row}
  .pfLogo{width:172px}
  .pfMenu{flex:1;max-width:560px;border-left:1px solid rgba(255,255,255,.2);padding-left:54px}
  .pfMenu a:first-child{border-top:none}
}
.pBack{padding:12px 16px 0}
.pBackBtn{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;padding:7px 15px;font-size:13px;font-weight:700;cursor:pointer;line-height:1}
.pBackBtn:hover{background:#f4f1ec}
.pTitle{padding:14px 16px 4px}
.pTitle h1{font-size:19px;font-weight:800;line-height:1.45}
.pTitle .brand{color:var(--sub);font-size:11.5px;letter-spacing:.06em;margin-top:2px}
.pTitle .priceRow{display:flex;align-items:baseline;gap:10px;margin-top:8px}
.pTitle .now{font-size:25px;font-weight:800}
.pTitle .tax{font-size:11px;color:var(--sub)}
/* ヘッダー価格・編集画面のみの「＋価格を入れる」プレースホルダ(お客様画面には出ない) */
.pTitle .priceRow[data-headprice]:hover{outline:1.5px dashed #cf4d08;outline-offset:3px;border-radius:6px}
.pTitle .priceAdd{font-size:13px;font-weight:700;color:#cf4d08}
.pTitle .ship{color:var(--good);font-size:12px;font-weight:700;margin-top:2px}

/* ブロック共通 */
.blk{position:relative}
.blk[data-type="heading"]{padding:22px 16px 2px}
.blk[data-type="heading"] .h{font-size:20px;font-weight:800;letter-spacing:.03em;line-height:1.6}
.blk[data-type="body"]{padding:12px 16px 2px}
.blk[data-type="body"] .t{font-size:16px;line-height:1.95}
.blk[data-type="hero"]{padding:12px 16px 0}
.blk[data-type="hero"] .frame{border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.blk[data-type="hero"] img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#f4f1ec}
.blk[data-type="hero"] img.full{aspect-ratio:auto;object-fit:unset;height:auto} /* 原寸表示(◳で切替・縦長プロモ等を切らない) */
.blk[data-type="hero"] .cap{font-size:11px;color:var(--sub);padding:7px 4px 0}
.blk[data-type="hero"]:has(.heroBleed){padding:0}
.shopView .blk[data-type="hero"]:has(.heroBleed){padding:0}
.heroBleed{margin-left:calc(50% - 50vw);width:100vw;max-width:100vw;overflow:hidden;display:flex;justify-content:center;line-height:0;position:relative;z-index:2}
.heroBleed.hbUp{margin-top:var(--upM,var(--up))}
@media(min-width:768px){.heroBleed.hbUp{margin-top:var(--up)}}
.blk[data-type="hero"] .heroBleed .hbImg{width:max(100vw,1600px);height:auto;flex:none;max-width:none;aspect-ratio:auto;object-fit:unset;background:none}
.blk[data-type="hero"] .heroBleed .hbSp{width:100%}
.blk[data-type="hero"] .heroBleed .hbSp{display:block}.blk[data-type="hero"] .heroBleed .hbPc{display:none}
@media(min-width:768px){.blk[data-type="hero"] .heroBleed .hbSp{display:none}.blk[data-type="hero"] .heroBleed .hbPc{display:block}}

/* スライダー */
.blk[data-type="slider"]{padding:14px 0 0}
.slider{position:relative}
.slTrack{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.slTrack::-webkit-scrollbar{display:none}
.slTrack .sl{flex:0 0 86%;margin-left:16px;scroll-snap-align:center;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.slTrack .sl:last-child{margin-right:16px}
.slTrack img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#f4f1ec}
.sl .slLabel{font-size:12px;line-height:1.7;color:#3c3a36;background:#fff;padding:8px 12px 9px;text-align:center}
.sl .slLabel:empty::before{content:attr(data-ph);color:#c9c2b6;font-size:11px}
.slTabs{display:flex;gap:6px;overflow-x:auto;padding:2px 14px 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.slTabs::-webkit-scrollbar{display:none}
.slTab{flex:none;display:inline-flex;align-items:center;gap:6px;border:0;border-bottom:2px solid transparent;background:none;color:var(--sub);font-size:13px;font-weight:700;padding:7px 4px;cursor:pointer;white-space:nowrap;letter-spacing:.02em}
.slTab i{width:13px;height:13px;border-radius:50%;border:1px solid var(--line);display:inline-block;flex:none}
.slTab.on{color:var(--ink);border-bottom-color:var(--ink)}
.sl .slClr{background:#fff;padding:4px 12px 10px;text-align:center}
.slThumbs{display:flex;gap:8px;overflow-x:auto;padding:11px 14px 2px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.slThumbs::-webkit-scrollbar{display:none}
.slThumb{flex:none;width:58px;height:58px;border-radius:9px;overflow:hidden;border:2px solid var(--line);background:#f4f1ec;cursor:pointer;padding:0}
.slThumb img{width:100%;height:100%;object-fit:cover;display:block}
.slThumb.on{border-color:var(--ink)}
.slDots{display:flex;gap:6px;justify-content:center;margin-top:9px}
.slDots i{width:6px;height:6px;border-radius:50%;background:#d8d4cc;transition:all .2s}
.slDots i.on{background:var(--ink);width:16px;border-radius:4px}
.slCap{font-size:11px;color:var(--sub);text-align:center;margin-top:6px;padding:0 16px}

/* ストーリー(ABOUT)。地色は 🎨(b.bg)で選べる。未指定なら夜色(--night)が既定。
   全幅の帯は従来どおり内側 .story に残す(色だけ --storyBg で差し替え)。文字色は地色の明暗で自動(render.js が変数を設定)。 */
.blk[data-type="story"] .story{background:var(--storyBg,var(--night));color:var(--storyInk,var(--nightInk));margin-top:18px;padding:30px 22px 32px}
/* 実ショップ(viewer)では story(ABOUT)の色も横いっぱいに伸ばす */
body.shopView .blk[data-type="story"] .story{box-shadow:0 0 0 100vw var(--storyBg,var(--night));clip-path:inset(0 -100vw)}
.blk[data-type="story"] .en{font-size:10px;letter-spacing:.3em;color:var(--storyEn,#b9a8d8);margin-bottom:14px;text-transform:uppercase}
.blk[data-type="story"] .h{font-size:23px;font-weight:800;line-height:1.7;margin-bottom:14px;color:var(--storyH,#fff)}
.blk[data-type="story"] .t{font-size:16px;line-height:2.0;opacity:.94}
.blk[data-type="story"] .t font[color]{color:var(--gold)!important}
/* ストーリーに画像を添える時のレイアウト。スマホ=縦積み(上下選択)/ PC(.shopView+768px〜)=横並び(左右選択)。色帯は .story のまま全幅維持。 */
.blk[data-type="story"] .storyInner{display:flex;flex-direction:column;gap:22px}
.blk[data-type="story"] .storyInner.m-top .storyImg{order:-1}
.blk[data-type="story"] .storyInner.m-bottom .storyImg{order:1}
.blk[data-type="story"] .storyImg img{width:100%;height:auto;display:block;border-radius:14px}
@media(min-width:768px){
  .shopView .blk[data-type="story"] .storyInner{flex-direction:row;align-items:center;gap:44px}
  .shopView .blk[data-type="story"] .storyInner .storyTextWrap{flex:1 1 0;min-width:0}
  .shopView .blk[data-type="story"] .storyInner .storyImg{flex:0 0 42%;max-width:42%}
  .shopView .blk[data-type="story"] .storyInner.d-left .storyImg{order:-1}
  .shopView .blk[data-type="story"] .storyInner.d-right .storyImg{order:0}
}

/* セクション見出し(.secT)の英語ラベル(small)は常に ja の上段に出す(汎用)。
   従来は各ブロック(features/news/…)が個別指定していたが、新ブロック(detailcards/featurecards/
   peekgallery)に効かず en と ja が同じ行に出る不具合があった。汎用化で全ブロックに適用。
   各ブロックの個別指定(.blk[data-type=…] .secT small)は specificity が高く同値なので二重にならない。 */
.secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}

/* 特徴表 */
.blk[data-type="features"]{padding:20px 16px 4px}
.blk[data-type="features"] .secT{font-size:14px;font-weight:800;margin-bottom:8px}
.blk[data-type="features"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
.feat{list-style:none}
.feat li{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.feat li:last-child{border-bottom:0}
.feat b{flex:0 0 86px;font-size:12px;color:var(--sub);padding-top:1px;font-weight:700}
.feat .fv{flex:1}

/* サイズ表 */
.blk[data-type="sizechart"]{padding:20px 16px 8px}
.blk[data-type="sizechart"] .secT{font-size:14px;font-weight:800;margin-bottom:8px}
.blk[data-type="sizechart"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
.scWrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.scTbl{border-collapse:collapse;width:100%;font-size:13px}
.scTbl th,.scTbl td{border:1px solid var(--line);padding:8px 10px;text-align:center;white-space:nowrap;vertical-align:middle}
.scTbl thead th{background:#f3f0ea;color:var(--sub);font-size:11.5px;font-weight:700;position:relative}
.scTbl td.scSize{background:#faf9f6;font-weight:700;color:var(--ink)}
.scTbl th span,.scTbl td span{display:inline-block;min-width:1.5em;outline:none}
.scTbl span:empty::before{content:attr(data-ph);color:#c9c2b6;font-weight:400}
.scTbl th.scEnd,.scTbl td.scEnd{border:0;padding:0 0 0 4px;white-space:nowrap;background:none}
.scDel{border:0;background:none;color:#c9c2b6;font-size:11px;cursor:pointer;position:absolute;top:2px;right:3px;line-height:1;padding:0}
.scDel:hover{color:#b3261e}
.scBar{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.scAdd{font-size:11px;color:#cf4d08;cursor:pointer;font-weight:700;border:1px solid #f0d8c8;border-radius:8px;padding:5px 10px}
.scAdd:hover{background:#fdf3ec}
.scAdd.scPreset{color:#2b6f4a;border-color:#cfe4d6}
.scAdd.scPreset:hover{background:#eef6f1}
.scHint{font-size:10.5px;color:var(--sub);margin-top:7px;line-height:1.6}

/* 詳細カード(スワイプ)= 新ブロック detailcards。横スワイプ・1枚ずつ・次が少し覗く(peek)。 */
.blk[data-type="detailcards"]{padding:20px 0 6px}
.blk[data-type="detailcards"] .secT{padding-left:16px;padding-right:16px}
.dcWrap{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 16px 2px}
.dcWrap::-webkit-scrollbar{display:none}
.dcCard{position:relative;flex:0 0 84%;scroll-snap-align:center;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 4px 16px rgba(40,34,26,.06);overflow:hidden;display:flex;flex-direction:column}
.dcImg{width:100%;height:240px;background:#f4f1ec;overflow:hidden;cursor:pointer}
.dcImg img{width:100%;height:100%;object-fit:cover;display:block}
.dcImg.empty{display:flex;align-items:center;justify-content:center;border-bottom:1px dashed var(--line)}
.dcImgAdd{font-size:12px;font-weight:700;color:#cf4d08}
.dcBody{padding:13px 15px 16px}
.dcLabel{font-size:11px;font-weight:800;letter-spacing:.08em;color:#cf4d08;margin-bottom:5px}
.dcTitle{font-size:15.5px;font-weight:800;line-height:1.45;color:var(--ink);margin-bottom:6px}
.dcDesc{font-size:12.5px;line-height:1.7;color:var(--sub)}
/* 編集時の空フィールドはプレースホルダ表示(お客様画面では空要素自体が出ない) */
.dcLabel:empty::before,.dcTitle:empty::before,.dcDesc:empty::before{content:attr(data-ph);color:#c9c2b6;font-weight:400}
.dcDel{position:absolute;top:8px;right:8px;z-index:3;border:0;background:rgba(255,255,255,.92);color:#b3261e;width:24px;height:24px;border-radius:50%;font-size:13px;font-weight:700;line-height:1;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.dcAdd{flex:0 0 auto;align-self:stretch;min-width:120px;border:1.5px dashed var(--line);background:#fff;color:#cf4d08;border-radius:16px;font-weight:700;cursor:pointer;font-size:12px;white-space:nowrap}
.dcDots{display:flex;justify-content:center;gap:6px;margin-top:11px}
.dcDot{width:7px;height:7px;border-radius:50%;background:#d8d4cc;transition:background .2s,width .2s}
.dcDot.on{background:#cf4d08;width:18px;border-radius:4px}
.dcSwipe{text-align:center;font-size:10px;letter-spacing:.18em;color:#b3ada3;font-weight:700;margin-top:7px}
/* 🔴 EDITモードのみ: 縦リスト(全カードが一度に見える)。VIEW(横スワイプ)は上の定義のまま不変。 */
.dcWrap.dcEdit{display:flex;flex-direction:column;gap:12px;overflow-x:visible;scroll-snap-type:none;padding:4px 16px}
.dcWrap.dcEdit .dcCard{flex:0 0 auto;width:100%;scroll-snap-align:none;flex-direction:row;align-items:stretch;overflow:visible}
.dcWrap.dcEdit .dcImg{flex:0 0 104px;width:104px;height:auto;min-height:104px;border-radius:0}
.dcWrap.dcEdit .dcImg.empty{border-bottom:0;border-right:1px dashed var(--line)}
.dcWrap.dcEdit .dcBody{flex:1;min-width:0;padding:11px 13px}
.dcWrap.dcEdit .dcCtl{display:flex;flex-direction:column;gap:5px;padding:9px 9px 9px 0;justify-content:center;flex:0 0 auto}
.dcWrap.dcEdit .dcMove,.dcWrap.dcEdit .dcDel{position:static;width:26px;height:26px;border-radius:7px;border:1px solid var(--line);background:#fff;font-size:13px;font-weight:700;line-height:1;cursor:pointer;box-shadow:none;padding:0}
.dcWrap.dcEdit .dcMove{color:#6f6b64}
.dcWrap.dcEdit .dcMove:disabled{opacity:.3;cursor:default}
.dcWrap.dcEdit .dcDel{color:#b3261e}
.dcWrap.dcEdit .dcAdd{align-self:stretch;width:100%;min-width:0;padding:13px}

/* カラー/特徴カード(縦リスト)= 新ブロック featurecards。縦に積む横レイアウトカード(左=画像 / 右=テキスト)。 */
.blk[data-type="featurecards"]{padding:20px 16px 8px}
.fcWrap{display:flex;flex-direction:column;gap:12px}
.fcItem{position:relative;display:flex;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 3px 12px rgba(40,34,26,.05);padding:12px}
.fcImg{flex:0 0 120px;width:120px;height:120px;border-radius:11px;overflow:hidden;background:#f4f1ec}
.fcImg img{width:100%;height:100%;object-fit:cover;display:block}
.fcImg.empty{display:flex;align-items:center;justify-content:center;border:1px dashed var(--line);cursor:pointer}
.fcImgAdd{font-size:11px;font-weight:700;color:#cf4d08}
.fcText{flex:1;min-width:0}
.fcHead{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.fcDot{flex:0 0 auto;width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.12);padding:0}
.fcDot.empty{background:#fff;border:1.5px dashed #cf4d08;cursor:pointer}
.fcName{font-size:15px;font-weight:800;color:var(--ink);line-height:1.4}
.fcSub{font-size:10.5px;font-weight:700;letter-spacing:.16em;color:var(--sub);margin-bottom:5px}
.fcDesc{font-size:12.5px;line-height:1.7;color:var(--sub)}
/* 編集時の空フィールドはプレースホルダ表示(お客様画面では空要素自体が出ない) */
.fcName:empty::before,.fcSub:empty::before,.fcDesc:empty::before{content:attr(data-ph);color:#c9c2b6;font-weight:400;letter-spacing:0}
.fcDel{position:absolute;top:8px;right:8px;z-index:3;border:0;background:rgba(255,255,255,.92);color:#b3261e;width:24px;height:24px;border-radius:50%;font-size:13px;font-weight:700;line-height:1;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.fcAdd{align-self:stretch;border:1.5px dashed var(--line);background:#fff;color:#cf4d08;border-radius:14px;padding:14px;font-weight:700;cursor:pointer;font-size:12px}

/* ピークギャラリー(横スクロール)= 新ブロック peekgallery。大きめ縦長画像を横に並べ、次が少し覗く(peek)。 */
.blk[data-type="peekgallery"]{padding:20px 0 8px}
.blk[data-type="peekgallery"] .secT{padding-left:16px;padding-right:16px}
.pgWrap{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 16px 4px}
.pgWrap::-webkit-scrollbar{display:none}
.pgItem{position:relative;flex:0 0 82%;scroll-snap-align:center;display:flex;flex-direction:column}
.pgImg{width:100%;height:420px;border-radius:16px;overflow:hidden;background:#f4f1ec;cursor:pointer}
.pgImg img{width:100%;height:100%;object-fit:cover;display:block}
.pgImg.empty{display:flex;align-items:center;justify-content:center;border:1px dashed var(--line)}
.pgImgAdd{font-size:12px;font-weight:700;color:#cf4d08}
.pgCap{font-size:13px;line-height:1.6;color:var(--sub);margin-top:9px;padding:0 2px}
/* 編集時の空フィールドはプレースホルダ表示(お客様画面では空要素自体が出ない) */
.pgCap:empty::before{content:attr(data-ph);color:#c9c2b6;font-weight:400}
.pgDel{position:absolute;top:8px;right:8px;z-index:3;border:0;background:rgba(255,255,255,.92);color:#b3261e;width:24px;height:24px;border-radius:50%;font-size:13px;font-weight:700;line-height:1;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.pgAdd{flex:0 0 auto;align-self:stretch;min-width:120px;border:1.5px dashed var(--line);background:#fff;color:#cf4d08;border-radius:16px;font-weight:700;cursor:pointer;font-size:12px;white-space:nowrap}
/* 🔴 EDITモードのみ: 縦リスト(全画像＋キャプションが一度に見える・並べ替え可)。VIEW(横スワイプ)は上の定義のまま不変。 */
.pgWrap.pgEdit{display:flex;flex-direction:column;gap:12px;overflow-x:visible;scroll-snap-type:none;padding:4px 16px}
.pgWrap.pgEdit .pgItem{flex:0 0 auto;width:100%;scroll-snap-align:none;flex-direction:row;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.pgWrap.pgEdit .pgImg{flex:0 0 104px;width:104px;height:auto!important;min-height:104px;border-radius:0}
.pgWrap.pgEdit .pgImg.empty{border:0;border-right:1px dashed var(--line)}
.pgWrap.pgEdit .pgCap{flex:1;min-width:0;margin-top:0;padding:11px 13px;align-self:center}
.pgWrap.pgEdit .pgCtl{display:flex;flex-direction:column;gap:5px;padding:9px 9px 9px 0;justify-content:center;flex:0 0 auto}
.pgWrap.pgEdit .pgMove,.pgWrap.pgEdit .pgDel{position:static;width:26px;height:26px;border-radius:7px;border:1px solid var(--line);background:#fff;font-size:13px;font-weight:700;line-height:1;cursor:pointer;box-shadow:none;padding:0}
.pgWrap.pgEdit .pgMove{color:#6f6b64}
.pgWrap.pgEdit .pgMove:disabled{opacity:.3;cursor:default}
.pgWrap.pgEdit .pgDel{color:#b3261e}
.pgWrap.pgEdit .pgAdd{align-self:stretch;width:100%;min-width:0;padding:13px}

/* 特徴グリッド(アイコン)= 新ブロック icongrid。2列・薄背景カード(アイコン/タイトル/説明)。アイコン=絵文字 or 画像。 */
.blk[data-type="icongrid"]{padding:20px 16px 8px}
.igGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.igItem{position:relative;background:#f5f3ee;border-radius:14px;padding:16px 14px;text-align:center}
.igIconBox{min-height:42px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.igIconBox.empty{cursor:pointer;border:1px dashed var(--line);border-radius:10px;min-height:42px}
.igIcon{display:inline-block}
img.igIcon{width:40px;height:40px;object-fit:contain}
.igIcon.igEmoji{font-size:30px;line-height:1}
.igIconAdd{font-size:11px;font-weight:700;color:#cf4d08}
.igTitle{font-size:14.5px;font-weight:800;color:var(--ink);line-height:1.4;margin-bottom:4px}
.igDesc{font-size:11.5px;line-height:1.6;color:var(--sub)}
/* 編集時の空フィールドはプレースホルダ表示(お客様画面では空要素自体が出ない) */
.igTitle:empty::before,.igDesc:empty::before{content:attr(data-ph);color:#c9c2b6;font-weight:400}
.igDel{position:absolute;top:6px;right:6px;z-index:3;border:0;background:rgba(255,255,255,.92);color:#b3261e;width:22px;height:22px;border-radius:50%;font-size:12px;font-weight:700;line-height:1;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.igAdd{grid-column:1 / -1;border:1.5px dashed var(--line);background:#fff;color:#cf4d08;border-radius:14px;padding:14px;font-weight:700;cursor:pointer;font-size:12px}

/* セット購入 */
.blk[data-type="setbuy"]{padding:22px 16px 8px}
.blk[data-type="setbuy"] .secT{font-size:14px;font-weight:800;margin-bottom:10px}
.blk[data-type="setbuy"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
.setList{list-style:none}
.setList li{display:flex;gap:10px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.setList li:last-child{border-bottom:0}
.setList .setIc{color:#2b6f4a;font-weight:700;flex-shrink:0}
.setList .setLbl{flex:1}
.setPrice{font-size:24px;font-weight:800;margin:14px 0 4px;letter-spacing:.01em}
.setPrice small{font-size:11px;color:var(--sub);font-weight:400;margin-left:8px}
.setBuyBtn{width:100%;border:0;border-radius:13px;padding:15px 8px;font-size:15px;font-weight:800;
           background:var(--accent,#e8590c);color:#fff;cursor:pointer;margin-top:12px;letter-spacing:.04em}
.setBuyBtn:disabled{background:#d8d4cc}
.setEd{font-size:11.5px;color:#6f6b64;margin-top:8px}
.setEd b,.setEd span{outline:none;border-bottom:1px dashed #d8d4cc;padding:0 4px;min-width:2em;display:inline-block}
.setEd span:empty::before{content:attr(data-ph);color:#c9c2b6}

/* お知らせ(トップ用) */
.blk[data-type="news"]{padding:22px 16px 8px}
.blk[data-type="news"] .secT{font-size:14px;font-weight:800;margin-bottom:8px}
.blk[data-type="news"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
/* 雑誌風カード: 正方形サムネ + 太字見出し + 日付 + カテゴリタグ(スマホ1列/PC2列) */
.newsGrid{display:grid;grid-template-columns:1fr;gap:24px 28px}
/* 2行表示の横スライド: カードを2行に並べ、横スクロール(スワイプ)＋丸矢印で流す */
.newsRailWrap{position:relative}
.newsRail{display:grid;grid-auto-flow:column;grid-template-rows:auto auto;grid-auto-columns:100%;gap:20px 16px;
  overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px 1px}
.newsRail::-webkit-scrollbar{display:none}
.newsRail .newsCard{scroll-snap-align:start}
.newsCard{display:flex;gap:14px;align-items:flex-start;text-decoration:none;color:var(--ink)}
.newsThumb{flex:none;width:96px;height:96px;border-radius:10px;overflow:hidden;background:#ece8e1}
.newsThumb img{width:100%;height:100%;object-fit:cover;display:block}
.newsCard .nBody{flex:1;min-width:0;padding-top:2px}
.newsTitle{font-size:14.5px;font-weight:800;line-height:1.5;letter-spacing:.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.newsMeta{margin-top:9px;font-size:11px;color:var(--sub);display:flex;align-items:center;gap:12px;letter-spacing:.07em;flex-wrap:wrap}
.newsMeta .nDate{font-weight:700}
.newsTag{display:inline-flex;align-items:center;gap:5px;color:#8d8a84;font-weight:700;text-transform:uppercase}
.newsTag i{width:7px;height:7px;border-radius:50%;background:#4a6fa5;display:inline-block;flex:none}
.newsPager{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:34px}
.newsPager button{width:54px;height:54px;border-radius:50%;border:1px solid var(--ink);background:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.newsPager button:disabled{opacity:.22;cursor:default}
.newsPager .pg{font-size:13px;letter-spacing:.14em;color:var(--ink)}
/* アーカイブ動線(ブログ連動時のみ)。横スライドの下に控えめに置く。 */
.newsMore{margin-top:22px;text-align:center}
.newsMore a{display:inline-flex;align-items:center;gap:6px;color:var(--ink);font-size:12.5px;font-weight:700;letter-spacing:.06em;text-decoration:none;border-bottom:1px solid var(--ink);padding-bottom:3px}
.newsMore a:hover{opacity:.7}
/* 編集モードのお知らせ行 */
.newsEd{display:flex;flex-direction:column;gap:10px}
.newsEdRow{display:flex;gap:10px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:10px}
.newsEdThumb{flex:none;width:64px;height:64px;border-radius:9px;border:1px dashed #c9c2b6;background:#f7f5f0;color:#a39d92;font-size:10px;cursor:pointer;overflow:hidden;padding:0}
.newsEdThumb img{width:100%;height:100%;object-fit:cover;display:block}
.newsEdBody{flex:1;min-width:0}
.newsEdTitle{font-size:13.5px;font-weight:700;line-height:1.5;outline:none;min-height:20px}
.newsEdTitle:empty::before{content:attr(data-ph);color:#c9c2b6}
.newsEdMeta{display:flex;align-items:center;gap:10px;margin-top:6px;flex-wrap:wrap}
.newsEdDate,.newsEdCat{font-size:11px;color:var(--sub);outline:none;border:1px solid var(--line);border-radius:6px;padding:3px 7px;min-width:40px}
.newsEdDate:empty::before,.newsEdCat:empty::before{content:attr(data-ph);color:#c9c2b6}
.newsEdColor{width:28px;height:24px;border:1px solid var(--line);border-radius:6px;padding:0;cursor:pointer;background:#fff}
.newsEdCfg{font-size:11px;color:var(--sub);margin-top:8px}
.newsEdCfg input{border:1px solid var(--line);border-radius:6px;padding:3px 5px;margin:0 4px}

/* ブログ(Wixブログ連動・ヘッドレス) */
.blk[data-type="blog"]{padding:22px 16px 8px}
.blk[data-type="blog"] .secT{font-size:14px;font-weight:800;margin-bottom:12px}
.blk[data-type="blog"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
.blogEdNote{font-size:12.5px;line-height:1.8;color:var(--ink);background:#f7f5f0;border:1px dashed #c9c2b6;border-radius:10px;padding:14px 16px}
.blogMsg{font-size:13px;color:var(--sub);padding:24px 4px;text-align:center}
/* 一覧カード(スマホ1列/PC2列) */
.blogGrid{display:grid;grid-template-columns:1fr 1fr;gap:18px 12px}
.blogCard{display:block;text-decoration:none;color:var(--ink)}
.blogCardImg{width:100%;aspect-ratio:1/1;border-radius:12px;overflow:hidden;background:#ece8e1}
.blogCardImg img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.blogCard:hover .blogCardImg img{transform:scale(1.04)}
.blogCardImg.noimg{background:#ece8e1}
.blogCardBody{padding-top:11px}
.blogCardMeta{font-size:11px;color:var(--sub);letter-spacing:.07em;font-weight:700;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.blogCardTitle{font-size:15px;font-weight:800;line-height:1.55;margin:6px 0 0;letter-spacing:.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blogCardEx{font-size:12.5px;line-height:1.7;color:var(--sub);margin:7px 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
/* 記事本文 */
.blogArticle{max-width:680px;margin:0 auto}
.blogHero{width:100%;border-radius:14px;overflow:hidden;background:#ece8e1;margin-bottom:20px}
.blogHero img{width:100%;height:auto;display:block}
.blogH1{font-size:21px;font-weight:800;line-height:1.5;letter-spacing:.01em;margin:0 0 10px}
.blogArtMeta{font-size:11.5px;color:var(--sub);letter-spacing:.07em;font-weight:700;display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.blogBody{font-size:14.5px;line-height:1.95;color:var(--ink);letter-spacing:.01em}
.blogBody p{margin:0 0 2px}
.blogBody p.blogSp{height:14px;margin:0}
.blogBody h2{font-size:17px;font-weight:800;margin:30px 0 12px;line-height:1.5}
.blogBody h3{font-size:15px;font-weight:800;margin:24px 0 10px;line-height:1.5}
.blogBody img{max-width:100%;height:auto;border-radius:12px;display:block;margin:18px auto}
.blogBody ul,.blogBody ol{margin:10px 0 14px;padding-left:1.4em}
.blogBody li{margin:0 0 6px;line-height:1.85}
.blogBody a{color:var(--accent,#cf4d08);text-decoration:underline}
.blogBackWrap{margin:34px 0 4px;text-align:center}
.blogBtn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--ink);border-radius:99px;padding:11px 26px;font-size:13px;font-weight:700;color:var(--ink);text-decoration:none;background:#fff}
.blogBtn:hover{background:var(--ink);color:#fff}
@media(min-width:640px){ .blogGrid{grid-template-columns:1fr 1fr;gap:28px 30px} }

/* 商品グリッド(トップ用) */
.blk[data-type="pgrid"]{padding:22px 16px 8px}
.blk[data-type="pgrid"] .secT{font-size:14px;font-weight:800;margin-bottom:10px}
.blk[data-type="pgrid"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
.pgGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pgCard{position:relative;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;text-decoration:none;color:var(--ink);display:block}
.pgCard img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#f4f1ec}
.pgCard .pgN{font-size:12px;font-weight:700;line-height:1.45;padding:8px 10px 2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:43px}
/* 色マーク + デザイン数(英語 design)。任意=未設定の商品は出ない */
.pgCard .pgMarks{display:flex;align-items:center;gap:5px;flex-wrap:wrap;padding:0 10px 3px}
.pgCard .pgDot{width:11px;height:11px;border-radius:50%;border:1px solid rgba(0,0,0,.16);display:inline-block;flex:none}
.pgCard .pgMore{font-size:10.5px;color:var(--sub);font-weight:700}
.pgCard .pgDsn{font-size:10.5px;color:var(--sub);font-weight:700;letter-spacing:.02em;margin-left:3px}
.pgCard .pgP{font-size:13.5px;font-weight:800;padding:0 10px 10px}
.pgDel{position:absolute;top:6px;right:6px;border:0;background:rgba(255,255,255,.92);color:#b3261e;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:12px;box-shadow:0 1px 4px rgba(0,0,0,.18)}

/* カテゴリ商品(自動グリッド・トップ用)。グリッドは .pgGrid を流用 */
.blk[data-type="catitems"]{padding:22px 16px 8px}
.blk[data-type="catitems"] .secT{font-size:14px;font-weight:800;margin-bottom:10px}
.blk[data-type="catitems"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}

/* 商品カテゴリ(トップ用) */
.blk[data-type="catgrid"]{padding:22px 16px 8px}
.blk[data-type="catgrid"] .secT{font-size:14px;font-weight:800;margin-bottom:10px}
.blk[data-type="catgrid"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
/* カテゴリー/アーティスト = 3列グリッド(スライダー無し・MUJI参考)。スクエア角丸タイル＋下に文章 */
.catGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
/* 枠無し(MUJI風: 画像角丸＋文章のみ・カードの枠と白背景を消す) */
.catGrid.noBorder .catCard{border:0;background:transparent}
/* カテゴリータブ(コレクションページ: 全商品 + 各カテゴリーで絞り込み) */
.catTabs{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px}
.catTab{border:1px solid var(--line);background:#fff;border-radius:99px;padding:7px 16px;font-size:12.5px;font-weight:700;color:#6f6b64;cursor:pointer;white-space:nowrap}
.catTab.on{background:#1d1d1b;color:#fff;border-color:#1d1d1b}
/* 商品カテゴリーへのナビ(別色・上段・他カテゴリへ移動)。作家タブ(catTab=黒)と区別するためオレンジ系。 */
.catNavBar{display:flex;flex-wrap:wrap;gap:8px;margin:2px 0 8px}
.catNavTag{border:1px solid #e7c9a8;background:#fdf3e9;border-radius:99px;padding:6px 14px;font-size:12px;font-weight:700;color:#b5601a;cursor:pointer;white-space:nowrap;text-decoration:none}
.catNavTag:hover{background:#f6e3cf;border-color:#dab184}
.catNavTag.on{background:#cf4d08;color:#fff;border-color:#cf4d08}
/* 🔴 スマホ: タグが折り返してぐちゃぐちゃになるのを防ぐ。1行で横スクロール(スワイプ)。 */
@media(max-width:640px){
  .catTabs,.catNavBar{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}
  .catTabs::-webkit-scrollbar,.catNavBar::-webkit-scrollbar{display:none}
  .catTab,.catNavTag{flex:0 0 auto}
  /* アーティストページの商品カテゴリー絞り込みは「全部見える折り返し」(スライダーにしない) */
  .catTabs.allWrap{flex-wrap:wrap;overflow-x:visible}
}
.catCard{position:relative;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;text-decoration:none;color:var(--ink);display:block}
.catCard .catImg{position:relative;background:#f4f1ec}
.catCard .catImg img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
.catCard .catN{font-size:13px;font-weight:800;line-height:1.4;padding:10px 12px;letter-spacing:.02em;outline:none}
.catCard .catN:empty::before{content:"カテゴリ名";color:#c9c2b6}
.catCard .catLink{font-size:10.5px;color:var(--sub);padding:0 12px 10px;outline:none;word-break:break-all}
.catCard .catLink:empty::before{content:attr(data-ph);color:#c9c2b6}
/* アイコングリッド(カテゴリー/作家=noBorder): アイコン小さめ・余白詰め・ラベル中央。ラベルは \n で改行可(render側で<br>化) */
.catGrid.noBorder .catImg{background:transparent;display:flex;align-items:center;justify-content:center}
.catGrid.noBorder .catImg img{width:78%;height:auto;aspect-ratio:1/1;object-fit:contain}
.catGrid.noBorder .catN{text-align:center;font-size:12px;padding:6px 4px 0;line-height:1.35;letter-spacing:0}
@media(max-width:767px){
  .catGrid.noBorder{gap:8px 6px}
  .catGrid.noBorder .catImg img{width:70%}
  .catGrid.noBorder .catN{font-size:11px;line-height:1.3;padding:4px 1px 0}
}
.catCard .catPic{position:absolute;top:6px;left:6px;border:0;background:rgba(255,255,255,.92);width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:13px;box-shadow:0 1px 4px rgba(0,0,0,.18);line-height:1}
.catCard .catEye{position:absolute;top:6px;right:6px;border:0;background:rgba(255,255,255,.92);width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:13px;box-shadow:0 1px 4px rgba(0,0,0,.18);line-height:1}
.catCard .catTools{display:flex;gap:4px;padding:6px 8px 0;justify-content:center}
.catCard .catTools button{width:26px;height:24px;border:1px solid var(--line);background:#fff;border-radius:7px;cursor:pointer;font-size:12px;line-height:1}
.catCard .catTools button:disabled{opacity:.3;cursor:default}
.catCard .catTools .catDel{color:#b3261e;border-color:#f0c9c4}
.catCard.catHidden{opacity:.4}
.catCard.catHidden .catImg::after{content:"非表示";position:absolute;top:6px;left:50%;transform:translateX(-50%);background:#6f6b64;color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:8px}

/* 関連アイテム(横スクロール・Amazon風) */
.blk[data-type="related"]{padding:20px 16px 12px}
.blk[data-type="related"] .secT{font-size:14px;font-weight:800;margin-bottom:12px}
.blk[data-type="related"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
.relRow{display:flex;gap:13px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
/* スマホは1画面に約2.5枚(3枚目が少し覗いて「次を見る」を促す)。割合ベースで端末幅に追従 */
.relCard{flex:0 0 38%;scroll-snap-align:start;text-decoration:none;color:var(--ink);position:relative;display:block}
.relImg{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#f4f1ec;aspect-ratio:1/1}
.relImg img{width:100%;height:100%;object-fit:cover;display:block}
.relBadge{position:absolute;top:8px;left:8px;z-index:2;font-size:10px;font-weight:800;letter-spacing:.05em;padding:3px 8px;border-radius:4px}
.relBadge.new{background:#1d1d1b;color:#fff}
.relBadge.sale{background:#cf4d08;color:#fff}
.relN{font-size:12.5px;font-weight:700;line-height:1.5;margin-top:9px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.relP{font-size:14px;font-weight:800;margin-top:3px}
.relAdd{flex:0 0 auto;align-self:center;border:1.5px dashed var(--line);background:#fff;color:#cf4d08;border-radius:12px;padding:16px 18px;font-weight:700;cursor:pointer;font-size:12px;white-space:nowrap}
.relCard .pgDel{position:absolute;top:6px;right:6px}

/* よくあるご質問(FAQ・アコーディオン) */
.blk[data-type="faq"]{padding:18px 16px 10px}
.blk[data-type="faq"] .secT{font-size:14px;font-weight:800;margin-bottom:8px}
.blk[data-type="faq"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
.faqCat{font-size:11.5px;font-weight:800;letter-spacing:.13em;color:var(--ink);margin:28px 0 4px;padding-bottom:8px;border-bottom:1px solid var(--ink)}
.faqItem{border-bottom:1px solid var(--line)}
.faqQ{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:none;border:0;text-align:left;padding:16px 2px;cursor:pointer;font-size:14px;font-weight:700;color:var(--ink);line-height:1.55;font-family:inherit}
.faqChev{transition:transform .25s;color:var(--sub);flex:none;font-size:13px;line-height:1}
.faqItem.open .faqChev{transform:rotate(180deg)}
.faqA{display:none;padding:0 2px 18px;font-size:13px;line-height:1.95;color:#48443d}
.faqItem.open .faqA{display:block}
.faqEd{display:flex;flex-direction:column;gap:12px}
.faqEdRow{display:grid;grid-template-columns:1fr auto;gap:7px;border-bottom:1px solid var(--line);padding-bottom:12px;align-items:start}
.faqEdRow .faqEdCat,.faqEdRow .faqEdQ{grid-column:1;border:1px solid var(--line);border-radius:7px;padding:6px 9px;font-size:12.5px;font-family:inherit}
.faqEdRow .faqEdQ{font-weight:700}
.faqEdRow .faqEdA{grid-column:1;border:1px solid var(--line);border-radius:7px;padding:7px 9px;font-size:12px;line-height:1.7;min-height:74px;font-family:inherit;resize:vertical}
.faqEdRow .rowDel{grid-column:2;grid-row:1/4;align-self:start}

/* バナー */
.blk[data-type="banner"] .bn{margin:18px 16px 0;border:1.5px dashed var(--accent);border-radius:13px;
  padding:13px 14px;font-size:13px;background:#fff8f3}

/* 線見出し(サブキャッチ + 横線で挟んだ見出し)。既定は無印良品ふうの「間隔広め・軽い字面・字間広め」 */
.blk[data-type="linehead"]{padding:30px 16px 16px}
.lineHead{text-align:center}
.lhSub{font-size:11.5px;color:var(--sub);letter-spacing:.2em;margin-bottom:18px;line-height:1.7}
.lhMain{display:flex;align-items:center;justify-content:center;gap:20px}
.lhLine{flex:1 1 0;max-width:72px;height:1px;background:var(--ink);opacity:.8}
.lhTxt{font-size:19px;font-weight:700;letter-spacing:.1em;line-height:1.7;white-space:nowrap}

/* 吹き出し(上に三角ポインタ) */
.blk[data-type="callout"]{padding:20px 16px 8px}
.callout{position:relative}
.coBox{position:relative;background:var(--cobg,#fbeef0);border-radius:14px;padding:16px 18px;
  font-size:14px;font-weight:700;line-height:1.8;color:var(--ink)}
.coBox::before{content:"";position:absolute;top:-9px;left:50%;transform:translateX(-50%);
  border-left:11px solid transparent;border-right:11px solid transparent;border-bottom:10px solid var(--cobg,#fbeef0)}
.coBox.dark{color:#f4f1ec}
/* 角アキ(左上だけ四角いチャット風・三角なし・本文向けに通常文字+広め行間) */
.coBox.corner{border-radius:3px 18px 18px 18px;font-weight:400;line-height:2.0;font-size:13.5px;padding:18px 20px}
.coBox.corner::before{display:none}

/* ボックス(角丸の箱) */
.blk[data-type="box"]{padding:16px 16px 6px}
.bxBox{background:var(--bxbg,#f1f1f3);border-radius:14px;padding:16px 18px;
  font-size:13.5px;line-height:1.95;color:var(--ink)}
.bxBox.dark{color:#f4f1ec}

/* 区切り線 */
.blk[data-type="divider"]{padding:20px 16px}
.dv{border:0;border-top:1px solid var(--line)}
.dv.bold{border-top:3px solid var(--ink)}
.dv.dot{border-top:2px dotted #c9c2b6}
.dv.dbl{border-top:4px double #c9c2b6}
.dv.cat{border:0;text-align:center;color:#c9c2b6;font-size:13px;letter-spacing:.6em;line-height:1}
.dv.cat:before{content:"🐾 🐾 🐾"}

/* 購入ブロック */
.blk[data-type="buy"]{padding:22px 16px 8px}
.blk[data-type="buy"] .secT{font-size:14px;font-weight:800;margin-bottom:12px}
.blk[data-type="buy"] .secT small{display:block;font-size:10px;color:var(--sub);letter-spacing:.22em;margin-bottom:3px}
.cards{display:flex;gap:9px;overflow-x:auto;padding-bottom:6px}
.card{flex:0 0 108px;border:1.5px solid var(--line);border-radius:13px;overflow:hidden;background:#fff;cursor:pointer}
.card img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#f4f1ec}
.card .nm{font-size:11.5px;font-weight:700;text-align:center;padding:6px 3px 2px}
.card .st{font-size:10px;text-align:center;padding-bottom:6px;color:var(--sub)}
.card .st.low{color:var(--accent-dark);font-weight:700}
.card .st.out{color:#b9b4ab;font-weight:700}
.card.sel{border-color:var(--ink);box-shadow:0 0 0 1.5px var(--ink)}
.card.out{opacity:.55;cursor:default}
.qty{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:12px;width:max-content;overflow:hidden;margin-top:12px}
.qty button{width:46px;height:46px;border:0;background:#fff;font-size:20px;cursor:pointer;color:var(--ink)}
.qty span{width:46px;text-align:center;font-weight:700}

.pFootNav{display:flex;justify-content:space-between;gap:10px;margin:26px 16px 10px}
.pFootNav a{flex:1;text-align:center;border:1.5px solid var(--line);border-radius:13px;padding:12px 6px;
  text-decoration:none;color:var(--ink);font-size:12.5px;font-weight:700;background:#fff}
.pDemoNote{margin:10px 16px 18px;font-size:10.5px;color:var(--sub);text-align:center}

.bar{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);
     padding:11px 14px calc(11px + env(safe-area-inset-bottom));z-index:30}
.bar .in{max-width:430px;margin:0 auto;display:flex;align-items:center;gap:11px}
.barL{min-width:92px}
.barL .p{font-size:17px;font-weight:800}
.barL .s{font-size:10px;color:var(--sub)}
.buy{flex:1;border:0;border-radius:13px;padding:14px 8px;font-size:15px;font-weight:800;
     background:var(--accent);color:#fff;cursor:pointer;letter-spacing:.04em}
.buy:disabled{background:#d8d4cc}

/* 文字装飾(本文内) */
.t b,.h b{font-weight:800}
.t mark,.h mark{background:var(--marker);padding:0 2px}
.t u,.h u{text-decoration-thickness:2px;text-underline-offset:3px}

/* ===== レスポンシブ(閲覧ページ専用 = body.shopView) =====
   エディタ(index.html)は .phone 430px 固定枠で body に shopView が付かないため、
   ここの media query はエディタのプレビューには一切効かない(意図的なスコープ) */
@media (min-width:700px){
  .shopView .page{max-width:920px;padding-bottom:130px}
  .shopView .pHeader{padding:16px 30px}
  .shopView .pTitle{padding:22px 30px 4px}
  /* セクションの左右余白をPC向けに広げる */
  .shopView .blk[data-type="hero"],
  .shopView .blk[data-type="news"],
  .shopView .blk[data-type="pgrid"],
  .shopView .blk[data-type="catgrid"],
  .shopView .blk[data-type="catitems"],
  .shopView .blk[data-type="banner"],
  .shopView .blk[data-type="heading"],
  .shopView .blk[data-type="body"]{padding-left:30px;padding-right:30px}
  .shopView .pBack{padding-left:30px;padding-right:30px}
  /* 商品グリッド・カテゴリは 3 列に展開(catGridはスマホ横スクロール→PCはグリッドに戻す) */
  .shopView .pgGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;overflow:visible}
  /* カテゴリー/アーティスト: スマホ3列・PCはブロック毎の列数(--pcCols 既定4・商品カテゴリは6) */
  .shopView .catGrid{display:grid;grid-template-columns:repeat(var(--pcCols,4),1fr);gap:18px;overflow:visible}
  /* お知らせ(雑誌風)は PC で 2 列 */
  .shopView .newsGrid{grid-template-columns:1fr 1fr;gap:30px 40px}
  /* 2行横スライド: PCは2列ぴったりで改ページ(覗き見なし。送りは丸矢印で) */
  .shopView .newsRail{grid-auto-columns:calc((100% - 32px) / 2);gap:26px 32px}
  /* PCはこれまでの見え方を維持(サムネ・見出しはスマホより大きめ) */
  .shopView .newsThumb{width:120px;height:120px}
  .shopView .newsTitle{font-size:16.5px}
  /* 関連アイテムは PC では固定幅カードで多めに並べてスクロール */
  .shopView .relCard{flex:0 0 210px}
  /* ヒーロー/単体画像は中央寄せで上限(横長画面で巨大化させない) */
  .shopView .blk[data-type="hero"] .frame{max-width:640px;margin:0 auto}
  .shopView .blk[data-type="hero"] .cap{text-align:center}
  /* 本文・見出しは読みやすい行長で中央 */
  .shopView .blk[data-type="body"] .t,
  .shopView .blk[data-type="heading"] .h{max-width:720px;margin-left:auto;margin-right:auto}
  /* アバウト(夜色帯)は全幅・中の文章だけ中央寄せ */
  .shopView .blk[data-type="story"] .story{padding:44px 40px 48px}
  .shopView .blk[data-type="story"] .en,
  .shopView .blk[data-type="story"] .h,
  .shopView .blk[data-type="story"] .t{max-width:760px;margin-left:auto;margin-right:auto}
  /* スライダーは 2 枚見せ */
  .shopView .slTrack .sl{flex:0 0 46%}
  /* ===== 新4ブロックの PC レイアウト(VIEW のみ・スマホ<700pxは不変)。
     編集の縦リスト/グリッド(.dcEdit/.pgEdit)は :not() で除外=現状維持。 ===== */
  /* 詳細カード: PCは 2〜2.5 枚見せ(peek維持)。編集縦リスト(.dcEdit)は対象外。 */
  .shopView .dcWrap:not(.dcEdit) .dcCard{flex:0 0 40%}
  /* ピークギャラリー: PCは 2 枚見せ。画像高さは現状維持。編集縦リスト(.pgEdit)は対象外。 */
  .shopView .pgWrap:not(.pgEdit) .pgItem{flex:0 0 47%}
  /* カラー/特徴カード: PCは 2 列グリッド(横長1行が広すぎるのを解消)。各カードは横レイアウトのまま。 */
  .shopView .fcWrap{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  /* 特徴グリッド(アイコン): PCは 4 列。 */
  .shopView .igGrid{grid-template-columns:repeat(4,1fr)}
  /* 下部の購入バーは中央のすっきりした幅に / フッターナビも中央 */
  .shopView .bar .in{max-width:560px}
  .shopView .pFootNav{max-width:560px;margin-left:auto;margin-right:auto}
}
@media (min-width:1080px){
  .shopView .page{max-width:1080px}
  .shopView .pgGrid{grid-template-columns:repeat(4,1fr)}
  /* カテゴリー/アーティストは3列のまま(CEo指定「3列」) */
}

/* お問い合わせフォーム(form ブロック) */
.blk[data-type="form"]{padding:14px 16px 6px}  /* 🔴 他ブロックと同じ左右16px。無いと .blk 既定padなしで全幅はみ出し */
.cform{margin:4px 0}
.cformIntro{font-size:13.5px;line-height:1.85;color:#5b554d;margin:0 0 16px}
.cformBox{display:flex;flex-direction:column;gap:14px;max-width:540px}
.cformF{display:flex;flex-direction:column;gap:5px}
.cformL{font-size:12.5px;font-weight:700;color:#4a443c}
.cformL em{color:#cf4d08;font-style:normal}
.cformI{font:inherit;font-size:15px;padding:11px 13px;border:1px solid #d8d2c8;border-radius:10px;background:#fff;color:#1d1d1b;width:100%;box-sizing:border-box}
.cformI:focus{outline:none;border-color:#cf4d08;box-shadow:0 0 0 3px rgba(207,77,8,.12)}
textarea.cformI{resize:vertical;line-height:1.7}
.cformI:disabled{background:#f4f1ec;color:#9b958b}
.cformBtn{align-self:flex-start;background:#1d1d1b;color:#fff;border:none;border-radius:11px;padding:13px 34px;font-size:14.5px;font-weight:800;cursor:pointer;letter-spacing:.04em}
.cformBtn:hover{background:#000}
.cformBtn:disabled{opacity:.55;cursor:default}
.cformStat{font-size:13.5px;line-height:1.8;padding:13px 15px;border-radius:10px}
.cformStat.ok{background:#eef6ed;color:#2c6e2c;border:1px solid #bfe0bd}
.cformStat.err{background:#fbeeea;color:#b13b12;border:1px solid #f0c8ba}

/* 商品グリッド(pgrid): 並べ替え↑↓ / 続きを見る / 編集トグル */
.pgCard{position:relative}
.pgMv{position:absolute;top:6px;width:26px;height:26px;border-radius:7px;border:none;background:rgba(29,29,27,.72);color:#fff;font-size:14px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}
.pgMv:hover{background:#1d1d1b}
.pgUp{left:6px}.pgDn{left:36px}
.pgMore{display:block;margin:16px auto 4px;background:#fff;color:#1d1d1b;border:1px solid #d8d2c8;border-radius:999px;padding:11px 30px;font-size:13.5px;font-weight:800;cursor:pointer;letter-spacing:.03em}
.pgMore:hover{border-color:#1d1d1b}
.pgMoreN{color:#8d8a84;font-weight:600;font-size:12px}
.pgEdCtl{display:flex;flex-direction:column;gap:4px;padding:9px 0 2px}
.pgEdAuto{font-size:12px;font-weight:700;color:#3a352e;display:flex;align-items:center;gap:6px;cursor:pointer}
.pgEdAuto input{width:15px;height:15px}
.pgEdHint{font-size:10.5px;color:#a39d92;line-height:1.6}
