/* ==== 1. Base palette & reset ==== */
:root{
  --c-bg:#0d0d0d; --c-indigo:#4A46FF; --c-aqua:#00CFC8;
  --c-bg-dark:#0d0d0d; --transition:.35s cubic-bezier(.4,.2,.2,1);
  --radius:14px;   --ease:.35s cubic-bezier(.4,.2,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',sans-serif;background:var(--c-bg);color:#fff;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
/* === Universal elements === */
img{max-width:100%;display:block;border-radius:var(--radius);}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-weight:800;letter-spacing:-.02em;}
.tag{display:inline-block;padding:.25rem .7rem;font-size:.68rem;border-radius:999px;background:rgba(255,255,255,.15);margin-right:.4rem;margin-bottom:.3rem;}
/* === Buttons & CTA === */
.btn{display:inline-flex;align-items:center;gap:.6rem;background:linear-gradient(135deg,var(--c-indigo),var(--c-aqua));color:#fff;border:none;padding:.9rem 1.4rem;font-weight:600;border-radius:var(--radius);cursor:pointer;transition:var(--ease);}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(0,0,0,.45);}
.article-cta{text-align:center;margin-top:2rem;}
.equipment-cta{padding:2rem 0;text-align:center;}
.equipment-cta h2{margin-bottom:1rem;}
.equipment-btn{display:inline-block;background:linear-gradient(135deg,var(--c-indigo),var(--c-aqua));padding:.9rem 1.6rem;border-radius:var(--radius);font-weight:600;}
/* fluid typography body */
body{font-size:clamp(.95rem,1vw + .85rem,1.06rem);line-height:1.7;}
/* ==== 3. Progress bar ==== */
#progress{position:fixed;top:0;left:0;height:4px;background:var(--c-indigo);width:0;z-index:260;}
/* ==== 4. Cover hero ==== */
.cover{position:relative;height:48vh;min-height:260px;overflow:hidden;}
.cover img{width:100%;height:100%;object-fit:cover;}
.cover-inner{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.0) 20%,rgba(0,0,0,.7) 90%);display:flex;align-items:flex-end;padding:1.4rem;}
.meta{font-size:.78rem;color:#cfcfcf;margin-bottom:.3rem;}
/* ==== 5. Breadcrumbs ==== */
.breadcrumbs{font-size:.78rem;color:#999;padding:1rem 0;}
.breadcrumbs span{opacity:.35;margin:0 .35rem;}
/* ==== 6. Article ==== */
main{padding:0 0 4rem;display:flex;justify-content:center;}
.article{max-width:clamp(90vw, 840px, 60ch);}
.article h1{font-size:clamp(1.8rem,5vw,2.4rem);}
.article h2{margin:clamp(1.6rem,5vw,2.1rem) 0 .9rem;font-size:clamp(1.3rem,4.5vw,1.6rem);}
.article h3{margin:clamp(1.3rem,4vw,1.6rem) 0 .7rem;font-size:clamp(1.1rem,4vw,1.35rem);}
.article p{margin-bottom:1.1rem;color:#e4e4e4;}
.article img{margin:1.3rem 0;max-height:420px;object-fit:cover;}
blockquote{margin:1.3rem 0;padding:1rem 1.2rem;border-left:4px solid var(--c-aqua);background:rgba(255,255,255,.07);font-style:italic;color:#ddd;}
pre{background:#1a1a1a;padding:1rem;border-radius:var(--radius);overflow:auto;font-size:.85rem;margin:1.3rem 0;}
/* ==== 8. Post navigation ==== */
.post-nav{display:grid;gap:1.4rem;margin-top:2.5rem;}
.post-card{background:rgba(255,255,255,.05);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;}
.post-card img{aspect-ratio:4/3;object-fit:cover;}
.post-card div{padding:.9rem;font-size:.9rem;line-height:1.4;}
/* two columns on ≥768 */
@media(min-width:768px){.post-nav{grid-template-columns:repeat(2,1fr);}}
/* ==== 10. Footer ==== */
/* ==== HOT‑FIX 2025‑06‑17 — mobile readability & overflow ==== */

/* 1. Контейнер статьи: убираем горизонтальный скролл */
.article{
  padding:0 2px;                 /* едва заметный buffer, чтобы ничего не “упиралось” */
  overflow-wrap:break-word;      /* длинные слова/ссылки переносятся */
}

/* 2. Абзацы, списки, цитаты: больше “воздуха” */
.article p,
.article ul,
.article ol,
.article blockquote,
.article pre{
  margin-bottom:1.4rem;          /* вместо 1.1rem */
}

/* 3. Списки: внутренние отступы */
.article ul,
.article ol{
  padding-left:1.1rem;
}

/* 4. Изображения: 100 % ширины, но не выше 360 px на мобилке */
@media(max-width:600px){
  .article img{
    width:100%;
    max-height:360px;
  }
}

/* 5. Код‑блоки: разрешаем перенос и вертикальный скролл */
.article pre{
  white-space:pre-wrap;          /* перенос строк */
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}

/* 6. Навигационные карточки “След / Пред” */
.post-card div{
  word-break:break-word;         /* много‑словные заголовки не вылезут */
  padding:1.1rem;
}
.post-card img{                  /* на узких экранах делаем 3:2, чтобы не уходило вниз слишком много */
  aspect-ratio:3/2;
}

/* 7. Общий контейнер nav (grid) — маленький gap */
@media(max-width:600px){
  .post-nav{gap:1rem;}
}

/* === Case gallery like equipment block === */
.equip-grid{gap:1.2rem;}
.equip-grid article{background:rgba(255,255,255,.04);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;}
.equip-grid img{height:200px;object-fit:cover;}
.equip-text{padding:1rem;font-size:.9rem;color:#c0c0c0;}

.snap-strip{
  display:flex;
  gap:1rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:.8rem;
  -ms-overflow-style:none;
  scrollbar-width:none;
}
.snap-strip::-webkit-scrollbar{display:none;}
.snap-strip > *{flex:0 0 80%;scroll-snap-align:center;}
.snap-strip::after{
  content:'';
  position:sticky;
  right:-1px;top:0;bottom:0;width:24px;
  pointer-events:none;
  background:linear-gradient(to right,transparent 0%,var(--c-bg-dark) 100%);
}

.card-glass{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(12px);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .35s cubic-bezier(.4,.2,.2,1);
}
@media(hover:hover){.card-glass:hover{transform:translateY(-4px) scale(1.03);}}
.card-glass img{height:200px;width:100%;object-fit:cover;}

@media(min-width:768px){
  .snap-strip{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    overflow:visible;
  }
  .snap-strip::after{display:none;}
  .snap-strip > *{flex:initial;scroll-snap-align:unset;}
}

