/* === Неймспейс: cat-* (каталог) === */

/* h1 страницы */
.cat-h1 {
  font-family: "Russo One";
  font-size: clamp(26px, 3.2vw, 40px);
  line-height: 1.15;
  width: var(--wrap);
  margin: calc(var(--header-h) + 24px) auto 8px; /* визуально привязан к хедеру */
}

/* ===== SECTION 1: Rack Boulevard ===== */
.cat-hero { position: relative; padding: 10px 0 28px; }
.cat-hero__grid {
  display: grid; gap: 28px;
  grid-template-columns: 1.15fr .85fr;
  align-items: center;
}
.cat-hero__title {
  font-family: "Russo One"; font-size: clamp(22px, 2.6vw, 30px); margin: 0 0 8px;
}
.cat-hero__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-hero__points { margin: 0 0 14px; padding: 0 0 0 18px; }
.cat-hero__points li { margin-bottom: 6px; }
.cat-hero__points li span { color: var(--mma-text); font-weight: 700; }

.rack-lights {
  display: grid; grid-auto-flow: column; gap: 6px;
  width: 100%; max-width: 420px; height: 10px;
  align-items: end;
}
.rack-lights i {
  width: 100%; height: 6px; border-radius: 2px;
  background: linear-gradient(90deg, #15E6C3, #20A4FF);
  box-shadow: 0 0 12px rgba(32,164,255,.35);
  opacity: .6;
  transform-origin: bottom center;
}

.cat-hero__shelf {
  display: grid; gap: 16px; justify-items: center;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  transform: translateY(2px);
}
.cat-hero__shelf .mma-img { box-shadow: 0 10px 28px rgba(0,0,0,.35); }

.cat-sep-bars {
  height: 16px; margin-top: 28px;
  background:
    repeating-linear-gradient(90deg, #0E1524 0 18px, #121A2A 18px 36px);
}

/* ===== SECTION 2: Chips / сценарии ===== */
.cat-scenarios { position: relative; padding: 40px 0 24px; }
.cat-scenarios__wrap { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: center; }
.cat-scenarios__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-scenarios__lead { color: var(--mma-text-2); margin: 0 0 12px; }

.chips { display: flex; flex-wrap: wrap; gap: 10px; }
.chip {
  border: 1px solid var(--mma-line);
  background: var(--mma-surface-1);
  color: var(--mma-text-2);
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 700;
  transition: transform .15s ease, box-shadow .15s ease, color .15s ease, border-color .15s ease;
  cursor: pointer;
}
.chip:hover { transform: translateY(-2px); color: var(--mma-text); border-color: #2C3B5C; box-shadow: var(--shadow); }
.chip.is-on {
  color: #0B0F17; border-color: transparent;
  background: var(--mma-grad-primary);
  box-shadow: 0 0 14px rgba(21,230,195,.35);
}

.cat-scenarios__media { display: grid; gap: 16px; justify-items: center; }
.cat-sep-wave {
  height: 18px; margin-top: 26px;
  background: linear-gradient(90deg, #0E1524 0%, #121A2A 50%, #0E1524 100%);
  mask: radial-gradient(90% 75% at 50% 120%, #000 50%, transparent 51%);
  -webkit-mask: radial-gradient(90% 75% at 50% 120%, #000 50%, transparent 51%);
}

/* ===== SECTION 3: Семейства микрофонов ===== */
.cat-micfamilies { position: relative; padding: 42px 0 24px; }
.cat-micfamilies__grid { display: grid; gap: 18px; }
.cat-micfamilies__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-micfamilies__lead { color: var(--mma-text-2); margin: 0; }

.families {
  display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  justify-items: center;
}
.families__item .mma-img { box-shadow: 0 10px 28px rgba(0,0,0,.35); }

/* ===== Адаптив страницы 2 ===== */
@media (max-width: 1100px) {
  .cat-hero__grid, .cat-scenarios__wrap { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .cat-hero__shelf { grid-template-columns: repeat(2, 1fr); }
  .families { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .cat-hero__shelf { grid-template-columns: 1fr; }
}
/* ===== SECTION 4: MIX LANES ===== */
.cat-mixlanes { position: relative; padding: 42px 0 24px; }
.cat-mixlanes__grid { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: center; }
.cat-mixlanes__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-mixlanes__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-mixlanes__points { margin: 0; padding: 0; list-style: none; display: grid; gap: 6px; }
.cat-mixlanes__points span { color: var(--mma-text); font-weight: 700; }

.lanes {
  display: grid; grid-auto-flow: column; gap: 10px; align-items: end;
  background: var(--mma-surface-1); border: 1px solid var(--mma-line); border-radius: 16px;
  padding: 16px; overflow: hidden;
}
.lane {
  position: relative; width: 10px; height: 140px; border-radius: 999px;
  background: #0F1524; border: 1px solid var(--mma-line);
  display: grid; align-items: end; justify-items: center;
}
.lane .knob {
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--mma-grad-primary);
  box-shadow: 0 0 12px rgba(21,230,195,.45);
  transform: translateY(0);
  will-change: transform;
}

/* ===== SECTION 5: RF PLAN ===== */
.cat-rfplan { position: relative; padding: 42px 0 24px; }
.cat-rfplan__grid { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: center; }
.cat-rfplan__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-rfplan__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.rf-notes { margin: 12px 0 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.rf-notes b { color: var(--mma-text); }

.spectrum {
  position: relative; height: 56px; border-radius: 12px; overflow: hidden;
  background: linear-gradient(90deg, #112033, #0E1524 30%, #112033 70%, #0E1524);
  border: 1px solid var(--mma-line);
  margin: 10px 0 8px;
}
.spectrum .scan {
  position: absolute; top: 0; bottom: 0; width: 8%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  animation: cat-scan 2.2s linear infinite;
}
@keyframes cat-scan { from { left: -10%; } to { left: 102%; } }
.spectrum .ch {
  position: absolute; top: 6px; bottom: 6px; width: 4px; border-radius: 2px;
  transform: translateX(var(--x));
}
.spectrum .ch.is-free { background: #2EEA7F; box-shadow: 0 0 12px rgba(46,234,127,.45); }
.spectrum .ch.is-busy { background: #FF4D8F; box-shadow: 0 0 12px rgba(255,77,143,.45); }

.cat-rfplan__media { display: grid; gap: 16px; justify-items: center; }

/* ===== SECTION 6: MOUNTS / BLUEPRINT ===== */
.cat-mounts { position: relative; padding: 42px 0 24px; overflow: hidden; }
.cat-mounts__grid { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: center; }
.cat-mounts__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-mounts__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-mounts__media { display: grid; gap: 16px; justify-items: center; }

.blueprint {
  position: relative; height: 120px; border-radius: 16px;
  background:
    radial-gradient(60% 80% at 30% 20%, rgba(21,230,195,.06), transparent 70%),
    repeating-linear-gradient(0deg, #0E1728 0 10px, #0F1A30 10px 20px),
    repeating-linear-gradient(90deg, #0E1728 0 10px, #0F1A30 10px 20px);
  border: 1px solid var(--mma-line);
  overflow: hidden;
}
.bp-line {
  position: absolute; left: -40%; right: -40%; height: 2px;
  background: linear-gradient(90deg, rgba(32,164,255,.5), rgba(21,230,195,.5));
  filter: drop-shadow(0 0 8px rgba(32,164,255,.35));
  animation: bp-move 6s linear infinite;
}
.bp-line:nth-child(1) { top: 25%; animation-delay: 0s; }
.bp-line:nth-child(2) { top: 45%; animation-delay: 1s; }
.bp-line:nth-child(3) { top: 65%; animation-delay: 2s; }
.bp-line:nth-child(4) { top: 85%; animation-delay: 3s; }
@keyframes bp-move { to { transform: translateX(80%); } }

/* ===== Адаптив (4–6) ===== */
@media (max-width: 1100px) {
  .cat-mixlanes__grid, .cat-rfplan__grid, .cat-mounts__grid { grid-template-columns: 1fr; }
}
/* ===== SECTION 7: SPEAKERS ===== */
.cat-speakers { position: relative; padding: 42px 0 24px; }
.cat-speakers__grid { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: center; }
.cat-speakers__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-speakers__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-speakers__points { margin: 12px 0 0; padding: 0; list-style: none; display: grid; gap: 6px; }
.cat-speakers__points span { color: var(--mma-text); font-weight: 700; }

.tri-bars { display: grid; gap: 10px; margin-top: 8px; }
.tb { position: relative; height: 14px; background: #0F1524; border: 1px solid var(--mma-line); border-radius: 999px; overflow: hidden; }
.tb b { position: absolute; inset: 0 auto 0 0; width: 24%; background: var(--mma-grad-primary); box-shadow: 0 0 12px rgba(21,230,195,.35); transition: width .3s ease; }
.tb span { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); font-family: "JetBrains Mono"; font-size: 12px; color: var(--mma-text); opacity: .9; }

.cat-speakers__media { display: grid; gap: 16px; justify-items: center; }

/* ===== SECTION 8: MIXERS ===== */
.cat-mixers { position: relative; padding: 42px 0 24px; }
.cat-mixers__grid { display: grid; gap: 20px; }
.cat-mixers__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-mixers__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.mixer-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.mtag {
  border: 1px solid var(--mma-line); background: var(--mma-surface-1);
  color: var(--mma-text-2); border-radius: 999px; padding: 8px 12px; font-weight: 700;
  transition: transform .15s ease, box-shadow .15s ease, color .15s ease, border-color .15s ease;
  cursor: pointer;
}
.mtag:hover { transform: translateY(-2px); color: var(--mma-text); border-color: #2C3B5C; box-shadow: var(--shadow); }
.mtag.is-on { color: #0B0F17; border-color: transparent; background: var(--mma-grad-hot); box-shadow: 0 0 14px rgba(255,77,143,.35); }

.cat-mixers__media { display: grid; gap: 16px; justify-items: center; grid-template-columns: repeat(2, minmax(0, 1fr)); }

/* ===== SECTION 9: CASE LOG ===== */
.cat-caselog { position: relative; padding: 42px 0 24px; overflow: hidden; }
.cat-caselog__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-caselog__lead { color: var(--mma-text-2); margin: 0 0 12px; }

.belt {
  position: relative; border: 1px solid var(--mma-line); border-radius: 16px; background: var(--mma-surface-1);
  overflow: hidden; padding: 14px 6px;
}
.belt__track {
  display: grid; grid-auto-flow: column; grid-auto-columns: minmax(180px, 1fr); gap: 12px; align-items: center; justify-items: center;
  animation: belt-move 12s ease-in-out infinite alternate;
}
@keyframes belt-move { from { transform: translateX(0); } to { transform: translateX(-10%); } }
.belt__item { text-align: center; }
.belt__item .mma-img { box-shadow: 0 10px 28px rgba(0,0,0,.35); }
.belt__item figcaption { margin-top: 8px; font-size: 14px; color: var(--mma-muted); }

/* ===== Адаптив (7–9) ===== */
@media (max-width: 1100px) { .cat-speakers__grid { grid-template-columns: 1fr; } }
@media (max-width: 820px)  { .cat-mixers__media { grid-template-columns: 1fr; } }
.spectrum .ch.pos-10 { transform: translateX(10%); }
.spectrum .ch.pos-28 { transform: translateX(28%); }
.spectrum .ch.pos-41 { transform: translateX(41%); }
.spectrum .ch.pos-57 { transform: translateX(57%); }
.spectrum .ch.pos-76 { transform: translateX(76%); }
.spectrum .ch.pos-88 { transform: translateX(88%); }
/* ===== SECTION 10: RF MICS ===== */
.cat-rfmics { position: relative; padding: 42px 0 24px; }
.cat-rfmics__grid { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: center; }
.cat-rfmics__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-rfmics__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-rfmics__media { display: grid; gap: 16px; justify-items: center; grid-template-columns: repeat(3, minmax(0,1fr)); }

.rf-bars {
  display: grid; grid-auto-flow: column; grid-auto-columns: 10px; gap: 6px;
  align-items: end; height: 60px; margin-top: 10px;
}
.rfb {
  width: 10px; height: 8px; border-radius: 3px;
  background: linear-gradient(180deg, #20A4FF, #15E6C3);
  box-shadow: 0 0 10px rgba(32,164,255,.35);
}

/* ===== SECTION 11: PODCAST ===== */
.cat-podcast { position: relative; padding: 42px 0 24px; }
.cat-podcast__grid { display: grid; gap: 24px; }
.cat-podcast__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-podcast__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-podcast__media { display: grid; gap: 16px; justify-items: center; grid-template-columns: repeat(2, minmax(0,1fr)); }

/* ===== SECTION 12: ACCESSORIES ===== */
.cat-access { position: relative; padding: 42px 0 24px; }
.cat-access__grid { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: start; }
.cat-access__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-access__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.access-points { margin: 12px 0 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.access-points li { position: relative; padding-left: 16px; }
.access-points li::before { content: ""; position: absolute; left: 0; top: .6em; width: 8px; height: 8px; border-radius: 2px; background: var(--mma-accent-2); box-shadow: 0 0 8px rgba(32,164,255,.45); }
.cat-access__media { display: grid; gap: 16px; justify-items: center; grid-template-columns: repeat(3, minmax(0,1fr)); }

/* ===== Адаптив (10–12) ===== */
@media (max-width: 1100px) {
  .cat-rfmics__grid, .cat-access__grid { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
  .cat-rfmics__media { grid-template-columns: 1fr; }
  .cat-podcast__media { grid-template-columns: 1fr; }
  .cat-access__media { grid-template-columns: 1fr; }
}
/* ===== SECTION 13: ROUTES MAP ===== */
.cat-routes { position: relative; padding: 42px 0 24px; }
.cat-routes__grid { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: center; }
.cat-routes__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-routes__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-routes__media { display: grid; gap: 16px; justify-items: center; grid-template-columns: repeat(3, minmax(0,1fr)); }

.route-map {
  position: relative; height: 180px; border-radius: 16px; overflow: hidden;
  border: 1px solid var(--mma-line); background:
    linear-gradient(0deg, rgba(21,230,195,.06), transparent 60%),
    repeating-linear-gradient(0deg, #0F1A30 0 18px, #0E1728 18px 36px),
    repeating-linear-gradient(90deg, #0F1A30 0 18px, #0E1728 18px 36px);
}
.route-map .route-scan {
  position: absolute; inset: -10% -60% auto -60%; height: 3px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  transform: rotate(12deg);
  animation: route-scan 3.6s linear infinite;
}
@keyframes route-scan { to { transform: rotate(12deg) translateX(140%); } }

.node {
  position: absolute; width: 10px; height: 10px; border-radius: 50%;
  background: #2EEA7F; box-shadow: 0 0 10px rgba(46,234,127,.6);
}
.node::after {
  content: ""; position: absolute; inset: -6px; border-radius: 50%;
  border: 2px solid rgba(46,234,127,.35); animation: node-pulse 1.8s ease-out infinite;
}
@keyframes node-pulse { from { transform: scale(.7); opacity: 1; } to { transform: scale(1.5); opacity: 0; } }

/* расставляем узлы классами, без инлайна */
.node.pos-a { left: 10%; top: 18%; }
.node.pos-b { left: 32%; top: 34%; }
.node.pos-c { left: 54%; top: 22%; }
.node.pos-d { left: 70%; top: 46%; }
.node.pos-e { left: 44%; top: 66%; }
.node.pos-f { left: 18%; top: 74%; }

/* ===== SECTION 14: TICKETS STACK ===== */
.cat-tickets { position: relative; padding: 42px 0 24px; }
.cat-tickets__grid { display: grid; gap: 28px; grid-template-columns: 1.1fr .9fr; align-items: start; }
.cat-tickets__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-tickets__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-tickets__media { display: grid; gap: 16px; justify-items: center; grid-template-columns: repeat(2, minmax(0,1fr)); }

.tickets { margin: 8px 0 0; padding: 0; list-style: none; display: grid; gap: 12px; }
.ticket {
  position: relative; padding: 14px 16px; border-radius: 16px;
  background: var(--mma-surface-1); border: 1px solid var(--mma-line);
  box-shadow: 0 8px 16px rgba(0,0,0,.18);
  transform: rotate(-1deg);
}
.ticket:nth-child(2) { transform: rotate(1.2deg) translateX(8px); }
.ticket:nth-child(3) { transform: rotate(-.6deg) translateX(4px); }
.ticket::before, .ticket::after {
  content: ""; position: absolute; top: 0; bottom: 0; width: 14px;
  background:
    radial-gradient(circle at 50% 6px, transparent 6px, var(--mma-surface-1) 7px) 0 0/100% 28px repeat-y;
}
.ticket::before { left: -7px; }
.ticket::after { right: -7px; }
.ticket header { font-weight: 700; margin-bottom: 6px; }
.ticket footer { margin-top: 8px; font-family: "JetBrains Mono"; color: var(--mma-text-2); }
.t-pod header { color: var(--mma-accent); }
.t-wed header { color: #FF9BC1; }
.t-live header { color: #89F0D9; }

/* ===== SECTION 15: DIAGONAL TIMELINE ===== */
.cat-timeline { position: relative; padding: 42px 0 24px; }
.cat-timeline__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-timeline__lead { color: var(--mma-text-2); margin: 0 0 12px; }

.diag-line {
  position: relative; margin: 10px 0 0; padding: 0; list-style: none;
}
.diag-line::before {
  content: ""; position: absolute; left: 50%; top: 0; bottom: 0; width: 4px; border-radius: 2px;
  background: linear-gradient(180deg, #20A4FF, #15E6C3);
  transform: skewX(-10deg);
  box-shadow: 0 0 10px rgba(32,164,255,.35);
}
.diag-item {
  position: relative; display: grid; gap: 10px; align-items: center; margin: 18px 0;
}
.diag-item.side-left  { grid-template-columns: 1fr 40px 1fr; }
.diag-item.side-right { grid-template-columns: 1fr 40px 1fr; }
.diag-item.side-left  > .mma-photo { grid-column: 1; }
.diag-item.side-left  > p         { grid-column: 3; }
.diag-item.side-right > p         { grid-column: 1; text-align: right; }
.diag-item.side-right > .mma-photo{ grid-column: 3; }

.diag-item::after {
  content: ""; width: 16px; height: 16px; border-radius: 50%;
  background: var(--mma-grad-primary); box-shadow: 0 0 12px rgba(21,230,195,.45);
  grid-column: 2; justify-self: center;
}

.cat-timeline__wrap .mma-photo .mma-img { box-shadow: 0 10px 28px rgba(0,0,0,.35); }

/* ===== Адаптив (13–15) ===== */
@media (max-width: 1100px) {
  .cat-routes__grid, .cat-tickets__grid { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
  .cat-routes__media { grid-template-columns: 1fr; }
  .cat-tickets__media { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .diag-line::before { left: 8px; transform: none; }
  .diag-item { grid-template-columns: 16px 1fr; }
  .diag-item.side-left  > .mma-photo,
  .diag-item.side-right > .mma-photo,
  .diag-item.side-left  > p,
  .diag-item.side-right > p { grid-column: 2; text-align: left; }
  .diag-item::after { grid-column: 1; justify-self: center; }
}
/* === MOBILE FIX: Section 15 (Диагональная тайм-лента) === */
@media (max-width: 700px) {
  .cat-timeline__wrap { padding-left: 12px; }

  /* центральная линия — влево, без наклона */
  .diag-line::before { left: 0; width: 3px; transform: none; }

  /* два столбца: линия + контент */
  .diag-item.side-left,
  .diag-item.side-right {
    grid-template-columns: 12px 1fr !important;
    align-items: start;
  }

  /* и фото, и текст — во второй колонке, слева */
  .diag-item > .mma-photo,
  .diag-item > p {
    grid-column: 2 !important;
    text-align: left !important;
  }

  /* маркер точки — в колонку с линией */
  .diag-item::after { grid-column: 1; }

  /* комфортные ширины изображений и текста */
  .cat-timeline__wrap .mma-photo { justify-self: start; }
  .cat-timeline__wrap .mma-photo .mma-img { max-width: 320px; }
  .diag-item p { margin: 6px 0 0; overflow-wrap: anywhere; hyphens: auto; }
}

@media (max-width: 420px) {
  .cat-timeline__wrap .mma-photo .mma-img { max-width: 280px; }
}
/* ===== SECTION 16: CABLE OPS ===== */
.cat-cableops { position: relative; padding: 42px 0 24px; }
.cat-cableops__grid { display: grid; gap: 28px; grid-template-columns: 1.15fr .85fr; align-items: start; }
.cat-cableops__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-cableops__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-cableops__points { margin: 10px 0 14px; padding: 0; list-style: none; display: grid; gap: 8px; }
.cat-cableops__points li { position: relative; padding-left: 16px; }
.cat-cableops__points li::before { content: ""; position: absolute; left: 0; top: .6em; width: 8px; height: 8px; border-radius: 2px; background: var(--mma-accent-2); box-shadow: 0 0 8px rgba(32,164,255,.45); }
.cat-cableops__media { display: grid; justify-items: center; }

.cable-rail {
  margin-top: 8px; height: 36px; border-radius: 12px;
  background: var(--mma-surface-1); border: 1px solid var(--mma-line);
  display: grid; grid-template-columns: 1fr; overflow: hidden; position: relative;
}
.cable-rail .rail {
  position: absolute; left: -20%; right: -20%; height: 4px; top: 50%;
  background:
    repeating-linear-gradient(90deg, rgba(21,230,195,.6) 0 16px, transparent 16px 28px);
  filter: drop-shadow(0 0 8px rgba(21,230,195,.45));
  transform: translateY(-50%);
  animation: cable-move 4s linear infinite;
}
.cable-rail .rail:nth-child(2) { top: 30%; animation-duration: 5.2s; opacity: .7; }
.cable-rail .rail:nth-child(3) { top: 70%; animation-duration: 3.6s; opacity: .7; }
@keyframes cable-move { to { transform: translate(10%, -50%); } }

/* ===== SECTION 17: FAQ (без JS) ===== */
.cat-faq { position: relative; padding: 42px 0 24px; }
.cat-faq__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-faq__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.faq-list { display: grid; gap: 10px; }
.faq {
  border: 1px solid var(--mma-line); border-radius: 14px; background: var(--mma-surface-1);
  padding: 8px 12px;
}
.faq summary {
  cursor: pointer; list-style: none; font-weight: 700; display: flex; align-items: center; gap: 10px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::before {
  content: "▸"; font-size: 14px; transform: translateY(1px); transition: transform .2s ease;
  color: var(--mma-accent);
}
.faq[open] summary::before { transform: rotate(90deg); }
.faq-a { color: var(--mma-text-2); margin: 8px 2px 4px 24px; }

/* ===== SECTION 18: COVERAGE ===== */
.cat-coverage { position: relative; padding: 42px 0 24px; }
.cat-coverage__grid { display: grid; gap: 28px; grid-template-columns: 1.15fr .85fr; align-items: start; }
.cat-coverage__title { font-family: "Russo One"; font-size: clamp(22px,2.6vw,30px); margin: 0 0 8px; }
.cat-coverage__lead { color: var(--mma-text-2); margin: 0 0 12px; }
.cat-coverage__media { display: grid; justify-items: center; }
.coverage-badges { margin: 10px 0 12px; padding: 0; list-style: none; display: flex; gap: 8px; flex-wrap: wrap; }
.coverage-badges li {
  padding: 8px 12px; border-radius: 999px; background: var(--mma-surface-1); border: 1px solid var(--mma-line);
}

.route-line {
  position: relative; height: 48px; border-radius: 12px;
  background: linear-gradient(90deg, #20A4FF, #15E6C3);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding: 2px; box-shadow: 0 0 12px rgba(21,230,195,.35);
}
.route-line::before {
  content: ""; position: absolute; inset: 10px; border-radius: 10px;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 18px, transparent 18px 36px);
  animation: route-dash 6s linear infinite;
}
@keyframes route-dash { to { transform: translateX(36px); } }
.route-line .dot {
  position: absolute; top: 50%; width: 8px; height: 8px; border-radius: 50%;
  background: #FFF; box-shadow: 0 0 10px rgba(255,255,255,.6);
  transform: translateY(-50%);
}
.route-line .dot:nth-child(1) { left: 10%; }
.route-line .dot:nth-child(2) { left: 36%; }
.route-line .dot:nth-child(3) { left: 62%; }
.route-line .dot:nth-child(4) { left: 86%; }

/* ===== АДАПТИВ (16–18) ===== */
@media (max-width: 1100px) {
  .cat-cableops__grid, .cat-coverage__grid { grid-template-columns: 1fr; }
}
