/* 0) Base & variables */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background:#121212; color:#e8e8e8; line-height:1.55;
  min-height:100vh; display:flex; flex-direction:column;
}

/* Тема — как в search.css */
:root{
  --nt-primary:#7709FF;
  --nt-primary-hover:#8d3bff;
  --nt-border:rgba(255,255,255,.08);
  --nt-card-bg:#1b1e28;
  --nt-text:#e8e8e8;
  --nt-text-dim:#b0b3c7;
  --nt-radius:8px;
  --nt-radius-lg:12px;
  --nt-shadow:0 4px 12px rgba(0,0,0,.45);
  --nt-transition:.24s cubic-bezier(.25,.8,.25,1);

  /* Макеты */
  --content-max: 1654px; /* как в search.css */
  --page-gutter: clamp(16px, (100vw - var(--content-max)) / 2, 160px);

  /* Лэйаут страницы игры */
  --game-left-w: 300px;  /* ширина левого сайдбара */
  --header-h: 72px;      /* подгони под реальную высоту хедера */
}

/* Документный поток: липкий футер */
header,footer{flex-shrink:0}
main{flex:1 0 auto}

/* 1) Новый лэйаут: фикс-левый сайдбар + правый контент */
.game-layout{
  display:grid;
  grid-template-columns: var(--game-left-w) 1fr;
  column-gap: var(--rail-gap, 24px); /* отступ между сайдбаром и контентом */
  min-height: calc(100vh - var(--header-h));
}
@media (max-width:1024px){
  .game-layout{ grid-template-columns: 1fr; }
}

/* Левый сайдбар — закреплён, скролл внутри */
.left-rail{
  position: sticky; top: var(--header-h); align-self:start;
  height: calc(100vh - var(--header-h));
  overflow:auto;
  background:#121212ad;
  padding:1.2rem 1rem;
  z-index:3;
  box-shadow: 8px 0 20px -14px rgba(120, 9, 255, 0.712);
}
.left-rail::-webkit-scrollbar{width:8px}
.left-rail::-webkit-scrollbar-thumb{background:var(--nt-border);border-radius:4px}

/* Контент справа: тот же правый gutter, что и на поиске */
.right-content{
  position:relative; z-index:1;
  padding-right: var(--page-gutter);
}
.right-content > .wrap{
  /* Контейнер секций: ограничиваем ширину, без центрирования —
     левый край прилегает к сайдбару, справа — общий gutter */
  max-width: var(--content-max);
  margin-inline: 0;
  padding-block: 3.2rem;
}
@media (max-width:1024px){
  .right-content{ padding-right: min(4vw,24px); }
}



/* 3) Сайдбар: логотип/меню игр/категорий */
.game-image-wrapper{text-align:center; margin-bottom:1.2rem}
.game-logo{width:100%; height:auto; object-fit:contain}

.menu .category{
  padding:.6rem .55rem; border-radius:6px; font-weight:700;
  color:var(--nt-text); cursor:pointer; display:flex; align-items:center; gap:.45rem;
  transition:background var(--nt-transition),color var(--nt-transition);
}
.menu .category:hover{ background: rgba(255,255,255,.06); }
.menu .category.active{ background:#2a2950; }

 .subcategory-list{
   overflow: hidden;
   max-height: 0;
   transition: max-height .28s ease;
   padding-left: 1.1rem;
}
 .subcategory-list.visible{ max-height: 800px; }

.subcategory{
  padding:.45rem .35rem; border-radius:6px; color:var(--nt-text-dim);
  cursor:pointer; display:flex; align-items:center; gap:.35rem;
  transition:background var(--nt-transition),color var(--nt-transition);
}
.subcategory:hover{ background:rgba(255,255,255,.05); color:#fff; }
.subcategory.active{ background:var(--nt-primary); color:#fff; }

/* 4) Заголовки и хлебные крошки */
.page-title-block h1{
  font-size:clamp(1.6rem,2.4vw,2.2rem); font-weight:800; margin-bottom:.6rem;
}
.page-title-block .short-desc-html{ font-size:1.02rem; color:var(--nt-text-dim); }


/* 5) Сетка офферов справа */
.offers-section{ padding-block: 1.2rem 2.4rem; }
.product-grid{
  display:grid; gap:1.6rem;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  margin-top: 1.6rem;
}
@media(min-width:2000px){ .product-grid{ gap:2rem; } }
.coming-soon{ font-size:1.1rem; color:var(--nt-text-dim); text-align:center; margin-top:2rem }

/* 6) Карточки товаров — идентичны поиску */
.product-card-new{
  background:var(--nt-card-bg);
  border:1px solid var(--nt-border);
  border-radius:var(--nt-radius-lg);
  overflow:hidden;
  display:flex; flex-direction:column; cursor:pointer;
  transition:transform var(--nt-transition), box-shadow var(--nt-transition);
  box-shadow:0 2px 18px rgba(0,0,0,.22);
}
.product-card-new:hover{ transform:translateY(-4px); box-shadow:0 6px 24px rgba(119,9,255,.35); }

.product-img-box{ position:relative; aspect-ratio:16/9; overflow:hidden }
.product-img-box img{ width:100%; height:100%; object-fit:cover; transition:transform .45s ease }
.product-card-new:hover .product-img-box img{ transform:scale(1.06) }

.product-badge-new{
  position:absolute; top:.6rem; right:.6rem; z-index:2;
  --badge-text:#fff;
  --badge-bg:var(--nt-primary);
  --badge-icon:none;
  padding:.35rem .6rem;
  font-size:.75rem; font-weight:700; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:.4rem;
  color:var(--badge-text);
  background:var(--badge-bg);
  border-radius:6px;
}
.product-badge-new .badge-ico{
  width:16px; height:16px; flex:0 0 16px; display:inline-block;
  background: currentColor;
  -webkit-mask: var(--badge-icon) no-repeat center / contain;
          mask: var(--badge-icon) no-repeat center / contain;
}
.product-badge-new .badge-label{ line-height:1; }

/* content */
.product-content{
  display:flex; flex-direction:column; gap:.6rem;
  padding:1rem 1rem 1.1rem;
  background:#121212; flex:1;
}
.product-title{ font-size:1.05rem; font-weight:800; color:#fff }
.product-desc{
  font-size:.95rem; color:var(--nt-text-dim);
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

/* price area (внизу карточки) */
.product-price-bottom{
  margin-top:auto; align-self:flex-start;
  display:flex; flex-direction:column; gap:.3rem;
  font-size:1.08rem; font-weight:800; color:#fff;
  text-shadow:0 2px 8px rgba(0,0,0,.22);
}

/* save badge */
.price-save-badge{
  display:inline-block; align-self:flex-start;
  background:#51cf66; color:#0b1c0b;
  padding:.18rem .5rem; border-radius:6px;
  font-size:.75rem; font-weight:800;
}

/* строка From + old + current */
.product-price-from-overlay{
  display:flex; align-items:baseline; gap:.45rem;
}
.product-price-from-overlay .from-label{ color:#b8b8c7; font-weight:600 }
.product-price-from-overlay .old-price{ color:#9aa0a6; text-decoration:line-through; font-weight:700; display:none }
.product-price-from-overlay .current-price{ color:#ffffff; font-weight:800 }
.product-price-from-overlay.has-discount .current-price{ color:#51cf66 }
.product-price-from-overlay.has-discount .old-price{ display:inline }

/* убрать возможный старый абсолютный overlay */
.product-price-from-overlay[style*="position: absolute"]{ position:static !important }

/* кнопка заказа больше не нужна на карточке */
.order-btn{ display:none !important }

/* Убираем внутренний скролл у SunEditor внутри карточки */
.product-desc .ql-editor{ overflow:visible!important; padding:0; max-height:none!important }

/* 7) Баннер кастом-заказа (как на поиске) */
.custom-order-banner{
  margin: 0 !important;
  background:linear-gradient(135deg,#121212 0%,#252323 100%);
  border:1px solid rgba(255,255,255,.07);
  border-radius:12px;
  padding:1.6rem 1.4rem;
  display:flex; align-items:center; justify-content:space-between;
  gap:1.2rem; flex-wrap:wrap;
}
.custom-order-banner__title{ font-size:1.25rem; font-weight:800; margin-bottom:.3rem; color:#fff }
.custom-order-banner__subtitle{ font-size:1rem; color:var(--nt-text-dim) }
.custom-order-btn{
  background:var(--nt-primary); border:none; border-radius:8px;
  padding:.75rem 1.4rem; font-weight:700; color:#fff; cursor:pointer;
  transition:background .2s ease; text-decoration:none;
  display:inline-flex; align-items:center; gap:.5rem;
}
.custom-order-btn:hover{ background:var(--nt-primary-hover) }




/* 8) Адаптивы и эффекты */
@media(hover:hover){
  .product-card-new:hover{ box-shadow:0 6px 24px rgba(119,9,255,.35); }
}
:focus-visible{ outline:2px solid #7709FF; outline-offset:2px }
@media(prefers-reduced-motion:reduce){
  .product-card-new, .product-img-box img{ transition:none !important }
}

/* 9) Контентные описания (из SunEditor) — аккуратная типографика */
.entity-description,
.entity-footer-description{
  margin-top:1.5rem; font-size:1rem; color:var(--nt-text-dим);
  line-height:1.65; overflow-x:auto;
}
.entity-description img,
.entity-footer-description img{ max-width:100%; display:block; margin:1rem auto; border-radius:8px }

/* 10) Мелочи */
.text-center{text-align:center}

/* ===== Конец файла ===== */


/* ---------- Entity descriptions ---------- */
.entity-description,
.entity-footer-description{margin-top:1.5rem;font-size:1rem;color:var(--nt-text-dim);}
.entity-description img,
.entity-footer-description img{max-width:100%;display:block;margin:1rem auto}

/* ---------- Custom order banner ---------- */
.custom-order-banner{
  margin:2.5rem 0;background:linear-gradient(135deg,#1e2231 0%,#262b3d 100%);
  border:1px solid rgba(255,255,255,.07);border-radius:var(--nt-radius-lg);
  padding:1.8rem 1.6rem;display:flex;align-items:center;justify-content:space-between;
  gap:1.4rem;flex-wrap:wrap;
}
.custom-order-banner__title{font-size:1.35rem;font-weight:700;margin-bottom:.35rem}
.custom-order-banner__subtitle{font-size:1rem;color:var(--nt-text-dim);}
.custom-order-btn{
  background:var(--nt-primary);border:none;border-radius:var(--nt-radius);
  padding:.75rem 1.6rem;font-weight:600;color:#fff;cursor:pointer;
  transition:background var(--nt-transition);
}
.custom-order-btn:hover{background:var(--nt-primary-hover);}


/* B) Price‑from overlay z‑index */
.product-price-from-overlay{z-index:3;} /* поверх масштабируемого img */

/* C) Banner alignment */
.custom-order-banner{display:flex;align-items:center;gap:1.6rem;}
.custom-order-banner>*:not(.custom-order-btn){flex:1 1 auto;} /* текст расширяется */
.custom-order-btn{margin-left:auto;} /* уезжает вправо */
/* на мобилке — уже задано flex-direction:column */


/* SunEditor tables: compact width + centered + container scroll */
.entity-description,
.entity-footer-description {
  overflow-x: auto; /* если таблица шире контейнера — появится горизонтальный скролл */
}

.entity-description table,
.entity-footer-description table {
  /* было: width:100%; display:block; — из-за этого таблица тянулась на всю ширину */
  width: auto;
  max-width: 100%;
  display: inline-table;      /* ширина по контенту */
  table-layout: auto;
  margin: .8rem auto;         /* центрирование */
}

.entity-description th,
.entity-description td,
.entity-footer-description th,
.entity-footer-description td {
  /* было: white-space: nowrap; — мешало сужаться колонкам */
  white-space: normal;
  word-break: break-word;     /* аккуратный перенос длинных слов/ссылок */
}


.entity-description table,
.entity-footer-description table {
  width: auto !important;        /* занимать всю ширину колонки */
  max-width: 100% !important;
  table-layout: fixed !important;/* фиксированная сетка — помогает переносам */
  display: table !important;     /* исключаем inline-table, чтобы не вылезала */
  border-collapse: collapse;
  box-sizing: border-box;
  margin: 1rem 0;
  background: #1b1e28;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  overflow: hidden;              /* скругления по краям */
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
}

/* Заголовок: выразительный фон, контрастный текст */
.entity-description th,
.entity-description td,
.entity-footer-description th,
.entity-footer-description td {
  background: linear-gradient(180deg,#262b3d 0%,#20253a 100%);
  color: #fff;
  font-weight: 700;
  letter-spacing: .02em;
}

/* Ячейки: компактные отступы + перенос длинных слов/URL */
.entity-description th, .entity-description td,
.entity-footer-description th, .entity-footer-description td,
.spoiler-content th, .spoiler-content td {
  padding: .65rem .85rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
  vertical-align: top;
  white-space: normal !important;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

/* “Зебра” и hover подсветка строк */
.entity-description tbody tr:nth-child(even) td,
.entity-footer-description tbody tr:nth-child(even) td,
.spoiler-content tbody tr:nth-child(even) td {
  background: rgba(255,255,255,.03);
}
.entity-description tbody tr:hover td,
.entity-footer-description tbody tr:hover td,
.spoiler-content tbody tr:hover td {
  background: rgba(255,255,255,.05);
}

/* Картинки/медиа внутри ячеек — вписать в ячейку */
.entity-description td img,
.entity-footer-description td img,
.spoiler-content td img,
.entity-description td video,
.entity-footer-description td video,
.spoiler-content td video {
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 6px;
}

/* Мелкий тюнинг на мобильных — чуть меньше шрифт в таблицах */
@media (max-width: 600px) {
  .entity-description table,
  .entity-footer-description table,
  .spoiler-content table {
    font-size: .95rem;
  }
}

.breadcrumbs {
  font-size: 14px;
  margin: 20px 0 24px;
  white-space: nowrap;
  overflow-x: auto;
  color: #9aa0a6; 
}
.breadcrumbs ol {
  list-style: none;
  display: flex;
  padding: 0;
  margin: 0;
}
.breadcrumbs li {
  display: flex;
  align-items: center;
}
.breadcrumbs li + li::before {
  content: "›";
  margin: 0 6px;
  color: #c9c9c9;
}
.breadcrumbs a{
  color: #ffffff;      /* все ссылки — белые */
  text-decoration: none;
  font-size: 15px;
}
.breadcrumbs a:hover{ text-decoration: underline; }


    /* Убрать подчеркивание у All Services и зафиксировать размеры иконки */
    .menu .category.all-services,
    .menu .category.all-services:link,
    .menu .category.all-services:visited,
    .menu .category.all-services:hover,
    .menu .category.all-services:active {
      text-decoration: none !important;
    }
    .menu .category.all-services .nav-svg svg {
      width: 28px; height: 28px; vertical-align: -3px; margin-right: 6px;
    }

    /* SunEditor content — Game page (Description / Footer Description) */
.entity-description,
.entity-footer-description {
  line-height: 1.65;
  color: #e8e8e8;
}

/* Типографика */
.entity-description p,
.entity-footer-description p { margin: .6rem 0; }
.entity-description h1,
.entity-description h2,
.entity-description h3,
.entity-footer-description h1,
.entity-footer-description h2,
.entity-footer-description h3 {
  margin: .9rem 0 .5rem;
  line-height: 1.22;
  color: #fff;
}
.entity-description a,
.entity-footer-description a {
  color: #55a8ff;
  text-decoration: underline;
}
.entity-description ul,
.entity-description ol,
.entity-footer-description ul,
.entity-footer-description ol {
  margin: .6rem 0 .6rem 1.2rem;
  padding-left: 1.1rem;
}
.entity-description li,
.entity-footer-description li { margin: .25rem 0; }

/* Картинки */
.entity-description img,
.entity-footer-description img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
  margin: .6rem auto;
}

/* Цитаты */
.entity-description blockquote,
.entity-footer-description blockquote {
  border-left: 3px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  padding: .7rem .9rem;
  margin: .9rem 0;
  border-radius: 6px;
  color: #dfe4f2;
}

/* Код */
.entity-description pre,
.entity-footer-description pre {
  background: #1b1f2b;
  color: #eaeefc;
  padding: .8rem 1rem;
  border-radius: 8px;
  overflow: auto;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: .95rem;
}
.entity-description code,
.entity-footer-description code {
  background: #1b1f2b;
  color: #eaeefc;
  padding: .15rem .35rem;
  border-radius: 6px;
}

/* =====================================================================
   Patch 2025‑07‑04 — Tables in entity-* match product.css
   ===================================================================== */

/* Контентные блоки: без горизонтального скролла, переносы в ячейках */
.entity-description,
.entity-footer-description {
  overflow-x: hidden !important;
}

/* Таблица не шире контейнера, фиксированная сетка, красивое оформление */
.entity-description table,
.entity-footer-description table {
  width: auto !important;
  max-width: 100% !important;
  table-layout: fixed !important;
  display: table !important;          /* переопределяем inline-table */
  border-collapse: collapse;
  box-sizing: border-box;
  margin: 1rem 0;
  background: #1b1e28;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  overflow: hidden;                    /* видимые скругления */
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
}

/* Шапка — выразительный фон, контраст */
.entity-description thead th,
.entity-footer-description thead th {
  background: linear-gradient(180deg,#262b3d 0%,#20253a 100%) !important;
  color: #fff !important;
  font-weight: 700;
  letter-spacing: .02em;
}

/* Базовые ячейки: отступы, переносы, разделители строк */
.entity-description th, .entity-description td,
.entity-footer-description th, .entity-footer-description td {
  padding: .65rem .85rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
  vertical-align: top;
  white-space: normal !important;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

/* На всякий случай снимаем ранее заданный градиент с td (если был) */
.entity-description td,
.entity-footer-description td {
  background: transparent !important;
  color: inherit;
  letter-spacing: normal;
  font-weight: inherit;
}

/* Зебра и hover подсветка строк */
.entity-description tbody tr:nth-child(even) td,
.entity-footer-description tbody tr:nth-child(even) td {
  background: rgba(255,255,255,.03);
}
.entity-description tbody tr:hover td,
.entity-footer-description tbody tr:hover td {
  background: rgba(255,255,255,.05);
}

/* Медиа внутри ячеек — вписываем */
.entity-description td img,
.entity-footer-description td img,
.entity-description td video,
.entity-footer-description td video {
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 6px;
}

/* Чуть компактнее на мобилках */
@media (max-width: 600px) {
  .entity-description table,
  .entity-footer-description table {
    font-size: .95rem;
  }
}
/* Если видео встречается в коротком описании (в заголовочном блоке) */
.page-title-block .short-desc-html iframe,
.page-title-block .short-desc-html video {
  display: block;
  max-width: 100%;
  width: auto;
  height: auto;
  border: 0;
}

/* === NT Slider (content inside SunEditor) ============================ */
.nt-slider{
  position: relative;
  overflow: hidden;
  border-radius: var(--nt-radius-lg);
  border: 1px solid var(--nt-border);
  background: #0f1218;
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
  display: block;            /* был inline-block: корректно центрируется как блок */
  /* убираем навязанное заполнение: ширину ставим из JS (px или %) */
  /* width: auto;  — не задаём, т.к. установим width инлайном через JS */
  max-width: 100%;
  margin: 1rem auto;
  user-select: none;
  cursor: pointer;
}
.nt-slides{
  display: flex;
  transition: transform .45s ease;
  will-change: transform;
}
.nt-slide{
  min-width: 100%;
  user-select: none;
}
.nt-slide img{
  display: block;
  width: 100%;                /* масштабируем под ширину слайдера */
  height: auto;
  object-fit: cover;
  -webkit-user-drag: none;    /* запрет перетаскивания картинки */
  user-drag: none;
  cursor: grab;
}

/* Arrows */
.nt-arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--nt-border);
  background: rgba(17,19,26,.72);
  backdrop-filter: blur(4px);
  color: #fff;
  display: grid; place-items: center;
  cursor: pointer;
  transition: opacity .2s ease, background .2s ease;
  z-index: 3;
}
.nt-arrow:hover{ background: rgba(17,19,26,.9); }
.nt-prev{ left: 10px; }
.nt-next{ right: 10px; }

/* Dots */
.nt-dots{
  position: absolute;
  left: 50%; transform: translateX(-50%);
  bottom: 10px;
  display: flex; gap: .4rem;
  z-index: 3;
}
.nt-dot{
  width: 8px; height: 8px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,.35);
  cursor: pointer;
  padding: 0;
}
.nt-dot.active{ background: #fff; }

/* Dark overlays stay visible over images */
.nt-slider::after{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.12), transparent 30%);
  pointer-events: none;
}

/* NT Slider x SunEditor: убрать внешние отступы у обёрток редактора и растянуть на 100% */
.nt-slide .se-component,
.nt-slide .se-image-container,
.nt-slide figure {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  width: 100% !important; /* Ключевое: внутренняя обёртка = ширине слайдера */
}
.nt-slide .se-component img,
.nt-slide figure img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Также запретим drag на всякий случай на уровне контейнера */
.nt-slider img { -webkit-user-drag: none; user-drag: none; }

/* SunEditor content — Game page: short_description (в заголовочном блоке) */
.page-title-block .short-desc-html {
  line-height: 1.6;
  color: #e8e8e8;
  /* если это div.ql-editor — убираем внутренние паддинги и ограничения */
  overflow: visible !important;
  padding: 0;
  max-height: none !important;
}

.card-short-description {
  margin-left: 20px;
  padding: 0;
}

/* Типографика (компактнее, чем в основном описании) */
.page-title-block .short-desc-html p { margin: .5rem 0; }
.page-title-block .short-desc-html h1,
.page-title-block .short-desc-html h2,
.page-title-block .short-desc-html h3 {
  margin: .6rem 0 .35rem;
  line-height: 1.22;
  color: #fff;
}

/* Ссылки */
.page-title-block .short-desc-html a {
  color: #55a8ff;
  text-decoration: underline;
}

/* Списки — аккуратно и компактно */
.page-title-block .short-desc-html ul,
.page-title-block .short-desc-html ol {
  margin: .5rem 0 .5rem 1.2rem;
  padding-left: 1.1rem;
}
.page-title-block .short-desc-html li { margin: .2rem 0; }

/* Картинки */
.page-title-block .short-desc-html img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
  margin: .5rem auto;
}

/* Цитаты */
.page-title-block .short-desc-html blockquote {
  border-left: 3px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  padding: .6rem .8rem;
  margin: .7rem 0;
  border-radius: 6px;
  color: #dfe4f2;
}

/* Код */
.page-title-block .short-desc-html pre {
  background: #1b1f2b;
  color: #eaeefc;
  padding: .7rem .9rem;
  border-radius: 8px;
  overflow: auto;
  font-family: ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;
  font-size: .93rem;
}
.page-title-block .short-desc-html code {
  background: #1b1f2b;
  color: #eaeefc;
  padding: .12rem .32rem;
  border-radius: 6px;
}

/* Таблицы: ширина по контенту + центрирование + горизонтальный скролл при необходимости */
.page-title-block .short-desc-html table {
  width: auto;
  max-width: 100%;
  display: inline-table;
  table-layout: auto;
  margin: .7rem auto;
  border-collapse: collapse;
  background: #1b1e28;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  overflow: hidden;
}
.page-title-block .short-desc-html thead th { background: #202435; color: #fff; }
.page-title-block .short-desc-html th,
.page-title-block .short-desc-html td {
  padding: .5rem .7rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
  white-space: nowrap; /* узкие таблицы не ломаем, пусть скроллятся контейнером */
}
.page-title-block .short-desc-html tr:nth-child(even) td {
  background: rgba(255,255,255,.03);
}

/* Выравнивания (SunEditor inline) */
.page-title-block .short-desc-html [style*="text-align:center"],
.page-title-block .short-desc-html .se-text-center { text-align: center; }
.page-title-block .short-desc-html [style*="text-align:right"],
.page-title-block .short-desc-html .se-text-right { text-align: right; }
.page-title-block .short-desc-html [style*="text-align:left"],
.page-title-block .short-desc-html .se-text-left { text-align: left; }

/* Фигуры/подписи */
.page-title-block .short-desc-html figure { margin: .6rem 0; }
.page-title-block .short-desc-html figcaption {
  color: #b0b3c7; font-size: .9rem; text-align: center; margin-top: .3rem;
}

/* Видео/iframe — уже были базовые стили, дополним селекторы на случай отсутствия их выше */
.page-title-block .short-desc-html .se-video-container,
.page-title-block .short-desc-html figure.se-video-container {
  display: inline-block;
  max-width: 100%;
  margin: .8rem auto;
  background: transparent;
  border: 0;
  overflow: visible;
}
.page-title-block .short-desc-html iframe,
.page-title-block .short-desc-html video {
  display: block;
  max-width: 100%;
  width: auto;
  height: auto;
  border: 0;
}

/* 1) Контейнер таблицы — строго как на product.css */
.entity-description table,
.entity-footer-description table {
  width: auto !important;
  max-width: 100% !important;
  table-layout: fixed !important;
  display: table !important;
  margin: 1rem 0 !important;
  background: #1b1e28 !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 10px rgba(0,0,0,.25) !important;
}

/* 2) Шапка таблицы — градиент и контраст как на product.css */
.entity-description thead th,
.entity-footer-description thead th {
  background: linear-gradient(180deg,#262b3d 0%,#20253a 100%) !important;
  color: #fff !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
}

/* 3) Тело таблицы — без фонового градиента и без лишней жирности */
.entity-description tbody th,
.entity-description tbody td,
.entity-description tfoot th,
.entity-description tfoot td,
.entity-footer-description tbody th,
.entity-footer-description tbody td,
.entity-footer-description tfoot th,
.entity-footer-description tfoot td {
  background: transparent !important;     /* снимаем ранее заданный фон */
  color: var(--nt-text) !important;       /* как на product.css */
  font-weight: 400 !important;            /* обычный вес */
}

/* 4) Паддинги, переносы, разделители строк — в тон product.css */
.entity-description th, .entity-description td,
.entity-footer-description th, .entity-footer-description td {
  padding: .65rem .85rem !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  vertical-align: top !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  hyphens: auto !important;
}

/* 5) Зебра и hover строк — идентично product.css */
.entity-description tbody tr:nth-child(even) td,
.entity-footer-description tbody tr:nth-child(even) td {
  background: rgba(255,255,255,.03) !important;
}
.entity-description tbody tr:hover td,
.entity-footer-description tbody tr:hover td {
  background: rgba(255,255,255,.05) !important;
}

/* 6) Медиа внутри ячеек */
.entity-description td img,
.entity-footer-description td img,
.entity-description td video,
.entity-footer-description td video {
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
  border-radius: 6px !important;
}

/* 7) Мобильная подстройка размера шрифта в таблицах */
@media (max-width: 600px) {
  .entity-description table,
  .entity-footer-description table {
    font-size: .95rem !important;
  }
}

@media (max-width: 1024px){
  .left-rail{ display: none; }
  .left-rail{ box-shadow: none; }
  .game-layout{ grid-template-columns: 1fr; }
  /* по умолчанию у нас только правый отступ — на мобиле дадим и слева немного,
     чтобы контент не прилипал к краю экрана */
  .right-content{
    padding-right: min(4vw, 24px);
    padding-left:  min(4vw, 24px);
  }
}

/* === Background image layer under content === */
.page-bg-img {
  position: absolute;
  top: 0; left: 0; right: 0;
  z-index: 0;              /* ниже контента */
  overflow: hidden;
}

.page-bg-img img {
  width: 100%;
  height: auto;
  display: block;
}

/* затемнение по нижнему краю картинки */
.page-bg-img::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: clamp(120px, 22vw, 280px);
  background:linear-gradient(
    to bottom,
    rgba(18,18,18,0)    0%,
    rgba(18,18,18,0.06) 28%,
    rgba(18,18,18,0.16) 48%,
    rgba(18,18,18,0.32) 66%,
    rgba(18,18,18,0.56) 82%,
    #121212             100%
  );
  pointer-events: none;
}

/* поднимаем всё содержимое выше картинки */
header,
.breadcrumbs,
.game-container,
.page-title-block {
  position: relative;
  z-index: 1;
}

/* Контент и футер гарантированно поверх фона */
header, .game-layout, footer { position: relative; z-index: 1; }
/* Совпасть с карточками поиска */
.product-card-new .product-content{ padding: 1rem 1rem 1.1rem; }
.product-card-new .product-title{ font-size: 1.05rem; font-weight: 700; }
.product-card-new .product-desc .card-short-description{ margin-left: 0; padding: 0; } /* ← ключевое отличие */
.product-card-new .product-img-box{ aspect-ratio: 16/9; }
.product-card-new{ border-radius: 12px; box-shadow: 0 2px 18px rgba(0,0,0,.22); }
@media(hover:hover){
  .product-card-new:hover{ transform: translateY(-4px); box-shadow: 0 6px 24px rgba(119,9,255,.35); }
}
/* [GAME] Custom order banner — match search.css */
.custom-order-banner{
  margin: 2.2rem 0;
  background: linear-gradient(135deg,#121212 0%,#252323 100%);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
  padding: 1.6rem 1.4rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.2rem; flex-wrap: wrap;
}
.custom-order-banner__title{ font-size: 1.25rem; font-weight: 800; margin-bottom: .3rem; color: #fff; }
.custom-order-banner__subtitle{ font-size: 1rem; color: var(--nt-text-dим); }
.custom-order-btn{
  background: var(--nt-primary); border: none; border-radius: 8px;
  padding: .75rem 1.4rem; font-weight: 700; color: #fff; cursor: pointer;
  transition: background .2s ease; text-decoration: none;
  display: inline-flex; align-items: center; gap: .5rem;
}
.custom-order-btn:hover{ background: var(--nt-primary-hover); }

/* === Sidebar: highlight current game link ============================== */
.left-rail .category.all-services.is-highlight{
  display:flex; align-items:center; gap:.55rem;
  margin: .25rem .1rem 1rem;
  padding: .7rem .65rem;
  border-radius: 10px;
  font-weight: 800;
  color:#fff;
  background: linear-gradient(135deg, rgba(100, 100, 100, 0.18), rgba(103, 101, 105, 0.1));
  border: 1px solid rgba(131, 131, 131, 0.35);
  box-shadow: inset 0 4px 14px rgba(73, 72, 73, 0.12);
  transition: background .2s ease, border-color .2s ease, transform .12s ease;
}
.left-rail .category.all-services.is-highlight:hover{
  background: linear-gradient(135deg, rgba(119,9,255,.28), rgba(119,9,255,.18));
  border-color: var(--nt-primary, #7709FF);
  transform: translateY(-1px);
}

/* === Sidebar subcategories smooth collapse === */
.subcategory-list{
  overflow: hidden;
  max-height: 0;
  transition: max-height .28s ease;
}
.subcategory-list.visible{
  display: block;            /* уже есть в файле, оставляем */
  max-height: 800px;         /* достаточно, чтобы плавно раскрыться */
}
.category.open .cat-toggle{ content: '−'; }

/* === Sidebar category toggle (SVG + / −) =============================== */
.cat-toggle{
  margin-left: auto;
  background: transparent;
  border: none;                 /* нет бордера по умолчанию */
  color: inherit;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  cursor: pointer;
  display: inline-grid;
  place-items: center;
  transition: background .18s ease, box-shadow .18s ease;
  padding: 0;
}
.cat-toggle:hover,
.cat-toggle:focus-visible{
  background: rgba(255,255,255,.08);    /* лёгкая подсветка */
  outline: 1px solid rgba(255,255,255,.20);  /* имитация бордера только при наведении/фокусе */
  outline-offset: 0;
}
.cat-toggle-icon{
  width: 16px;
  height: 16px;
  pointer-events: none; /* чтобы клики шли по кнопке, а не по <img> */
  display: block;
}


/* === Pagination (match search) === */
.nt-pagination{
  display:flex; align-items:center; justify-content:center;
  gap:.35rem; margin-top:1.6rem; flex-wrap:wrap;
}
.nt-page-btn{
  background:#1a1d26; border:1px solid var(--nt-border);
  color:#fff; font-weight:700; font-size:.95rem;
  border-radius:8px; padding:.5rem .8rem; cursor:pointer;
  transition:background .18s ease,border-color .18s ease,transform .12s ease;
}
.nt-page-btn:hover{ background:#202535; border-color:rgba(255,255,255,.16) }
.nt-page-btn.is-current{ background:var(--nt-primary); border-color:transparent }
.nt-page-btn.is-disabled{ opacity:.45; pointer-events:none }
.nt-page-ellipsis{ color:var(--nt-text-dим); padding:.5rem .4rem; user-select:none }
.nt-pagination:empty { display: none; }



/* === Smooth appear like Guides (fade-in on cards) ===================== */
@keyframes ntCardAppear {
  0% { opacity: 0; }
  100% { opacity: 1; }
}

.product-grid .product-card-new{
  opacity: 0;                 /* невидимы по умолчанию */
  animation: none;            /* анимация не стартует сама */
}

/* включаем анимацию только когда JS повесит класс */
.product-grid.reveal-ready .product-card-new.nt-reveal{
  animation: ntCardAppear .45s ease both;
  opacity: 1;
}

/* временная глушилка, чтобы ничего не мигало во время реорганизации DOM */
.product-grid.nt-suppress-anim .product-card-new{
  animation: none !important;
  opacity: 0 !important;
}
/* Лёгкая «ступенька» по позициям, чтобы не мигали все разом */
.product-grid .product-card-new:nth-child(1n) { animation-delay: .01s; }
.product-grid .product-card-new:nth-child(2n) { animation-delay: .05s; }
.product-grid .product-card-new:nth-child(3n) { animation-delay: .08s; }
.product-grid .product-card-new:nth-child(4n) { animation-delay: .12s; }
.product-grid .product-card-new:nth-child(5n) { animation-delay: .16s; }
/* Уважение настроек доступности */
@media (prefers-reduced-motion: reduce) {
  .product-grid .product-card-new { animation: none !important; }
}
/* Опционально: мягкий fade для заголовка и краткого описания */
.page-title-block,
.entity-description,
.entity-footer-description {
  animation: ntCardAppear .48s ease both;
}

/* Единые контейнеры под иконки */
.nav-svg{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
}

/* размеры и для inline <svg>, и для <img> из файла */
.menu .category .nav-svg svg,
.menu .category .nav-svg img,
.menu .category .nav-svg .nav-svg-img{
  width: 28px;
  height: 28px;
  display: block;
  object-fit: contain;
}

/* «All Services» ранее таргетировал только svg — расширим */
.menu .category.all-services .nav-svg svg,
.menu .category.all-services .nav-svg img,
.menu .category.all-services .nav-svg .nav-svg-img{
  width: 28px;
  height: 28px;
  vertical-align: -3px;
  margin-right: 6px;
}

/* Sidebar icons: game, categories, subcategories */
.left-rail .nav-svg{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
}
/* поддерживаем и inline <svg>, и <img src="*.svg"> */
.left-rail .nav-svg svg,
.left-rail .nav-svg img,
.left-rail .nav-svg .nav-svg-img{
  width: 28px;
  height: 28px;
  display: block;
  object-fit: contain;
}
/* --- Favorites heart in title row --- */
.page-title-block .title-row{
  display:flex;
  align-items: baseline;    /* <-- ключ: базовая линия текста */
  gap:12px;
}
.page-title-block .icon-btn{
  display:inline-grid;
  place-items:center;
  width:36px; height:36px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;
  background: rgba(44, 44, 44, 0.466);
  transition: background .16s ease, border-color .16s ease;
  position: relative;
  top: .08em;               /* микро-подстройка к базовой линии */
}
.page-title-block .icon-btn:hover,
.page-title-block .icon-btn:focus-visible{
  background: rgba(0,0,0,.55);
  border-color: rgba(255,255,255,.16);
}
.page-title-block .icon-btn .icon{
  width:18px; height:18px; display:block;
  pointer-events:none;
}