    .catalog-page {
      background: #F6F6F6;
      color: var(--fg);
    }
    .catalog-hero {
      background: linear-gradient(180deg, #FFFFFF 0%, #F6F6F6 100%);
      padding-block: 34px 44px;
    }
    .catalog-hero-inner,
    .catalog-content,
    .catalog-categories,
    .catalog-products {
      display: grid;
      gap: 28px;
    }
    .catalog-hero-grid {
      display: grid;
      grid-template-columns: minmax(0, 0.98fr) minmax(340px, 0.72fr);
      gap: 44px;
      align-items: center;
    }
    .catalog-hero-copy {
      display: grid;
      gap: 20px;
      max-inline-size: 720px;
    }
    .section-kicker {
      margin: 0;
      color: var(--accent);
      font-size: 14px;
      line-height: 1.2;
      font-weight: 800;
      text-transform: uppercase;
    }
    .catalog-hero-copy h1,
    .catalog-section-head h2,
    .catalog-toolbar h2 {
      margin: 0;
      color: var(--fg);
      font-weight: 800;
      letter-spacing: -0.02em;
    }
    .catalog-hero-copy h1 {
      font-size: clamp(32px, 4vw, 52px);
      line-height: 1.05;
    }
    .catalog-hero-copy p:not(.section-kicker) {
      margin: 0;
      max-inline-size: 680px;
      color: var(--fg);
      font-size: 18px;
      line-height: 1.55;
      font-weight: 500;
    }
    .catalog-hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
    }
    .catalog-hero-actions .btn {
      min-inline-size: 222px;
      min-block-size: 56px;
      border-radius: 4px;
      font-size: 18px;
      font-weight: 400;
      transition: background-color 160ms ease, border-color 160ms ease, transform 160ms ease;
    }
    .catalog-hero-actions .btn.primary {
      background: #013366;
      border-color: #013366;
      color: white;
    }
    .catalog-hero-actions .btn:not(.primary) {
      border: 1px solid #FB6A0D;
      color: var(--fg);
      background: var(--surface);
    }
    .catalog-hero-media {
      margin: 0;
      padding: 18px;
      border-radius: 6px;
      background: var(--surface);
      overflow: hidden;
      box-shadow: 0 14px 34px color-mix(in oklch, var(--fg) 14%, transparent);
    }
    .catalog-hero-media img {
      display: block;
      inline-size: 100%;
      max-inline-size: 100%;
      block-size: 320px;
      max-block-size: 320px;
      object-fit: contain;
      border-radius: 5px;
      background: #F6F6F6;
    }
    .catalog-shop {
      padding-block: 30px 54px;
    }
    .catalog-shop-inner {
      display: grid;
      grid-template-columns: 282px minmax(0, 1fr);
      gap: 34px;
      align-items: start;
    }
    .catalog-category-layout {
      display: grid;
      gap: 34px;
    }
    .catalog-product-area {
      display: grid;
      grid-template-columns: 282px minmax(0, 1fr);
      gap: 34px;
      align-items: start;
    }
    .catalog-product-area .catalog-filter {
      margin-block-start: 62px;
    }
    .catalog-shop-inner--with-categories .catalog-content {
      display: contents;
    }
    .catalog-shop-inner--with-categories .catalog-categories {
      grid-column: 1 / -1;
      order: 1;
    }
    .catalog-shop-inner--with-categories .catalog-filter {
      grid-column: 1;
      order: 2;
    }
    .catalog-shop-inner--with-categories .catalog-products {
      grid-column: 2;
      order: 3;
      margin-block-start: 0;
    }
    .catalog-shop-inner--with-category-seo .catalog-content {
      display: contents;
    }
    .catalog-shop-inner--with-category-seo .catalog-category-seo {
      grid-column: 1 / -1;
      order: 3;
    }
    .catalog-shop-inner--with-category-seo .catalog-filter {
      grid-column: 1;
      order: 1;
    }
    .catalog-shop-inner--with-category-seo .catalog-products {
      grid-column: 2;
      order: 2;
      margin-block-start: 0;
    }
    .catalog-filter {
      position: sticky;
      --catalog-filter-sticky-top: 96px;
      inset-block-start: var(--catalog-filter-sticky-top);
      display: grid;
      gap: 18px;
      padding: 22px;
      border: 0;
      border-radius: 6px;
      background: var(--surface);
      box-shadow: 0 9px 22px color-mix(in oklch, var(--fg) 7%, transparent);
    }
    .catalog-filter-head {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      align-items: center;
    }
    .catalog-filter h2 {
      margin: 0;
      color: var(--fg);
      font-size: 24px;
      line-height: 1.1;
    }
    .catalog-filter button {
      border: 0;
      padding: 0;
      background: transparent;
      color: var(--accent);
      font: inherit;
      font-size: 14px;
      font-weight: 700;
      cursor: pointer;
    }
    .catalog-filter .catalog-search {
      display: grid;
      grid-template-columns: 1fr;
      gap: 8px;
      color: var(--fg);
      font-size: 14px;
      font-weight: 700;
    }
    .catalog-filter .catalog-search span {
      display: block;
      inline-size: 100%;
      font-size: 15px;
      line-height: 1.25;
      font-weight: 800;
    }
    .catalog-search input,
    .catalog-sort select {
      inline-size: 100%;
      min-block-size: 44px;
      border: 1px solid color-mix(in oklch, var(--fg) 24%, white);
      border-radius: 4px;
      background: #FFFFFF;
      color: var(--fg);
      font: inherit;
      font-size: 14px;
      outline: none;
    }
    .catalog-filter .catalog-search input {
      display: block;
      grid-column: 1;
      padding: 11px 13px;
    }
    .catalog-search input:focus,
    .catalog-sort select:focus {
      border-color: var(--accent);
    }
    .catalog-filter fieldset {
      display: grid;
      gap: 10px;
      margin: 0;
      padding: 0 0 16px;
      border: 0;
      border-block-end: 1px solid var(--border);
    }
    .catalog-filter legend {
      margin-block-end: 10px;
      color: var(--fg);
      font-size: 15px;
      line-height: 1.25;
      font-weight: 800;
    }
    .catalog-filter label {
      display: grid;
      grid-template-columns: 18px 1fr;
      gap: 10px;
      align-items: start;
      color: var(--fg);
      font-size: 14px;
      line-height: 1.35;
      cursor: pointer;
    }
    .catalog-filter input[type="checkbox"] {
      inline-size: 18px;
      block-size: 18px;
      margin: 1px 0 0;
      accent-color: var(--fg);
    }
    .catalog-filter-note {
      display: grid;
      gap: 8px;
      padding: 16px;
      border-radius: 5px;
      background: #F6F6F6;
    }
    .catalog-filter-note b,
    .catalog-filter-note p,
    .catalog-filter-note a {
      margin: 0;
      color: var(--fg);
      font-size: 14px;
      line-height: 1.4;
    }
    .catalog-filter-note a {
      inline-size: fit-content;
      color: var(--accent);
      font-weight: 800;
    }
    .catalog-category-seo {
      display: grid;
      gap: 24px;
    }
    .catalog-seo-card {
      display: grid;
      gap: 15px;
      padding: 26px;
      border: 0;
      border-radius: 6px;
      background: var(--surface);
      box-shadow: 0 9px 22px color-mix(in oklch, var(--fg) 7%, transparent);
    }
    .catalog-seo-card p {
      margin: 0;
      color: var(--fg);
      font-size: 16px;
      line-height: 1.62;
      font-weight: 500;
    }
    .catalog-seo-card ul {
      display: grid;
      gap: 9px;
      margin: 2px 0 0;
      padding-inline-start: 20px;
      color: var(--fg);
      font-size: 15px;
      line-height: 1.5;
      font-weight: 700;
    }
    .catalog-section-head,
    .catalog-toolbar {
      display: flex;
      justify-content: space-between;
      gap: 28px;
      align-items: end;
    }
    .catalog-section-head h2,
    .catalog-toolbar h2 {
      margin-block-start: 8px;
      font-size: 34px;
      line-height: 1.08;
    }
    .catalog-section-head p,
    .catalog-toolbar p {
      margin: 0;
      max-inline-size: 380px;
      color: var(--fg);
      font-size: 15px;
      line-height: 1.5;
      font-weight: 500;
    }
    .catalog-category-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 18px;
    }
    .catalog-category-card {
      display: grid;
      gap: 10px;
      min-block-size: 260px;
      padding: 12px 12px 18px;
      border: 0;
      border-radius: 6px;
      background: var(--surface);
      color: var(--fg);
      box-shadow: 0 8px 18px color-mix(in oklch, var(--fg) 7%, transparent);
      transition: transform 160ms ease, box-shadow 160ms ease;
    }
    .catalog-category-card:hover,
    .catalog-category-card:focus-visible {
      outline: none;
      transform: translateY(-2px);
      box-shadow: 0 12px 26px color-mix(in oklch, var(--fg) 11%, transparent);
    }
    .catalog-category-card:focus-visible {
      outline: 2px solid color-mix(in oklch, var(--accent) 74%, white);
      outline-offset: 3px;
    }
    .catalog-category-card img {
      display: block;
      inline-size: 100%;
      max-inline-size: 100%;
      block-size: 148px;
      max-block-size: 148px;
      object-fit: contain;
      padding: 10px;
      border-radius: 5px;
      background: #F6F6F6;
    }
    .catalog-category-card span {
      color: var(--fg);
      font-size: 17px;
      line-height: 1.2;
      font-weight: 800;
    }
    .catalog-category-card small {
      color: color-mix(in oklch, var(--fg) 72%, white);
      font-size: 13px;
      line-height: 1.35;
    }
    .catalog-products {
      margin-block-start: 10px;
    }
    .catalog-sort {
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      gap: 12px;
      align-items: end;
      color: var(--fg);
      font-size: 14px;
      font-weight: 700;
    }
    .catalog-sort-field {
      display: grid;
      gap: 6px;
      min-inline-size: 220px;
      position: relative;
    }
    .catalog-sort-head {
      display: flex;
      justify-content: space-between;
      gap: 14px;
      align-items: center;
      color: var(--fg);
      font-size: 14px;
      line-height: 1.25;
    }
    .catalog-sort select {
      padding-inline: 12px 34px;
    }
    .catalog-sort-native {
      position: absolute;
      inline-size: 1px;
      block-size: 1px;
      margin: -1px;
      padding: 0;
      overflow: hidden;
      clip: rect(0 0 0 0);
      white-space: nowrap;
      border: 0;
    }
    .catalog-sort-custom {
      position: relative;
    }
    .catalog-sort-toggle {
      position: relative;
      display: flex;
      justify-content: space-between;
      gap: 14px;
      align-items: center;
      inline-size: 100%;
      min-block-size: 44px;
      padding: 11px 44px 11px 12px;
      border: 1px solid color-mix(in oklch, var(--fg) 24%, white);
      border-radius: 4px;
      background: #FFFFFF;
      color: var(--fg);
      font: inherit;
      font-size: 14px;
      line-height: 1.2;
      text-align: start;
      cursor: pointer;
    }
    .catalog-sort-toggle::after {
      content: "";
      position: absolute;
      inset-inline-end: 16px;
      inset-block-start: 50%;
      inline-size: 8px;
      block-size: 8px;
      border-inline-end: 2px solid var(--fg);
      border-block-end: 2px solid var(--fg);
      transform: translateY(-70%) rotate(45deg);
      pointer-events: none;
    }
    .catalog-sort-custom.is-open .catalog-sort-toggle {
      border-color: var(--accent);
    }
    .catalog-sort-menu {
      position: absolute;
      z-index: 30;
      inset-block-start: calc(100% + 6px);
      inset-inline: 0;
      display: grid;
      gap: 2px;
      margin: 0;
      padding: 6px;
      list-style: none;
      border: 1px solid color-mix(in oklch, var(--fg) 18%, white);
      border-radius: 4px;
      background: #FFFFFF;
      box-shadow: 0 14px 28px color-mix(in oklch, var(--fg) 14%, transparent);
    }
    .catalog-sort-menu[hidden] {
      display: none;
    }
    .catalog-sort-option {
      display: block;
      inline-size: 100%;
      padding: 10px 11px;
      border: 0;
      border-radius: 3px;
      background: transparent;
      color: var(--fg);
      font: inherit;
      font-size: 14px;
      line-height: 1.25;
      text-align: start;
      cursor: pointer;
    }
    .catalog-sort-option:hover,
    .catalog-sort-option:focus-visible,
    .catalog-sort-option.is-selected {
      background: color-mix(in oklch, var(--accent) 12%, white);
      outline: none;
    }
    .catalog-product-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 22px;
    }
    .catalog-product-card {
      display: flex;
      flex-direction: column;
      min-block-size: 100%;
      overflow: hidden;
      border: 0;
      border-radius: 6px;
      background: var(--surface);
      color: var(--fg);
      box-shadow: 0 9px 22px color-mix(in oklch, var(--fg) 8%, transparent);
    }
    .catalog-product-card[hidden] {
      display: none;
    }
    .catalog-product-media {
      position: relative;
      display: grid;
      place-items: center;
      block-size: 218px;
      background: #F6F6F6;
      border-block-end: 0;
      overflow: hidden;
    }
    .catalog-product-media::before {
      content: "В наличии";
      position: absolute;
      inset-block-start: 10px;
      inset-inline-start: 10px;
      z-index: 1;
      display: inline-flex;
      align-items: center;
      min-block-size: 18px;
      padding: 4px 6px;
      border-radius: 4px;
      border: 1px solid var(--accent);
      background: var(--surface);
      color: var(--fg);
      font-size: 9px;
      font-weight: 800;
      line-height: 1;
      letter-spacing: 0;
      text-transform: uppercase;
      box-shadow: 0 6px 14px rgb(1 51 102 / 10%);
      pointer-events: none;
    }
    .catalog-product-media.is-popular::before {
      inset-block-start: 42px;
    }
    .catalog-product-media.is-popular::after {
      content: "Популярное";
      position: absolute;
      inset-block-start: 10px;
      inset-inline-start: 10px;
      z-index: 1;
      display: inline-flex;
      align-items: center;
      min-block-size: 18px;
      padding: 4px 6px;
      border-radius: 4px;
      border: 1px solid var(--fg);
      background: var(--fg);
      color: #fff;
      font-size: 9px;
      font-weight: 800;
      line-height: 1;
      letter-spacing: 0;
      text-transform: uppercase;
      box-shadow: 0 6px 14px rgb(1 51 102 / 14%);
      pointer-events: none;
    }
    .catalog-product-media img {
      display: block;
      inline-size: auto;
      max-inline-size: 100%;
      height: auto;
      block-size: auto;
      max-block-size: 182px;
      max-height: 182px;
      object-fit: contain;
      padding: 18px;
    }
    .catalog-product-body {
      display: grid;
      gap: 14px;
      padding: 20px;
      flex: 1;
    }
    .catalog-product-kicker {
      margin: 0;
      color: var(--accent);
      font-size: 13px;
      line-height: 1.2;
      font-weight: 800;
      text-transform: uppercase;
    }
    .catalog-product-card h3 {
      margin: 0;
      color: var(--fg);
      font-size: 23px;
      line-height: 1.12;
      font-weight: 800;
      letter-spacing: -0.01em;
    }
    .catalog-product-card h3 a:hover {
      color: var(--accent);
    }
    .catalog-product-card p:not(.catalog-product-kicker) {
      margin: 0;
      color: var(--fg);
      font-size: 14px;
      line-height: 1.45;
    }
    .catalog-product-card ul {
      display: grid;
      gap: 0;
      margin: 2px 0 0;
      padding: 0;
      list-style: none;
    }
    .catalog-product-card li {
      display: flex;
      justify-content: space-between;
      gap: 14px;
      padding-block: 8px;
      border-block-end: 1px solid color-mix(in oklch, var(--fg) 13%, transparent);
      color: var(--fg);
      font-size: 13px;
      line-height: 1.35;
    }
    .catalog-product-card li:last-child {
      border-block-end: 0;
    }
    .catalog-product-card li b {
      text-align: end;
      font-weight: 700;
    }
    .catalog-product-actions {
      display: grid;
      gap: 14px;
      margin-block-start: auto;
    }
    .catalog-product-action-row {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
    }
    .catalog-price {
      color: var(--accent);
      font-size: 18px;
      line-height: 1.2;
      font-weight: 800;
    }
    .catalog-product-actions .card-cta {
      inline-size: 100%;
      min-inline-size: 0;
      min-block-size: 42px;
      margin: 0;
      padding: 10px 12px;
      font-size: 14px;
      line-height: 1.15;
      white-space: nowrap;
    }
    .catalog-product-actions .cart-card-cta {
      border-color: var(--accent);
      background: var(--surface);
      color: var(--fg);
    }
    .catalog-product-actions .cart-card-cta:hover,
    .catalog-product-actions .cart-card-cta.is-added {
      border-color: var(--accent);
      background: var(--accent);
      color: white;
    }
    .catalog-empty {
      margin: 0;
      padding: 28px;
      border: 0;
      border-radius: 6px;
      background: var(--surface);
      box-shadow: 0 9px 22px color-mix(in oklch, var(--fg) 7%, transparent);
      color: var(--fg);
      font-size: 16px;
      line-height: 1.5;
      font-weight: 700;
    }
    .catalog-request {
      padding-block-start: 26px;
    }

    @media (max-width: 1180px) {
      .catalog-shop-inner {
        grid-template-columns: 250px minmax(0, 1fr);
        gap: 24px;
      }
      .catalog-category-grid,
      .catalog-product-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (max-width: 860px) {
      .catalog-hero-grid,
      .catalog-shop-inner,
      .catalog-product-area {
        grid-template-columns: 1fr;
      }
      .catalog-shop-inner--with-categories .catalog-categories,
      .catalog-shop-inner--with-categories .catalog-filter,
      .catalog-shop-inner--with-categories .catalog-products,
      .catalog-shop-inner--with-category-seo .catalog-category-seo,
      .catalog-shop-inner--with-category-seo .catalog-filter,
      .catalog-shop-inner--with-category-seo .catalog-products {
        grid-column: 1;
      }
      .catalog-filter {
        position: static;
      }
      .catalog-product-area .catalog-filter {
        margin-block-start: 0;
      }
      .catalog-section-head,
      .catalog-toolbar {
        align-items: start;
        flex-direction: column;
      }
      .catalog-sort {
        justify-content: flex-start;
      }
    }

    @media (max-width: 620px) {
      .catalog-hero {
        padding-block-start: 24px;
      }
      .catalog-hero-copy h1 {
        font-size: 30px;
      }
      .catalog-hero-copy p:not(.section-kicker) {
        font-size: 16px;
      }
      .catalog-hero-actions {
        gap: 12px;
        flex-direction: column;
      }
      .catalog-hero-actions .btn {
        inline-size: 100%;
        min-inline-size: 0;
        min-block-size: 50px;
        font-size: 16px;
      }
      .catalog-product-grid {
        grid-template-columns: 1fr;
      }
      .catalog-product-action-row {
        grid-template-columns: 1fr;
      }
      .catalog-category-grid {
        gap: 10px;
      }
      .catalog-filter {
        padding: 18px;
      }
      .catalog-section-head h2,
      .catalog-toolbar h2 {
        font-size: 28px;
      }
      .catalog-category-card {
        min-block-size: auto;
        min-inline-size: 0;
        gap: 8px;
        padding: 8px 8px 12px;
      }
      .catalog-hero-media img,
      .catalog-product-media {
        block-size: 210px;
      }
      .catalog-category-card img {
        block-size: 124px;
        padding: 5px;
      }
      .catalog-category-card span {
        min-inline-size: 0;
        font-size: 14px;
        line-height: 1.16;
        overflow-wrap: anywhere;
      }
      .catalog-category-card small {
        font-size: 11px;
        line-height: 1.25;
      }
      .catalog-product-media img {
        max-block-size: 174px;
        max-height: 174px;
      }
      .catalog-product-media::before {
        inset-block-start: 8px;
        inset-inline-start: 8px;
        min-block-size: 16px;
        padding: 3px 5px;
        font-size: 8px;
      }
      .catalog-product-media.is-popular::before {
        inset-block-start: 36px;
      }
      .catalog-product-media.is-popular::after {
        inset-block-start: 8px;
        inset-inline-start: 8px;
        min-block-size: 16px;
        padding: 3px 5px;
        font-size: 8px;
      }
    }
