:root{
  /* ===== night coffee palette (darker, still pastel) ===== */
  --bg: #1c1714;           /* тёмный кофе/дерево */
  --bg2: #141110;          /* почти эспрессо */
  --fg: #efe2d3;           /* тёплый кремовый текст */
  --muted: rgba(104, 84, 61, 0.78);
  --muted2: rgba(239,226,211,.56);

  --card: rgba(39,31,26,.74);    /* тёплая тёмная карточка */
  --card2: rgba(46,36,30,.86);   /* чуть плотнее */
  --border: rgba(239,226,211,.12);
  --border2: rgba(239,226,211,.20);

  --accent: #d09a5a;       /* лампы/янтарь */
  --accent2: #8b5a3c;      /* корица/карамель */
  --danger: #d06a5e;

  --shadow: 0 22px 70px rgba(0,0,0,.55);
  --shadow2: 0 12px 28px rgba(0,0,0,.40);

  --radius: 22px;
  --radius2: 18px;

  --font: "Nunito", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --serif: "Fraunces", ui-serif, Georgia, "Times New Roman", serif;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }

html{
  background: var(--bg);
}

body{
  margin: 0;
  color: var(--fg);
  font-family: var(--font);
  letter-spacing: 0;
  overflow-x: hidden;
  background: transparent;
  position: relative;
}

/* ===== “вечерняя кофейня” фон, фиксированный ===== */
body::before{
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -3;

  background:
    /* тёплые “окна/лампы” */
    radial-gradient(800px 520px at 22% 10%, rgba(208,154,90,.28), transparent 62%),
    radial-gradient(650px 460px at 78% 22%, rgba(208,154,90,.20), transparent 64%),
    radial-gradient(720px 560px at 55% 85%, rgba(139,90,60,.16), transparent 70%),

    /* холодная ночь слегка */
    radial-gradient(1200px 900px at 50% -10%, rgba(60,80,110,.12), transparent 60%),

    /* база */
    linear-gradient(180deg, var(--bg), var(--bg2));
}


/* мягкое зерно (не “киберпанк”, а “плёнка”) */
.bg-noise{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E");
  opacity: .22;
  mix-blend-mode: multiply;
}

/* вместо “grid” — еле заметные “волокна бумаги” */
.bg-grid{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background-image:
    linear-gradient(to right, rgba(125,86,54,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(125,86,54,.06) 1px, transparent 1px);
  background-size: 140px 140px;
  opacity: .20;
  mask-image: radial-gradient(700px 700px at 50% 18%, rgba(0,0,0,.85), transparent 72%);
}

::selection{
  background: rgba(176,122,70,.28);
}

.wrap{
  width: min(1100px, calc(100% - 40px));
  margin: 0 auto;
}

a{ color: inherit; text-decoration: none; }
a:hover{ text-decoration: underline; text-underline-offset: 3px; }

/* ===== topbar ===== */
.topbar{
  position: sticky;
  top: 0;
  z-index: 50;

  background: rgba(255,248,238,.72);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow2);
}
.topbar{
  background: rgba(32,26,22,.72);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow2);
}
.topbar__inner{
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 14px;
  padding: 14px 0;
}
.brand{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  letter-spacing: .01em;
}
.brand__dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, rgba(255,220,170,1), rgba(176,122,70,1));
  box-shadow: 0 0 0 6px rgba(176,122,70,.10);
}
.brand__text{
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: -.01em;
}
.brand__muted{
  color: var(--muted2);
  font-weight: 600;
}

.topbar__actions{
  display: inline-flex;
  gap: 10px;
  justify-content: flex-end;
}

/* ===== buttons ===== */
.btn{
  border: 1px solid var(--border);
  background: rgba(255,248,238,.78);
  color: var(--fg);
  border-radius: 999px;
  padding: 10px 14px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
  transition: transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
  box-shadow: 0 10px 18px rgba(40,24,12,.08);
}
.btn:hover{
  transform: translateY(-1px);
  background: rgba(255,248,238,.92);
  border-color: rgba(176,122,70,.34);
  box-shadow: 0 14px 24px rgba(40,24,12,.12);
}
.btn:active{ transform: translateY(0); }
.btn__icon{ opacity: .85; }
.btn__text{ opacity: .92; font-weight: 700; }

.btn--primary{
  background: linear-gradient(180deg, rgba(255,220,170,.60), rgba(176,122,70,.22));
  border-color: rgba(176,122,70,.34);
}
.btn--ghost{
  background: rgba(255,248,238,.62);
}

/* ===== hero ===== */
.hero{
  padding: 34px 0 18px;
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items: start;
}
.hero__title{
  margin: 0;
  font-family: var(--serif);
  font-size: 44px;
  line-height: 1.02;
  letter-spacing: -.03em;
}
.hero__subtitle{
  display: block;
  margin-top: 12px;
  font-size: 15px;
  color: rgba(151, 129, 104, 0.78);
  font-weight: 600;
  letter-spacing: .04em;
}
.hero__desc{
  margin: 14px 0 0;
  color: var(--muted);
  line-height: 1.75;
}
.hero__hint{
  color: rgba(122,75,43,.92);
  font-weight: 700;
}

/* ===== search ===== */
.hero__controls{
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
}
.search{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 999px;
  background: rgba(255,248,238,.78);
  border: 1px solid var(--border);
  box-shadow: 0 12px 22px rgba(40,24,12,.08);
}
.search__icon{ color: var(--muted2); }
.search__input{
  width: 100%;
  background: transparent;
  border: 0;
  outline: none;
  color: var(--fg);
  font-family: var(--font);
  font-size: 15px;
}
.search__input::placeholder{
  color: rgba(43,33,26,.45);
}
.search__clear{
  border: 0;
  background: transparent;
  color: var(--muted2);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 4px 8px;
  border-radius: 999px;
}
.search__clear:hover{
  background: rgba(176,122,70,.10);
  color: var(--fg);
}

/* ===== tag bar ===== */
.tagbar{
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tag{
  border: 1px solid var(--border);
  background: rgba(255,248,238,.72);
  color: var(--muted);
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 13px;
  cursor: pointer;
  transition: transform .12s ease, border-color .12s ease, background .12s ease, box-shadow .12s ease;
  box-shadow: 0 10px 18px rgba(40,24,12,.07);
}
.tag:hover{
  transform: translateY(-1px);
  border-color: rgba(176,122,70,.35);
  background: rgba(255,248,238,.92);
}
.tag.is-active{
  color: var(--fg);
  border-color: rgba(176,122,70,.45);
  background: linear-gradient(180deg, rgba(255,220,170,.52), rgba(255,248,238,.88));
}

/* ===== stream ===== */
.stream{ padding: 8px 0 44px; }
.stream__head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
  padding: 14px 0;
}
.stream__title{
  margin: 0;
  font-size: 14px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(145, 121, 103, 0.55);
  font-weight: 800;
}
.stream__right{
  display: inline-flex;
  gap: 10px;
}

/* ===== posts ===== */
.posts{
  display: grid;
  gap: 14px;
}

.post{
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: linear-gradient(180deg, var(--card2), var(--card));
  box-shadow: var(--shadow);
  overflow: hidden;
}
.post.is-hidden{ display: none; }

.post__header{
  padding: 3px 10px;
  padding-bottom: 9px;
  border-bottom: 1px solid rgba(125,86,54,.14);
  background: #251c18;
}
.post__title{
  margin: 0;
  font-family: var(--serif);
  font-size: 30px;
  line-height: 1.18;
  letter-spacing: -.02em;
}
.post__meta{
  margin: 8px 0 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  color: rgba(43,33,26,.55);
  font-size: 12px;
  font-weight: 700;
}

.post__num,
.post__date{
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(125,86,54,.16);
  background: rgba(195, 184, 167, 0.78);
  color: rgba(43,33,26,.68);
}
.post__num{ margin-left: auto; }

.post__tags{
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* badges are buttons from JS */
.badge{
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(176,122,70,.25);
  background: rgba(255,220,170,.30);
  color: rgba(43,33,26,.82);
  font-weight: 800;
  cursor: pointer;
}
.badge:hover{
  background: rgba(255,220,170,.45);
  border-color: rgba(176,122,70,.38);
}
.badge--ghost{
  border-color: rgba(125,86,54,.16);
  background: rgba(255,248,238,.60);
  color: rgba(43,33,26,.55);
}

.post__content{
  padding: 14px 16px 16px;
  display: grid;
  gap: 12px;
}

.post__p{
  margin: 0;
  color: rgb(216, 204, 195);
  line-height: 1.82;
  font-size: 15.5px;
}

/* media */
.post__media{
  margin: 0;
  border: 1px solid rgba(125,86,54,.16);
  border-radius: var(--radius2);
  overflow: hidden;
  background: #2D231D;
  box-shadow: 0 14px 26px rgba(40,24,12,.10);
}

.post__img{
  width: 30%;
  height: auto;
  display: block;
}

.post__video{
  width: 30%;
  display: block;
}

.post__audio{
  width: 100%;
  display: block;
  padding: 10px;
}

.post__caption{
  padding: 10px 12px;
  color: rgba(43,33,26,.62);
  border-top: 1px solid rgba(125,86,54,.14);
  background: rgba(255,248,238,.70);
  font-size: 12px;
}

.post__file{
  border: 1px solid rgba(125,86,54,.16);
  background: rgba(255,248,238,.72);
  border-radius: var(--radius2);
  padding: 12px;
}
.post__filelink{
  display: inline-flex;
  gap: 8px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(125,86,54,.18);
  background: rgba(255,248,238,.86);
  box-shadow: 0 10px 18px rgba(40,24,12,.08);
}
.post__filelink:hover{
  text-decoration: none;
  border-color: rgba(176,122,70,.34);
}

/* ===== collapsible content ===== */
.post__content.is-collapsed{
  display: none;
}

.post__toggleRow{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-top: 1px solid rgba(125,86,54,.14);
  background: #251c18;
}
.post__toggleSpacer{ flex: 1; }

.post__toggle{
  border: 1px solid rgba(125,86,54,.20);
  background: linear-gradient(180deg, rgba(255,220,170,.45), rgba(255,248,238,.80));
  color: rgba(43,33,26,.90);
  border-radius: 999px;
  padding: 9px 14px;
  cursor: pointer;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 800;
  box-shadow: 0 10px 18px rgba(40,24,12,.08);
}
.post__toggle:hover{
  border-color: rgba(176,122,70,.38);
  background: linear-gradient(180deg, rgba(255,220,170,.60), rgba(255,248,238,.90));
}

/* ===== footer ===== */
.footer{
  margin-top: 26px;
  padding: 14px 0 10px;
}
.footer__line{
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(125,86,54,.28), transparent);
  opacity: .9;
}
.footer__row{
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.tiny{ font-size: 12px; }
.tiny--muted{ color: rgba(43,33,26,.55); }
.tiny--link{
  cursor: pointer;
  border: 0;
  background: transparent;
  font-family: var(--font);
  font-weight: 800;
  color: rgba(122,75,43,.92);
}
.tiny--link:hover{ text-decoration: underline; }

/* ===== profanity censor ===== */
body.swear-censor-on .cuss{
  display: inline-block;
  padding: 0 .18em;
  border-radius: 6px;

  color: transparent;
  background: rgba(24, 24, 24, 0.92);
  box-shadow: 0 0 0 1px rgba(43,33,26,.35) inset;

  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

/* hover/keyboard focus показывает слово */
body.swear-censor-on .cuss:hover,
body.swear-censor-on .cuss:focus,
body.swear-censor-on .cuss.is-peek{
  color: rgba(43,33,26,.92);
  background: rgba(255,220,170,.55);
  box-shadow: 0 0 0 1px rgba(176,122,70,.22) inset;
  outline: none;
}

/* Глобально “показывать брань” => никаких замазок */
body.swear-show-all .cuss{
  color: inherit !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  user-select: text;
}

.cuss:focus { outline: none; }
.cuss:focus-visible { outline: none; }

/* после тапа (is-peek) — показываем слово без лишней рамки */
body.swear-censor-on .cuss.is-peek{
  box-shadow: none !important;
  background: rgba(255,220,170,.42);
}

/* ===== responsive ===== */
@media (max-width: 900px){
  .hero{ grid-template-columns: 1fr; }
  .hero__right{ order: -1; }
  .hero__title{ font-size: 38px; }
  .post__video{ width: 50%; }
  .post__img{ width: 50%; }
}
@media (max-width: 560px){
  .topbar__inner{ grid-template-columns: 1fr auto; }
  .hero__title{ font-size: 34px; }
  .hero__controls{ grid-template-columns: 1fr; }
  .post__video{ width: 100%; }
  .post__img{ width: 100%; }
}
.btn{
  background: rgba(46,36,30,.70);
  border: 1px solid rgba(239,226,211,.14);
  color: var(--fg);
}
.btn:hover{
  background: rgba(54,42,35,.82);
  border-color: rgba(208,154,90,.28);
}
.btn--primary{
  background: linear-gradient(180deg, rgba(208,154,90,.30), rgba(139,90,60,.18));
  border-color: rgba(208,154,90,.28);
}
.btn--ghost{
  background: rgba(46,36,30,.58);
}
.search{
  background: rgba(46,36,30,.68);
  border: 1px solid rgba(239,226,211,.14);
  box-shadow: 0 14px 28px rgba(0,0,0,.35);
}
.search__input{ color: var(--fg); }
.search__input::placeholder{ color: rgba(239,226,211,.40); }
.search__clear:hover{ background: rgba(208,154,90,.12); }

/* ===== media gallery (album/grid) ===== */
.post__gallery{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.post__gallery .post__media{
  border: 1px solid rgba(125,86,54,.16);
  border-radius: var(--radius2);
  overflow: hidden;
  background: #2D231D;
  box-shadow: 0 14px 26px rgba(40,24,12,.10);
}

/* медиа внутри плитки — занимает всю ширину плитки */
.post__gallery .post__img,
.post__gallery .post__video{
  width: 100%;
  height: auto;
  display: block;
}

/* видео обычно лучше с одинаковой высотой карточек */
.post__gallery .post__video{
  width: 100%;
  height: auto;        /* важно */
  object-fit: contain;/* на всякий случай */
  background: #000;
}


/* подпись (если есть) */
.post__gallery .post__caption{
  padding: 10px 12px;
  color: rgba(43,33,26,.62);
  border-top: 1px solid rgba(125,86,54,.14);
  background: rgba(255,248,238,.70);
  font-size: 12px;
}

.post__gallery{
  grid-auto-rows: min-content;
  align-items: start;
}

/* responsive */
@media (max-width: 900px){
  .post__gallery{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .post__gallery{ grid-template-columns: 1fr; }
}

/* старое мешает галерее */
.post__img{ width: 30%; }
.post__video{ width: 30%; }

.post__img,
.post__video{
  width: 100%;
}

/* ===== media gallery (album/grid) ===== */
.post__gallery{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.post__gallery .post__media{
  margin: 0;
  border: 1px solid rgba(125,86,54,.16);
  border-radius: var(--radius2);
  overflow: hidden;
  background: #2D231D;
  box-shadow: 0 14px 26px rgba(40,24,12,.10);
}

/* плитка медиа = 100% ширины */
.post__gallery .post__img,
.post__gallery .post__video{
  width: 100%;
  height: auto;
  display: block;
}

/* responsive */
@media (max-width: 900px){
  .post__gallery{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .post__gallery{ grid-template-columns: 1fr; }
}

.post__img,
.post__video{
  width: 100%;
  height: auto;
  display: block;
}


/* ===== media gallery (final, no crop) ===== */
.post__gallery{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  align-items: start;
  grid-auto-rows: min-content;
}

@media (max-width: 900px){
  .post__gallery{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .post__gallery{ grid-template-columns: 1fr; }
}

.post__gallery .post__media{
  margin: 0;
  border: 1px solid rgba(125,86,54,.16);
  border-radius: var(--radius2);
  overflow: hidden;
  background: #2D231D;
  box-shadow: 0 14px 26px rgba(40,24,12,.10);
}

/* медиа НЕ обрезаем */
.post__gallery .post__img,
.post__gallery .post__video{
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain; /* cover = режет, contain = нет */
}

.post__id,
.post__date{
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(125,86,54,.16);
  background: rgba(195, 184, 167, 0.78);
  color: rgba(43,33,26,.68);
}

.post__id{
  margin-left: auto;
}

.post__views{
  padding: 10px;
  font-size: 12px;
  opacity: .65;
  user-select: none;
}
