    /* 首页商品区：蓝主色 + 少量绿（信任/正向）+ 中性灰，层次清爽 */
    .hk-home-page {
      --hk-blue: #2563eb;
      --hk-blue-700: #1d4ed8;
      --hk-blue-50: #eff6ff;
      --hk-blue-100: #dbeafe;
      --hk-green: #059669;
      --hk-green-soft: #ecfdf5;
      --hk-ink: #0f172a;
      --hk-muted: #64748b;
      --hk-line: #e2e8f0;
      --hk-surface: #f5f8fc;
      /* 与商品白卡一致，避免列表下方整段露出浅灰渐变（桌面窄栏时像多包了一层底） */
      background: #fff;
      border-radius: 0;
      min-width: 0;
      max-width: 100%;
      box-sizing: border-box;
    }
    .hk-home-page > .card {
      border-color: var(--hk-line);
      box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
      min-width: 0;
      max-width: 100%;
    }

    /* Iconfont SVG (Alibaba) */
    .ic { width: 16px; height: 16px; display:inline-flex; align-items:center; justify-content:center; flex:none; }
    .ic svg { width: 16px; height: 16px; display:block; }
    .top-search-wrap { min-width: 0; }
    .top-search-card { margin: 0; }
    .top-search-inner {
      display: flex;
      align-items: center;
      gap: 10px;
      min-height: 48px;
      padding: 4px 5px 4px 14px;
      border-radius: 999px;
      background: #fff;
      border: 1px solid #e8ecf2;
      box-shadow: 0 2px 10px rgba(15, 23, 42, .04);
      transition: border-color .2s ease, box-shadow .2s ease;
    }
    .top-search-inner:focus-within {
      border-color: #93c5fd;
      box-shadow: 0 0 0 3px rgba(37, 99, 235, .1), 0 2px 12px rgba(37, 99, 235, .08);
    }
    .top-search-ico {
      flex: none;
      color: #94a3b8;
      width: 20px;
      height: 20px;
    }
    .top-search-ico svg { width: 20px; height: 20px; display: block; }
    .top-search-input {
      flex: 1 1 auto;
      min-width: 0;
      width: 100%;
      border: 0;
      background: transparent;
      outline: none;
      font-size: 16px;
      color: #1e293b;
      padding: 8px 0;
    }
    .top-search-input::placeholder { color: #a8b4c4; }
    .top-search-btn {
      flex: none;
      height: 40px;
      min-width: 76px;
      padding: 0 18px;
      border-radius: 999px;
      border: 0;
      color: #fff;
      font-weight: 700;
      font-size: 15px;
      letter-spacing: .04em;
      background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
      box-shadow: 0 4px 12px rgba(37, 99, 235, .28);
      cursor: pointer;
      transition: transform .12s ease, box-shadow .15s ease, filter .15s ease;
    }
    .top-search-btn:hover {
      filter: brightness(1.04);
      box-shadow: 0 5px 14px rgba(37, 99, 235, .34);
    }
    .top-search-btn:active { transform: scale(.98); }
    .store-section {
      display: grid;
      gap: 10px;
      min-width: 0;
    }
    .store-card {
      border-radius: 20px;
      background: #fff;
      border: 1px solid #eef1f6;
      box-shadow: 0 2px 12px rgba(15, 23, 42, .05);
      overflow: hidden;
    }
    .store-head {
      display: flex;
      align-items: flex-start;
      gap: 14px;
      padding: 18px 18px 14px;
    }
    .store-logo {
      width: 72px;
      height: 72px;
      border-radius: 10px;
      overflow: hidden;
      border: 0;
      background: linear-gradient(160deg, #b8f3d8 0%, #c8e6ff 48%, #dbeafe 100%);
      display: grid;
      place-items: center;
      flex: none;
    }
    .store-logo img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .store-logo-fallback {
      font-size: 13px;
      font-weight: 700;
      color: #1e40af;
      line-height: 1.15;
      text-align: center;
      padding: 6px;
    }
    .store-body { min-width: 0; flex: 1 1 auto; }
    .store-title-row {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 8px;
      min-width: 0;
    }
    .store-title-group {
      display: flex;
      align-items: center;
      gap: 5px;
      min-width: 0;
      flex: 1 1 auto;
    }
    .store-title {
      margin: 0;
      font-size: 19px;
      font-weight: 700;
      color: #222;
      line-height: 1.25;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .store-badge-qiye {
      flex: none;
      display: inline-grid;
      place-items: center;
      width: 20px;
      height: 20px;
      border-radius: 4px;
      background: #1890ff;
      color: #fff;
      font-size: 11px;
      font-weight: 700;
      line-height: 1;
    }
    .store-sold {
      flex: none;
      font-size: 13px;
      color: #999;
      white-space: nowrap;
      padding-top: 3px;
    }
    .store-sold em {
      font-style: normal;
      color: #1890ff;
      font-weight: 600;
    }
    .store-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 7px;
      margin-top: 10px;
    }
    .store-tag {
      display: inline-flex;
      align-items: center;
      padding: 2px 10px;
      border-radius: 4px;
      font-size: 12px;
      font-weight: 500;
      line-height: 1.45;
      border: 1px solid transparent;
      background: #fff;
    }
    .store-tag--blue { color: #1890ff; border-color: #91caff; }
    .store-tag--green { color: #52c41a; border-color: #b7eb8f; }
    .store-tag--orange { color: #fa8c16; border-color: #ffd591; }
    .store-rating {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 4px 6px;
      margin-top: 10px;
      font-size: 13px;
      color: #999;
      line-height: 1.35;
    }
    .store-stars {
      display: inline-flex;
      align-items: center;
      gap: 0;
      color: #ffc107;
    }
    .store-stars svg { width: 15px; height: 15px; display: block; }
    .store-rating-score { color: #faad14; font-weight: 600; }
    .store-rating-note { color: #bbb; font-size: 11px; }
    .store-divider {
      height: 1px;
      margin: 0 18px;
      background: #f0f0f0;
    }
    .store-trust {
      display: grid;
      gap: 11px;
      padding: 14px 18px 16px;
    }
    .store-trust-row {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 13px;
      color: #333;
      line-height: 1.4;
    }
    .store-trust-ico {
      width: 18px;
      height: 18px;
      flex: none;
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
    .store-trust-ico svg { width: 18px; height: 18px; display: block; }
    .hero-static {
      border-radius: 14px;
      overflow: hidden;
      background: transparent;
      line-height: 0;
    }
    .hero-static img {
      width: 100%;
      height: 108px;
      display: block;
      object-fit: cover;
      object-position: center;
    }
    .hero-swiper { margin-top: 8px; border-radius: 14px; overflow: hidden; border: 1px solid var(--hk-line); background: var(--hk-blue-50); position: relative; }
    .hero-track {
      display: flex;
      width: 100%;
      height: 112px;
      transform: translate3d(0,0,0);
      transition: transform 420ms cubic-bezier(.22,.61,.36,1);
      will-change: transform;
      touch-action: pan-y;
      user-select: none;
    }
    .hero-slide { flex: 0 0 100%; height: 112px; }
    .hero-slide img { width: 100%; height: 112px; object-fit: cover; display: block; }
    .hero-track.is-dragging { transition: none !important; cursor: grabbing; }
    .hero-dots { position: absolute; left: 50%; bottom: 8px; transform: translateX(-50%); display: inline-flex; gap: 4px; }
    .hero-dot { width: 16px; height: 3px; border-radius: 999px; background: rgba(255,255,255,.45); }
    .hero-dot.active { background: #fff; }

    .quick-entry {
      display: grid;
      place-items: center;
      gap: 8px;
      border-radius: 14px;
      padding: 12px 8px;
      transition: background-color .15s ease, transform .12s ease;
    }
    .quick-entry:hover { background: #f8fafc; transform: translateY(-1px); }
    .quick-entry-ico {
      width: 44px;
      height: 44px;
      border-radius: 14px;
      display: grid;
      place-items: center;
      color: #fff;
      font-size: 16px;
      font-weight: 700;
      box-shadow: 0 8px 18px rgba(15, 23, 42, .08);
    }
    .quick-entry-label { font-size: 12px; font-weight: 600; color: var(--hk-muted); }
    .qe-order { background: linear-gradient(135deg, var(--hk-blue-700) 0%, var(--hk-blue) 100%); }
    .qe-verify { background: linear-gradient(135deg, #1e40af 0%, #3b82f6 100%); }
    .qe-cs { background: linear-gradient(135deg, var(--hk-green) 0%, #10b981 100%); }
    .qe-agent { background: linear-gradient(135deg, #1d4ed8 0%, #60a5fa 100%); }

    /* 流量号卡卡片（对齐参考：浅蓝头区 / 流量角标 / 右侧绿标 / 白底四宫格 / 底栏图标） */
    .hk-sim-card.card {
      padding: 0 !important;
      border-radius: 14px;
      overflow: hidden;
      border: 1px solid var(--hk-line);
      box-shadow: 0 1px 3px rgba(37, 99, 235, .05), 0 8px 24px rgba(15, 23, 42, .05);
      background: #fff;
    }
    .p2-card { padding: 0; border-radius: 14px; border: 0; background: #fff; }
    .p2-card[data-product-href] { cursor: pointer; }
    .p2-top {
      display: grid;
      grid-template-columns: 88px minmax(0, 1fr) max-content;
      gap: 12px;
      align-items: start;
    }
    .p2-thumb {
      width: 88px;
      flex: none;
    }
    .p2-cover-wrap {
      width: 88px;
      height: 88px;
      border-radius: 10px;
      overflow: hidden;
      background: #fff;
      border: 1px solid var(--hk-line);
      position: relative;
    }
    .p2-cover-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }
    .p2-cover-ph {
      width: 100%;
      height: 100%;
      display: grid;
      place-items: center;
      font-size: 11px;
      font-weight: 800;
      color: #94a3b8;
      background: linear-gradient(145deg, #f1f5f9, #e2e8f0);
    }
    .p2-title {
      font-size: 16px;
      font-weight: 800;
      color: var(--hk-ink);
      line-height: 1.25;
      margin: 0;
      white-space: normal !important;
      overflow: hidden !important;
      text-overflow: clip !important;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
    }
    .p2-line-primary {
      margin-top: 6px;
      font-size: 13px;
      font-weight: 700;
      color: var(--hk-blue-700);
      line-height: 1.35;
    }
    .p2-line-secondary {
      margin-top: 4px;
      font-size: 11px;
      font-weight: 600;
      color: #9ca3af;
      line-height: 1.35;
    }
    .p2-badges-stack {
      display: flex;
      flex-direction: column;
      align-items: flex-end;
      justify-content: flex-start;
      gap: 6px;
      flex: none;
      justify-self: end;
      align-self: start;
      min-width: 0;
      text-align: right;
    }
    .p2-side-badge {
      display: inline-flex;
      flex-direction: row;
      align-items: center;
      flex-wrap: nowrap;
      gap: 3px;
      border-radius: 6px;
      padding: 4px 7px;
      font-size: 10px;
      font-weight: 800;
      line-height: 1.2;
      white-space: nowrap;
    }
    .p2-side-badge.is-ok {
      background: var(--hk-green-soft);
      color: var(--hk-green);
      border: 1px solid #a7f3d0;
    }
    .p2-side-badge.is-muted {
      background: #f3f4f6;
      color: #6b7280;
      border: 1px solid #e5e7eb;
    }
    .p2-side-badge.is-broadband {
      background: linear-gradient(135deg, #eff6ff, #dbeafe);
      color: #1d4ed8;
      border: 1px solid #93c5fd;
    }
    .p2-broadband-mark {
      position: absolute;
      left: 0;
      top: 0;
      z-index: 2;
      display: inline-flex;
      align-items: center;
      gap: 2px;
      padding: 3px 6px 3px 4px;
      border-radius: 0 0 8px 0;
      background: linear-gradient(135deg, #2563eb, #1d4ed8);
      color: #fff;
      font-size: 10px;
      font-weight: 800;
      line-height: 1;
      box-shadow: 0 2px 8px rgba(37, 99, 235, .35);
      pointer-events: none;
    }
    .p2-broadband-mark .p2-broadband-ico {
      width: 11px;
      height: 11px;
    }
    .p2-broadband-ico {
      width: 12px;
      height: 12px;
      flex: none;
    }
    .p2-mid { margin: 0; border-radius: 0; border: 0; border-top: 1px solid var(--hk-line); background: #fafcfe; overflow: hidden; }
    .p2-metrics { display: grid; grid-template-columns: repeat(4, 1fr); }
    .p2-metric { padding: 12px 6px; text-align: center; background: #fafcfe; }
    .p2-metric + .p2-metric { border-left: 1px solid var(--hk-line); }
    .p2-val-red,
    .p2-val-blue,
    .p2-val {
      font-size: 18px;
      font-weight: 800;
      color: var(--hk-ink);
      line-height: 1;
    }
    .p2-metric:first-child .p2-val { color: var(--hk-blue-700); }
    .p2-lbl { margin-top: 6px; font-size: 11px; font-weight: 600; color: var(--hk-muted); }
    .p2-bottom {
      margin: 0;
      padding: 12px 14px 14px;
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: 10px;
      border-top: 1px solid var(--hk-line);
      background: #fff;
    }
    .p2-meta { display: flex; flex-direction: column; gap: 6px; font-size: 12px; color: var(--hk-muted); min-width: 0; flex: 1; }
    .p2-meta-row {
      display: flex;
      align-items: center;
      gap: 6px;
      min-width: 0;
    }
    .p2-meta-ico { width: 14px; height: 14px; flex: none; color: #9ca3af; display: inline-flex; align-items: center; justify-content: center; }
    .p2-meta-ico svg { width: 14px; height: 14px; display: block; }
    .p2-meta-row span { min-width: 0; }
    .p2-actions { display: flex; align-items: center; gap: 8px; flex: none; }
    .p2-btn {
      height: 36px;
      padding: 0 14px;
      border-radius: 10px;
      font-size: 13px;
      font-weight: 800;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 6px;
      text-decoration: none;
      border: 1px solid transparent;
    }
    .p2-btn-share {
      background: #fff;
      color: #6b7280;
      border-color: #e5e7eb;
    }
    .p2-btn-share .p2-share-ico { width: 14px; height: 14px; opacity: .85; }
    .p2-btn-primary {
      background: linear-gradient(180deg, var(--hk-blue) 0%, var(--hk-blue-700) 100%);
      color: #fff;
      border-color: transparent;
      box-shadow: 0 4px 12px rgba(37, 99, 235, .28);
    }
    .p2-btn-primary:active { transform: scale(.99); }

    /* 首页主 Tab + 运营商：随页面滚动，不吸顶固定 */
    .hk-main-tabs {
      border-radius: 18px;
      border: 1px solid #eef1f6;
      background: #fff;
      box-shadow: 0 2px 12px rgba(15, 23, 42, .05);
      overflow: hidden;
    }
    .hk-tab-row {
      display: flex;
      gap: 8px;
      padding: 10px 12px 0;
    }
    .hk-tab-inner {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 7px;
      width: 100%;
      padding: 11px 10px;
      border-radius: 12px;
      transition: background-color .2s ease, color .2s ease, box-shadow .2s ease;
    }
    .hk-tab-ico {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 22px;
      height: 22px;
      border-radius: 8px;
      background: #f1f5f9;
      color: #94a3b8;
      transition: background-color .2s ease, color .2s ease;
    }
    .hk-tab-ico svg { width: 14px; height: 14px; display: block; }
    .hk-tab-btn {
      flex: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0;
      font-size: 15px;
      font-weight: 700;
      color: #94a3b8;
      background: transparent;
      border: 0;
      cursor: pointer;
      transition: color .2s ease;
    }
    .hk-tab-btn:hover:not(.is-active) { color: #64748b; }
    .hk-tab-btn:hover:not(.is-active) .hk-tab-ico {
      background: #e8eef5;
      color: #64748b;
    }
    .hk-tab-btn.is-active { color: #fff; }
    .hk-tab-btn.is-active .hk-tab-inner {
      background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
      box-shadow: 0 4px 14px rgba(37, 99, 235, .28);
    }
    .hk-tab-btn.is-active .hk-tab-ico {
      background: rgba(255, 255, 255, .22);
      color: #fff;
    }
    .hk-tab-panel.hidden { display: none !important; }
    .hk-tab-panel { display: block; min-width: 0; max-width: 100%; }

    .hk-op-bar {
      display: flex;
      align-items: center;
      gap: 6px;
      margin: 0;
      padding: 10px 12px 12px;
      border: 0;
      background: #fff;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
    }
    .hk-op-bar::-webkit-scrollbar { display: none; }
    .hk-op-bar.is-hidden { display: none !important; }
    .hk-op-ico {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 18px;
      height: 18px;
      border-radius: 6px;
      background: rgba(148, 163, 184, .12);
      color: currentColor;
      flex: none;
      overflow: hidden;
    }
    .hk-op-ico svg { width: 12px; height: 12px; display: block; }
    .hk-op-ico--brand {
      width: 20px;
      height: 20px;
      border-radius: 6px;
      background: #fff;
      border: 1px solid rgba(15, 23, 42, .08);
      padding: 0;
    }
    .hk-op-ico--brand .hk-carrier-logo {
      width: 100%;
      height: 100%;
      display: block;
      border-radius: 5px;
    }
    .hk-op-ico--brand .hk-carrier-logo--img {
      object-fit: cover;
      border-radius: 5px;
    }
    .hk-op-tab.is-active .hk-op-ico--brand {
      background: #fff;
      border-color: rgba(15, 23, 42, .1);
      box-shadow: 0 1px 4px rgba(15, 23, 42, .08);
    }
    .hk-op-inner {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 5px;
      white-space: nowrap;
    }
    .hk-op-tab {
      flex: 1 1 0;
      min-width: 52px;
      text-align: center;
      padding: 0 4px;
      font-size: 12px;
      font-weight: 600;
      color: #64748b;
      background: #f4f6f9;
      border: 1px solid transparent;
      border-radius: 10px;
      cursor: pointer;
      transition: color .18s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease;
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 36px;
      white-space: nowrap;
    }
    .hk-op-tab:hover:not(.is-active) {
      color: #334155;
      background: #eef2f7;
    }
    .hk-op-tab.is-active {
      color: var(--hk-blue-700);
      font-weight: 800;
      background: #fff;
      border-color: #bfdbfe;
      box-shadow: 0 2px 8px rgba(37, 99, 235, .12);
    }
    .hk-op-tab.is-active .hk-op-ico:not(.hk-op-ico--brand) {
      background: rgba(37, 99, 235, .12);
      color: var(--hk-blue);
    }
    .hk-op-tab.op-m.is-active { color: #047857; border-color: #86efac; }
    .hk-op-tab.op-t.is-active { color: #1d4ed8; border-color: #93c5fd; }
    .hk-op-tab.op-u.is-active { color: #b91c1c; border-color: #fca5a5; }
    .hk-op-tab.op-b.is-active { color: #1e3a8a; border-color: #93c5fd; }

    .hk-shop-cat-bar {
      display: flex;
      flex-wrap: nowrap;
      align-items: stretch;
      gap: 6px;
      width: 100%;
      margin: 0;
      padding: 10px 12px 12px;
      border: 0;
      background: #fff;
      box-sizing: border-box;
      overflow: hidden;
    }
    .hk-shop-cat-bar.is-hidden { display: none !important; }
    .hk-shop-cat-tab {
      flex: 1 1 0;
      min-width: 0;
      max-width: 100%;
      text-align: center;
      padding: 8px 10px;
      font-size: 12px;
      font-weight: 600;
      color: #64748b;
      background: #f4f6f9;
      border: 1px solid transparent;
      border-radius: 999px;
      cursor: pointer;
      transition: color .18s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 4px;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      text-decoration: none;
      box-sizing: border-box;
    }
    .hk-shop-cat-tab:hover:not(.is-active) {
      color: #334155;
      background: #eef2f7;
    }
    .hk-shop-cat-tab.is-active {
      color: var(--hk-blue-700);
      font-weight: 800;
      background: #fff;
      border-color: #bfdbfe;
      box-shadow: 0 2px 8px rgba(37, 99, 235, .12);
    }
    .p2-card { transition: transform .2s ease, box-shadow .2s ease; }
    .hk-sim-card { transition: transform .2s ease, box-shadow .2s ease; }
    .hk-sim-card:hover {
      transform: translateY(-2px);
      box-shadow: 0 4px 14px rgba(37, 99, 235, .1), 0 12px 28px rgba(15, 23, 42, .07);
    }
    .p2-hero {
      border-radius: 0;
      padding: 14px 14px 12px;
      margin: 0;
      background: linear-gradient(135deg, var(--hk-blue-50) 0%, #f8fafc 55%, #fff 100%);
    }
    .p2-hero--mobile,
    .p2-hero--telecom,
    .p2-hero--unicom,
    .p2-hero--broadnet,
    .p2-hero--def {
      background: linear-gradient(135deg, var(--hk-blue-50) 0%, #f8fafc 55%, #fff 100%);
    }

    .hk-shop-grid {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 10px;
    }
    .hk-shop-grid > .hk-shop-card {
      flex: 0 0 calc((100% - 12px) / 2);
      width: calc((100% - 12px) / 2);
      max-width: calc((100% - 12px) / 2);
      box-sizing: border-box;
    }
    .hk-shop-card {
      border-radius: 14px;
      border: 1px solid var(--hk-line);
      background: #fff;
      overflow: hidden;
      box-shadow: 0 1px 3px rgba(37, 99, 235, .05), 0 6px 18px rgba(15, 23, 42, .05);
      transition: transform .2s ease, box-shadow .2s ease;
    }
    .hk-shop-card:hover {
      transform: translateY(-2px);
      box-shadow: 0 4px 14px rgba(37, 99, 235, .1), 0 12px 28px rgba(15, 23, 42, .07);
    }
    .hk-shop-img {
      height: 148px;
      background: #f8fafc;
      display: grid;
      place-items: center;
      overflow: hidden;
      padding: 6px;
      box-sizing: border-box;
    }
    .hk-shop-img img { width: 100%; height: 100%; object-fit: contain; object-position: center; display: block; }
    .hk-shop-body { padding: 10px 10px 12px; }
    .hk-shop-title { font-size: 14px; font-weight: 900; color: #111827; line-height: 1.35; }
    .hk-shop-desc { margin-top: 4px; font-size: 11px; color: #64748b; line-height: 1.4; min-height: 2.8em; }
    .hk-shop-foot { margin-top: 8px; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
    .hk-shop-price { font-size: 17px; font-weight: 800; color: var(--hk-blue-700); }
    .hk-shop-buy {
      height: 30px;
      padding: 0 12px;
      border-radius: 999px;
      border: 0;
      font-size: 12px;
      font-weight: 800;
      color: #fff;
      background: linear-gradient(90deg, var(--hk-blue-700), var(--hk-blue));
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 2px 8px rgba(37, 99, 235, .25);
    }
    .hk-shop-cats {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 10px;
      padding: 2px 0;
      align-items: center;
    }
    .hk-list-pager {
      margin-top: 8px;
      padding: 8px 8px 0;
      border-top: 1px solid #f1f5f9;
      background: #fff;
    }
    .hk-inf-scroll {
      padding: 14px 8px 20px;
      text-align: center;
      min-height: 44px;
    }
    .hk-inf-scroll__hint {
      font-size: 12px;
      font-weight: 600;
      color: #94a3b8;
      letter-spacing: .02em;
    }
    .hk-inf-scroll.is-loading .hk-inf-scroll__hint::after {
      content: '…';
    }
    .hk-inf-scroll.is-done .hk-inf-scroll__hint--done {
      color: #cbd5e1;
    }
    .hk-shop-pager {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      flex-wrap: nowrap;
    }
    .hk-shop-pager a, .hk-shop-pager span {
      min-width: 72px;
      height: 36px;
      padding: 0 12px;
      border-radius: 10px;
      border: 1px solid #e5e7eb;
      background: #fff;
      font-size: 13px;
      font-weight: 700;
      color: #334155;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      text-decoration: none;
      box-sizing: border-box;
    }
    .hk-shop-pager a:hover { border-color: var(--hk-blue); color: var(--hk-blue-700); }
    .hk-shop-pager .is-disabled {
      border-color: #e2e8f0;
      background: #f8fafc;
      color: #94a3b8;
      cursor: not-allowed;
    }
    .hk-shop-pager .is-current {
      min-width: 56px;
      border-color: var(--hk-blue);
      background: var(--hk-blue-50);
      color: var(--hk-blue-700);
      font-weight: 800;
    }

    /* 首页：列表紧贴版权；底部留白只由页脚为固定导航预留一次，避免 main+footer 双重垫高 */
    body.hk-page-home.hk-has-bottom-nav main {
      flex: 0 1 auto;
      padding-bottom: 0;
    }
    body.hk-page-home .hk-home-page {
      padding-bottom: 0;
    }
    body.hk-page-home .hk-site-footer {
      margin-top: 0;
      background: #fff;
      border-top: 1px solid #f1f5f9;
    }
    body.hk-page-home .hk-site-footer__glow {
      display: none;
    }
    body.hk-page-home.hk-has-bottom-nav .hk-site-footer__inner {
      padding: 6px 16px calc(10px + 52px + env(safe-area-inset-bottom, 0px));
    }
    body.hk-page-home .hk-site-footer__copy {
      font-size: 11px;
      color: #94a3b8;
    }
    body.hk-page-home .hk-site-footer__accent {
      margin-top: 6px;
      width: 32px;
      height: 2px;
      opacity: 0.5;
    }
    /* 号卡工具条：与 .hk-op-bar 同卡、同色带，仅「流量号卡」时显示 */
    .hk-main-tabs:has(#hkTabShop.is-active) .hk-sim-tools {
      display: none !important;
    }
    .hk-sim-tools {
      margin: 0;
      padding: 0 12px 12px;
      border-top: 1px solid #f1f5f9;
      background: #fff;
    }
    .hk-sim-tools.is-geo-guide-open {
      position: relative;
      z-index: 206;
      overflow: visible;
    }
    .hk-sim-tools .top-filter-card {
      margin: 0;
      padding: 0;
      background: transparent;
      border: 0;
      box-shadow: none;
      overflow: visible;
      min-width: 0;
      max-width: 100%;
      box-sizing: border-box;
    }
    .hk-sim-tools .top-filter-bar {
      display: flex;
      align-items: stretch;
      gap: 8px;
      width: 100%;
      min-width: 0;
      box-sizing: border-box;
      padding: 0;
      border-radius: 0;
      background: transparent;
    }
    .hk-sim-tools .top-filter-item {
      flex: 1 1 0;
      min-width: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 36px;
      padding: 0 10px;
      font-size: 13px;
      font-weight: 600;
      color: #64748b;
      background: #fff;
      border: 1px solid var(--hk-line);
      border-radius: 10px;
      cursor: pointer;
      transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
    }
    .hk-sim-tools .top-filter-item:hover {
      color: var(--hk-blue-700);
      border-color: var(--hk-blue-100);
      background: var(--hk-blue-50);
    }
    .hk-sim-tools .top-filter-item--cta {
      color: var(--hk-blue-700);
      font-weight: 700;
    }
    .hk-sim-tools .tfi-stack {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 5px;
      min-width: 0;
      max-width: 100%;
    }
    .hk-sim-tools .tfi-txt {
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .hk-sim-tools .tfi-ico {
      width: 16px;
      height: 16px;
      min-width: 16px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      color: currentColor;
    }
    .hk-sim-tools .tfi-ico svg {
      width: 15px;
      height: 15px;
      display: block;
    }
    .hk-sim-tools .tfi-chev {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      width: 10px;
      height: 10px;
      color: #94a3b8;
    }
    .hk-sim-tools .tfi-chev svg {
      width: 10px;
      height: 10px;
      display: block;
    }

    /* 首页定位新手引导 */
    .geo-guide {
      position: fixed;
      inset: 0;
      z-index: 125;
      display: none;
      pointer-events: none;
    }
    .geo-guide.is-open {
      display: block;
      pointer-events: auto;
    }
    .geo-guide__backdrop {
      position: absolute;
      inset: 0;
      background: rgba(15, 23, 42, 0.38);
    }
    .geo-guide__popover {
      position: fixed;
      left: 50%;
      top: 0;
      width: min(300px, calc(100vw - 24px));
      max-height: min(360px, calc(100vh - 24px));
      overflow: auto;
      padding: 14px 14px 12px;
      border-radius: 14px;
      border: 1px solid #eef2f7;
      background: #fff;
      box-shadow: 0 12px 32px rgba(15, 23, 42, 0.1), 0 2px 6px rgba(15, 23, 42, 0.04);
      box-sizing: border-box;
      z-index: 205;
    }
    .geo-guide__popover.is-below::before {
      content: '';
      position: absolute;
      left: var(--geo-guide-arrow-x, 50%);
      top: -6px;
      width: 12px;
      height: 12px;
      margin-left: -6px;
      background: #fff;
      border-left: 1px solid #eef2f7;
      border-top: 1px solid #eef2f7;
      transform: rotate(45deg);
    }
    .geo-guide__popover.is-above::before {
      content: '';
      position: absolute;
      left: var(--geo-guide-arrow-x, 50%);
      bottom: -6px;
      width: 12px;
      height: 12px;
      margin-left: -6px;
      background: #fff;
      border-right: 1px solid #eef2f7;
      border-bottom: 1px solid #eef2f7;
      transform: rotate(45deg);
    }
    .geo-guide__popover::before {
      display: none;
    }
    .geo-guide__popover.is-below::before,
    .geo-guide__popover.is-above::before {
      display: block;
    }
    .geo-guide__head {
      display: flex;
      align-items: flex-start;
      gap: 10px;
    }
    .geo-guide__head-ico {
      flex: none;
      width: 32px;
      height: 32px;
      border-radius: 10px;
      background: #f8fafc;
      border: 1px solid #eef2f7;
      color: #2563eb;
      display: grid;
      place-items: center;
    }
    .geo-guide__head-ico svg {
      width: 17px;
      height: 17px;
      display: block;
    }
    .geo-guide__head-main {
      min-width: 0;
      flex: 1;
    }
    .geo-guide__badge {
      display: inline-flex;
      align-items: center;
      height: 20px;
      padding: 0 7px;
      border-radius: 5px;
      background: #f8fafc;
      color: #64748b;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.02em;
    }
    .geo-guide__title {
      margin-top: 6px;
      font-size: 14px;
      font-weight: 800;
      color: #0f172a;
      line-height: 1.4;
    }
    .geo-guide__region {
      margin-top: 10px;
      padding: 8px 10px;
      border-radius: 8px;
      background: #f8fafc;
      border: 1px solid #eef2f7;
      font-size: 12px;
      font-weight: 600;
      line-height: 1.4;
      color: #334155;
    }
    .geo-guide__region[hidden] {
      display: none;
    }
    .geo-guide__region::before {
      content: '当前识别：';
      color: #94a3b8;
      font-weight: 500;
    }
    .geo-guide__tip {
      margin-top: 8px;
      font-size: 12px;
      line-height: 1.55;
      color: #64748b;
    }
    .geo-guide__tip strong {
      color: #334155;
      font-weight: 700;
    }
    .geo-guide__actions {
      display: flex;
      flex-direction: column;
      gap: 8px;
      margin-top: 12px;
    }
    .geo-guide__btn {
      display: block;
      width: 100%;
      min-width: 0;
      height: 36px;
      border: 0;
      border-radius: 999px;
      font-size: 13px;
      font-weight: 700;
      cursor: pointer;
    }
    .geo-guide__btn--primary {
      background: #2563eb;
      color: #fff;
      box-shadow: 0 4px 12px rgba(37, 99, 235, 0.16);
    }
    .geo-guide__btn--ghost {
      background: #fff;
      color: #64748b;
      border: 1px solid #e2e8f0;
    }
    .geo-guide__btn--ghost:disabled {
      opacity: 0.55;
      cursor: not-allowed;
      color: #94a3b8;
      border-color: #e8eef5;
      background: #f8fafc;
    }
    .geo-guide__btn:active {
      transform: scale(0.99);
      opacity: 0.96;
    }

    .top-cats { padding: 7px 10px 9px; display:flex; flex-wrap:wrap; gap:7px; }
    .cat-pill {
      display:inline-flex; align-items:center; justify-content:center;
      height: 28px; padding: 0 12px; border-radius: 999px;
      font-size: 11px; font-weight: 800; text-decoration:none;
    }
    .cat-pill.active { background: var(--hk-blue-700); color: #fff; }
    .cat-pill.inactive { background:#f1f5f9; color:#111827; }
    .cat-pill.inactive:hover { background:#e2e8f0; }
    .cat-break { flex-basis: 100%; height: 0; }

    /* Dropdown (match 图1): compact floating menu under the clicked filter */
    .dd {
      position: absolute;
      top: 52px;
      z-index: 120;
      opacity: 0;
      transform: translateY(-6px) scale(0.985);
      pointer-events: none;
      transition: opacity .14s ease, transform .16s ease;
      will-change: transform, opacity;
    }
    .dd.is-open {
      opacity: 1;
      transform: translateY(0) scale(1);
      pointer-events: auto;
    }
    .dd-panel {
      border-radius: 12px;
      border: 1px solid #e5e7eb;
      background: #fff;
      box-shadow: 0 12px 28px rgba(15,23,42,.14);
      overflow: hidden;
      max-height: 46vh;
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
    }
    .dd-item {
      width: 100%;
      text-align: left;
      padding: 9px 10px;
      font-size: 12px;
      font-weight: 800;
      color: #111827;
      background: #fff;
      border: 0;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .dd-item:hover { background: #f8fafc; }
    .dd-item + .dd-item { border-top: 1px solid #f1f5f9; }
    .dd-item.is-active { background:#f1f5f9; color:#111827; }
    .dd-item small { font-size: 12px; font-weight: 900; color: var(--hk-blue-700); }
    .dd-backdrop { position: fixed; inset: 0; z-index: 40; background: transparent; display:none; }
    .dd-backdrop.is-open { display:block; }

    /* 定制付费需求弹窗：与 .hk-main-tabs / 商品卡同系圆角、描边与主色 */
    .hk-cr-backdrop {
      position: fixed;
      inset: 0;
      z-index: 80;
      background: rgba(15, 23, 42, 0.36);
      backdrop-filter: blur(4px);
      -webkit-backdrop-filter: blur(4px);
      display: none;
      align-items: center;
      justify-content: center;
      padding: 16px 14px calc(18px + env(safe-area-inset-bottom, 0px));
      box-sizing: border-box;
    }
    .hk-cr-backdrop.is-open { display: flex; }
    .hk-cr-sheet {
      width: 100%;
      max-width: 400px;
      background: #fff;
      border-radius: 14px;
      border: 1px solid var(--hk-line);
      box-shadow: 0 4px 18px rgba(15, 23, 42, 0.08), 0 1px 2px rgba(15, 23, 42, 0.04);
      padding: 0 0 16px;
      max-height: min(88vh, 560px);
      display: flex;
      flex-direction: column;
      gap: 0;
      box-sizing: border-box;
      overflow: hidden;
      animation: hkCrIn 0.24s cubic-bezier(0.22, 0.61, 0.36, 1) both;
    }
    @keyframes hkCrIn {
      from { opacity: 0; transform: translateY(8px); }
      to { opacity: 1; transform: translateY(0); }
    }
    .hk-cr-head {
      text-align: center;
      padding: 12px 18px 8px;
      flex: none;
    }
    .hk-cr-kicker {
      font-size: 11px;
      font-weight: 800;
      letter-spacing: 0.06em;
      color: #94a3b8;
      margin-bottom: 4px;
    }
    .hk-cr-title {
      font-size: 17px;
      font-weight: 900;
      color: var(--hk-ink);
      letter-spacing: -0.02em;
      line-height: 1.25;
    }
    .hk-cr-hint {
      font-size: 12.5px;
      color: var(--hk-muted);
      line-height: 1.55;
      padding: 0 18px 12px;
      flex: none;
    }
    .hk-cr-hint .hk-cr-em {
      color: #475569;
      font-weight: 800;
    }
    .hk-cr-pricebox {
      margin: 0 18px 12px;
      padding: 10px 12px;
      border-radius: 12px;
      background: linear-gradient(135deg, var(--hk-blue-50) 0%, #f8fafc 55%, #fff 100%);
      border: 1px solid var(--hk-blue-100);
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      flex: none;
    }
    .hk-cr-pricebox.is-warn {
      background: #fffbeb;
      border-color: #fde68a;
    }
    .hk-cr-price-label {
      font-size: 12px;
      font-weight: 800;
      color: var(--hk-muted);
    }
    .hk-cr-price-num {
      font-size: 17px;
      font-weight: 900;
      letter-spacing: -0.02em;
      color: var(--hk-ink);
      font-variant-numeric: tabular-nums;
    }
    .hk-cr-price-num em {
      font-style: normal;
      color: var(--hk-green);
    }
    .hk-cr-price-warn {
      font-size: 14px;
      font-weight: 800;
      color: #b45309;
    }
    .hk-cr-fields {
      padding: 0 18px;
      display: flex;
      flex-direction: column;
      gap: 12px;
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
    }
    .hk-cr-field label {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 8px;
      font-size: 12.5px;
      font-weight: 800;
      color: #334155;
      margin-bottom: 6px;
    }
    .hk-cr-field .hk-cr-subl {
      font-size: 11px;
      font-weight: 600;
      color: #94a3b8;
    }
    .hk-cr-field input,
    .hk-cr-field textarea {
      width: 100%;
      box-sizing: border-box;
      border: 1px solid var(--hk-line);
      border-radius: 12px;
      padding: 11px 12px;
      font-size: 15px;
      outline: none;
      background: #fafcfe;
      transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
    }
    .hk-cr-field input::placeholder,
    .hk-cr-field textarea::placeholder {
      color: #94a3b8;
      font-size: 13px;
    }
    .hk-cr-field input:focus,
    .hk-cr-field textarea:focus {
      border-color: rgba(37, 99, 235, 0.45);
      background: #fff;
      box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
    }
    .hk-cr-field textarea { min-height: 104px; resize: vertical; line-height: 1.45; }
    .hk-cr-actions {
      display: flex;
      gap: 10px;
      margin-top: 14px;
      padding: 0 18px;
      flex: none;
    }
    .hk-cr-actions button {
      flex: 1;
      border-radius: 12px;
      padding: 11px 10px;
      font-size: 15px;
      font-weight: 800;
      border: 1px solid var(--hk-line);
      background: #fafcfe;
      color: var(--hk-muted);
      cursor: pointer;
      transition: transform .12s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease;
    }
    .hk-cr-actions button:active { transform: scale(0.98); }
    .hk-cr-actions button.primary {
      border: 0;
      color: #fff;
      background: linear-gradient(180deg, var(--hk-blue) 0%, var(--hk-blue-700) 100%);
      box-shadow: 0 4px 12px rgba(37, 99, 235, 0.28);
    }
    .hk-cr-actions button.primary:disabled {
      opacity: 0.55;
      cursor: not-allowed;
      transform: none;
      box-shadow: none;
    }

    /* Geo picker drawer (定位 -> 选择收货地) */
    .geo-backdrop{
      position: fixed; inset: 0; z-index: 130;
      background: rgba(0,0,0,.32);
      opacity: 0; pointer-events: none;
      transition: opacity .18s ease;
    }
    .geo-backdrop.is-open{ opacity: 1; pointer-events: auto; }
    .geo-drawer{
      position: fixed; top: 0; right: 0; bottom: 0;
      z-index: 140;
      width: min(92vw, 520px);
      background: #fff;
      border-left: 1px solid #e5e7eb;
      box-shadow: -18px 0 44px rgba(15,23,42,.18);
      transform: translate3d(12px,0,0);
      opacity: 0;
      pointer-events: none;
      transition: transform .22s cubic-bezier(.22,.61,.36,1), opacity .18s ease;
      display: flex;
      flex-direction: column;
    }
    .geo-drawer.is-open{ transform: translate3d(0,0,0); opacity: 1; pointer-events: auto; }
    .geo-head{
      display:flex; align-items:center; justify-content:space-between;
      padding: 12px 12px;
      border-bottom: 1px solid #f1f5f9;
    }
    .geo-title{ font-size: 14px; font-weight: 900; color:#111827; }
    .geo-head-actions{ display:flex; align-items:center; gap: 8px; }
    .geo-btn{
      border: 1px solid #e5e7eb;
      background: #fff;
      color: #111827;
      border-radius: 10px;
      padding: 6px 10px;
      font-size: 12px;
      font-weight: 800;
    }
    .geo-btn.primary{ background:#2563eb; border-color:#1d4ed8; color:#fff; }
    .geo-btn:active{ transform: scale(.99); }
    .geo-body{ flex: 1; min-height: 0; display:flex; }
    .geo-col{
      min-width: 0;
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      padding: 8px 0;
    }
    .geo-col + .geo-col{ border-left: 1px solid #f1f5f9; }
    .geo-col.prov{ width: 34%; background: #f8fafc; }
    .geo-col.city{ width: 33%; background: #fff; }
    .geo-col.dist{ width: 33%; background: #fff; }
    .geo-item{
      width: 100%;
      text-align: left;
      padding: 10px 12px;
      border: 0;
      background: transparent;
      font-size: 13px;
      font-weight: 800;
      color:#111827;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .geo-item:hover{ background: #f1f5f9; }
    .geo-item.is-active{ background: var(--hk-blue-50); color: var(--hk-blue-700); }
    .geo-foot{
      padding: 12px;
      border-top: 1px solid #f1f5f9;
      background: #fff;
    }
    .geo-confirm{
      width: 100%;
      height: 44px;
      border-radius: 10px;
      border: 1px solid #1d4ed8;
      background: #2563eb;
      color: #fff;
      font-size: 14px;
      font-weight: 900;
    }

    /* 局部刷新：即时反馈，减轻「点了没反应」的卡顿感 */
    #hkSimAjaxMount.hk-swapping,
    #hkShopAjaxMount.hk-swapping {
      opacity: 0.66;
      pointer-events: none;
      transition: opacity 0.1s ease-out;
      will-change: opacity;
    }

    /* 商品/好物列表：内层 grid 的 gap 会透出 .hk-home-page 浅灰渐变，看起来像卡片背后一条灰底 */
    #hkPanelSim.hk-tab-panel {
      background: #fff;
      min-width: 0;
    }
    #hkSimAjaxMount,
    #hkShopAjaxMount {
      background: #fff;
      min-width: 0;
    }
    @media (max-width: 420px) {
      .top-search-inner { min-height: 44px; padding: 3px 4px 3px 12px; gap: 8px; }
      .top-search-ico { width: 18px; height: 18px; }
      .top-search-ico svg { width: 18px; height: 18px; }
      .top-search-input { font-size: 16px; padding: 7px 0; }
      .top-search-btn { min-width: 68px; height: 36px; font-size: 14px; padding: 0 14px; }

      .store-head { padding: 16px 16px 12px; gap: 12px; }
      .store-logo { width: 64px; height: 64px; }
      .store-title { font-size: 17px; }
      .store-sold { font-size: 12px; }
      .store-tag { font-size: 11px; }
      .store-rating { font-size: 12px; }
      .store-stars svg { width: 14px; height: 14px; }
      .store-trust { padding: 12px 16px 14px; }
      .store-trust-row { font-size: 12px; }
      .hero-static img { height: 96px; }
      .hero-track, .hero-slide, .hero-slide img { height: 104px; }

      .hk-tab-row { padding: 8px 10px 0; gap: 6px; }
      .hk-tab-btn { font-size: 14px; }
      .hk-tab-inner { padding: 10px 8px; }
      .hk-tab-ico { width: 20px; height: 20px; }
      .hk-tab-ico svg { width: 13px; height: 13px; }
      .hk-op-bar { gap: 5px; padding: 8px 10px 10px; }
      .hk-op-tab { font-size: 11px; min-height: 34px; min-width: 48px; }
      .hk-shop-cat-bar { gap: 5px; padding: 8px 10px 10px; }
      .hk-shop-cat-tab { font-size: 11px; padding: 7px 12px; }

      .hk-sim-tools { padding: 6px 8px 8px; }
      .hk-sim-tools .top-filter-item { min-height: 36px; font-size: 13px; }
      .hk-cr-backdrop { padding: 12px 10px calc(14px + env(safe-area-inset-bottom, 0px)); }
      .hk-cr-sheet { border-radius: 12px; max-height: min(90vh, 540px); }
      .hk-cr-head { padding: 10px 14px 6px; }
      .hk-cr-title { font-size: 16px; }
      .hk-cr-hint { font-size: 12px; padding: 0 14px 10px; }
      .hk-cr-pricebox { margin: 0 14px 10px; padding: 9px 10px; }
      .hk-cr-fields { padding: 0 14px; gap: 10px; }
      .hk-cr-actions { margin-top: 12px; padding: 0 14px; gap: 8px; }
      .hk-cr-actions button { padding: 10px 8px; font-size: 14px; border-radius: 11px; }
      .dd { top: 48px; }

      .p2-thumb, .p2-cover-wrap { width: 76px; height: 76px; }
      .p2-cover-wrap { height: 76px; }
      .p2-top { grid-template-columns: 76px minmax(0, 1fr) max-content; gap: 10px; }
      .p2-title { font-size: 15px; line-height: 1.22; }
      .p2-line-primary { font-size: 12px; }
      .p2-line-secondary { font-size: 10px; }
      .p2-side-badge { font-size: 9px; padding: 3px 6px; }
      .p2-val-red, .p2-val-blue, .p2-val { font-size: 16px; }
      .p2-lbl { font-size: 10px; margin-top: 5px; }
      .p2-meta { font-size: 11px; }
      .p2-bottom { padding: 10px 12px 12px; }
      .p2-actions { gap: 8px; }
      .p2-btn { height: 34px; padding: 0 12px; font-size: 12px; border-radius: 9px; }
    }

    @media (max-width: 360px) {
      .store-title-row { flex-wrap: wrap; }
      .store-sold { width: 100%; text-align: right; padding-top: 0; }

      .hk-sim-tools { padding: 5px 6px 7px; }
      .hk-sim-tools .top-filter-item { min-height: 32px; font-size: 11px; }
      .hk-cr-sheet { max-height: min(92vh, 520px); }
      .hk-cr-head { padding: 8px 12px 4px; }
      .hk-cr-hint { padding: 0 12px 8px; font-size: 11.5px; }
      .hk-cr-pricebox { margin: 0 12px 8px; }
      .hk-cr-fields { padding: 0 12px; gap: 9px; }
      .hk-cr-actions { padding: 0 12px; margin-top: 10px; }
      .dd { top: 46px; }

      .p2-thumb, .p2-cover-wrap { width: 70px; height: 70px; }
      .p2-cover-wrap { height: 70px; }
      .p2-top { grid-template-columns: 70px minmax(0, 1fr) max-content; gap: 8px; }
      .p2-title { font-size: 14px; }
      .p2-line-primary { font-size: 11px; }
      .p2-line-secondary { font-size: 9px; }
      .p2-badges-stack { gap: 4px; }
      .p2-metric { padding: 8px 4px; }
      .p2-val-red, .p2-val-blue, .p2-val { font-size: 14px; }
      .p2-lbl { font-size: 9px; }
      .p2-meta { gap: 4px; }
      .p2-btn { height: 32px; padding: 0 10px; font-size: 11px; }
    }
