/* ================================================================
   BIBLIOTEKA OASIS — main.css v3
   Bronze: #CD7F32  Chamois: #F5DEB3
   Fonts: Cinzel, Playfair Display, EB Garamond
================================================================ */
:root {
  --bronze:        #B87333;
  --bronze-light:  #C98A4B;
  --bronze-dark:   #8F5520;
  --bronze-deeper: #241608;
  --chamois:       #F2D49A;
  --chamois-mid:   #E8C478;
  --chamois-dark:  #CBAA72;
  --ink:           #1E1208;
  --ink-mid:       #2C1C0C;
  --ink-light:     #5A3C1E;
  --ink-faint:     #8A6640;
  --cream:         #FBF5E6;
  --surface:       #F5EDD4;
  --gold:          #D4922A;
  --font-display:  'Cinzel', Georgia, serif;
  --font-heading:  'Playfair Display', Georgia, serif;
  --font-body:     'EB Garamond', Georgia, serif;
  --container:        1160px;
  --container-narrow: 780px;
  --radius:    4px;
  --radius-lg: 10px;
  --shadow-sm: 0 1px 4px rgba(26,18,8,.12);
  --shadow-md: 0 4px 20px rgba(26,18,8,.16);
  --shadow-lg: 0 12px 48px rgba(26,18,8,.22);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:18px}
body{font-family:var(--font-body);background:var(--cream);color:var(--ink);line-height:1.7;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:var(--bronze);text-decoration:none;transition:color .2s}
a:hover{color:var(--bronze-dark)}
.container{max-width:var(--container);margin-inline:auto;padding-inline:24px}
.container--narrow{max-width:var(--container-narrow);margin-inline:auto;padding-inline:24px}
.section-eyebrow{font-family:var(--font-display);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bronze-light);margin-bottom:6px}
.section-heading{font-family:var(--font-heading);font-size:clamp(1.4rem,2.5vw,1.9rem);font-weight:600;color:var(--ink);line-height:1.25;margin-bottom:32px}
.section-heading em{font-style:italic;color:var(--bronze)}
.sep{color:var(--bronze-light);margin-inline:6px}
.badge{display:inline-block;font-family:var(--font-display);font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;padding:3px 10px;border-radius:2px;background:var(--badge-color,var(--bronze));color:#fff;margin-bottom:10px}
.badge--sm{font-size:.5rem;padding:2px 8px}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;padding:11px 24px;border-radius:var(--radius);border:none;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;text-decoration:none}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--bronze);color:#fff;box-shadow:0 2px 10px rgba(205,127,50,.35)}
.btn--primary:hover{background:var(--bronze-dark);color:#fff}
.btn--ghost{background:transparent;color:var(--bronze);border:1px solid var(--bronze)}
.btn--ghost:hover{background:var(--bronze);color:#fff}
.btn--sm{font-size:.58rem;padding:7px 16px}
.btn--google{background:#fff;color:var(--ink);border:1px solid var(--chamois-dark);font-size:.62rem;width:100%;justify-content:center}
.btn--google:hover{background:var(--chamois);color:var(--ink)}

/* TOPBAR */
.topbar{position:sticky;top:0;z-index:100;background:var(--ink);border-bottom:1px solid var(--bronze-dark)}
.topbar__inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:52px;padding-inline:24px}
.topbar__logo{display:flex;align-items:center;gap:10px;color:var(--chamois);font-family:var(--font-display);font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;justify-self:start}
.topbar__logo:hover{color:var(--bronze-light)}
.topbar__logo-icon{color:var(--bronze)}
.topbar__nav{display:flex;gap:28px;justify-self:center;align-items:center}
.topbar__link{font-family:var(--font-display);font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;color:var(--chamois-dark);padding:4px 0;border-bottom:1px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap}
.topbar__link:hover{color:var(--bronze-light);border-color:var(--bronze)}
.topbar__auth{display:flex;align-items:center;gap:10px;justify-self:end}
.topbar__user{display:flex;align-items:center;gap:10px}
.topbar__avatar{width:28px;height:28px;border-radius:50%;border:1px solid var(--bronze);object-fit:cover}
.topbar__avatar--placeholder{display:inline-flex;align-items:center;justify-content:center;background:var(--bronze);color:#fff;font-family:var(--font-display);font-size:.6rem}
.topbar__username{font-size:.78rem;color:var(--chamois)}
.topbar__logout{font-family:var(--font-display);font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.topbar__logout:hover{color:var(--bronze-light)}

/* FEATURED POST */
.featured-post{position:relative;min-height:560px;display:flex;align-items:flex-end;overflow:hidden;padding-inline:clamp(24px,calc((100vw - 1160px) / 2 + 24px),9999px)}
.featured-post__bg{position:absolute;inset:0;background:var(--bronze-deeper)}
.featured-post__cover{width:100%;height:100%;object-fit:cover;opacity:.5}
.featured-post__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,18,8,.95) 0%,rgba(26,18,8,.6) 40%,rgba(26,18,8,.15) 100%)}
.featured-post__body{position:relative;z-index:2;padding-block:56px 52px;max-width:760px}
.featured-post__meta-top{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.featured-post__label{font-family:var(--font-display);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bronze-light)}
.featured-post__title{font-family:var(--font-heading);font-size:clamp(1.7rem,3.8vw,2.8rem);font-weight:600;line-height:1.22;color:var(--chamois);margin-bottom:14px;max-width:760px}
.featured-post__excerpt{font-size:1rem;color:var(--chamois-mid);max-width:540px;line-height:1.65;font-style:italic;margin-bottom:18px}
.featured-post__meta{display:flex;align-items:center;font-family:var(--font-display);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:26px}
.featured-post__actions{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.featured-post__quick-links{display:flex;gap:12px}
.quick-link{font-family:var(--font-display);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--chamois-dark);padding:7px 14px;border:1px solid rgba(245,222,179,.2);border-radius:var(--radius);transition:border-color .2s,color .2s}
.quick-link:hover{color:var(--bronze-light);border-color:var(--bronze)}

/* AD SLOT */
.ad-block{margin-block:28px}
.ad-block--placeholder{display:flex;align-items:center;justify-content:center;height:90px;border:1px dashed var(--chamois-dark);border-radius:var(--radius-lg);background:var(--surface)}
.ad-block__label{font-family:var(--font-display);font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:var(--chamois-dark)}

/* CATEGORY NAVIGATOR */
.category-nav{padding-block:60px;background:var(--surface);border-top:1px solid var(--chamois-dark);border-bottom:1px solid var(--chamois-dark)}
.category-nav__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.category-card{background:var(--cream);border:1px solid var(--chamois-dark);border-radius:var(--radius-lg);padding:28px 24px;display:flex;flex-direction:column;gap:14px;transition:box-shadow .25s,transform .25s,border-color .25s;color:inherit}
.category-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--bronze);color:inherit}
.category-card--premium{background:linear-gradient(135deg,var(--cream) 0%,#fdf3e0 100%);border-color:var(--gold)}
.category-card__icon-wrap{width:52px;height:52px;border-radius:50%;background:var(--surface);border:1px solid var(--chamois-dark);display:flex;align-items:center;justify-content:center}
.category-card--premium .category-card__icon-wrap{background:linear-gradient(135deg,var(--bronze-dark),var(--bronze));border-color:var(--gold)}
.category-card__icon{font-size:1.3rem;line-height:1}
.category-card__title{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--ink);line-height:1.3}
.category-card__desc{font-size:.85rem;color:var(--ink-light);line-height:1.6}
.category-card__access,.category-card__price{display:flex;align-items:center;gap:6px;font-family:var(--font-display);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.category-card__price{color:var(--bronze)}
.access-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.access-dot--locked{background:var(--ink-faint)}
.access-dot--premium{background:var(--gold)}
.category-card__cta{font-family:var(--font-display);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bronze);margin-top:auto}

/* POST FEED */
.post-feed{padding-block:60px}
.post-feed__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:36px}
.post-feed__footer{text-align:center}
.post-feed__empty{grid-column:1/-1;text-align:center;color:var(--ink-faint);font-style:italic;padding:48px}
.post-card{background:var(--cream);border:1px solid var(--chamois-dark);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s}
.post-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.post-card__thumb-link{display:block;overflow:hidden;flex-shrink:0}
.post-card__thumb{width:100%;height:190px;object-fit:cover;transition:transform .4s ease}
.post-card:hover .post-card__thumb{transform:scale(1.04)}
.post-card__thumb--placeholder{height:190px;background:var(--surface);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:2rem;color:var(--chamois-dark)}
.post-card__body{padding:22px;flex:1;display:flex;flex-direction:column}
.post-card__title{font-family:var(--font-heading);font-size:1.05rem;font-weight:600;line-height:1.35;color:var(--ink);margin-bottom:8px}
.post-card__title a{color:inherit}
.post-card__title a:hover{color:var(--bronze-dark)}
.post-card__excerpt{font-size:.85rem;color:var(--ink-light);line-height:1.6;flex:1;margin-bottom:14px}
.post-card__meta{display:flex;gap:12px;font-family:var(--font-display);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);border-top:1px solid var(--chamois-dark);padding-top:10px;margin-top:auto}

/* ARCHIVE */
.archive{padding-block:56px}
.archive__title{font-family:var(--font-heading);font-size:clamp(1.4rem,3vw,2rem);color:var(--ink);margin-bottom:24px}
.archive__filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.filter-tag{font-family:var(--font-display);font-size:.57rem;letter-spacing:.11em;text-transform:uppercase;padding:5px 14px;border:1px solid var(--chamois-dark);border-radius:2px;color:var(--ink-light);transition:all .2s}
.filter-tag:hover,.filter-tag--active{background:var(--bronze);border-color:var(--bronze);color:#fff}
.pagination{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:48px;padding-top:28px;border-top:1px solid var(--chamois-dark)}
.pagination__btn{font-family:var(--font-display);font-size:.6rem;letter-spacing:.11em;text-transform:uppercase;color:var(--bronze);padding:8px 18px;border:1px solid var(--bronze);border-radius:var(--radius);transition:all .2s}
.pagination__btn:hover{background:var(--bronze);color:#fff}
.pagination__info{font-family:var(--font-display);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}

/* ARTICLE */
.article{padding-bottom:80px;background:var(--cream)}
.article__header{background:var(--surface);padding-top:52px;position:relative;overflow:hidden}
.article__header--has-cover{
  background:var(--ink) var(--cover-url) center/cover no-repeat;
  padding-top:0;min-height:560px;
  display:flex;align-items:flex-end;
}
.article__cover-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    to bottom,
    rgba(20,12,4,0.15) 0%,
    rgba(20,12,4,0.5)  50%,
    rgba(20,12,4,0.85) 100%
  );
  z-index:1;
}
.article__header--has-cover .article__header-inner{
  position:relative;z-index:2;
  padding:48px 40px 40px;
  max-width:var(--container);margin-inline:auto;width:100%;
}
.article__header--has-cover .article__title{color:#fff}
.article__header--has-cover .article__excerpt{color:rgba(255,255,255,0.85)}
.article__header-inner{
  max-width:var(--container);margin-inline:auto;
  padding:48px 40px 36px;
}
.article__colophon{
  max-width:var(--container);margin-inline:auto;
  padding:24px 40px 48px;
  font-family:var(--font-display);font-size:.56rem;
  letter-spacing:.11em;text-transform:uppercase;
  color:var(--ink-faint);
  border-top:1px solid var(--chamois-dark);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.article__header .container--narrow{padding-bottom:36px;max-width:var(--container);margin-inline:auto;padding-inline:40px}
.article__title{font-family:var(--font-heading);font-size:clamp(1.5rem,3.5vw,2.4rem);font-weight:600;line-height:1.25;color:var(--ink);margin-bottom:16px}
.article__excerpt{font-size:1.05rem;color:var(--ink-light);line-height:1.65;font-style:italic;margin-bottom:18px}
.article__meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-family:var(--font-display);font-size:.56rem;letter-spacing:.11em;text-transform:uppercase;color:var(--ink-light)}
.article__sep{color:var(--bronze-light)}
.article__cover-wrap{max-height:460px;overflow:hidden}
.article__cover{width:100%;height:100%;object-fit:cover}

/* ARTICLE BODY */
.article__body{
  padding-top:40px;
  padding-bottom:20px;
  font-size:1.05rem;
  line-height:1.7;
  color:var(--ink-mid);
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:40px;
}
.article__body p,
.article__body .ds-markdown-paragraph{
  margin-top:0;
  margin-bottom:1rem;
  line-height:1.7;
}

/* Изображения — float для обтекания текстом */
.article__body img{
  max-width:100%;height:auto;
  border-radius:var(--radius-lg);
  margin:1.2rem 0;display:block;
}
.article__body img.alignleft{
  float:left;margin:0 28px 16px 0;
  max-width:46%;border-radius:var(--radius-lg);
}
.article__body img.alignright{
  float:right;margin:0 0 16px 28px;
  max-width:46%;border-radius:var(--radius-lg);
}
.article__body::after{content:"";display:table;clear:both}

/* Колонки */
.article__body .columns{
  display:grid;grid-template-columns:1fr 1fr;
  gap:32px;margin-block:1.5rem;
}

.article__body h2{
  font-family:var(--font-heading);font-size:1.4rem;
  font-weight:600;color:var(--ink);
  margin-block:2.2rem .8rem;clear:both;
}
.article__body h3{
  font-family:var(--font-heading);font-size:1.15rem;
  font-weight:600;color:var(--ink);
  margin-block:1.8rem .6rem;
}
.article__body h4{
  font-family:var(--font-display);font-size:.75rem;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--bronze);margin-block:1.5rem .5rem;
}
.article__body blockquote{
  border-left:3px solid var(--bronze);
  padding:8px 22px;margin-inline:0;
  font-style:italic;color:var(--ink-light);
  margin-block:1.8rem;
  background:var(--surface);
  border-radius:0 var(--radius) var(--radius) 0;
}
.article__body ul,.article__body ol{
  padding-left:1.4rem;margin-bottom:1rem;
}
.article__body li{margin-bottom:.4rem;line-height:1.65;}
.article__body ul li::marker{color:var(--bronze);}
.article__body a{border-bottom:1px solid var(--chamois-dark)}
.article__body a:hover{color:var(--bronze-dark);border-color:var(--bronze-dark)}
.article__body strong{font-weight:600;color:var(--ink)}
.article__body hr{
  border:none;border-top:1px solid var(--chamois-dark);
  margin-block:2rem;clear:both;
}

.article__nav{
  margin-top:56px;padding-top:28px;
  border-top:1px solid var(--chamois-dark);
  max-width:var(--container);
  margin-inline:auto;padding-inline:40px;
}
.article__nav-inner{display:flex;justify-content:space-between;gap:16px}
.article__nav-item{flex:1;display:flex;flex-direction:column;gap:5px;padding:18px;border:1px solid var(--chamois-dark);border-radius:var(--radius-lg);transition:border-color .2s,box-shadow .2s}
.article__nav-item:hover{border-color:var(--bronze);box-shadow:var(--shadow-sm)}
.article__nav-item--next{text-align:right}
.article__nav-label{font-family:var(--font-display);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bronze)}
.article__nav-title{font-family:var(--font-heading);font-size:.9rem;color:var(--ink);line-height:1.35}

/* LOGIN */
.login-page{min-height:calc(100vh - 52px);display:flex;align-items:center;justify-content:center;background:var(--surface);padding:40px 24px}
.login-card{background:var(--cream);border:1px solid var(--chamois-dark);border-radius:var(--radius-lg);padding:44px 36px;width:100%;max-width:380px;text-align:center;box-shadow:var(--shadow-lg)}
.login-card__icon{font-size:2rem;margin-bottom:14px}
.login-card__title{font-family:var(--font-heading);font-size:1.5rem;color:var(--ink);margin-bottom:6px}
.login-card__sub{font-size:.88rem;color:var(--ink-light);margin-bottom:28px}
.login-card__label{font-family:var(--font-display);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:8px}
.login-card__divider{position:relative;text-align:center;margin-block:18px}
.login-card__divider::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--chamois-dark)}
.login-card__divider span{position:relative;background:var(--cream);padding-inline:10px;font-family:var(--font-display);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}
.login-card__note{font-size:.72rem;color:var(--ink-faint);margin-top:20px;line-height:1.6}

/* READING PROGRESS */
.reading-progress{position:fixed;top:52px;left:0;width:100%;height:2px;background:var(--chamois-dark);z-index:99}
.reading-progress__bar{height:100%;width:0%;background:linear-gradient(90deg,var(--bronze),var(--gold));transition:width .1s linear}

/* BREADCRUMBS */
.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:18px;font-family:var(--font-display);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase}
.breadcrumb a{color:var(--ink-faint)}
.breadcrumb a:hover{color:var(--bronze-light)}
.breadcrumb span{color:var(--chamois-dark)}
.breadcrumb__sep{color:var(--bronze);opacity:.5}

/* MESSAGES */
.messages{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:10px;max-width:320px}
.message{padding:12px 16px;border-radius:var(--radius-lg);border-left:3px solid var(--bronze);background:var(--cream);box-shadow:var(--shadow-md);font-size:.82rem;color:var(--ink);animation:slideIn .3s ease}
.message--error{border-color:#a33}
.message--success{border-color:#3a7}
@keyframes slideIn{from{transform:translateX(16px);opacity:0}to{transform:none;opacity:1}}

/* FOOTER */
.footer{background:var(--ink);border-top:1px solid var(--bronze-dark);padding-block:36px}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer__logo{font-family:var(--font-display);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--chamois)}
.footer__tagline{font-size:.75rem;color:var(--ink-faint);margin-top:3px}
.footer__links{display:flex;gap:18px}
.footer__links a{font-family:var(--font-display);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.footer__links a:hover{color:var(--bronze-light)}

/* RESPONSIVE */
@media(max-width:860px){
  .topbar__nav{display:none}
  .topbar__inner{grid-template-columns:1fr auto}
  .featured-post{min-height:420px}
  .featured-post__quick-links{display:none}
  .category-nav__grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .post-feed__grid{grid-template-columns:1fr}
  .article__body{padding-inline:16px}
}
@media(max-width:540px){
  html{font-size:16px}
  .article__nav-inner{flex-direction:column}
  .login-card{padding:28px 20px}
  .featured-post__body{padding-block:36px}
}
@media print{
  .topbar,.footer,.ad-block,.article__nav,.reading-progress{display:none !important}
  .article__body{font-size:12pt;line-height:1.6}
}
/* ================================================================
   ДОБАВИТЬ В КОНЕЦ static/css/main.css
   Блок: Share buttons + Comments
================================================================ */

/* ── SHARE BLOCK ─────────────────────────────────────────── */
.post-share {
  max-width: var(--container);
  margin-inline: auto;
  padding: 28px 40px;
  border-top: 1px solid var(--chamois-dark);
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.post-share__label {
  font-family: var(--font-display);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  white-space: nowrap;
}
.post-share__buttons {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.share-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-display);
  font-size: .55rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 8px 14px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: transform .15s, box-shadow .2s, opacity .2s;
  white-space: nowrap;
}
.share-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
  opacity: .9;
  color: #fff;
}
.share-btn svg { flex-shrink: 0; }

.share-btn--vk  { background: #0077FF; color: #fff; }
.share-btn--tg  { background: #229ED9; color: #fff; }
.share-btn--x   { background: #000;    color: #fff; }
.share-btn--fb  { background: #1877F2; color: #fff; }
.share-btn--copy {
  background: transparent;
  color: var(--bronze);
  border-color: var(--bronze);
}
.share-btn--copy:hover {
  background: var(--bronze);
  color: #fff;
}

@media (max-width: 640px) {
  .post-share { padding-inline: 16px; }
  .share-btn span { display: none; }
  .share-btn { padding: 9px 10px; }
}

/* ── COMMENTS ────────────────────────────────────────────── */
.comments {
  background: var(--surface);
  border-top: 1px solid var(--chamois-dark);
  padding-bottom: 60px;
}
.comments__inner {
  max-width: var(--container);
  margin-inline: auto;
  padding: 48px 40px 0;
}
.comments__title {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 32px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.comments__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--bronze);
  color: #fff;
  font-family: var(--font-display);
  font-size: .55rem;
  letter-spacing: .06em;
  min-width: 22px;
  height: 22px;
  border-radius: 11px;
  padding-inline: 6px;
}
.comments__empty {
  font-style: italic;
  color: var(--ink-faint);
  margin-bottom: 32px;
}
.comments__list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 40px;
  border: 1px solid var(--chamois-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* Single comment */
.comment {
  display: flex;
  gap: 16px;
  padding: 20px 24px;
  background: var(--cream);
  border-bottom: 1px solid var(--chamois-dark);
}
.comment:last-child { border-bottom: none; }
.comment:nth-child(even) { background: var(--surface); }

.comment__avatar {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
}
.comment__avatar img {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--chamois-dark);
  object-fit: cover;
}
.comment__avatar-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--bronze);
  color: #fff;
  font-family: var(--font-display);
  font-size: .7rem;
  font-weight: 600;
  border: 1px solid var(--bronze-dark);
}
.comment__body { flex: 1; min-width: 0; }
.comment__meta {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}
.comment__name {
  font-family: var(--font-display);
  font-size: .62rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink);
}
.comment__time {
  font-family: var(--font-display);
  font-size: .52rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.comment__text {
  font-size: .92rem;
  color: var(--ink-mid);
  line-height: 1.65;
  word-break: break-word;
  margin: 0;
}

/* Comment form */
.comment-form {
  background: var(--cream);
  border: 1px solid var(--chamois-dark);
  border-radius: var(--radius-lg);
  padding: 28px;
  margin-top: 8px;
}
.comment-form__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 16px;
}
.comment-form__author {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.comment-form__avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid var(--chamois-dark);
  object-fit: cover;
}
.comment-form__avatar--placeholder {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--bronze);
  color: #fff;
  font-family: var(--font-display);
  font-size: .6rem;
}
.comment-form__name {
  font-family: var(--font-display);
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-light);
}
.comment-form__textarea {
  width: 100%;
  min-height: 110px;
  padding: 12px 14px;
  font-family: var(--font-body);
  font-size: .95rem;
  line-height: 1.6;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--chamois-dark);
  border-radius: var(--radius);
  resize: vertical;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
}
.comment-form__textarea:focus {
  border-color: var(--bronze);
  box-shadow: 0 0 0 3px rgba(184,115,51,.12);
}
.comment-form__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  flex-wrap: wrap;
  gap: 8px;
}
.comment-form__hint {
  font-family: var(--font-display);
  font-size: .52rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* Not-logged-in prompt */
.comment-login {
  background: var(--cream);
  border: 1px solid var(--chamois-dark);
  border-radius: var(--radius-lg);
  padding: 28px;
  text-align: center;
  margin-top: 8px;
}
.comment-login__text {
  font-size: .9rem;
  color: var(--ink-light);
  margin-bottom: 16px;
  font-style: italic;
}

/* VK login button */
.btn--vk {
  background: #0077FF;
  color: #fff;
  border: 1px solid #0077FF;
  width: 100%;
  justify-content: center;
  font-size: .62rem;
}
.btn--vk:hover {
  background: #0060cc;
  color: #fff;
  border-color: #0060cc;
}

@media (max-width: 640px) {
  .comments__inner { padding-inline: 16px; }
  .comment { padding: 16px; gap: 12px; }
  .comment-form { padding: 20px 16px; }
}
/* ================================================================
   ДОБАВИТЬ В КОНЕЦ static/css/main.css
   Блок: Share buttons + Comments
================================================================ */

/* ── SHARE BLOCK ─────────────────────────────────────────── */
.post-share {
  max-width: var(--container);
  margin-inline: auto;
  padding: 28px 40px;
  border-top: 1px solid var(--chamois-dark);
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.post-share__label {
  font-family: var(--font-display);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  white-space: nowrap;
}
.post-share__buttons {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.share-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-display);
  font-size: .55rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 8px 14px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: transform .15s, box-shadow .2s, opacity .2s;
  white-space: nowrap;
}
.share-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
  opacity: .9;
  color: #fff;
}
.share-btn svg { flex-shrink: 0; }

.share-btn--vk  { background: #0077FF; color: #fff; }
.share-btn--tg  { background: #229ED9; color: #fff; }
.share-btn--x   { background: #000;    color: #fff; }
.share-btn--fb  { background: #1877F2; color: #fff; }
.share-btn--copy {
  background: transparent;
  color: var(--bronze);
  border-color: var(--bronze);
}
.share-btn--copy:hover {
  background: var(--bronze);
  color: #fff;
}

@media (max-width: 640px) {
  .post-share { padding-inline: 16px; }
  .share-btn span { display: none; }
  .share-btn { padding: 9px 10px; }
}

/* ── COMMENTS ────────────────────────────────────────────── */
.comments {
  background: var(--surface);
  border-top: 1px solid var(--chamois-dark);
  padding-bottom: 60px;
}
.comments__inner {
  max-width: var(--container);
  margin-inline: auto;
  padding: 48px 40px 0;
}
.comments__title {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 32px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.comments__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--bronze);
  color: #fff;
  font-family: var(--font-display);
  font-size: .55rem;
  letter-spacing: .06em;
  min-width: 22px;
  height: 22px;
  border-radius: 11px;
  padding-inline: 6px;
}
.comments__empty {
  font-style: italic;
  color: var(--ink-faint);
  margin-bottom: 32px;
}
.comments__list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 40px;
  border: 1px solid var(--chamois-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* Single comment */
.comment {
  display: flex;
  gap: 16px;
  padding: 20px 24px;
  background: var(--cream);
  border-bottom: 1px solid var(--chamois-dark);
}
.comment:last-child { border-bottom: none; }
.comment:nth-child(even) { background: var(--surface); }

.comment__avatar {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
}
.comment__avatar img {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--chamois-dark);
  object-fit: cover;
}
.comment__avatar-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--bronze);
  color: #fff;
  font-family: var(--font-display);
  font-size: .7rem;
  font-weight: 600;
  border: 1px solid var(--bronze-dark);
}
.comment__body { flex: 1; min-width: 0; }
.comment__meta {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}
.comment__name {
  font-family: var(--font-display);
  font-size: .62rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink);
}
.comment__time {
  font-family: var(--font-display);
  font-size: .52rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.comment__text {
  font-size: .92rem;
  color: var(--ink-mid);
  line-height: 1.65;
  word-break: break-word;
  margin: 0;
}

/* Comment form */
.comment-form {
  background: var(--cream);
  border: 1px solid var(--chamois-dark);
  border-radius: var(--radius-lg);
  padding: 28px;
  margin-top: 8px;
}
.comment-form__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 16px;
}
.comment-form__author {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.comment-form__avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid var(--chamois-dark);
  object-fit: cover;
}
.comment-form__avatar--placeholder {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--bronze);
  color: #fff;
  font-family: var(--font-display);
  font-size: .6rem;
}
.comment-form__name {
  font-family: var(--font-display);
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-light);
}
.comment-form__textarea {
  width: 100%;
  min-height: 110px;
  padding: 12px 14px;
  font-family: var(--font-body);
  font-size: .95rem;
  line-height: 1.6;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--chamois-dark);
  border-radius: var(--radius);
  resize: vertical;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
}
.comment-form__textarea:focus {
  border-color: var(--bronze);
  box-shadow: 0 0 0 3px rgba(184,115,51,.12);
}
.comment-form__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  flex-wrap: wrap;
  gap: 8px;
}
.comment-form__hint {
  font-family: var(--font-display);
  font-size: .52rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* Not-logged-in prompt */
.comment-login {
  background: var(--cream);
  border: 1px solid var(--chamois-dark);
  border-radius: var(--radius-lg);
  padding: 28px;
  text-align: center;
  margin-top: 8px;
}
.comment-login__text {
  font-size: .9rem;
  color: var(--ink-light);
  margin-bottom: 16px;
  font-style: italic;
}

/* VK login button */
.btn--vk {
  background: #0077FF;
  color: #fff;
  border: 1px solid #0077FF;
  width: 100%;
  justify-content: center;
  font-size: .62rem;
}
.btn--vk:hover {
  background: #0060cc;
  color: #fff;
  border-color: #0060cc;
}

@media (max-width: 640px) {
  .comments__inner { padding-inline: 16px; }
  .comment { padding: 16px; gap: 12px; }
  .comment-form { padding: 20px 16px; }
}

/* share-block fix */
.post-share {
  width: 100%;
  display: flex !important;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  padding: 28px 40px;
  border-top: 1px solid var(--chamois-dark);
}
