:root {
      --blue-light: #E8F2FF;
      --blue-mid: #B8D9FF;
      --blue-dark: #0A5FCC;
      --green: var(--color_brand);
      --green-bg: #ECFDF5;
      --text: #1A1A2E;
      --text-secondary: #64748B;
      --surface: #FFFFFF;
      --border: #E2E8F0;
      --bg: #F7F9FC;
      --radius: 16px;
      --shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 4px 16px rgba(0, 0, 0, .04);
      --shadow-hover: 0 2px 8px rgba(31, 135, 255, .12), 0 8px 32px rgba(31, 135, 255, .08);
    }

    .price-section {
      /* max-width: 1120px;*/
      margin: 0 auto;
      padding: 56px 20px 72px;
    }

    .section-header {
      text-align: center;
      margin-bottom: 40px;
    }

    .section-badge {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: var(--blue-light);
      color: var(--color_brand);
      font-size: 13px;
      font-weight: 600;
      padding: 6px 14px;
      border-radius: 100px;
      margin-bottom: 16px;
      letter-spacing: .02em;
    }

    .section-badge svg {
      flex-shrink: 0;
      width: 14px;
      height: 14px;
    }

    .section-title {
      font-size: clamp(26px, 4vw, 40px);
      font-weight: 800;
      line-height: 1.15;
      color: var(--text);
      margin-bottom: 12px;
      letter-spacing: -.02em;
    }

    .section-subtitle {
      font-size: 16px;
      color: var(--text-secondary);
      max-width: 520px;
      margin: 0 auto;
    }

    /* ─── Toolbar ─── */
    .toolbar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      margin-bottom: 28px;
      flex-wrap: wrap;
    }

    .filter-bar {
      display: flex;
      gap: 6px;
      flex-wrap: wrap;
    }

    .filter-btn {
      border: none;
      background: transparent;
      font-family: inherit;
      font-size: 14px;
      font-weight: 500;
      color: var(--text-secondary);
      padding: 8px 18px;
      border-radius: 100px;
      cursor: pointer;
      transition: all .2s;
    }

    .filter-btn:hover {
      background: var(--blue-light);
      color: var(--color_brand);
    }

    .filter-btn.active {
      background: var(--color_brand);
      color: #fff;
      box-shadow: 0 2px 8px rgb(from var(--color_brand) r g b / 0.3);
    }

    .search-box {
      position: relative;
      width: 280px;
      flex-shrink: 0;
    }

    .search-box input {
      width: 100%;
      font-family: inherit;
      font-size: 14px;
      padding: 10px 16px 10px 40px;
      border: 1.5px solid var(--border);
      border-radius: 100px;
      background: var(--surface);
      color: var(--text);
      outline: none;
      transition: border-color .2s, box-shadow .2s;
    }

    .search-box input::placeholder {
      color: var(--text-secondary);
      opacity: .7;
    }

    .search-box input:focus {
      border-color: var(--color_brand);
      box-shadow: 0 0 0 3px rgba(31, 135, 255, .12);
    }

    .search-icon {
      position: absolute;
      left: 14px;
      top: 50%;
      transform: translateY(-50%);
      color: var(--text-secondary);
      pointer-events: none;
      opacity: .5;
    }

    .search-clear {
      position: absolute;
      right: 6px;
      top: 50%;
      transform: translateY(-50%);
      width: 28px;
      height: 28px;
      border: none;
      background: var(--bg);
      border-radius: 50%;
      cursor: pointer;
      display: none;
      align-items: center;
      justify-content: center;
      color: var(--text-secondary);
      transition: background .15s;
    }

    .search-clear:hover {
      background: var(--border);
    }

    .search-box.has-value .search-clear {
      display: flex;
    }

    .empty-state {
      display: none;
      text-align: center;
      padding: 48px 20px;
      color: var(--text-secondary);
    }

    .empty-state.visible {
      display: block;
    }

    .empty-state svg {
      margin-bottom: 12px;
      opacity: .3;
    }

    .empty-state p {
      font-size: 15px;
    }

    .empty-state strong {
      color: var(--text);
    }

    /* ─── Price grid ─── */
    .price-grid {
      background: var(--surface);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      overflow: hidden;
      border: 1px solid var(--border);
    }

    .pg-header {
      display: grid;
      grid-template-columns: 48px 1fr 160px 160px 140px;
      background: var(--bg);
      border-bottom: 1px solid var(--border);
      position: sticky;
      top: 0;
      z-index: 2;
    }

    .pg-header span {
      font-size: 12px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: var(--text-secondary);
      padding: 14px 16px;
    }

    .pg-header span:nth-child(n+3) {
      text-align: center;
    }

    .pg-row {
      display: grid;
      grid-template-columns: 48px 1fr 160px 160px 140px;
      align-items: center;
      border-bottom: 1px solid var(--border);
      transition: background .15s;
    }

    .pg-row:last-of-type {
      border-bottom: none;
    }

    .pg-row:hover {
      background: var(--blue-light);
    }

    .pg-row.is-hidden {
      display: none;
    }

    .pg-num {
      padding: 16px;
      font-size: 13px;
      font-weight: 500;
      color: var(--text-secondary);
      text-align: center;
    }

    .pg-model {
      padding: 16px;
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .series-a .model-icon {
      background: #EEF2FF;
      color: #6366F1;
    }

    .series-s .model-icon {
      background: #FFF7ED;
      color: #F59E0B;
    }

    .series-z .model-icon {
      background: #F0FDF4;
      color: #22C55E;
    }

    .model-icon {
      width: auto;
      padding: 0 10px;
      height: 40px;
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: flex-start;
      font-size: 16px;
      flex-shrink: 0;
    }

    .model-info {
      display: flex;
      flex-direction: column;
      min-width: 0;
    }

    .model-title {
      font-weight: 600;
      font-size: 15px;
      white-space: nowrap;
    }

    .model-sub {
      font-size: 12px;
      font-weight: 400;
      color: var(--text-secondary);
    }

    .popular-badge {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      font-size: 11px;
      font-weight: 600;
      background: linear-gradient(135deg,
          color-mix(in oklab, var(--color_brand) 70%, white),
          var(--color_brand));
      color: #fff;
      padding: 3px 8px;
      border-radius: 100px;
      margin-left: 8px;
      white-space: nowrap;
      max-width: 100px;
      vertical-align: middle;
    }

    .pg-price {
      padding: 16px;
      text-align: center;
      font-weight: 700;
      font-size: 15px;
      font-variant-numeric: tabular-nums;
    }

    .pg-price.original {
      color: var(--text);
    }

    .pg-price.analog {
      display: flex;
      flex-direction: column;
      color: var(--green);
    }

    .save-tag {
      display: inline-block;
      align-self: center;
      font-size: 11px;
      font-weight: 600;
      background: var(--green-bg);
      color: var(--green);
      padding: 2px 8px;
      border-radius: 100px;
      margin-top: 2px;
    }

    .pg-time {
      padding: 16px;
      text-align: center;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 5px;
      font-weight: 500;
      color: var(--text-secondary);
      font-size: 14px;
    }

    .pg-time svg {
      opacity: .5;
      width: 16px;
      height: 16px;
    }

    .pg-time svg circle {
      stroke: var(--color_brand);
    }

    .mobile-label {
      display: none;
    }

    .show-more-wrap {
      border-top: 1px solid var(--border);
    }

    .show-more-btn {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      width: 100%;
      padding: 14px 20px;
      background: transparent;
      border: none;
      font-family: inherit;
      font-size: 14px;
      font-weight: 600;
      color: var(--color_brand);
      cursor: pointer;
      transition: background .15s;
    }

    .show-more-btn:hover {
      background: var(--blue-light);
    }

    .show-more-btn svg {
      width: 20px;
      height: 20px;
      transition: transform .3s;
    }

    .show-more-btn.expanded svg {
      transform: rotate(180deg);
    }

    .table-footer {
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      gap: 12px;
      padding: 16px 20px;
      background: var(--bg);
      border-top: 1px solid var(--border);
      font-size: 13px;
      color: var(--text-secondary);
    }

    .table-footer-note {
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .table-footer-note svg {
      flex-shrink: 0;
      opacity: .5;
      width: 14px;
      height: 14px;
    }

    .cta-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: var(--color_brand);
      color: #fff;
      font-family: inherit;
      font-size: 14px;
      font-weight: 600;
      padding: 10px 24px;
      border-radius: 100px;
      border: none;
      cursor: pointer;
      transition: all .2s;
      text-decoration: none;
    }

    .cta-btn:hover {
      background: var(--blue-dark);
      box-shadow: 0 4px 16px rgba(31, 135, 255, .35);
      transform: translateY(-1px);
    }

    .cta-btn svg {
      height: 14px;
      width: 14px;
    }

    mark {
      background: #FEF08A;
      color: inherit;
      border-radius: 2px;
      padding: 0 1px;
    }

    /* ─── Responsive ─── */
    @media (max-width: 820px) {
      .price-section {
        padding: 40px 16px 56px;
      }

      .toolbar {
        flex-direction: column;
        align-items: stretch;
      }

      .filter-bar {
        justify-content: center;
      }

      .search-box {
        width: 100%;
      }

      .price-grid {
        background: transparent;
        border: none;
        box-shadow: none;
        overflow: visible;
      }

      .pg-header {
        display: none;
      }

      .pg-row {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        grid-template-rows: auto auto;
        gap: 0;
        background: var(--surface);
        border: 1px solid var(--border);
        border-radius: var(--radius);
        margin-bottom: 12px;
        padding: 20px;
      }

      .pg-row:hover {
        background: var(--surface);
      }

      .pg-num {
        display: none;
      }

      .pg-model {
        grid-column: 1 / -1;
        padding: 0 0 16px 0;
      }

      .pg-price,
      .pg-time {
        background: var(--bg);
        border-radius: 10px;
        padding: 12px 8px;
        flex-direction: column;
        gap: 4px;
        margin: 0 2px;
        display: flex;
        align-items: center;
      }

      .mobile-label {
        display: block;
        font-size: 11px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: .04em;
        color: var(--text-secondary);
        margin-bottom: 4px;
      }

      .pg-time {
        font-size: 14px;
        font-weight: 700;
        color: var(--color_brand);
      }

      .pg-time svg {
        display: none;
      }

      .show-more-wrap {
        background: transparent;
        border: none;
      }

      .show-more-btn {
        background: var(--surface);
        border: 1.5px dashed var(--border);
        border-radius: var(--radius);
        transition: background .15s, border-color .15s;
      }

      .show-more-btn:hover {
        background: var(--blue-light);
        border-color: var(--blue-mid);
      }

      .table-footer {
        background: transparent;
        border-top: none;
        padding: 20px 0 0;
        justify-content: center;
        text-align: center;
      }
    }

    @media (max-width: 480px) {
      .pg-row {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto auto;
      }

      .pg-model {
        grid-column: 1 / -1;
      }

      .pg-time {
        grid-column: 1 / -1;
        margin-top: 4px;
      }

      .filter-btn {
        font-size: 13px;
        padding: 7px 14px;
      }
    }

    @keyframes fadeUp {
      from {
        opacity: 0;
        transform: translateY(12px);
      }

      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    .price-grid {
      animation: fadeUp .5s ease both;
    }