/* 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);
  --a: 0deg;
  /* Макеты */
  --content-max: 1654px; /* как в search.css */
  --page-gutter: clamp(16px, (100vw - var(--content-max)) / 2, 160px);

  /* Лэйаут страницы игры */
  --game-left-w: 300px;  /* ширина левого сайдбара */
  --header-h: 72px;      
}
@property --a { syntax: '<angle>'; initial-value: 0deg; inherits: false; }
@keyframes rouletteBorderSpin { to { --a: 360deg; } }
/* Документный поток: липкий футер */
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);
  margin-top: 1px;
}
.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{
   position:relative;
   padding:.55rem .7rem;
   margin-bottom:2px;
   border-radius:8px;
   font-weight:600;
   color:var(--nt-text-dim);
   cursor:pointer;
   display:flex; align-items:center; gap:.45rem;
   transition:background var(--nt-transition),color var(--nt-transition),box-shadow var(--nt-transition);
 }
 .menu .category:hover{
   background:rgba(255, 255, 255, 0.075);
   color:var(--nt-text);
 }
 .menu .category.active{
   background:linear-gradient(90deg, rgba(119,9,255,.28), rgba(119,9,255,.05));
   color:#fff;
 }
 .menu .category.active::before{
   opacity:1;
   transform:scaleY(1);
 }

 .subcategory-list{
   overflow:hidden;
   max-height:0;
   transition:max-height .28s ease;
   padding-left:1.1rem;
   margin-top:2px;
   border-left:1px solid rgba(255,255,255,.05);
 }
 .subcategory-list.visible{ max-height:800px; }

 .subcategory{
   position:relative;
   padding:.35rem .6rem;
   margin:.06rem 0;
   border-radius:6px;
   font-size:.92rem;
   color:var(--nt-text-dim);
   cursor:pointer;
   display:flex; align-items:center; gap:.35rem;
   transition:background var(--nt-transition),color var(--nt-transition),transform var(--nt-transition);
 }
 .subcategory::before{
   content:'';
   position:absolute;
   left:0;
   top:50%;
   width:4px; height:4px;
   border-radius:50%;
   background:transparent;
   transform:translateY(-50%);
   transition:background .2s ease,transform .2s ease;
 }
 .subcategory:hover{
   background:rgba(255, 255, 255, 0.075);
   color:#fff;
 }
 .subcategory.active{
   background:linear-gradient(90deg, rgba(119,9,255,.28), rgba(119,9,255,.05));
   color:#fff;
 }


/* 4) Заголовки и хлебные крошки */
.page-title-block h1{
  font-size:clamp(1.6rem,2.4vw,2.2rem); font-weight:800; margin-bottom:.1rem;
}
.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 }

/* Блок баннеров на странице игры / категории / сабкатегории */
.page-banners{
  margin-top:1.4rem;
  opacity:0;
  transform:translateY(16px);
  animation:page-banners-in .55s ease-out forwards;
  animation-delay:.15s; /* можно чуть увеличить/уменьшить */
}
.page-banners-grid{
  display:grid;
  gap:1.4rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Ряд чипов (баннеров без картинок) — компактная flex-лента */
.page-banners-chips{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem .8rem;
  margin-bottom:1rem; /* небольшой отступ от карточек ниже */
}

@media (max-width: 1100px){
  .page-banners-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 700px){
  .page-banners-grid{
    grid-template-columns: minmax(0, 1fr);
  }
}

.page-banner-card{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:var(--nt-radius-lg);
  border:1px solid var(--nt-border);
  background:#10121a;
  box-shadow:0 2px 18px rgba(0,0,0,.22);
  max-height:200px;
  text-decoration:none;
  color:inherit;
  transition:
    box-shadow var(--nt-transition),
    border-color var(--nt-transition);
}

.page-banner-card__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
   transform: scale(1.2);
  transition:transform .45s ease;
}
.page-banner-card__character{
  position:absolute;
  top:0;
  bottom:0;
  right:0;
  width:50%;                  /* только правая половина баннера */
  display:flex;
  justify-content:center;     /* центрируем внутри правой половины */
  align-items:flex-end;
  padding-right:1.4rem;
  pointer-events:none;
  z-index:2;
}
.page-banner-card__character-img{
  max-height:100%;
  width:auto;
  object-fit:contain;
  transform:translateX(8%) scale(0.95);   /* лёгкий сдвиг вправо */
  filter:drop-shadow(0 12px 26px rgba(0,0,0,.85));
  transition:transform .45s ease;      /* для анимации приближения */
}
.page-banner-card__overlay{
  position:absolute;
  inset:0;
  padding:1.8rem 2rem;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  align-items:flex-start;
  background:linear-gradient(
    90deg,
    rgba(3,7,18,0.9) 0%,
    rgba(3,7,18,0.7) 40%,
    rgba(3,7,18,0.1) 100%
  );
}
.page-banner-card__content{
  max-width:55%;
  position: relative;   /* создаём позиционированный слой */
  z-index: 3;           /* текст выше персонажа (у него z-index:2) */
}
@media (max-width:900px){
  .page-banner-card__content{
    max-width:100%;
  }
}
@media (max-width:900px){
  .page-banner-card__character{
    padding-right:.75rem;
    width:55%;
    justify-content:center;
  }
  .page-banner-card__character-img{
    max-height:115%;
    transform:scale(1); /* без сдвига, чтобы не резалось */
  }
}
@media (max-width:700px){
  .page-banner-card__character{
    opacity:.9;
  }
}

.page-banner-card__title{
  font-size:1.35rem;
  font-weight:800;
  color:#fff;
  margin-bottom:.35rem;
  line-height:1.2;

}

.page-banner-card__subtitle{
  font-size:.98rem;
  color:var(--nt-text-dim);
}
.page-banner-card::before{
  content:'';
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(circle at top left, rgba(119,9,255,.35), transparent 55%),
    radial-gradient(circle at bottom right, rgba(255,211,108,.28), transparent 55%);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}
.page-banner-card:hover{
box-shadow:0 6px 24px rgba(119,9,255,.35);
}
.page-banner-card:hover::before{
  opacity:1;
}
.page-banner-card:hover .page-banner-card__img{
  transform:scale(1.04);
}
.page-banner-card:hover .page-banner-card__character-img{
  transform:translateX(8%) scale(1.06);
}

@media (max-width:900px){
  .page-banners{
    margin-top:1rem;
  }
  .page-banner-card{
    min-height:160px;
  }
}
@media (max-width:600px){
  .page-banners-grid{
    gap:1.1rem;
  }
  .page-banner-card{
    min-height:140px;
  }
  .page-banner-card__title{
    font-size:1.05rem;
  }
  .page-banner-card__subtitle{
    font-size:.95rem;
  }
}

@keyframes page-banners-in{
  from{
    opacity:0;
    transform:translateY(16px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}
/* 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;
  overflow:hidden;
  background:#121212; /* тот же фон, что у .product-content */
}

.product-title-overlay{
  position:absolute;
  left:0;
  right:0;
  bottom:-1px; /* чуть заезжаем вниз, чтобы не было щели */
  padding:.7rem 1rem .8rem;
  pointer-events:none;
  z-index: 1; /* поднимаем слой с градиентом и текстом над картинкой */
}


/* градиент как отдельный слой под текстом */
.product-title-overlay::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.9), rgba(0,0,0,0));
  transform-origin:50% 100%;
  transition:transform .45s ease;
  z-index:-1;
}
.product-card-new .product-title{
  position:relative; /* чтобы текст был над ::before */
}


.product-img-box img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transform-origin:50% 50%;
  transition:transform .45s ease;
}

/* зумим картинку и градиент-подложку, но не сам текст */
.product-card-new:hover .product-img-box img,
.product-card-new:hover .product-title-overlay::before{
  transform:scale(1.05);
}


.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:0.7rem 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);
  line-height:1.35;
}


/* 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: full art background + center hero === */
.custom-order-banner{
  margin: 2.2rem 0;
  position: relative;
  border-radius: 14px;
  padding:1.8rem 1.6rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.6rem;
  flex-wrap: wrap;
  overflow: visible; /* даём герою вылезать за рамки */
}
/* Светящийся крутящийся бордер */
.custom-order-banner::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  padding:3px;
  background: conic-gradient(
    from var(--a),
    rgba(119,9,255,0)    0deg,
    rgba(119,9,255,.85) 36deg,
    rgba(119,9,255,0)   72deg,
    rgba(119,9,255,.55) 180deg,
    rgba(119,9,255,0)   198deg,
    rgba(119,9,255,.75) 342deg,
    rgba(119,9,255,0)   360deg
  );
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  animation: rouletteBorderSpin 12s linear infinite;
  opacity:.45;
  z-index:1; /* выше фона, ниже контента */
}

@media (prefers-reduced-motion: reduce){
  .custom-order-banner::before{ animation:none; }
}

/* Фон-арт на весь баннер */
.custom-order-banner__bg{
  position:absolute;
  inset:0;
  border-radius:inherit;
  overflow:hidden;
  z-index:0;
}
.custom-order-banner__bg-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* лёгкий тёмный градиент, чтобы текст читался */
.custom-order-banner__bg::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at left, rgba(0, 0, 0, 0.35) 0, transparent 55%),
              radial-gradient(circle at right, rgba(0, 0, 0, 0.4) 0, transparent 55%),
              linear-gradient(to bottom, rgba(0,0,0,.25), rgba(0,0,0,.65));
  pointer-events:none;
}

/* Герой по центру, аккуратно вылезает за низ */
.custom-order-banner__hero{
  position:absolute;
  left:50%;
  bottom:0%; /* меньше вылезает вниз на десктопе */
  transform: translateX(-50%);
  width: clamp(130px, 14vw, 190px); /* в целом поменьше */
  display:flex;
  align-items:flex-end;
  justify-content:center;
  pointer-events:none;
  z-index:2;
}

.custom-order-banner__hero-img{
  width:100%;
  height:auto;
  display:block;
}


/* Контент — текст + кнопка поверх картинки */
.custom-order-banner__content{
  position: relative;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.6rem;
  width:100%;
}
.custom-order-banner__text{
  max-width: min(420px, 55%);
}
.custom-order-banner__title{
  font-size:1.3rem;
  font-weight:800;
  margin-bottom:.3rem;
  color:#fff;
}
.custom-order-banner__subtitle{
  font-size:1rem;
  color:var(--nt-text-dim);
}
.custom-order-banner__subtitle span{
  color:#fff;
  font-weight:600;
}

/* Кнопка чата в стиле page-banner-chip */
.custom-order-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.65rem 1.25rem;
  border-radius:8px;
  border:2px solid #ffffffa8;
  background:rgba(255, 255, 255, 0.123);
  box-shadow:0 2px 12px rgba(0,0,0,.22);
  color:#fff;
  font-weight:800;
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.03em;
  text-decoration:none;
  cursor:pointer;
  gap:.45rem;
  margin-left:auto;      /* справа на десктопе */
  white-space:nowrap;
  transition:
    background .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    transform .12s ease;
}

.custom-order-btn:hover{
  background:linear-gradient(90deg, rgba(108, 52, 177, 0.28), rgba(119,9,255,.08));
  border-color:rgba(255,255,255,.16);
  box-shadow:0 4px 16px rgba(0,0,0,.35);
}

/* Адаптивы */
@media (max-width: 1024px){
  .custom-order-banner{
    padding: 1.4rem 1.2rem 3rem;  /* чуть меньше паддинг снизу */
    margin: 2rem 0;
  }
  .custom-order-banner__content{
    flex-direction:column;
    align-items:flex-start;
    gap: 1.1rem;
  }
  .custom-order-banner__text{
    max-width: 100%;
  }
  .custom-order-btn{
    margin-left:0;              /* кнопка под текстом слева */
    align-self:flex-start;
  }
  .custom-order-banner__hero{
    bottom:0%;                /* герой ближе к баннеру */
    width: clamp(160px, 34vw, 220px);
  }
}

@media (max-width: 900px){
  .custom-order-banner{
    padding: 1.4rem 1.2rem 3rem;  /* чуть меньше паддинг снизу */
    margin: 2rem 0;
  }
  .custom-order-banner__content{
    flex-direction:column;
    align-items:flex-start;
    gap: 1.1rem;
  }
  .custom-order-banner__text{
    max-width: 100%;
  }
  .custom-order-btn{
    margin-left:0;              /* кнопка под текстом слева */
    align-self:flex-start;
  }
  .custom-order-banner__hero{
    bottom:0%;                /* герой ближе к баннеру */
    width: clamp(160px, 34vw, 220px);
  }
}

@media (max-width: 600px){
  .custom-order-banner{
    padding: 1.2rem 1.1rem 2.6rem;  /* ещё меньше паддинг снизу */
    margin: 1.8rem 0;
  }
  .custom-order-banner__title{
    font-size:1.15rem;
  }
  .custom-order-banner__hero{
    bottom:0%;                 /* почти не вылезает — всё видно */
    width: clamp(150px, 48vw, 200px);
  }
}


/* 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}

/* B) Price‑from overlay z‑index */
.product-price-from-overlay{z-index:3;} /* поверх масштабируемого img */

/* 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 0px;
  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 / root страницы игры) */
.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;
  display:flex; align-items:center; gap:.55rem;
  margin: 0rem 0rem 1rem;
  padding: .7rem .65rem;  
}


    /* 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;
}

/* Типографика (компактнее, чем в основном описании) */
.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-title{
  font-size: 1.05rem;
  font-weight: 800;
  color:#fff;
  line-height:1.25;
}


/* short description = до ~3 строк, дальше обрезаем */
.product-card-new .product-desc .card-short-description{
  margin:.25rem 0 0;
  padding:0;
  max-height:calc(1.35em * 3);   /* высота под 3 строки */
}

/* аккуратные буллеты */
.product-card-new .product-desc .card-short-description ul{
  margin:0;
  padding:0;
  list-style:none;
}
.product-card-new .product-desc .card-short-description li{
  position:relative;
  padding-left:1.05rem;
  margin:.1rem 0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.product-card-new .product-desc .card-short-description li::before{
  content:'';
  position:absolute;
  left:0;
  top:.55em;
  width:4px;
  height:4px;
  border-radius:50%;
  background:var(--nt-primary); /* можешь заменить на брендовый */
}

a.product-card-new{
  text-decoration:none;
  color:inherit;
}
a.product-card-new:visited{
  color:inherit;
}

/* как и было */
.product-card-new .product-img-box{ aspect-ratio: 3 / 2; }

.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); }
}

/* === 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;
}

/* 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;
}

/* Баннер без картинки — компактная «кнопка» */
.page-banner-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.65rem 1rem;
  border-radius:8px;
  border:1px solid var(--nt-border);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.02em;
  text-decoration:none;
  box-shadow:0 2px 12px rgba(0,0,0,.22);
  width:fit-content;
  align-self:start;          /* не растягиваемся на всю колонку */
}
.page-banner-chip:hover{
  background:linear-gradient(90deg, rgba(119,9,255,.28), rgba(119,9,255,.08));
  border-color:rgba(255,255,255,.12);
}

/* === Raid mini widget on product cards ==================================== */
.raid-row{
  display:flex; align-items:center; gap:.4rem; flex-wrap:nowrap;
  font-weight:700; letter-spacing:.02em;
}
.raid-label{
  font-size:.78rem; text-transform:uppercase; color:#bfc3d9;
}
.raid-countdown{
  font-variant-numeric: tabular-nums;
  font-size:.86rem;
  padding:.08rem .42rem; border-radius:6px;
  box-shadow: 0 0 0 3px rgba(111, 53, 255, .18);
  border:1px solid #6f35ff;;
}
.raid-chips{
  display:flex; gap:.4rem; margin-top:.35rem; flex-wrap:wrap;
}
.raid-chip{
  font-size:.73rem;
  padding:.22rem .4rem; border-radius:6px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
}
.raid-more{
  margin-top:.3rem; font-size:.78rem; color:var(--nt-text-dim);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

.guides-grid{
  display:grid; gap:1.6rem;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  margin-top: 1.6rem;
}
@media(min-width:2000px){ .guides-grid{ gap:2rem; } }

/* Карточка гайда (использует product-card-new базу) */
.product-card-new.guide-card{ cursor:pointer; }

/* Картинка гайда */
.product-img-box.guide-img-box img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Тело карточки */
.product-content.guide-body{
  display:flex;
  flex-direction:column;
  gap:10px;
}

/* Short description из редактора — без лишних паддингов */
.product-desc.guide-desc .ql-editor{
  padding:0;
  margin:0;
}

/* Метаданные (дата/время чтения/просмотры) */
.product-price-bottom.guide-meta{ margin-top:auto; } /* прижимает мету вниз */
.guide-meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px 14px;
  align-items:center;
  font-size:13px;
  opacity:.85;
}

.rt-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
}
.rt-pill img{
  width:14px;
  height:14px;
  opacity:.9;
}

/* Сообщение "Guides coming soon" */
.empty-msg{
  margin-top:14px;
  opacity:.85;
}

/* guide-desc uses SunEditor html — ensure same clamping as product-desc */
.guide-desc{ font-size:.95rem; color:var(--nt-text-dim); display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden }
.guide-desc .ql-editor{ padding:0; margin:0; color:var(--nt-text-dим); }