/* ================================================================
   tobiuo-theme / assets/css/style.css
   PC・SP 明確分離版  重複なし
================================================================ */

/* ━━ RESET ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;font-size:var(--t-md);line-height:1.75;
     color:#1a1209;background:#f5f3ef;overflow-x:hidden}
a{color:inherit;text-decoration:none;transition:all .2s}
img{display:block;max-width:100%;height:auto}
button{cursor:pointer;font-family:inherit;border:none;background:none}
ul{list-style:none;padding:0;margin:0}
input,select,textarea{font-family:inherit}
:root{
  --nv:#0A1628;--nv2:#0d1f38;--nv3:#162d4a;
  --gd:#B8860B;--gd2:#d4a017;--gdp:#f7f0df;
  --bg:#f5f3ef;--bg2:#ede9e2;
  --border:#ddd8ce;--border2:#e8e4dc;
  --text:#1a1209;--text2:#3d3428;--text3:#8a8078;
  --r:#BF0000;--a:#FF9900;--y:#FF0033;--m:#FF0211;
  --sh:0 2px 12px rgba(10,22,40,.08);
  --sh2:0 8px 32px rgba(10,22,40,.16);
  --rad:6px;
  /* タイポグラフィスケール */
  --t-xl:1.5rem;    /* 24px ページタイトル・商品詳細名 */
  --t-lg:1.1rem;    /* 18px セクション見出し */
  --t-md:0.875rem;  /* 14px カード名・セールタイトル */
  --t-base:0.8125rem; /* 13px 本文・説明文 */
  --t-sm:0.75rem;   /* 12px 補足・日付 */
  --t-xs:0.6875rem; /* 11px バッジ・ラベル */
}
.sp-only{display:none}

/* ━━ OPENING ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#op{position:fixed;inset:0;z-index:9999;background:var(--nv);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:9px;pointer-events:none}
.op-logo{height:56px;width:auto;opacity:0;transform:translateY(10px);
         animation:opIn .9s ease .15s forwards}
.op-ln{width:36px;height:1px;background:var(--gd);
       opacity:0;animation:opIn .8s ease .45s forwards}
.op-en{font-family:'Roboto',sans-serif;font-size:.58rem;color:rgba(255,255,255,.35);
       letter-spacing:.3em;text-transform:uppercase;
       opacity:0;animation:opIn .8s ease .6s forwards}
@keyframes opIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
#op.out{animation:opOut .5s ease forwards}
@keyframes opOut{to{opacity:0}}

/* ━━ HERO ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#hero{position:relative;width:100%;height:100svh;min-height:560px;
      overflow:hidden;background:linear-gradient(158deg,#050f1e 0%,#0a1e38 50%,#0f2944 100%)}
.hsl{position:absolute;inset:0;opacity:0;transition:opacity 1.6s ease;overflow:hidden}
.hsl.on{opacity:1}
.hsl-vid,.hsl-bg{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  min-width:100%;min-height:100%;
  width:auto;height:auto;object-fit:cover;
}
.hero-ov{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(to right,rgba(5,15,30,.14) 0%,rgba(5,15,30,.25) 55%,transparent 100%),
    linear-gradient(to top,rgba(5,15,30,.82) 0%,rgba(5,15,30,.3) 40%,transparent 72%);
}
.hero-grid{position:absolute;inset:0;z-index:1;
  background-image:linear-gradient(rgba(184,134,11,.05) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(184,134,11,.05) 1px,transparent 1px);
  background-size:64px 64px}
.hbar-t,.hbar-b{position:absolute;left:0;height:2px;width:0;z-index:20}
.hbar-t{top:0;background:linear-gradient(90deg,var(--gd),rgba(212,160,23,.25))}
.hbar-b{bottom:0;background:rgba(255,255,255,.25)}
@keyframes barW{from{width:0}to{width:100%}}
.hero-logo-top{position:absolute;top:24px;left:32px;z-index:20}
.hero-logo-img{height:32px;width:auto;display:block}
.hero-cap{position:absolute;top:70%;left:8%;transform:translateY(-50%);
          z-index:10;color:#fff;max-width:580px}
.hero-ey{font-family:'Roboto',sans-serif;font-size:.62rem;font-weight:bold;
         letter-spacing:.16em;color:rgba(184,134,11,.71);text-transform:uppercase;
         margin-bottom:8px;line-height:1.2;
         opacity:0;transform:translateY(8px);transition:opacity .7s .1s,transform .7s .1s}
.hsl.on .hero-ey{opacity:1;transform:translateY(0)}
.hero-cap h1{font-size:clamp(1.6rem,3.2vw,42px);font-weight:600;line-height:1.3;
             letter-spacing:.1em;text-shadow:0 2px 28px rgba(0,0,0,.55);margin-bottom:16px;
             opacity:0;transform:translateY(24px);filter:blur(3px)}
.hsl.on .hero-cap h1{animation:heroTitleFade 1.0s ease forwards}
.hero-cap p{font-size:clamp(.78rem,.95vw,14px);line-height:1.85;font-weight:400;
            letter-spacing:.01em;color:rgba(255,255,255,.82);
            opacity:0;transform:translateY(20px);filter:blur(3px)}
.hsl.on .hero-cap p{animation:heroTextFade 1.15s ease forwards .18s}
@keyframes heroTitleFade{
  from{opacity:0;transform:translateY(24px);filter:blur(3px)}
  to{opacity:1;transform:translateY(0);filter:blur(0)}}
@keyframes heroTextFade{
  from{opacity:0;transform:translateY(20px);filter:blur(3px)}
  to{opacity:1;transform:translateY(0);filter:blur(0)}}
.scr-ind{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
         display:flex;flex-direction:column;align-items:center;gap:7px;opacity:.5;z-index:10}
.scr-ind span{font-family:'Roboto',sans-serif;font-size:.55rem;letter-spacing:.22em;
              color:#fff;text-transform:uppercase}
.scr-ln{width:1px;height:30px;background:linear-gradient(to bottom,#fff,transparent);
        animation:sl 2.4s ease-in-out infinite}
@keyframes sl{
  0%,100%{transform:scaleY(0);transform-origin:top}
  45%{transform:scaleY(1);transform-origin:top}
  55%{transform:scaleY(1);transform-origin:bottom}
  99%{transform:scaleY(0);transform-origin:bottom}}
.hero-dots{position:absolute;bottom:28px;right:8%;z-index:10;display:flex;gap:7px}
.hdot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.32);
      border:none;padding:0;transition:all .3s;cursor:pointer}
.hdot.on{background:var(--gd);transform:scale(1.4)}
.hn{display:none!important}

/* ━━ HEADER ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#hdr{background:rgba(10,22,40,.97);border-bottom:1px solid rgba(184,134,11,.2);
     position:sticky;top:0;z-index:200;backdrop-filter:blur(14px);
     box-shadow:0 2px 16px rgba(0,0,0,.22)}
.hdr-inner{max-width:1380px;margin:0 auto;display:flex;align-items:center;
           padding:10px 24px;gap:20px}
.hdr-logo{flex-shrink:0;display:block}
.site-logo-svg{height:38px;width:auto;display:block}
.hdr-search{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}
.hdr-search form{display:flex;width:100%}
.hdr-search input{flex:1;padding:9px 16px;border:1px solid rgba(255,255,255,.14);border-right:none;
  border-radius:4px 0 0 4px;background:rgba(255,255,255,.1);color:#fff;font-size:var(--t-base);outline:none;
  transition:border-color .2s,background .2s}
.hdr-search input::placeholder{color:rgba(255,255,255,.35)}
.hdr-search input:focus{border-color:var(--gd);background:rgba(255,255,255,.14)}
.hdr-search button{background:var(--gd);color:#fff;border:1px solid var(--gd);
  padding:0 20px;border-radius:0 4px 4px 0;font-size:var(--t-base);font-weight:600;
  font-family:'Roboto',sans-serif;letter-spacing:.06em;cursor:pointer;
  transition:background .2s;display:flex;align-items:center;gap:6px;white-space:nowrap}
.hdr-search button:hover{background:var(--gd2)}
.hdr-keywords{display:flex;align-items:center;gap:7px;flex-wrap:nowrap;overflow:hidden}
.hdr-kw-lbl{font-family:'Roboto',sans-serif;font-size:.58rem;
            color:rgba(255,255,255,.38);letter-spacing:.08em;white-space:nowrap}
.hdr-kw{font-size:var(--t-xs);color:rgba(255,255,255,.58);background:rgba(255,255,255,.06);
        border:1px solid rgba(255,255,255,.1);padding:3px 11px;border-radius:999px;
        transition:all .2s;white-space:nowrap}
.hdr-kw:hover{color:#fff;background:rgba(184,134,11,.2);border-color:rgba(184,134,11,.45)}
.icon-nav{display:flex;align-items:center;gap:2px;flex-shrink:0}
.icon-link{display:flex;flex-direction:column;align-items:center;gap:3px;
           padding:5px 10px;border-radius:5px;color:rgba(255,255,255,.72);
           font-size:var(--t-xs);font-weight:500;transition:all .2s;
           white-space:nowrap;position:relative;text-decoration:none}
.icon-link:hover{color:#fff;background:rgba(255,255,255,.09)}
.icon-link svg{stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.icon-badge{position:absolute;top:2px;right:6px;width:14px;height:14px;border-radius:50%;
            background:var(--gd);color:var(--nv);font-family:'Roboto',sans-serif;
            font-size:7px;font-weight:700;display:flex;align-items:center;justify-content:center}
.icon-sep{width:1px;height:32px;background:rgba(255,255,255,.1);margin:0 2px}
.burger{display:flex;flex-direction:column;gap:0;padding:6px 8px}
.burger span{display:block;width:24px;height:1px;background:rgba(255,255,255,.9);border-radius:0;transition:all .3s;margin:5px 0}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.sp-srch{padding:8px 12px;background:var(--nv2);border-bottom:1px solid rgba(184,134,11,.12);display:none}
.sp-srch form{display:flex}
.sp-srch input{flex:1;padding:8px 12px;border:1px solid rgba(255,255,255,.12);border-right:none;
  border-radius:3px 0 0 3px;background:rgba(255,255,255,.09);color:#fff;font-size:var(--t-base);outline:none}
.sp-srch input::placeholder{color:rgba(255,255,255,.3)}
.sp-srch button{background:var(--gd);color:#fff;border:1px solid var(--gd);
  padding:0 13px;border-radius:0 3px 3px 0;display:flex;align-items:center}

/* ━━ DRAWER ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.dr-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.62);z-index:300}
.dr-ov.open{display:block}
.dr{position:fixed;top:0;right:0;bottom:0;width:280px;background:var(--nv);z-index:400;
    transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
    border-left:1px solid rgba(184,134,11,.18);overflow-y:auto;padding:54px 0 32px}
.dr.open{transform:translateX(0)}
.dr-x{position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;
      background:rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;
      justify-content:center;cursor:pointer;border:none;font-size:.85rem;transition:background .2s}
.dr-x:hover{background:rgba(255,255,255,.2)}
.dr-lbl{padding:11px 20px 4px;font-family:'Roboto',sans-serif;font-size:.58rem;
        font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gd);
        border-top:1px solid rgba(255,255,255,.06);margin-top:4px}
.dr-link{display:flex;align-items:center;padding:11px 20px;font-size:var(--t-base);font-weight:500;
         color:rgba(255,255,255,.72);border-bottom:1px solid rgba(255,255,255,.05);transition:all .2s}
.dr-link:hover{color:var(--gd);background:rgba(255,255,255,.04)}

/* ━━ GLOBAL NAV ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.gnav{background:var(--nv);border-bottom:2px solid var(--gd);position:sticky;top:62px;z-index:190}
.gnav ul{display:flex;max-width:1380px;margin:0 auto;padding:0 24px;
         overflow-x:auto;scrollbar-width:none}
.gnav ul::-webkit-scrollbar{display:none}
.gnav li{position:relative}
.gnav li a{display:block;padding:12px 15px;font-size:var(--t-base);font-weight:600;
           color:rgba(255,255,255,.78);white-space:nowrap;letter-spacing:.04em;
           transition:color .2s;position:relative}
.gnav li a::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:2px;
                  background:var(--gd);transform:scaleX(0);transform-origin:center;transition:transform .22s}
.gnav li a:hover{color:var(--gd)}
.gnav li a:hover::after{transform:scaleX(1)}
.ndrop{display:none;position:absolute;top:100%;left:0;min-width:175px;
       background:var(--nv2);border:1px solid rgba(184,134,11,.2);
       border-top:2px solid var(--gd);z-index:300;padding:5px 0;
       box-shadow:0 8px 28px rgba(0,0,0,.28)}
.ndrop.open{display:block}
.ndrop a{display:block;padding:9px 17px;font-size:var(--t-base);color:rgba(255,255,255,.7);transition:all .18s}
.ndrop a::after{display:none}
.ndrop a:hover{color:var(--gd);background:rgba(255,255,255,.05)}

/* ━━ BREADCRUMB ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.breadcrumb-wrap{background:#fff;border-bottom:1px solid var(--border2);padding:10px 0}
.breadcrumb{max-width:1380px;margin:0 auto;padding:0 24px;
            display:flex;align-items:center;gap:6px;flex-wrap:wrap;
            font-family:'Roboto',sans-serif;font-size:var(--t-sm);color:var(--text3)}
.breadcrumb a{color:var(--text3);transition:color .2s}
.breadcrumb a:hover{color:var(--gd)}
.bc-sep{color:#ccc}

/* ━━ LAYOUT ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.wrap{display:flex;max-width:1380px;margin:0 auto;padding:30px 24px 64px;
      gap:28px;align-items:flex-start}
#main{flex:1;min-width:0;width:100%}
#sidebar{width:300px;flex-shrink:0}
.sec{margin:0 0 44px}
.sec-hd{display:flex;align-items:flex-end;justify-content:space-between;
        gap:12px;margin-bottom:22px;padding-bottom:14px;border-bottom:1px solid var(--border2)}
.sec-ttl{margin:0;display:flex;flex-direction:column;gap:0;line-height:1}
.sec-en{font-family:'Roboto',sans-serif;font-size:.42rem;font-weight:400;
        color:rgba(184,134,11,.4);letter-spacing:.08em;text-transform:uppercase;
        display:block;line-height:1;margin-bottom:4px}
.sec-ttl-ja{font-size:var(--t-lg);font-weight:700;color:var(--nv);letter-spacing:.04em;line-height:1.3}
.sec-more{font-size:var(--t-sm);font-weight:600;color:var(--gd);
          display:inline-flex;align-items:center;gap:3px;
          border-bottom:1px solid var(--gd);padding-bottom:1px;white-space:nowrap;transition:all .2s}
.sec-more:hover{color:var(--nv);border-color:var(--nv)}
.fi,.fi3{opacity:0;transform:translateY(18px);transition:opacity .65s,transform .65s}
.fi.vis,.fi3.vis{opacity:1;transform:translateY(0)}

/* ━━ SALE ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sale-tabs{display:flex;border-bottom:1px solid var(--border2);margin-bottom:16px}
.stab{padding:9px 22px;font-size:var(--t-base);font-weight:600;color:var(--text3);
      border-bottom:2px solid transparent;margin-bottom:-1px;
      transition:all .22s;cursor:pointer;letter-spacing:.04em;font-family:inherit}
.stab.on{color:var(--nv);border-bottom-color:var(--gd)}
.spanel{display:none;flex-direction:column;gap:12px}
.spanel.on{display:flex}
.sale-empty{font-size:var(--t-base);color:var(--text3);padding:14px 0}
.sale-card{border:1px solid var(--border2);border-radius:var(--rad);background:#fff;
           padding:20px 22px;position:relative;overflow:hidden;transition:box-shadow .26s,transform .26s}
.sale-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.sale-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
                   background:var(--gd);opacity:0;transition:opacity .26s}
.sale-card:hover::before{opacity:1}
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px;align-items:center}
.chip{font-family:'Roboto',sans-serif;display:inline-block;font-size:var(--t-xs);font-weight:700;
      padding:3px 10px;border-radius:999px;letter-spacing:.04em}
.chip-disc{background:var(--gdp);color:var(--nv);border:1px solid rgba(184,134,11,.4)}
.chip-hot{background:var(--nv);color:#fff}
.chip-upcoming{background:var(--gdp);color:#7a5c2a;border:1px solid var(--gd)}
.sale-ttl{font-size:var(--t-md);font-weight:700;color:var(--nv);margin-bottom:6px;line-height:1.45}
.sale-detail{font-size:var(--t-base);color:var(--text2);line-height:1.8;margin-bottom:5px}
.sale-period{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3);margin-bottom:14px}
.sale-cd{display:inline-flex;align-items:center;gap:8px;background:var(--nv);color:#fff;
         padding:5px 14px;border-radius:3px;margin-bottom:14px}
.cd-lbl{font-size:var(--t-xs);font-weight:600;letter-spacing:.08em;opacity:.7}
.cd-val{font-family:'Roboto',sans-serif;font-size:var(--t-md);font-weight:700;letter-spacing:.1em;color:var(--gd2)}
.sale-cta{display:inline-block;padding:10px 24px;background:var(--nv);color:#fff;
          border-radius:3px;font-size:var(--t-base);font-weight:700;letter-spacing:.06em;transition:background .2s}
.sale-cta:hover{background:var(--gd)}
.sale-cta-ghost{display:inline-block;padding:10px 24px;border:1px solid var(--border);
               border-radius:3px;color:var(--nv);font-size:var(--t-base);font-weight:700;
               letter-spacing:.06em;transition:all .2s}
.sale-cta-ghost:hover{border-color:var(--nv)}

/* ━━ PRODUCTS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cat-bar{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;
         margin-bottom:14px;scrollbar-width:none}
.cat-bar::-webkit-scrollbar{display:none}
.cat-btn{padding:6px 16px;border-radius:999px;border:1px solid var(--border);
         background:#fff;color:var(--text2);font-size:var(--t-sm);font-weight:500;
         white-space:nowrap;cursor:pointer;transition:all .2s;font-family:inherit}
.cat-btn:hover{border-color:var(--nv);color:var(--nv)}
.cat-btn.on{background:var(--nv);color:#fff;border-color:var(--nv)}
.price-bar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:18px;
           padding:10px 14px;background:#fff;border:1px solid var(--border2);border-radius:var(--rad)}
.price-lbl{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:500;
           color:var(--text3);white-space:nowrap;letter-spacing:.06em}
.price-btn{padding:5px 13px;border-radius:999px;border:1px solid var(--border);
           background:#fff;color:var(--text2);font-size:var(--t-sm);cursor:pointer;
           transition:all .2s;white-space:nowrap;font-family:inherit}
.price-btn:hover{border-color:var(--gd);color:var(--nv)}
.price-btn.on{background:var(--nv);color:#fff;border-color:var(--nv)}
.filter-count{font-family:'Roboto',sans-serif;font-size:var(--t-sm);color:var(--text3)}
.filter-count strong{font-family:'Roboto',sans-serif;font-size:1.1rem;font-weight:700;
                     color:var(--nv);margin:0 2px}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pc2{border:1px solid var(--border2);border-radius:var(--rad);overflow:hidden;
     background:#fff;cursor:pointer;transition:box-shadow .26s,transform .26s,border-color .26s}
.pc2:hover{box-shadow:var(--sh2);transform:translateY(-4px);border-color:rgba(184,134,11,.5)}
.pc2-img{position:relative;padding-top:100%;overflow:hidden;background:var(--bg2)}
.pc2-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pc2:hover .pc2-img img{transform:scale(1.07)}
.pc2-noimg{position:absolute;inset:0;display:flex;align-items:center;
           justify-content:center;background:var(--bg2);color:var(--text3)}
.pc2-badge{position:absolute;top:7px;left:7px;font-family:'Roboto',sans-serif;
           font-size:var(--t-xs);font-weight:700;padding:3px 8px;border-radius:3px;letter-spacing:.06em}
.pb-best{background:var(--gd);color:#fff}
.pb-new{background:var(--nv);color:#fff}
.pc2-body{padding:11px 12px 13px}
.pc2-cat{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
         color:var(--gd);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.pc2-name{font-size:var(--t-base);font-weight:500;color:var(--text);line-height:1.5;margin-bottom:8px;
          display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pc2-price{font-family:'Roboto',sans-serif;margin-bottom:6px;display:flex;align-items:baseline;gap:2px}
.pc2-pold{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3);
          text-decoration:line-through;font-weight:400;margin-right:4px}
.pc2-price-num{font-family:'Roboto',sans-serif;color:var(--r);font-size:1.1rem;font-weight:600}
.pc2-price-yen-unit{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3);font-weight:300}
.pc2-ptax{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3);margin-left:2px;font-weight:300}
.pc2-dots{display:flex;gap:5px;align-items:center;margin-top:2px}
.pdot{width:20px;height:20px;border-radius:3px;object-fit:contain;background:#f5f5f5;padding:1px}
.load-wrap{text-align:center;margin-top:28px}
.btn-more{display:inline-block;padding:12px 50px;border:1px solid #e3e3e3;border-radius:36px;
          font-size:var(--t-base);font-weight:600;color:#fff;background:#b5b5b5;
          cursor:pointer;letter-spacing:.06em;transition:all .2s;font-family:inherit;margin:0 auto}

/* ━━ ARTICLES ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.article-card{border:1px solid var(--border2);border-radius:var(--rad);overflow:hidden;
              background:#fff;display:block;transition:box-shadow .25s,transform .25s}
.article-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.article-img{padding-top:66%;position:relative;overflow:hidden;background:var(--nv2)}
.article-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.8}
.article-img-label{position:absolute;inset:0;display:flex;align-items:center;
                   justify-content:center;font-size:1rem;color:rgba(255,255,255,.8);
                   letter-spacing:.1em;padding:16px;text-align:center}
.article-body{padding:14px}
.article-cat{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
             color:var(--gd);letter-spacing:.14em;text-transform:uppercase;margin-bottom:5px}
.article-title{font-size:var(--t-md);font-weight:700;color:var(--nv);line-height:1.5;margin-bottom:8px}
.article-date{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3)}

/* ━━ COMMITMENT ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.commit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.commit-card{padding:22px;border:1px solid var(--border2);border-radius:var(--rad);
             background:#fff;transition:border-color .2s,box-shadow .2s;position:relative;overflow:hidden}
.commit-card::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;
                     background:var(--nv);border-radius:var(--rad) 0 0 var(--rad)}
.commit-card:hover{border-color:rgba(184,134,11,.4);box-shadow:var(--sh)}
.commit-ico{width:36px;height:36px;background:var(--nv);border-radius:5px;
            display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.commit-ico svg{color:#fff;stroke:#fff;fill:none}
.commit-ttl{font-size:var(--t-md);font-weight:700;color:var(--nv);margin-bottom:6px}
.commit-txt{font-size:var(--t-sm);color:var(--text2);line-height:1.9}

/* ━━ SPECIALTY ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.specialty-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.specialty-card{display:flex;gap:14px;align-items:flex-start;background:#fff;
                border:1px solid var(--border2);border-radius:var(--rad);padding:16px;
                transition:box-shadow .2s,border-color .2s}
.specialty-card:hover{box-shadow:var(--sh);border-color:rgba(184,134,11,.35)}
.specialty-icon{width:60px;height:60px;border-radius:8px;overflow:hidden;
                background:var(--bg2);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.specialty-icon img{width:56px;height:56px;object-fit:cover;border-radius:6px}
.specialty-body{flex:1;min-width:0}
.specialty-name{font-size:var(--t-md);font-weight:700;color:var(--nv);margin-bottom:2px;line-height:1.3}
.specialty-sub{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--gd);letter-spacing:.06em;margin-bottom:6px}
.specialty-desc{font-size:var(--t-sm);color:var(--text2);line-height:1.8}

/* ━━ FURUSATO ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.furu-box{border:1px solid #d4b896;border-radius:var(--rad);
          background:linear-gradient(135deg,#fffbf5,#fdf6ec);
          border-top:3px solid var(--gd);padding:24px 26px;
          display:flex;gap:20px;align-items:flex-start}
.furu-ico{width:64px;height:64px;background:var(--gdp);border-radius:var(--rad);
          display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gd)}
.furu-ttl{font-size:1rem;font-weight:700;color:var(--nv);margin-bottom:8px}
.furu-txt{font-size:var(--t-base);color:var(--text2);line-height:1.9;margin-bottom:14px}
.furu-links{display:flex;gap:8px;flex-wrap:wrap}
.furu-link{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
           padding:6px 16px;border-radius:3px;letter-spacing:.04em;transition:opacity .2s}
.furu-link:hover{opacity:.85}
.fl-r{background:var(--r);color:#fff}
.fl-a{background:#131921;color:var(--a)}
.fl-y{background:var(--y);color:#fff}

/* ━━ SNS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sns-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.sns-card{border:1px solid var(--border2);border-radius:var(--rad);padding:20px;
          background:#fff;display:block;transition:border-color .2s,box-shadow .2s}
.sns-card:hover{border-color:rgba(184,134,11,.4);box-shadow:var(--sh)}
.sns-pl{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
        color:var(--text3);letter-spacing:.14em;text-transform:uppercase;margin-bottom:4px}
.sns-nm{font-size:var(--t-md);font-weight:700;color:var(--nv);margin-bottom:2px}
.sns-hd{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3);margin-bottom:10px}
.sns-txt{font-size:var(--t-sm);color:var(--text2);line-height:1.9;margin-bottom:14px}
.sns-btn{display:inline-block;font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
         padding:6px 16px;border-radius:3px;background:var(--nv);color:#fff;letter-spacing:.06em}

/* ━━ SIDEBAR ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.side-box{border:1px solid var(--border2);border-radius:var(--rad);background:#fff;
          border-top:3px solid var(--nv);padding:16px 18px 20px;margin-bottom:18px;box-shadow:var(--sh)}
.side-hd{padding-bottom:12px;margin-bottom:14px;border-bottom:1px solid var(--nv)}
.side-en{font-family:'Roboto',sans-serif;font-size:.44rem;font-weight:400;
         color:rgba(10,22,40,.35);letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:2px}
.side-ja{font-size:var(--t-md);font-weight:700;color:var(--nv);margin:0}
.rank-shop-card{background:#fff;border:1px solid var(--border2);border-radius:var(--rad);
                padding:14px;transition:box-shadow .2s,transform .2s}
.rank-shop-card:hover{box-shadow:var(--sh);transform:translateY(-1px)}
.rank-shop-head{display:flex;align-items:center;justify-content:center;padding:10px 0 8px;margin-bottom:8px}
.rank-shop-logo{object-fit:contain;max-width:80px;height:auto;display:block}
.rank-shop-desc{font-size:var(--t-xs);color:var(--text3);line-height:1.7;margin-bottom:10px}
.rank-shop-btn{display:flex;align-items:center;justify-content:center;gap:6px;
               width:100%;padding:10px 12px;border-radius:4px;
               font-size:var(--t-sm);font-weight:700;color:#fff;letter-spacing:.04em;transition:opacity .2s,transform .2s}
.rank-shop-btn:hover{opacity:.88;transform:translateY(-1px);color:#fff}
.cat-icon-list{display:flex;flex-direction:column;gap:1px}
.cat-icon-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:5px;
               text-decoration:none;color:var(--text2);transition:all .2s;border:1px solid transparent}
.cat-icon-item:hover{background:var(--bg);border-color:var(--border2);color:var(--nv)}
.cat-icon-img{width:48px;height:48px;border-radius:5%;background:var(--bg2);overflow:hidden;
              display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cat-icon-img img{width:48px;height:48px;object-fit:cover;border-radius:5%}
.cat-icon-name{flex:1;font-size:var(--t-base);font-weight:500}
.cat-icon-arr{color:var(--text3);flex-shrink:0}
.side-sale-item{padding:10px 0;border-bottom:1px solid var(--border2)}
.side-sale-item:last-child{border-bottom:none}
.side-sale-chip{font-family:'Roboto',sans-serif;display:inline-block;font-size:var(--t-xs);
                font-weight:700;padding:2px 8px;border-radius:999px;color:#fff;margin-bottom:5px}
.side-sale-ttl{font-size:var(--t-sm);font-weight:700;color:var(--nv);margin-bottom:5px;line-height:1.5}
.side-sale-link{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:600;color:var(--gd)}

/* ━━ MODAL ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.modal-ov{display:none;position:fixed;inset:0;background:rgba(5,15,28,.92);
          z-index:1000;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(12px)}
.modal-ov.open{display:flex}
.modal-box{background:#fff;border-radius:var(--rad);max-width:860px;width:100%;
           max-height:90vh;overflow-y:auto;position:relative;display:grid;grid-template-columns:1fr 1fr}
.modal-x{position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;
         background:#f0f0f0;display:flex;align-items:center;justify-content:center;
         z-index:10;transition:all .2s;font-size:.85rem;color:var(--text2);cursor:pointer;border:none}
.modal-x:hover{background:var(--nv);color:#fff}
.modal-img-col{background:var(--bg2);padding:22px;border-radius:var(--rad) 0 0 var(--rad)}
.modal-main{aspect-ratio:1;overflow:hidden;border-radius:4px;margin-bottom:9px;background:var(--bg2)}
.modal-main img{width:100%;height:100%;object-fit:cover}
.modal-info{padding:24px 20px;display:flex;flex-direction:column;gap:11px}
.modal-cat{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
           color:var(--gd);letter-spacing:.16em;text-transform:uppercase}
.modal-name{font-size:1.05rem;font-weight:700;color:var(--nv);line-height:1.5}
.modal-price-wrap{display:flex;align-items:baseline;gap:4px;flex-wrap:wrap}
.modal-price-old{font-family:'Roboto',sans-serif;font-size:var(--t-base);color:var(--text3);
                 text-decoration:line-through;font-weight:300}
.modal-price-num{font-family:'Roboto',sans-serif;font-size:1.75rem;font-weight:800;color:var(--nv)}
.modal-price-unit{font-family:'Roboto',sans-serif;font-size:var(--t-sm);color:var(--text3)}
.msh-lbl{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
         color:var(--text3);letter-spacing:.13em;text-transform:uppercase}
.msh-btns{display:flex;flex-direction:column;gap:6px}
.msh-btn{display:flex;align-items:center;justify-content:space-between;padding:10px 13px;
         border-radius:4px;border:1px solid var(--border2);font-size:var(--t-base);color:var(--text2);
         background:#fff;transition:all .2s}
.msh-btn:hover{border-color:var(--gd);background:var(--gdp);color:var(--nv)}
.msh-l{display:flex;align-items:center;gap:8px}
.msh-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.msh-price{font-family:'Roboto',sans-serif;font-size:var(--t-md);font-weight:800;color:var(--nv)}

/* ━━ CHAT ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.chat-fab{position:fixed;bottom:68px;right:14px;width:50px;height:50px;border-radius:50%;
          background:linear-gradient(135deg,var(--nv),var(--nv3));border:2px solid var(--gd);
          display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:600;
          box-shadow:0 4px 20px rgba(0,0,0,.3);transition:transform .3s;color:#fff}
.chat-fab:hover{transform:scale(1.08)}
.chat-badge{position:absolute;top:-2px;right:-2px;width:13px;height:13px;border-radius:50%;
            background:var(--gd);font-family:'Roboto',sans-serif;font-size:7px;font-weight:700;
            color:var(--nv);display:flex;align-items:center;justify-content:center}
.chat-panel{position:fixed;bottom:126px;right:14px;width:316px;max-height:420px;
            background:#fff;border-radius:10px;border:1px solid var(--border2);
            box-shadow:var(--sh2);z-index:600;display:none;flex-direction:column;overflow:hidden}
.chat-panel.open{display:flex}
.chat-hdr{background:var(--nv);color:#fff;padding:11px 14px;display:flex;align-items:center;gap:9px}
.chat-hdr-ico{width:30px;height:30px;border-radius:50%;background:var(--gd);
              display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-hdr-nm{font-size:var(--t-base);font-weight:700}
.chat-hdr-sb{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:rgba(255,255,255,.5)}
.chat-cls{background:none;border:none;color:rgba(255,255,255,.5);padding:4px;cursor:pointer;font-size:var(--t-sm)}
.chat-msgs{flex:1;overflow-y:auto;padding:13px;display:flex;flex-direction:column;gap:9px}
.chat-msg{max-width:84%;font-size:var(--t-base);line-height:1.7;padding:8px 11px;border-radius:9px}
.chat-msg.bot{background:#f0f2f5;color:var(--text);border-radius:3px 9px 9px 9px;align-self:flex-start}
.chat-msg.user{background:var(--nv);color:#fff;border-radius:9px 3px 9px 9px;align-self:flex-end}
.chat-foot{padding:9px;border-top:1px solid var(--border2);display:flex;gap:7px}
.chat-in{flex:1;padding:8px 12px;border:1px solid var(--border2);border-radius:999px;
         font-size:var(--t-base);outline:none;transition:border-color .2s;font-family:inherit}
.chat-in:focus{border-color:var(--nv)}
.chat-send{width:32px;height:32px;border-radius:50%;background:var(--nv);color:#fff;
           display:flex;align-items:center;justify-content:center;flex-shrink:0;
           transition:background .2s;cursor:pointer}
.chat-send:hover{background:var(--gd)}

/* ━━ FOOTER ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
footer{background:var(--nv);color:rgba(255,255,255,.7);padding:52px 0 28px}
.ftr-in{max-width:1380px;margin:0 auto;padding:0 24px}
.ftr-cat-section{padding-bottom:28px;margin-bottom:28px;border-bottom:1px solid rgba(255,255,255,.1)}
.ftr-cat-section .ftr-col-ttl{margin-bottom:12px}
.ftr-cat-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:8px}
.ftr-cat-all{grid-column:1/-1;display:block;padding:9px 12px;border-radius:5px;
             font-size:var(--t-sm);color:rgba(255,255,255,.75);font-weight:500;
             background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
             transition:all .2s;text-align:center;margin-top:8px}
.ftr-cat-all:hover{color:#fff;background:rgba(255,255,255,.14)}
.ftr-cat-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 4px;
              border-radius:8px;text-decoration:none;color:rgba(255,255,255,.72);
              background:rgba(255,255,255,.04);border:1px solid transparent;
              transition:all .2s;text-align:center}
.ftr-cat-item:hover{color:#fff;background:rgba(255,255,255,.1);border-color:rgba(184,134,11,.35)}
.ftr-cat-item img{width:52px;height:52px;border-radius:5%;object-fit:cover;opacity:.9;
                  border:1px solid rgba(255,255,255,.18)}
.ftr-cat-item span{font-size:var(--t-xs);line-height:1.3}
.ftr-bottom-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px;margin-bottom:32px}
.ftr-logo-jp{font-size:1.1rem;color:#fff;letter-spacing:.12em;margin-bottom:2px;font-weight:700}
.ftr-logo-en{font-family:'Roboto',sans-serif;font-size:.52rem;color:rgba(255,255,255,.28);
             letter-spacing:.22em;margin-bottom:12px}
.ftr-ab{font-size:var(--t-sm);line-height:1.9;color:rgba(255,255,255,.46);max-width:280px}
.ftr-col-ttl{font-family:'Roboto',sans-serif;font-size:.57rem;font-weight:700;
             letter-spacing:.16em;color:rgba(255,255,255,.3);text-transform:uppercase;margin-bottom:12px}
.ftr-links{display:flex;flex-direction:column;gap:9px}
.ftr-links a{font-size:var(--t-base);color:rgba(255,255,255,.56);transition:color .2s}
.ftr-links a:hover{color:var(--gd)}
.ftr-btm{border-top:1px solid rgba(255,255,255,.1);padding-top:17px;
         display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.ftr-copy{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:rgba(255,255,255,.26)}
.ftr-aff{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:rgba(255,255,255,.2);
         max-width:440px;line-height:1.8}

/* ━━ SCROLL TOP ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.totop{position:fixed;bottom:16px;right:14px;background:rgba(10,22,40,.8);color:#fff;
       width:36px;height:36px;border-radius:4px;display:flex;align-items:center;
       justify-content:center;z-index:500;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.2);
       font-size:.85rem;opacity:0;transform:translateY(8px);transition:all .3s}
.totop.show{opacity:1;transform:translateY(0)}
.totop:hover{background:var(--gd)}

/* ━━ 商品詳細 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.pd-wrap{display:flex;max-width:1380px;margin:0 auto;
         padding:28px 24px 64px;gap:28px;align-items:flex-start}
.pd-main{flex:1;min-width:0}
.pd-top{margin-bottom:40px}
.pd-main-img{aspect-ratio:1;overflow:hidden;border-radius:8px;background:var(--bg2);
             margin-bottom:10px;border:1px solid var(--border2)}
.pd-main-img img{width:100%;height:100%;object-fit:cover}
.pd-no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg2)}
.pd-thumbs{display:flex;gap:7px;flex-wrap:wrap}
.pd-thumb{width:64px;height:64px;border-radius:4px;overflow:hidden;
          border:2px solid transparent;cursor:pointer;transition:border-color .2s;background:var(--bg2)}
.pd-thumb.on,.pd-thumb:hover{border-color:var(--gd)}
.pd-thumb img{width:100%;height:100%;object-fit:cover}
.pd-info{display:flex;flex-direction:column;gap:16px}
.pd-cat{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
        color:var(--gd);letter-spacing:.14em;text-transform:uppercase}
.pd-name{font-size:clamp(var(--t-lg),2.2vw,var(--t-xl));font-weight:700;color:var(--nv);line-height:1.5}
.pd-catch{font-size:var(--t-base);color:var(--text2);line-height:1.9;padding:12px 16px;
          background:var(--bg);border-left:3px solid var(--gd);border-radius:0 4px 4px 0}
.pd-price-block{background:#fff;border:1px solid var(--border2);border-radius:var(--rad);
                padding:16px 18px;border-left:4px solid var(--nv)}
.pd-price-old{font-family:'Roboto',sans-serif;font-size:var(--t-base);font-weight:400;
              color:var(--text3);text-decoration:line-through;margin-right:8px}
.pd-discount{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
             background:var(--r);color:#fff;padding:2px 7px;border-radius:3px}
.pd-price-num{font-family:'Roboto',sans-serif;font-size:2rem;font-weight:800;color:var(--nv)}
.pd-price-unit{font-family:'Roboto',sans-serif;font-size:var(--t-md);color:var(--text3);margin-left:2px}
.pd-buy-section{display:flex;flex-direction:column;gap:8px}
.pd-buy-label{display:flex;align-items:center;gap:7px;font-family:'Roboto',sans-serif;
              font-size:var(--t-xs);font-weight:700;color:var(--text3);letter-spacing:.1em;
              text-transform:uppercase;margin-bottom:2px}
.pd-buy-btn{display:flex;align-items:center;justify-content:space-between;
            padding:13px 16px;border-radius:5px;border:1px solid var(--border2);
            background:#fff;transition:all .22s}
.pd-buy-btn:hover{border-color:var(--gd);background:var(--gdp);transform:translateX(3px)}
.pd-buy-left{display:flex;align-items:center;gap:10px}
.pd-buy-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.pd-buy-name{font-size:var(--t-md);font-weight:600;color:var(--nv)}
.pd-buy-right{display:flex;align-items:center;gap:8px}
.pd-buy-price{font-family:'Roboto',sans-serif;font-size:var(--t-md);font-weight:800;color:var(--nv)}
.pd-buy-note{font-size:var(--t-xs);color:#aaa;line-height:1.7}
.pd-spec{border:1px solid var(--border2);border-radius:var(--rad);overflow:hidden}
.pd-spec-row{display:grid;grid-template-columns:120px 1fr;border-bottom:1px solid var(--border2)}
.pd-spec-row:last-child{border-bottom:none}
.pd-spec-label{padding:10px 14px;background:var(--bg);font-size:var(--t-sm);font-weight:600;
               color:var(--text2);border-right:1px solid var(--border2)}
.pd-spec-val{padding:10px 14px;font-size:var(--t-base);color:var(--text)}
.pd-related{margin-top:40px;padding-top:32px;border-top:1px solid var(--border2)}

/* 記事ページ */
.single-wrap{max-width:1380px;margin:0 auto;padding:30px 24px 64px}
.single-main{max-width:820px;margin:0 auto}
.single-cat{font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
            color:var(--gd);letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.single-title{font-size:clamp(1.4rem,3vw,2rem);font-weight:700;color:var(--nv);
              line-height:1.4;margin-bottom:12px}
.single-meta{font-family:'Roboto',sans-serif;font-size:var(--t-sm);color:var(--text3);margin-bottom:24px}
.single-thumb{border-radius:var(--rad);overflow:hidden;margin-bottom:28px;aspect-ratio:16/9}
.single-thumb img{width:100%;height:100%;object-fit:cover}
.single-body{font-size:var(--t-md);line-height:2;color:var(--text)}
.single-body h2{font-size:1.2rem;font-weight:700;color:var(--nv);margin:28px 0 12px;
                padding-bottom:8px;border-bottom:2px solid var(--gd)}
.single-body h3{font-size:1rem;font-weight:700;color:var(--nv);margin:22px 0 10px}
.single-body p{margin-bottom:16px}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PC レスポンシブ（breakpoint）
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media(max-width:1380px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1100px){
  .wrap,.pd-wrap{flex-direction:column}
  #sidebar{width:100%}
  .ftr-cat-grid{grid-template-columns:repeat(6,1fr)}
  .ftr-bottom-grid{grid-template-columns:1fr 1fr 1fr;gap:24px}
}
@media(max-width:960px){
  .article-grid{grid-template-columns:repeat(2,1fr)}
  .ftr-bottom-grid{grid-template-columns:1fr 1fr}
  .ftr-bottom-grid > div:first-child{grid-column:1/-1}
}
@media(max-width:600px){
  .modal-box{grid-template-columns:1fr}
  .furu-box{flex-direction:column}
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SP専用（max-width:768px）  ここだけに書く
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media(max-width:768px){
  /* 基本 */
  body{overflow-x:hidden;max-width:100vw}
  .pc-only{display:none!important}
  .sp-only{display:block}

  /* ヒーロー */
  .hero-logo-top{top:16px;left:16px}
  .hero-logo-img{height:24px}
  .hero-cap{top:65%;left:5%;right:5%;max-width:100%;transform:translateY(-50%)}
  .hero-ey{font-size:.52rem!important}
  .hero-cap h1{font-size:28px!important;letter-spacing:.06em!important;
               line-height:1.3!important;margin-bottom:12px!important}
  .hero-cap p{font-size:11px;line-height:1.75!important}
  .scr-ind{bottom:20px}
  .hero-dots{bottom:20px;right:5%}

  /* ヘッダー */
  .hdr-inner{padding:10px 14px;gap:10px;justify-content:space-between}
  .site-logo-svg{height:30px}
  .hdr-search{display:none}
  .icon-nav{display:none}
  .sp-srch{display:block}
  .gnav{top:50px}
  .gnav li a{padding:10px 12px;font-size:var(--t-sm)}

  /* レイアウト */
  .wrap{flex-direction:column!important;padding:14px 10px 20px;gap:18px;
        width:100%;max-width:100%;overflow-x:hidden}
  #main{width:100%;min-width:0;max-width:100%}
  #sidebar{width:100%!important;min-width:0}

  /* 商品 */
  .pgrid{grid-template-columns:repeat(2,1fr)!important;gap:8px}
  .pc2-body{padding:8px 9px 10px}
  .pc2-name{font-size:var(--t-base)}
  .pc2-price-num{font-size:16px}
  .cat-bar{gap:6px}
  .cat-btn{padding:5px 11px;font-size:var(--t-xs)}
  .price-bar{padding:8px 10px;gap:5px}
  .price-btn{padding:4px 9px;font-size:var(--t-xs)}

  /* セール */
  .sale-card{padding:14px}
  .stab{padding:8px 16px;font-size:var(--t-sm)}

  /* セクション */
  .sec{margin:0 0 28px}
  .sec-hd{margin-bottom:14px;padding-bottom:10px}
  .sec-ttl-ja{font-size:1rem}

  /* グリッド系 */
  .commit-grid{grid-template-columns:1fr!important}
  .sns-grid{grid-template-columns:1fr!important}
  .specialty-grid{grid-template-columns:1fr!important}
  .article-grid{grid-template-columns:1fr!important}
  .specialty-card{padding:13px}

  /* サイドバーカテゴリ2列 */
  .cat-icon-list{display:grid;grid-template-columns:repeat(2,1fr);gap:2px}
  .cat-icon-item{padding:7px 8px}

  /* 商品詳細 */
  .pd-wrap{flex-direction:column!important;padding:12px 12px 40px;gap:16px}
  .pd-top{grid-template-columns:1fr!important}

  /* チャット */
  .chat-panel{width:calc(100vw - 28px);right:14px}
  .chat-fab{bottom:62px}

  /* フッター カテゴリ */
  .ftr-cat-grid{grid-template-columns:repeat(4,1fr)!important;gap:6px}
  .ftr-cat-item img{width:44px;height:44px}
  .ftr-cat-item span{font-size:var(--t-xs)}
  .ftr-cat-all{grid-column:1/-1;font-size:var(--t-sm);margin-top:20px}

  /* フッター 下部 */
  .ftr-bottom-grid{grid-template-columns:1fr 1fr!important;gap:16px}
  .ftr-bottom-grid > div:first-child{grid-column:1/-1}
  .ftr-ab{font-size:var(--t-xs);line-height:1.9;color:rgba(255,255,255,.21);max-width:100%}
  .ftr-btm{flex-direction:column;align-items:center;gap:6px}
  .ftr-copy{font-size:var(--t-xs);color:rgba(255,255,255,.14);text-align:center}
  .ftr-aff{font-size:8px;color:rgba(255,255,255,.2);max-width:100%;
           line-height:1.8;text-align:center;margin:0 auto}
}

/* ━━ 特集記事スライダー ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.article-slider-wrap{
  position:relative;
  overflow:hidden;
}
.article-slider{
  display:flex;
  gap:14px;
  transition:transform .4s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
.article-slide-card{
  flex:0 0 calc((100% - 14px * 4) / 5);  /* PC:5枚 */
  min-width:0;
  border:1px solid var(--border2);border-radius:var(--rad);
  overflow:hidden;background:#fff;
  display:block;transition:box-shadow .25s,transform .25s;
  text-decoration:none;
}
.article-slide-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}

/* スライダーボタン */
.aslider-btn{
  position:absolute;top:33%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;
  background:rgba(10,22,40,.75);color:#fff;
  border:1px solid rgba(255,255,255,.2);
  font-size:1.4rem;display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;transition:background .2s;
  line-height:1;
}
.aslider-btn:hover{background:var(--gd)}
.aslider-prev{left:4px}
.aslider-next{right:4px}
.aslider-btn:disabled{opacity:.3;cursor:default}

/* SP:2枚表示 */
@media(max-width:768px){
  .article-slide-card{
    flex:0 0 calc((100% - 10px) / 2);
  }
  .article-slider{gap:10px}
  .aslider-btn{top:30%;width:28px;height:28px;font-size:1.1rem}
}

/* ━━ 手動ランキング ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ranking-list{display:flex;flex-direction:column;gap:10px}
.ranking-item{
  display:grid;
  grid-template-columns:44px 80px 1fr auto;
  align-items:center;gap:16px;
  background:#fff;border:1px solid var(--border2);border-radius:var(--rad);
  padding:14px 18px;text-decoration:none;color:var(--text);
  transition:box-shadow .22s,transform .22s,border-color .22s;
  position:relative;overflow:hidden;
}
.ranking-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--border2);transition:background .22s;
}
.ranking-item:hover{box-shadow:var(--sh2);transform:translateY(-2px);border-color:rgba(184,134,11,.4)}
.ranking-item:hover::before{background:var(--gd)}

/* 順位数字 */
.rank-num{
  font-family:'Roboto',sans-serif;font-size:2rem;font-weight:800;
  text-align:center;line-height:1;flex-shrink:0;
}
.ranking-item:nth-child(1) .rank-num{font-size:2.2rem}

/* サムネイル */
.rank-img{
  width:80px;height:80px;border-radius:5px;overflow:hidden;
  background:var(--bg2);flex-shrink:0;
}
.rank-img img{width:100%;height:100%;object-fit:cover}

/* 情報 */
.rank-info{flex:1;min-width:0}
.rank-cat{
  font-family:'Roboto',sans-serif;font-size:var(--t-xs);
  font-weight:700;color:var(--gd);letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:4px;
}
.rank-name{
  font-size:var(--t-md);font-weight:700;color:var(--nv);
  line-height:1.4;margin-bottom:5px;
  display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;
}
.rank-comment{font-size:var(--t-sm);color:var(--text2);line-height:1.6;margin-bottom:5px}
.rank-season{
  font-family:'Roboto',sans-serif;font-size:var(--t-xs);
  background:var(--gdp);color:var(--gd);font-weight:700;
  padding:2px 9px;border-radius:999px;
  border:1px solid rgba(184,134,11,.35);
}

/* 右側：価格・ロゴ */
.rank-right{
  display:flex;flex-direction:column;align-items:flex-end;gap:8px;
  flex-shrink:0;
}
.rank-price{display:flex;align-items:baseline;gap:2px}
.rank-price-num{
  font-family:'Roboto',sans-serif;font-size:1.3rem;
  font-weight:800;color:var(--r);
}
.rank-price-unit{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3)}
.rank-price-tax{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3);margin-left:3px}
.rank-logos{display:flex;gap:4px;align-items:center}
.rank-logos img{width:22px;height:22px;object-fit:contain;border-radius:3px;background:#f5f5f5;padding:1px}
.rank-arrow{
  font-family:'Roboto',sans-serif;font-size:var(--t-sm);
  color:var(--gd);font-weight:700;
}

/* SP */
@media(max-width:768px){
  .ranking-item{
    grid-template-columns:32px 60px 1fr;
    gap:10px;padding:12px;
  }
  .rank-right{display:none}
  .rank-img{width:60px;height:60px}
  .rank-num{font-size:1.5rem}
  .ranking-item:nth-child(1) .rank-num{font-size:1.8rem}
  .rank-name{font-size:var(--t-base)}
  .rank-comment{display:none}
}

/* ━━ 特集記事：全幅レイアウト ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.articles-fullwidth{
  width:100%;
  max-width:100%;
  padding:32px 24px 24px;
  margin:0;
  background:var(--bg);
}
.articles-fullwidth .sec-hd{
  max-width:1380px;
  margin:0 auto 18px;
}
.articles-fullwidth .article-slider-wrap{
  max-width:1380px;
  margin:0 auto;
}
@media(max-width:768px){
  .articles-fullwidth{padding:20px 12px 16px}
}

/* ━━ 静的ページ共通 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.static-page{padding:0 0 20px}
.static-body{display:flex;flex-direction:column;gap:28px}

/* お知らせバナー */
.static-notice{
  background:var(--gdp);
  border-left:4px solid var(--gd);
  border-radius:0 var(--rad) var(--rad) 0;
  padding:14px 18px;
  font-size:var(--t-sm);color:var(--text2);line-height:1.85;
}

/* セクション */
.static-sec{display:flex;flex-direction:column;gap:16px}
.static-sec-head{
  display:flex;align-items:center;gap:12px;
  padding-bottom:12px;border-bottom:1px solid var(--border2);
}
.static-sec-ico{
  width:36px;height:36px;border-radius:8px;
  background:var(--nv);display:flex;align-items:center;
  justify-content:center;flex-shrink:0;
}
.static-sec-ico svg{stroke:#fff;fill:none;stroke-linecap:round;stroke-linejoin:round}
.static-sec-title{
  font-size:var(--t-lg);font-weight:700;color:var(--nv);
  letter-spacing:.04em;margin:0;
}
.static-sec p{font-size:var(--t-base);color:var(--text2);line-height:1.9;margin:0}

/* ショップカード（ガイド用） */
.guide-shops{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.guide-shop-card{
  background:#fff;border:1px solid var(--border2);border-radius:var(--rad);
  padding:20px;transition:all .25s;text-decoration:none;
  display:flex;flex-direction:column;gap:12px;
  position:relative;overflow:hidden;
}
.guide-shop-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--gd);opacity:0;transition:opacity .25s;
}
.guide-shop-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.guide-shop-card:hover::before{opacity:1}
.guide-shop-card img{height:22px;width:auto;object-fit:contain;align-self:flex-start}
.guide-shop-card p{font-size:var(--t-sm);color:var(--text2);line-height:1.8;margin:0;flex:1}
.guide-shop-card-btn{
  display:inline-flex;align-items:center;gap:6px;
  font-size:var(--t-xs);font-weight:700;color:var(--gd);
  margin-top:auto;
}

/* 支払・配送 情報カード */
.info-cards{display:flex;flex-direction:column;gap:8px}
.info-card{
  background:#fff;border:1px solid var(--border2);border-radius:var(--rad);
  overflow:hidden;
}
.info-card-head{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;background:var(--nv);color:#fff;
}
.info-card-head svg{stroke:#fff;fill:none;flex-shrink:0}
.info-card-title{font-size:var(--t-base);font-weight:700;letter-spacing:.04em}
.info-card-body{padding:14px 16px;font-size:var(--t-sm);color:var(--text2);line-height:1.9}
.info-card-body strong{color:var(--nv);font-weight:700}

/* 送料テーブル */
.shipping-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
}
.shipping-item{
  background:#fff;border:1px solid var(--border2);border-radius:var(--rad);
  padding:16px;text-align:center;
}
.shipping-area{font-size:var(--t-sm);font-weight:600;color:var(--nv);margin-bottom:6px}
.shipping-price{
  font-family:'Roboto',sans-serif;font-size:1.3rem;font-weight:800;
  color:var(--r);
}
.shipping-price span{font-size:var(--t-xs);color:var(--text3);font-weight:400}

/* 特定商取引スペックテーブル */
.spec-table{width:100%;border-collapse:collapse}
.spec-table tr{border-bottom:1px solid var(--border2)}
.spec-table tr:last-child{border-bottom:none}
.spec-table th{
  padding:13px 16px;background:var(--bg);
  font-size:var(--t-sm);font-weight:700;color:var(--nv);
  text-align:left;vertical-align:top;
  width:160px;white-space:nowrap;
  border-right:2px solid var(--gd);
}
.spec-table td{
  padding:13px 16px;font-size:var(--t-sm);
  color:var(--text2);line-height:1.85;vertical-align:top;
}

/* キャンセルポリシー */
.policy-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.policy-card{
  background:#fff;border:1px solid var(--border2);
  border-radius:var(--rad);padding:18px;
  position:relative;overflow:hidden;
}
.policy-card::before{
  content:'';position:absolute;top:0;left:0;bottom:0;
  width:3px;background:var(--nv);
}
.policy-card.ng::before{background:var(--r)}
.policy-card.ok::before{background:#2a9d5c}
.policy-card-label{
  font-family:'Roboto',sans-serif;font-size:var(--t-xs);font-weight:700;
  letter-spacing:.1em;margin-bottom:8px;text-transform:uppercase;
}
.policy-card.ng .policy-card-label{color:var(--r)}
.policy-card.ok .policy-card-label{color:#2a9d5c}
.policy-card-title{font-size:var(--t-md);font-weight:700;color:var(--nv);margin-bottom:6px}
.policy-card-body{font-size:var(--t-sm);color:var(--text2);line-height:1.8}

/* お問い合わせボタン */
.contact-btns{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:4px}
.contact-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 16px;border-radius:var(--rad);
  font-size:var(--t-sm);font-weight:700;color:#fff;
  text-align:center;transition:opacity .2s,transform .2s;
}
.contact-btn:hover{opacity:.88;transform:translateY(-1px);color:#fff}

/* プライバシー・免責 */
.prose-block{
  background:#fff;border:1px solid var(--border2);
  border-radius:var(--rad);padding:22px 24px;
}
.prose-block h3{
  font-size:var(--t-md);font-weight:700;color:var(--nv);
  padding-bottom:8px;margin-bottom:12px;
  border-bottom:1px solid var(--border2);
}
.prose-block p{font-size:var(--t-base);color:var(--text2);line-height:1.9;margin-bottom:10px}
.prose-block p:last-child{margin-bottom:0}

/* SP */
@media(max-width:768px){
  .guide-shops{grid-template-columns:1fr}
  .shipping-grid{grid-template-columns:1fr 1fr}
  .policy-cards{grid-template-columns:1fr}
  .contact-btns{grid-template-columns:1fr}
  .spec-table th{width:100px;font-size:11px}
}

/* ━━ FAQ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{
  border:1px solid var(--border2);border-radius:var(--rad);
  background:#fff;cursor:pointer;transition:border-color .2s;
  overflow:hidden;
}
.faq-item:hover{border-color:rgba(184,134,11,.4)}
.faq-item.open{border-color:var(--gd)}
.faq-q{
  display:flex;align-items:flex-start;gap:12px;
  padding:16px 18px;
  font-size:var(--t-md);font-weight:600;color:var(--nv);line-height:1.6;
}
.faq-icon{
  flex-shrink:0;width:24px;height:24px;border-radius:50%;
  background:var(--nv);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Roboto',sans-serif;font-size:12px;font-weight:700;
  margin-top:1px;
}
.faq-icon-a{background:var(--gd)}
.faq-arrow{
  margin-left:auto;flex-shrink:0;color:var(--text3);
  transition:transform .25s;margin-top:3px;
}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{
  display:none;padding:0 18px 16px 54px;
  font-size:var(--t-base);color:var(--text2);line-height:1.9;
  display:flex;gap:12px;align-items:flex-start;
  max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;
  padding-top:0;padding-bottom:0;
}
.faq-item.open .faq-a{
  max-height:400px;padding:0 18px 16px 18px;
}
.faq-a .faq-icon{margin-top:1px;flex-shrink:0}
.faq-a > span:last-child{flex:1}

/* 商品詳細内FAQ */
.pd-faq{margin-top:40px;padding-top:32px;border-top:1px solid var(--border2)}

/* ━━ カテゴリページ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cat-page-header{
  background:#fff;border:1px solid var(--border2);
  border-radius:var(--rad);border-top:4px solid var(--gd);
  padding:24px;margin-bottom:40px;margin-top:0;
}
.cat-page-header-inner{display:flex;align-items:flex-start;gap:18px}
.cat-page-icon{
  width:72px;height:72px;border-radius:12px;overflow:hidden;
  background:var(--bg2);flex-shrink:0;
}
.cat-page-icon img{width:100%;height:100%;object-fit:cover}
.cat-page-en{
  font-family:'Roboto',sans-serif;font-size:.52rem;font-weight:700;
  color:var(--gd);letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:4px;
}
.cat-page-title{
  font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:700;
  color:var(--nv);margin-bottom:8px;line-height:1.3;
}
.cat-page-desc{
  font-size:var(--t-sm);color:var(--text2);line-height:1.85;margin:0;
}

/* 関連カテゴリ */
.related-cats{
  display:grid;grid-template-columns:repeat(6,1fr);gap:10px;
}
.related-cat-item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:12px 6px;border-radius:var(--rad);
  border:1px solid var(--border2);background:#fff;
  text-decoration:none;color:var(--text2);
  transition:all .2s;text-align:center;font-size:var(--t-xs);
}
.related-cat-item:hover{border-color:var(--gd);color:var(--nv);box-shadow:var(--sh)}
.related-cat-item img{
  width:44px;height:44px;border-radius:8px;object-fit:cover;
}

/* cat-btnをリンク化したので見た目を維持 */
a.cat-btn{display:inline-block;cursor:pointer;text-decoration:none}

@media(max-width:768px){
  .related-cats{grid-template-columns:repeat(3,1fr)}
  .cat-page-header-inner{flex-direction:column;gap:12px}
  .cat-page-icon{width:56px;height:56px}
}

/* ━━ カテゴリ一覧グリッド ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cat-grid-full{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cat-grid-card{
  display:flex;align-items:center;gap:14px;
  padding:16px;border-radius:var(--rad);
  border:1px solid var(--border2);background:#fff;
  text-decoration:none;color:var(--text);
  transition:all .25s;position:relative;overflow:hidden;
}
.cat-grid-card::before{
  content:'';position:absolute;top:0;left:0;bottom:0;
  width:3px;background:var(--gd);opacity:0;transition:opacity .25s;
}
.cat-grid-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.cat-grid-card:hover::before{opacity:1}
.cat-grid-icon{
  width:56px;height:56px;border-radius:10px;overflow:hidden;
  background:var(--bg2);flex-shrink:0;
}
.cat-grid-icon img{width:100%;height:100%;object-fit:cover}
.cat-grid-body{flex:1;min-width:0}
.cat-grid-en{font-family:'Roboto',sans-serif;font-size:.5rem;color:var(--gd);
             letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px}
.cat-grid-name{font-size:var(--t-md);font-weight:700;color:var(--nv);margin-bottom:3px}
.cat-grid-desc{font-size:var(--t-xs);color:var(--text3);line-height:1.5;margin-bottom:4px}
.cat-grid-cnt{font-family:'Roboto',sans-serif;font-size:var(--t-xs);color:var(--text3)}
.cat-grid-cnt span{font-size:var(--t-md);font-weight:700;color:var(--nv);margin-right:2px}
.cat-grid-arr{color:var(--text3);flex-shrink:0}

/* ━━ 検索ページ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.search-header{
  background:#fff;border:1px solid var(--border2);
  border-radius:var(--rad);border-top:4px solid var(--nv);
  padding:24px;
}
.search-header-inner{display:flex;flex-direction:column;gap:12px}
.search-title{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:700;color:var(--nv)}
.search-meta{font-size:var(--t-sm);color:var(--text3)}
.search-meta strong{color:var(--nv);font-family:'Roboto',sans-serif;font-size:var(--t-md)}
.search-form{display:flex;max-width:560px}
.search-form input{
  flex:1;padding:10px 16px;
  border:1px solid var(--border2);border-right:none;
  border-radius:4px 0 0 4px;font-size:var(--t-base);outline:none;
  transition:border-color .2s;
}
.search-form input:focus{border-color:var(--nv)}
.search-form button{
  background:var(--nv);color:#fff;border:none;
  padding:0 20px;border-radius:0 4px 4px 0;
  font-size:var(--t-sm);font-weight:600;cursor:pointer;
  display:flex;align-items:center;gap:7px;transition:background .2s;
}
.search-form button:hover{background:var(--gd)}
.search-empty{
  background:#fff;border:1px solid var(--border2);
  border-radius:var(--rad);padding:32px;text-align:center;
}
.search-empty p{font-size:var(--t-sm);color:var(--text3);margin-bottom:8px}

/* SP */
@media(max-width:768px){
  .cat-grid-full{grid-template-columns:1fr}
  .cat-grid-card{padding:12px}
  .cat-grid-icon{width:44px;height:44px}
}

/* ━━ チャット内商品カード ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.chat-prod-cards{
  display:flex;flex-direction:column;gap:6px;
  padding:0 13px 10px;
}
.chat-prod-card{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 12px;border-radius:6px;
  background:var(--bg);border:1px solid var(--border2);
  text-decoration:none;transition:all .2s;
}
.chat-prod-card:hover{border-color:var(--gd);background:var(--gdp)}
.chat-prod-name{
  font-size:11px;font-weight:500;color:var(--nv);
  flex:1;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.chat-prod-price{
  font-family:'Roboto',sans-serif;font-size:13px;font-weight:700;
  color:var(--r);flex-shrink:0;margin-left:8px;
}
.chat-prod-price span{font-size:10px;color:var(--text3);font-weight:300}

/* ━━ 商品詳細ページ補足 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.pd-top{margin-bottom:40px}
.pd-top-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.pd-img-col{display:flex;flex-direction:column;gap:10px}
@media(max-width:768px){
  .pd-top-grid{grid-template-columns:1fr!important}
}
