/* ===== reset ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
button,input,select,textarea{font:inherit;color:inherit;background:none;border:0;outline:0}
button{cursor:pointer}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
ol,ul{list-style:none}

/* ===== tokens ===== */
:root{
  --bg:#f3f1ea;          /* off-white paper */
  --bg-2:#ece9df;
  --ink:#0c0c0c;
  --ink-2:#222;
  --muted:#6b6b66;
  --line:#0c0c0c;
  --acid:#c8ff00;        /* accent — резкий, не градиент */
  --hot:#ff3b1f;         /* красный */
  --cool:#1a64ff;        /* синий */
  --paper:#ffffff;
  --shadow:6px 6px 0 var(--ink);
  --shadow-sm:3px 3px 0 var(--ink);
}

/* ===== base ===== */
html{background:var(--bg)}
body{
  font-family:"Space Grotesk",system-ui,sans-serif;
  color:var(--ink);
  background:
    /* лёгкий «бумажный» шум — никакого блюра, просто паттерн точек */
    radial-gradient(var(--ink) 0.6px, transparent 0.6px) 0 0 / 22px 22px,
    var(--bg);
  background-blend-mode:multiply;
  font-size:15px;
  line-height:1.4;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
@media (max-width:780px){ body{cursor:auto} .cursor{display:none} }

/* ===== ticker top ===== */
.ticker{
  border-bottom:2px solid var(--ink);
  background:var(--ink);
  color:var(--bg);
  overflow:hidden;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  letter-spacing:.04em;
}
.ticker__track{
  display:inline-flex;gap:32px;
  white-space:nowrap;
  padding:8px 0;
  animation:tick 60s linear infinite;
}
.ticker__track b{color:var(--acid);font-weight:700}
@keyframes tick{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ===== header ===== */
.hdr{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:24px;
  padding:18px 28px;
  border-bottom:2px solid var(--ink);
  background:var(--bg);
  position:sticky;top:0;z-index:50;
}
.logo{display:inline-flex;align-items:baseline;gap:10px}
.logo__mark{font-size:28px;line-height:1;transform:translateY(2px);display:inline-block}
.logo__txt{font-family:"Playfair Display",serif;font-size:30px;font-weight:400;letter-spacing:-.01em}
.logo__accent{
  background:var(--ink);color:var(--acid);padding:0 8px;
  font-family:"Space Grotesk",sans-serif;font-size:22px;font-weight:700;
  letter-spacing:.04em;display:inline-block;transform:translateY(-3px);
}
.logo__sub{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-left:6px}

.hdr__nav{display:flex;gap:22px;font-weight:500;letter-spacing:.06em;font-size:13px}
.hdr__nav a{position:relative;padding:6px 2px}
.hdr__nav a:hover{background:var(--ink);color:var(--acid)}
.hdr__nav a.is-active{background:var(--ink);color:var(--acid)}
.hdr__nav a::before{content:"";position:absolute;left:-8px;top:50%;width:4px;height:4px;background:var(--ink);transform:translateY(-50%) rotate(45deg);opacity:0}
.hdr__nav a:hover::before{opacity:0;}

.hdr__r{display:flex;align-items:center;gap:14px;justify-self:end}
.clock{font-family:"JetBrains Mono",monospace;font-size:12px;background:var(--paper);border:2px solid var(--ink);padding:6px 10px}

/* ===== buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  border:2px solid var(--ink);
  padding:11px 16px;
  font-weight:700;letter-spacing:.06em;font-size:13px;
  text-transform:uppercase;
  background:var(--paper);
  box-shadow:var(--shadow-sm);
  transition:transform .08s ease, box-shadow .08s ease, background .08s;
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}
.btn--solid{background:var(--ink);color:var(--acid)}
.btn--solid:hover{background:var(--acid);color:var(--ink)}
.btn--ghost{background:transparent}
.btn--sm{padding:7px 11px;font-size:11px}

/* ===== hero ===== */
.hero{padding:48px 28px 0;border-bottom:2px solid var(--ink)}
.hero__grid{display:grid;grid-template-columns:1.4fr .9fr;gap:48px;align-items:start}
.hero__col--main{padding-bottom:32px}

.kicker{display:inline-flex;align-items:center;gap:10px;
  border:2px solid var(--ink);background:var(--paper);
  padding:6px 12px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.05em;
}
.dot{width:8px;height:8px;background:var(--hot);display:inline-block;animation:blink 1.4s steps(2) infinite}
@keyframes blink{50%{opacity:.2}}

.title{
  font-family:"Playfair Display",serif;
  font-weight:400;
  font-size:clamp(56px,9vw,128px);
  line-height:.92;
  letter-spacing:-.03em;
  margin:22px 0 18px;
  display:flex;flex-wrap:wrap;gap:0 18px;
}
.title span{display:inline-block}
.title span:nth-child(2){font-style:italic;color:var(--ink-2)}
.title span:nth-child(3){
  font-family:"Space Grotesk",sans-serif;font-weight:700;
  background:var(--ink);color:var(--acid);padding:0 12px 6px;
}
.title__alt{font-style:italic;text-decoration:underline;text-decoration-thickness:4px;text-underline-offset:8px}

.lede{max-width:56ch;font-size:18px;color:var(--ink-2)}
.lede b{background:var(--acid);padding:0 4px;font-weight:700}
.hero__cta{display:flex;gap:14px;margin-top:26px;flex-wrap:wrap}

/* side panel */
.panel{border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow)}
.panel__hd{
  background:var(--ink);color:var(--bg);
  padding:10px 14px;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;
  display:flex;justify-content:space-between;align-items:center;
}
.panel__hd::after{content:"●●●";color:var(--hot);letter-spacing:2px}
.stats{padding:6px 0}
.stats li{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:12px 14px;border-top:1px dashed var(--ink);
}
.stats li:first-child{border-top:0}
.stats__k{font-size:13px;color:var(--muted);text-transform:lowercase}
.stats__v{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:22px}
.stats__v--red{color:var(--hot)}
.panel__ft{padding:10px 14px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);border-top:2px solid var(--ink);background:var(--bg-2)}

/* sticker */
.sticker{
  margin-top:18px;
  border:2px solid var(--ink);background:var(--acid);
  padding:18px;
  font-family:"Playfair Display",serif;
  text-align:center;
  cursor:pointer;
  transform:rotate(-3deg);
  box-shadow:var(--shadow);
  transition:transform .15s ease;
  user-select:none;
}
.sticker:hover{transform:rotate(2deg) scale(1.02)}
.sticker__r1{display:block;font-size:42px;line-height:1}
.sticker__r2{display:block;font-size:42px;line-height:1;font-style:italic}
.sticker__r3{display:block;margin-top:6px;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:6px}

/* marquee */
.marquee{margin-top:32px;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);overflow:hidden;background:var(--paper)}
.marquee__track{display:inline-flex;gap:36px;white-space:nowrap;padding:12px 0;animation:tick 40s linear infinite;font-family:"Playfair Display",serif;font-size:22px;font-style:italic}
.marquee__track span{display:inline-flex;align-items:center;gap:8px}

/* ===== catalog ===== */
.cat{padding:32px 28px;border-bottom:2px solid var(--ink)}
.cat__toolbar{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  flex-wrap:wrap;margin-bottom:24px;
}
.tabs{display:flex;flex-wrap:wrap;gap:0;border:2px solid var(--ink);background:var(--paper)}
.tab{
  padding:11px 16px;
  font-weight:700;letter-spacing:.06em;font-size:12px;
  border-right:2px solid var(--ink);
  display:inline-flex;align-items:center;gap:8px;
}
.tab:last-child{border-right:0}
.tab i{font-style:normal;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);font-weight:400}
.tab:hover{background:var(--bg-2)}
.tab.is-active{background:var(--ink);color:var(--acid)}
.tab.is-active i{color:var(--acid);opacity:.7}

.search{
  display:inline-flex;align-items:center;gap:10px;
  border:2px solid var(--ink);background:var(--paper);
  padding:8px 12px;min-width:280px;
}
.search__slash{font-family:"JetBrains Mono",monospace;color:var(--muted)}
.search input{flex:1;font-size:14px}
.search kbd{
  font-family:"JetBrains Mono",monospace;font-size:11px;
  border:1px solid var(--ink);padding:1px 6px;color:var(--muted)
}

.cat__layout{display:grid;grid-template-columns:240px 1fr;gap:24px}

/* filters */
.filters{border:2px solid var(--ink);background:var(--paper);align-self:start;position:sticky;top:96px}
.filters__hd{
  background:var(--ink);color:var(--bg);padding:10px 14px;
  font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;
}
.filters__grp{padding:14px;border-top:1px dashed var(--ink)}
.filters__grp:first-of-type{border-top:0}
.filters__t{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-bottom:10px;letter-spacing:.08em;display:flex;justify-content:space-between;align-items:baseline}
.filters__t i{font-style:normal;color:var(--ink);font-weight:700}
.filters__list{max-height:260px;overflow-y:auto;padding-right:6px;margin:0 -4px 0 0;display:flex;flex-direction:column;gap:2px}
.filters__list::-webkit-scrollbar{width:8px}
.filters__list::-webkit-scrollbar-track{background:var(--bg-2);border-left:2px solid var(--ink)}
.filters__list::-webkit-scrollbar-thumb{background:var(--ink)}
.filters__list label{font-size:12px;padding:3px 0}
.filters label{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px;cursor:pointer}
.filters label i{margin-left:auto;font-style:normal;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.filters input[type=checkbox],
.filters input[type=radio]{
  appearance:none;width:14px;height:14px;border:2px solid var(--ink);
  display:inline-grid;place-items:center;background:var(--paper);
}
.filters input[type=checkbox]:checked{background:var(--ink)}
.filters input[type=checkbox]:checked::after{content:"";width:6px;height:6px;background:var(--acid)}
.filters input[type=radio]{border-radius:50%}
.filters input[type=radio]:checked{background:var(--ink)}
.filters input[type=radio]:checked::after{content:"";width:4px;height:4px;background:var(--acid);border-radius:50%}

.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{
  border:2px solid var(--ink);padding:3px 8px;font-size:11px;
  font-family:"JetBrains Mono",monospace;letter-spacing:.04em;
  background:var(--paper);cursor:pointer;
}
.chip.is-on{background:var(--ink);color:var(--acid)}

.filters__ft{padding:12px 14px;border-top:2px solid var(--ink);background:var(--bg-2)}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:0;border:2px solid var(--ink);background:var(--paper)}
.card{
  border-right:2px solid var(--ink);
  border-bottom:2px solid var(--ink);
  padding:18px;
  position:relative;
  background:var(--paper);
  transition:background .12s;
  display:flex;flex-direction:column;gap:10px;
}
.card:hover{background:var(--bg-2)}
.card:hover .card__cta{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.card__top{display:flex;align-items:flex-start;gap:6px}
.card__top .card__verif{margin-left:auto}
.card__type{
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.1em;
  padding:2px 6px;border:1.5px solid var(--ink);background:var(--bg);
}
.card__type--channel{background:var(--acid);color:var(--ink)}
.card__type--bot{background:var(--cool);color:var(--paper)}
.card__type--chat{background:var(--hot);color:var(--paper)}
.card__type--aff{background:var(--ink);color:var(--acid)}
.card__verif{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.card__verif b{color:var(--ink)}
.card__name{font-family:"Playfair Display",serif;font-size:26px;line-height:1.05;letter-spacing:-.01em}
.card__handle{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted)}
.card__desc{
  font-size:13px;color:var(--ink-2);
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;
  overflow:hidden;
}
.card__tags{display:flex;flex-wrap:wrap;gap:4px;max-height:42px;overflow:hidden}
.card__tag{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.04em;padding:1px 6px;border:1px solid var(--ink);background:var(--bg)}
.card__bot{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;padding-top:6px;margin-top:auto;flex-wrap:wrap}

/* inline счётчики на карточке (read-only — голосовать только в модалке) */
.card__meta{display:inline-flex;flex-wrap:wrap;align-items:baseline;gap:6px}
.card__meta-dot{color:var(--muted)}
.card__meta-like{color:var(--ink-2)}
.card__meta-like b{color:var(--ink)}
.card__meta-dis{color:var(--muted)}

/* ===== реакции (только в модалке) ===== */
.react{display:inline-flex;border:2px solid var(--ink);background:var(--paper)}
.react__btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 9px;
  font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.03em;
  background:var(--paper);color:var(--ink);
  border:0;border-right:2px solid var(--ink);
  cursor:pointer;
  transition:background .12s, color .12s;
}
.react__btn:last-child{border-right:0}
.react__btn:hover{background:var(--bg-2)}
.react__btn.is-on{background:var(--acid);color:var(--ink)}
.react__btn--dis.is-on{background:var(--hot);color:var(--paper)}
.react__arr{font-size:11px;line-height:1}
.react__btn.is-on .react__arr{transform:scale(1.15)}
.react__n{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.02em}

/* большой вариант для модалки */
.react--lg{margin:18px 0 0;box-shadow:var(--shadow-sm)}
.react--lg .react__btn{padding:11px 18px;font-size:14px;gap:10px}
.react--lg .react__arr{font-size:16px}
.react--lg .react__n{font-size:15px}

/* locked: пользователь не залогинен */
.react--locked{opacity:.6;cursor:not-allowed}
.react--locked .react__btn{cursor:pointer}
.react__lock{
  margin:8px 0 0;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em;
}
.react__lock a{color:var(--ink);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;font-weight:700}
.react__lock a:hover{background:var(--acid);color:var(--ink)}
.card__meta{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.card__meta b{color:var(--ink);font-weight:700}
.card__cta{
  display:inline-flex;align-items:center;gap:6px;
  border:2px solid var(--ink);background:var(--ink);color:var(--acid);
  padding:6px 10px;font-size:12px;font-weight:700;letter-spacing:.06em;
  box-shadow:var(--shadow-sm);
  transition:transform .08s ease, box-shadow .08s ease;
}
.card__cta:hover{background:var(--acid);color:var(--ink)}

.card__num{position:absolute;top:8px;right:10px;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted)}
.card.is-hot::before{
  content:"NEW";
  position:absolute;top:-2px;left:-2px;
  background:var(--hot);color:var(--paper);
  padding:3px 8px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.1em;font-weight:700;
}
.card.is-pick::before{
  content:"★ ВЫБОР РЕДАКЦИИ";
  position:absolute;top:-2px;left:-2px;
  background:var(--acid);color:var(--ink);
  padding:3px 8px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.1em;font-weight:700;
}

/* ===== manifest ===== */
.mani{
  display:grid;grid-template-columns:1fr 1.4fr;gap:48px;
  padding:64px 28px;border-bottom:2px solid var(--ink);
  background:var(--bg-2);
}
.h2{
  font-family:"Playfair Display",serif;font-weight:400;
  font-size:clamp(36px,5vw,68px);line-height:1;letter-spacing:-.02em;margin-top:18px;
}
.h2 em{font-style:italic;background:var(--ink);color:var(--acid);padding:0 8px}
.rules{display:flex;flex-direction:column;gap:18px}
.rules li{display:grid;grid-template-columns:64px 1fr;gap:16px;border-top:2px solid var(--ink);padding-top:14px;font-size:17px}
.rules li b{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--muted);font-weight:400}

/* ===== page-hero (для отдельных страниц вроде /cabinet) ===== */
.page-hero{
  display:grid;grid-template-columns:1.4fr .9fr;gap:48px;
  padding:48px 28px;border-bottom:2px solid var(--ink);
  align-items:start;
}
.page-hero__title{
  font-family:"Playfair Display",serif;font-weight:400;
  font-size:clamp(48px,7vw,96px);line-height:.95;letter-spacing:-.02em;
  margin:18px 0 14px;
}
.page-hero__title em{font-style:italic;background:var(--ink);color:var(--acid);padding:0 10px}
.page-hero__sub{font-size:17px;color:var(--ink-2);max-width:48ch}
.page-hero__how{padding:6px 0}
.page-hero__how li{
  display:grid;grid-template-columns:40px 1fr;gap:8px;
  padding:11px 14px;border-top:1px dashed var(--ink);
  font-size:13px;color:var(--ink-2);
}
.page-hero__how li:first-child{border-top:0}
.page-hero__how li b{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);font-weight:400}
.page-hero__how b{font-weight:700}

@media (max-width:1024px){
  .page-hero{grid-template-columns:1fr}
}

/* кабинет как отдельная страница — растянуть на всю ширину */
.cab--page{padding:48px 28px}
.cab--page .cab__inner{display:block}
.cab--page .cab__panel{max-width:none}

/* ===== cabinet ===== */
.cab{padding:64px 28px;border-bottom:2px solid var(--ink)}
.cab__inner{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}
.cab__t .big-num{font-family:"Playfair Display",serif;font-size:96px;line-height:1;display:inline-block;transform:rotate(-8deg);margin-bottom:8px}
.cab__t p{color:var(--muted);margin-top:10px;font-size:16px;max-width:42ch}

.cab__panel{border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow);min-height:320px}

/* welcome (для незалогиненных) */
.cab__welcome{padding:36px 32px;display:flex;flex-direction:column;gap:16px}
.cab__welcome-icon{
  font-family:"Playfair Display",serif;
  font-size:72px;
  line-height:1;
  color:var(--ink);
  transform:rotate(-6deg);
  transform-origin:left center;
  display:block;
  width:fit-content;
  margin-bottom:4px;
  padding:8px 4px;
}
.cab__welcome h3{
  font-family:"Playfair Display",serif;
  font-size:32px;
  line-height:1.1;
  letter-spacing:-.01em;
  margin:0;
  max-width:24ch;
}
.cab__welcome p{font-size:15px;color:var(--ink-2);max-width:48ch;margin:0}
.cab__welcome-actions{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}
.cab__feat{
  display:flex;flex-direction:column;gap:8px;
  margin-top:18px;padding-top:18px;
  border-top:1px dashed var(--ink);
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);
}
.cab__feat li{display:flex;gap:10px;align-items:baseline;line-height:1.4}
.cab__feat li b{color:var(--ink);font-weight:700;flex-shrink:0;min-width:14px}

/* balance bar в кабинете */
.cab__wallet{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 22px;border-bottom:2px solid var(--ink);background:var(--bg-2);
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);
  gap:10px;flex-wrap:wrap;
}
.cab__wallet b{font-family:"Playfair Display",serif;font-size:24px;color:var(--ink);font-weight:400;margin-left:6px}
.cab__wallet .btn{padding:8px 14px;font-size:12px}

/* per-row actions */
.cab__acts{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.cab__act{
  border:1.5px solid var(--ink);background:var(--paper);
  padding:5px 9px;font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.04em;
  cursor:pointer;
  transition:transform .08s, background .12s, color .12s;
}
.cab__act:hover{transform:translate(-1px,-1px);background:var(--bg-2)}
.cab__act--promo{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.cab__act--promo:hover{background:var(--ink);border-color:var(--ink)}
.cab__act--vip{background:#ffd400;color:var(--ink)}
.cab__act--vip:hover{background:var(--ink);color:#ffd400}
.cab__act--ed:hover{background:var(--acid)}
.cab__act--del{color:var(--hot)}
.cab__act--del:hover{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.cab__act.is-disabled{
  opacity:.4;cursor:not-allowed;
  filter:grayscale(.5);
}
.cab__act.is-disabled:hover{transform:none;background:var(--paper);color:var(--ink);border-color:var(--ink)}

/* indicator on row when promo/vip активен */
.cab__row-bdg{font-family:"JetBrains Mono",monospace;font-size:9px;font-weight:700;letter-spacing:.06em;padding:1px 5px;border:1.5px solid var(--ink);display:inline-block;vertical-align:middle;margin-left:6px}
.cab__row-bdg--promo{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.cab__row-bdg--vip{background:#ffd400;color:var(--ink)}
.cab__row-bdg--pend{background:#ffd400;color:var(--ink)}
.cab__row-bdg--rej{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.cab__reject-reason{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--hot);margin-top:4px;letter-spacing:.04em}

/* ===== admin page ===== */
.admin{padding:48px 28px;border-bottom:2px solid var(--ink)}
.admin__panel{border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow);min-height:380px}

/* login форма */
.admin__login{padding:30px 32px;max-width:480px;margin:0 auto}
.admin__login form{display:grid;gap:14px}
.admin__login label{display:flex;flex-direction:column;gap:6px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;color:var(--muted)}
.admin__login input{border:2px solid var(--ink);padding:11px 12px;background:var(--bg);font-family:"Space Grotesk",sans-serif;font-size:14px;color:var(--ink)}
.admin__login input:focus{background:var(--paper);box-shadow:inset 0 0 0 2px var(--acid)}

/* головная плашка после входа */
.admin__head{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 22px;border-bottom:2px solid var(--ink);
  background:var(--ink);color:var(--bg);
}
.admin__role{font-family:"Playfair Display",serif;font-size:24px;color:var(--acid)}
.admin__sub{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-top:2px}

/* статы */
.admin__stats{display:flex;gap:0;border-bottom:2px solid var(--ink);flex-wrap:wrap}
.admin__stats span{
  flex:1;min-width:140px;padding:12px 16px;
  border-right:1px dashed var(--ink);
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);
}
.admin__stats span:last-child{border-right:0}
.admin__stats b{display:block;font-size:22px;color:var(--ink);font-weight:700;margin-top:3px}
.admin__stats b.admin__bld{color:var(--hot)}

/* табы */
.admin__tabs{display:flex;border-bottom:2px solid var(--ink);background:var(--bg-2);overflow-x:auto}
.admin__tab{
  padding:13px 18px;
  font-family:"Space Grotesk",sans-serif;font-weight:700;letter-spacing:.06em;font-size:12px;
  border-right:2px solid var(--ink);background:var(--bg-2);
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
}
.admin__tab:last-child{border-right:0}
.admin__tab i{font-style:normal;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);font-weight:400}
.admin__tab:hover{background:var(--paper)}
.admin__tab.is-active{background:var(--ink);color:var(--acid)}
.admin__tab.is-active i{color:var(--acid);opacity:.7}

.admin__content{padding:0}
.admin__empty{padding:60px 30px;text-align:center;font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--muted);letter-spacing:.04em}

/* таблица заявок */
.admin__tbl{width:100%;border-collapse:collapse;font-size:13px}
.admin__tbl th{
  text-align:left;padding:10px 16px;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;
  font-weight:400;color:var(--muted);
  border-bottom:1px dashed var(--ink);background:var(--bg-2);
}
.admin__tbl td{padding:14px 16px;border-bottom:1px dashed var(--ink);vertical-align:top}
.admin__tbl td:nth-child(1){width:60px}
.admin__tbl td .av{width:44px;height:44px;box-shadow:none}
.admin__tbl td .av .av__init{font-size:22px}
.admin__tbl td b{font-weight:700;font-size:14px}
.admin__tbl td .card__type{margin-left:8px;vertical-align:middle}
.admin__desc{font-size:13px;color:var(--ink-2);max-width:42ch;line-height:1.35}
.admin__reason{margin-top:6px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--hot);letter-spacing:.04em}

/* кнопки действий */
.admin__acts{display:flex;flex-direction:column;gap:6px;align-items:stretch;min-width:160px}
.admin__act{
  border:2px solid var(--ink);background:var(--paper);
  padding:7px 10px;
  font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.05em;
  cursor:pointer;text-align:left;
  box-shadow:var(--shadow-sm);
  transition:transform .08s, box-shadow .08s, background .12s, color .12s;
}
.admin__act:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.admin__act--ok{background:var(--acid)}
.admin__act--ok:hover{background:var(--ink);color:var(--acid)}
.admin__act--rj:hover{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.admin__act--del{color:var(--hot)}
.admin__act--del:hover{background:var(--hot);color:var(--paper);border-color:var(--hot)}

.admin__ok-tag{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-2);padding:1px 6px;border:1.5px solid var(--ink);background:var(--acid)}

@media (max-width:780px){
  .admin__tbl thead{display:none}
  .admin__tbl,.admin__tbl tbody,.admin__tbl tr,.admin__tbl td{display:block;width:auto}
  .admin__tbl tr{border-bottom:2px solid var(--ink);padding:14px 0}
  .admin__tbl td{border-bottom:0;padding:6px 16px}
  .admin__acts{flex-direction:row;flex-wrap:wrap}
}

/* profile */
.cab__head{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:18px 22px;border-bottom:2px solid var(--ink);
  background:var(--ink);color:var(--bg);
}
.cab__head-l{display:flex;align-items:center;gap:14px}
.cab__user-av{
  width:44px;height:44px;border:2px solid var(--acid);background:var(--acid);
  display:grid;place-items:center;
  font-family:"Playfair Display",serif;font-style:italic;font-size:22px;color:var(--ink);
}
.cab__user{font-family:"Playfair Display",serif;font-size:22px;line-height:1}
.cab__email{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-top:3px}
.cab__head-r{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.cab__stats{
  display:flex;gap:0;border-bottom:2px solid var(--ink);
}
.cab__stats span{
  flex:1;padding:14px 18px;
  border-right:1px dashed var(--ink);
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);
}
.cab__stats span:last-child{border-right:0}
.cab__stats b{display:block;font-size:22px;color:var(--ink);font-weight:700;margin-top:2px}

.cab__tbl{width:100%;border-collapse:collapse;font-size:13px}
.cab__tbl th{
  text-align:left;padding:9px 14px;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;
  font-weight:400;color:var(--muted);
  border-bottom:1px dashed var(--ink);
  background:var(--bg-2);
}
.cab__tbl td{padding:10px 14px;border-bottom:1px dashed var(--ink);vertical-align:middle}
.cab__tbl td .av{width:40px;height:40px;box-shadow:none}
.cab__tbl td .av .av__init{font-size:22px}
.cab__tbl td b{font-weight:700}
.cab__handle{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.cab__del{
  border:2px solid var(--ink);background:var(--paper);
  width:30px;height:30px;font-size:14px;font-weight:700;line-height:1;
  display:inline-grid;place-items:center;cursor:pointer;
}
.cab__del:hover{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.cab__empty{padding:34px;text-align:center;color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:12px}

.cab__add{padding:22px;border-top:2px solid var(--ink);background:var(--bg-2)}
/* визуалы внутри add-формы (аватарка + шапка) */
.add-vis{
  grid-column:1/-1;
  display:grid;grid-template-columns:100px 1fr;gap:10px;
  margin-bottom:4px;
}
.add-vis__slot{
  position:relative;
  border:2px dashed var(--ink);background:var(--paper);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  cursor:pointer;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;color:var(--muted);
  padding:6px;overflow:hidden;
  transition:background .12s, border-color .12s;
}
.add-vis__slot:hover{background:var(--acid);border-color:var(--ink);color:var(--ink)}
.add-vis__slot--av{width:100px;height:100px}
.add-vis__slot--cv{aspect-ratio:6 / 1;max-height:200px;min-height:80px}
.add-vis__slot.is-filled{border-style:solid}
.add-vis__slot.is-filled img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.95);
}
.add-vis__slot.is-filled .add-vis__cap{
  position:absolute;left:0;right:0;bottom:0;
  background:rgba(12,12,12,.8);color:var(--acid);
  padding:3px 6px;font-size:10px;text-align:center;
}
.add-vis__plus{font-family:"Playfair Display",serif;font-size:36px;line-height:1;color:var(--ink)}
.add-vis__cap{text-align:center;line-height:1.2}
@media (max-width:680px){
  .add-vis{grid-template-columns:1fr}
  .add-vis__slot--av{width:100%;height:120px}
}
.cab__add-hd{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;color:var(--muted);
  margin-bottom:10px;
}
.cab__add form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cab__add label{display:flex;flex-direction:column;gap:6px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;color:var(--muted)}
.cab__add label[hidden]{display:none}
.cab__add input,.cab__add select,.cab__add textarea{
  border:2px solid var(--ink);padding:9px 11px;background:var(--paper);
  font-family:"Space Grotesk",sans-serif;font-size:14px;color:var(--ink);
}
.cab__add input:focus,.cab__add select:focus,.cab__add textarea:focus{box-shadow:inset 0 0 0 2px var(--acid)}
.cab__add label.form__full{grid-column:1/-1}
.cab__add .cab__add-actions{grid-column:1/-1;display:flex;gap:10px;align-items:center}
.cab__ok{
  font-family:"JetBrains Mono",monospace;font-size:12px;
  background:var(--acid);border:2px solid var(--ink);padding:6px 10px;
}

@media (max-width:680px){
  .cab__add form{grid-template-columns:1fr}
}

.form{display:grid;grid-template-columns:1fr 1fr;gap:14px;border:2px solid var(--ink);background:var(--paper);padding:20px;box-shadow:var(--shadow)}
.form label{display:flex;flex-direction:column;gap:6px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;color:var(--muted)}
.form input,.form select,.form textarea{
  border:2px solid var(--ink);padding:9px 11px;background:var(--bg);
  font-family:"Space Grotesk",sans-serif;font-size:14px;color:var(--ink);
}
.form input:focus,.form select:focus,.form textarea:focus{background:var(--paper);box-shadow:inset 0 0 0 2px var(--acid)}
.form__full{grid-column:1/-1}
.form .btn{grid-column:1/-1;justify-content:center}
.form__ok{grid-column:1/-1;background:var(--acid);border:2px solid var(--ink);padding:10px 12px;font-family:"JetBrains Mono",monospace;font-size:12px}

/* ===== footer ===== */
.ft{
  display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;
  padding:22px 28px;background:var(--ink);color:var(--bg);
  font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.04em;
}
.ft__logo{color:var(--acid);font-size:16px;margin-right:14px}
.ft__c{display:flex;gap:18px;justify-content:center}
.ft__c a:hover{color:var(--acid)}
.ft__r{text-align:right}
.ft__bld{color:var(--acid)}

/* ===== generic dialog (auth/shop/edit) ===== */
.dlg{position:fixed;inset:0;z-index:250;display:flex;align-items:center;justify-content:center;padding:20px}
.dlg[hidden]{display:none}
.dlg__bg{position:absolute;inset:0;background:rgba(12,12,12,.72);cursor:pointer}
.dlg__win{
  position:relative;z-index:1;
  width:min(460px,100%);max-height:calc(100vh - 40px);
  background:var(--paper);border:2px solid var(--ink);box-shadow:10px 10px 0 var(--ink);
  display:flex;flex-direction:column;
  animation:popin .18s cubic-bezier(.2,.9,.2,1.2);
}
.dlg__win--lg{width:min(560px,100%)}
.dlg__hd{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--ink);color:var(--bg);
  padding:10px 14px;
  border-bottom:2px solid var(--ink);
  font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;
  flex-shrink:0;
}
.dlg__title{font-weight:700}
.dlg__close{
  width:28px;height:28px;display:inline-grid;place-items:center;
  border:2px solid var(--bg);background:var(--ink);color:var(--bg);
  font-size:15px;font-weight:700;line-height:1;
  transition:transform .08s, background .12s;
}
.dlg__close:hover{background:var(--hot);color:var(--paper);transform:rotate(90deg)}
.dlg__body{overflow:auto;padding:22px}
.dlg__body h3{font-family:"Playfair Display",serif;font-size:28px;line-height:1;margin-bottom:8px;letter-spacing:-.01em}
.dlg__body p{font-size:14px;color:var(--ink-2);max-width:50ch}
.dlg__body p + p{margin-top:8px}

/* tabs внутри dlg */
.dlg__tabs{display:flex;margin:-22px -22px 18px;border-bottom:2px solid var(--ink)}
.dlg__tab{flex:1;padding:13px;font-weight:700;letter-spacing:.06em;font-size:13px;background:var(--bg-2);border-right:2px solid var(--ink)}
.dlg__tab:last-child{border-right:0}
.dlg__tab.is-active{background:var(--ink);color:var(--acid)}

/* форма внутри dlg */
.dlg form{display:grid;gap:12px}
.dlg label{display:flex;flex-direction:column;gap:6px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;color:var(--muted)}
.dlg input,.dlg select,.dlg textarea{
  border:2px solid var(--ink);padding:11px 12px;background:var(--bg);
  font-family:"Space Grotesk",sans-serif;font-size:14px;color:var(--ink);
}
.dlg input:focus,.dlg select:focus,.dlg textarea:focus{background:var(--paper);box-shadow:inset 0 0 0 2px var(--acid)}
.dlg .form__full{grid-column:1/-1}
.dlg .dlg__hint{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.dlg .dlg__err{background:var(--hot);color:var(--paper);padding:8px 12px;font-family:"JetBrains Mono",monospace;font-size:12px;border:2px solid var(--ink)}
.dlg .dlg__ok{background:var(--acid);color:var(--ink);padding:8px 12px;font-family:"JetBrains Mono",monospace;font-size:12px;border:2px solid var(--ink)}

/* ===== edit панель (внутри shopDlg, размер dlg--lg) ===== */
.ed{display:flex;flex-direction:column;gap:18px;margin:-22px;padding:0}
.ed__hd{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:2px solid var(--ink);background:var(--bg-2)}
.ed__hd-h{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--ink)}
.ed__sect{padding:0 18px 14px;border-bottom:1px dashed var(--ink)}
.ed__sect:last-of-type{border-bottom:0}
.ed__sect-hd{display:flex;justify-content:space-between;align-items:center;padding:14px 0 10px}
.ed__sect-t{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.1em;color:var(--muted)}
.ed form{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0}
.ed form{padding:0 18px}
.ed form > .ed__sect{grid-column:1/-1;padding:14px 0 0;margin:0;border-bottom:0;border-top:1px dashed var(--ink)}
.ed form .form__full{grid-column:1/-1}
.ed form label{display:flex;flex-direction:column;gap:6px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;color:var(--muted)}
.ed form input,.ed form textarea{
  border:2px solid var(--ink);padding:10px 12px;background:var(--bg);
  font-family:"Space Grotesk",sans-serif;font-size:14px;color:var(--ink);
}
.ed form input:focus,.ed form textarea:focus{background:var(--paper);box-shadow:inset 0 0 0 2px var(--acid)}
.ed__actions{display:flex;gap:10px;padding:14px 18px 18px;border-top:2px solid var(--ink);background:var(--bg-2)}

/* кнопки внутри edit */
.ed__btn{
  border:2px solid var(--ink);background:var(--paper);
  padding:8px 12px;font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.06em;
  cursor:pointer;
  box-shadow:var(--shadow-sm);
  transition:transform .08s, box-shadow .08s, background .12s;
}
.ed__btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink);background:var(--acid)}
.ed__btn--rm{color:var(--hot)}
.ed__btn--rm:hover{background:var(--hot);color:var(--paper);border-color:var(--hot)}

/* cover превью */
.ed__cover{
  width:100%;aspect-ratio:6 / 1;max-height:200px;border:2px solid var(--ink);overflow:hidden;
  background:
    repeating-linear-gradient(135deg, transparent 0 14px, rgba(12,12,12,.08) 14px 15px),
    var(--bg-2);
  display:flex;align-items:center;justify-content:center;
}
.ed__cover img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.ed__cover-empty{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.06em}
.ed__cover.is-off,
.ed__row-acts.is-off{opacity:.45;pointer-events:none}

/* avatar превью */
.ed__avatar-row{display:flex;gap:18px;align-items:center}
.ed__avatar-prev .av{width:96px;height:96px}
.ed__avatar-prev .av .av__init{font-size:52px}
.ed__avatar-acts{display:flex;flex-direction:column;gap:8px;flex:1}
.ed__avatar-note{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-top:2px}
.ed__hint{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em;align-self:center}

.ed__row-acts{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.ed__row-acts--col{flex-direction:column;align-items:flex-start}

/* toggle (вкл/выкл) — брутал-стайл свитч */
.toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.toggle input{position:absolute;opacity:0;pointer-events:none}
.toggle__box{
  position:relative;
  width:42px;height:22px;
  border:2px solid var(--ink);background:var(--paper);
  flex-shrink:0;
  transition:background .12s;
}
.toggle__box::before{
  content:"";position:absolute;left:0;top:0;
  width:16px;height:18px;background:var(--ink);
  transition:left .14s cubic-bezier(.4,.2,.2,1.2), background .12s;
}
.toggle input:checked + .toggle__box{background:var(--ink)}
.toggle input:checked + .toggle__box::before{left:calc(100% - 16px);background:var(--acid)}
.toggle__lbl{font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--ink);min-width:36px}
.toggle__lbl::before{content:"ВЫКЛ";color:var(--muted)}
.toggle input:checked ~ .toggle__lbl::before{content:"ВКЛ";color:var(--ink)}

/* shop tiles (тарифы) */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.tile{
  border:2px solid var(--ink);padding:14px;background:var(--paper);
  cursor:pointer;display:flex;flex-direction:column;gap:6px;
  transition:transform .1s, box-shadow .1s, background .12s;
  box-shadow:var(--shadow-sm);
}
.tile:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink);background:var(--bg-2)}
.tile.is-on{background:var(--ink);color:var(--bg)}
.tile.is-on .tile__price{color:var(--acid)}
.tile__name{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;color:var(--muted)}
.tile.is-on .tile__name{color:var(--acid)}
.tile__price{font-family:"Playfair Display",serif;font-size:28px;line-height:1}
.tile__sub{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted)}
.tile.is-on .tile__sub{color:var(--bg)}

/* строка с балансом в диалоге */
.dlg__balance{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 12px;background:var(--bg-2);border:2px solid var(--ink);
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);
  margin-bottom:14px;
}
.dlg__balance b{font-family:"Playfair Display",serif;font-size:20px;color:var(--ink);font-weight:400}

/* ===== card badges: VIP ===== */
.card__vip{
  display:inline-flex;align-items:center;
  font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:700;letter-spacing:.08em;
  background:#ffd400;color:var(--ink);
  border:1.5px solid var(--ink);
  padding:2px 6px;
}
.card.is-vip{background:#fffae0}
.card.is-vip:hover{background:#fff4c2}

/* ===== avatars ===== */
.av{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;
  border:2px solid var(--ink);
  background:var(--paper);
  flex-shrink:0;
  overflow:hidden;
  font-family:"Playfair Display",serif;
  user-select:none;
  isolation:isolate;
}
.av--sm{width:56px;height:56px;box-shadow:var(--shadow-sm)}
.av--lg{width:120px;height:120px;box-shadow:var(--shadow)}

/* монограмма */
.av__init{
  font-size:32px;font-style:italic;line-height:1;letter-spacing:-.02em;
  color:var(--ink);
  z-index:2;
  text-shadow: 1px 1px 0 rgba(255,255,255,.4);
}
.av--lg .av__init{font-size:64px}

/* угловой штамп с типом */
.av__stamp{
  position:absolute;top:-2px;right:-2px;
  font-family:"JetBrains Mono",monospace;font-style:normal;
  font-size:10px;font-weight:700;letter-spacing:.04em;
  background:var(--ink);color:var(--bg);
  padding:1px 4px 2px;
  border:2px solid var(--ink);
  z-index:3;line-height:1;
}
.av--lg .av__stamp{font-size:12px;padding:2px 6px 3px}

/* «штриховка» — печатный паттерн на фоне */
.av__hatch{
  position:absolute;inset:0;z-index:1;
  background-image: repeating-linear-gradient(135deg, transparent 0 5px, rgba(12,12,12,.08) 5px 6px);
  pointer-events:none;
}

/* картинка */
.av--img img{width:100%;height:100%;object-fit:cover;display:block;filter:contrast(1.05) saturate(.95)}
.av--img .av__init,
.av--img .av__hatch{display:none}

/* 5 цветовых схем — детерминированно по name+handle */
.av--s0{background:var(--acid)}
.av--s0 .av__init{color:var(--ink)}
.av--s1{background:var(--hot)}
.av--s1 .av__init{color:var(--paper);text-shadow:1px 1px 0 rgba(0,0,0,.3)}
.av--s1 .av__stamp{background:var(--paper);color:var(--ink);border-color:var(--ink)}
.av--s2{background:var(--cool)}
.av--s2 .av__init{color:var(--paper);text-shadow:1px 1px 0 rgba(0,0,0,.3)}
.av--s2 .av__stamp{background:var(--acid);color:var(--ink);border-color:var(--ink)}
.av--s3{background:var(--ink)}
.av--s3 .av__init{color:var(--acid);text-shadow:none}
.av--s3 .av__stamp{background:var(--acid);color:var(--ink);border-color:var(--acid)}
.av--s4{background:var(--bg-2)}
.av--s4 .av__init{color:var(--ink)}

/* hover-«живинка» только на крупном аватаре */
.av--lg{transition:transform .15s ease}
.av--lg:hover{transform:translate(-2px,-2px)}
.av--lg:hover{box-shadow:9px 9px 0 var(--ink)}

/* ====== card identity (avatar + name) ====== */
.card__id{display:flex;gap:12px;align-items:flex-start;margin-top:2px}
.card__id-r{min-width:0;flex:1}
.card__id-r .card__name{font-size:24px;line-height:1.05}
.card__id-r .card__handle{margin-top:2px}

/* ====== modal cover (баннер) ====== */
.modal__cover{
  position:relative;
  width:100%;
  aspect-ratio: 3 / 1;
  border:2px solid var(--ink);
  margin-bottom:18px;
  overflow:hidden;
  background:var(--bg-2);
}
.modal__cover img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.modal__cover--empty{
  cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:
    repeating-linear-gradient(135deg, transparent 0 14px, rgba(12,12,12,.07) 14px 15px),
    var(--bg-2);
}
.modal__cover-prompt{
  font-family:"JetBrains Mono",monospace;font-size:13px;font-weight:700;letter-spacing:.08em;
  background:var(--ink);color:var(--acid);
  padding:9px 16px;
  border:2px solid var(--ink);
  box-shadow:var(--shadow-sm);
  transition:transform .1s, box-shadow .1s;
}
.modal__cover--empty:hover .modal__cover-prompt{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.modal__cover-hint{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em}

.modal__cover-overlay{
  position:absolute;inset:0;
  background:rgba(12,12,12,.7);
  display:flex;align-items:center;justify-content:center;gap:10px;
  opacity:0;transition:opacity .12s;pointer-events:none;
}
.modal__cover:hover .modal__cover-overlay,
.modal__cover:focus-within .modal__cover-overlay{opacity:1;pointer-events:auto}
.modal__cover-overlay button{
  border:2px solid var(--bg);background:transparent;color:var(--bg);
  font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:700;letter-spacing:.06em;
  padding:8px 14px;cursor:pointer;
  transition:background .12s, color .12s, border-color .12s;
}
.modal__cover-overlay button:first-child:hover{background:var(--acid);color:var(--ink);border-color:var(--acid)}
.modal__cover-overlay button:last-child:hover{background:var(--hot);color:var(--paper);border-color:var(--hot)}

@media (hover:none){
  .modal__cover-overlay{opacity:1;pointer-events:auto;background:rgba(12,12,12,.55)}
}

/* ====== modal identity row ====== */
.modal__id{display:flex;gap:18px;align-items:flex-start}
.modal__av-wrap{position:relative;flex-shrink:0}
.modal__id-r{flex:1;min-width:0;padding-top:4px}

/* upload overlay — внутри границы аватарки */
.av__overlay{
  position:absolute;inset:2px;            /* за границей */
  display:flex;flex-direction:column;
  background:rgba(12,12,12,.85);
  opacity:0;transition:opacity .12s;
  pointer-events:none;
  z-index:4;
}
.modal__av-wrap:hover .av__overlay,
.modal__av-wrap:focus-within .av__overlay{opacity:1;pointer-events:auto}
.av__upload{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--acid);
  font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.06em;
  border:0;background:transparent;cursor:pointer;text-align:center;padding:6px;
}
.av__upload:hover{background:rgba(200,255,0,.08)}
.av__upload-sub{font-size:8px;color:var(--bg);font-weight:400;letter-spacing:.04em}
.av__reset{
  border:0;border-top:1px solid rgba(255,255,255,.15);
  background:transparent;color:var(--hot);
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.06em;font-weight:700;
  padding:6px 4px;cursor:pointer;
}
.av__reset:hover{background:var(--hot);color:var(--paper)}

/* на тач-устройствах: оверлей всегда виден, чуть прозрачнее */
@media (hover:none){
  .av__overlay{opacity:1;pointer-events:auto;background:rgba(12,12,12,.55)}
}

/* ===== card page — на всю ширину/высоту ===== */
.cardpage{padding:0;border-bottom:0}
.cardpage__nav{
  display:flex;align-items:center;gap:14px;
  padding:14px clamp(20px, 4vw, 48px);
  border-bottom:2px solid var(--ink);background:var(--bg-2);
  flex-wrap:wrap;
}
.cardpage__crumb{
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);letter-spacing:.04em;
}
.cardpage__body{max-width:none;margin:0}

/* компактная карточка — должна влезать на один экран */
.cp{
  display:block;
  max-width:1100px;
  margin:0 auto;
  padding:18px 24px 24px;
  background:transparent;
}
.cp__cover{
  width:100%;
  aspect-ratio:6 / 1;             /* фиксированные пропорции — совпадают со слотом загрузки */
  max-height:200px;
  overflow:hidden;
  border:2px solid var(--ink);
  box-shadow:var(--shadow-sm);
  margin-bottom:16px;
  background:var(--bg-2);
}
.cp__cover img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}

/* identity: аватар + текст + кнопка в одной строке */
.cp__id{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px;
  align-items:center;
  margin-bottom:14px;
}
.cp__av-wrap{flex-shrink:0}
.cp__av-wrap .av{
  width:clamp(80px, 9vw, 104px);
  height:clamp(80px, 9vw, 104px);
  box-shadow:5px 5px 0 var(--ink);
}
.cp__av-wrap .av .av__init{font-size:clamp(40px, 5vw, 54px)}
.cp__id-text{min-width:0}
.cp__id-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:6px}
.cp__title{
  font-family:"Playfair Display",serif;font-weight:400;
  font-size:clamp(28px, 4vw, 48px);
  line-height:1;letter-spacing:-.02em;
  margin:0 0 4px;
  word-wrap:break-word;
}
.cp__handle{
  display:inline-block;
  font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.04em;
  background:var(--bg-2);border:1.5px solid var(--ink);
  padding:3px 7px;color:var(--ink);
}
.cp__open{
  padding:13px 20px;
  font-size:13px;font-weight:700;letter-spacing:.07em;
  box-shadow:var(--shadow-sm);
  white-space:nowrap;
}
.cp__open:hover{box-shadow:5px 5px 0 var(--ink)}

/* флаг-стрип — тонкая моноширная полоса */
.cp__flagstrip{
  background:var(--ink);color:var(--bg);
  padding:7px 12px;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:14px;
}

/* body: 2 колонки в рамках, компактно */
.cp__body{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:14px;
}
.cp__body-l, .cp__body-r{
  border:2px solid var(--ink);
  background:var(--paper);
  padding:14px;
  box-shadow:var(--shadow-sm);
}
.cp__lede{
  font-size:15px;line-height:1.35;color:var(--ink);margin:0;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.cp__lede b{background:var(--acid);padding:0 4px;font-weight:700}
.cp__long-line{
  font-size:13px;color:var(--ink-2);margin-top:8px;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.cp__tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px;max-height:48px;overflow:hidden}

.cp__body-r{display:flex;flex-direction:column;gap:10px;background:var(--bg-2)}
.cp__metrics-strip{
  display:grid;grid-template-columns:1fr 1fr;
  border:2px solid var(--ink);background:var(--paper);
}
.cp__metric{
  padding:8px 10px;
  border-right:1px dashed var(--ink);border-bottom:1px dashed var(--ink);
}
.cp__metric:nth-child(2n){border-right:0}
.cp__metric:nth-last-child(-n+2){border-bottom:0}
.cp__metric b{display:block;font-family:"JetBrains Mono",monospace;font-weight:700;font-size:16px;line-height:1}
.cp__metric span{display:block;margin-top:2px;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);letter-spacing:.04em}

.cp__bottom-row{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  margin-top:auto;padding-top:8px;border-top:1px dashed var(--ink);
}
.cp__report{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em;
}
.cp__report:hover{color:var(--hot)}

/* ===== posts block на странице карточки ===== */
.cp__news{
  margin-top:18px;
  padding:22px;
  border:2px solid var(--ink);
  background:var(--bg-2);
  box-shadow:var(--shadow-sm);
}
.cp__news-hd{
  display:flex;align-items:baseline;gap:14px;
  border-bottom:2px dashed var(--ink);padding-bottom:14px;margin-bottom:18px;
}
.cp__news-title{
  font-family:"Playfair Display",serif;font-weight:400;
  font-size:clamp(26px, 3vw, 36px);line-height:1;letter-spacing:-.01em;margin:0;
}
.cp__news-title em{font-style:italic;background:var(--ink);color:var(--acid);padding:0 8px}
.cp__news-count{
  font-family:"JetBrains Mono",monospace;font-size:14px;
  border:2px solid var(--ink);padding:3px 8px;background:var(--paper);
}
.cp__news-list{
  display:grid;gap:14px;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
}
.cp-post{
  border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;overflow:hidden;
  color:var(--ink);text-decoration:none;
  transition:transform .08s, box-shadow .08s, background .12s;
}
.cp-post:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink);background:var(--bg-2)}
.cp-post:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}
.cp-post__more{color:var(--ink);font-weight:700}
.cp-post__img{width:100%;aspect-ratio:16/9;background:var(--bg-2);border-bottom:2px solid var(--ink)}
.cp-post__img img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.cp-post__b{padding:14px;display:flex;flex-direction:column;flex:1}
.cp-post__text{
  font-size:14px;line-height:1.45;color:var(--ink);margin:0;
  white-space:pre-wrap;word-wrap:break-word;
  display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden;
}
.cp-post__meta{
  margin-top:auto;padding-top:10px;border-top:1px dashed var(--ink);
  display:flex;justify-content:space-between;align-items:baseline;gap:10px;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em;
}
.cp-post__by{color:var(--ink);font-weight:700}
@media (max-width:680px){
  .cp__news{padding:16px}
  .cp__news-list{grid-template-columns:1fr}
}

/* ===== posts manager (диалог в кабинете) ===== */
.pm{display:flex;flex-direction:column;gap:0;margin:-22px}
.pm__hd{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:14px 18px;border-bottom:2px solid var(--ink);background:var(--bg-2);flex-wrap:wrap;
}
.pm__t{font-family:"Playfair Display",serif;font-size:24px;line-height:1;letter-spacing:-.01em}
.pm__sub{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-top:3px}
.pm__form{padding:18px;border-bottom:2px solid var(--ink);background:var(--paper);display:grid;gap:12px}
.pm__form-img{
  width:100%;aspect-ratio:16/9;max-height:220px;
  border:2px dashed var(--ink);background:var(--paper);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  cursor:pointer;overflow:hidden;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.06em;
}
.pm__form-img:hover{background:var(--acid);color:var(--ink)}
.pm__form-img img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.pm__form-plus{font-family:"Playfair Display",serif;font-size:36px;line-height:1;color:var(--ink)}
.pm__form-cap{text-align:center}
.pm__form-text{display:flex;flex-direction:column;gap:6px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;color:var(--muted)}
.pm__form-text textarea{
  border:2px solid var(--ink);padding:10px 12px;background:var(--bg);
  font-family:"Space Grotesk",sans-serif;font-size:14px;color:var(--ink);resize:vertical;
}
.pm__form-text textarea:focus{background:var(--paper);box-shadow:inset 0 0 0 2px var(--acid)}
.pm__form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.pm__form-hint{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.pm__list{padding:18px;display:flex;flex-direction:column;gap:12px;max-height:380px;overflow-y:auto}
.pm__empty{padding:30px;text-align:center;font-family:"JetBrains Mono",monospace;color:var(--muted);font-size:12px;border:2px dashed var(--ink)}

.post-row{
  display:grid;grid-template-columns:auto 1fr;gap:12px;
  border:2px solid var(--ink);background:var(--paper);padding:12px;box-shadow:var(--shadow-sm);
}
.post-row__img{width:120px;aspect-ratio:16/9;overflow:hidden;border:1.5px solid var(--ink)}
.post-row__img img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.post-row__b{display:flex;flex-direction:column;gap:8px;min-width:0}
.post-row__meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.post-row__bdg{
  font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:700;letter-spacing:.06em;
  padding:2px 6px;border:1.5px solid var(--ink);
}
.post-row__bdg--pend{background:#ffd400;color:var(--ink)}
.post-row__bdg--ok{background:var(--acid);color:var(--ink)}
.post-row__bdg--rj{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.post-row__date{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em}
.post-row__text{
  font-size:13px;line-height:1.4;color:var(--ink);margin:0;white-space:pre-wrap;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
}
.post-row__reason{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--hot);margin:0;letter-spacing:.04em}
.post-row__acts{display:flex;gap:6px}

.cab__act--posts{background:var(--bg-2)}
.cab__act--posts i{font-style:normal;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);font-weight:400;margin-left:4px}
.cab__act--posts:hover{background:var(--acid)}

@media (max-width:560px){
  .post-row{grid-template-columns:1fr}
  .post-row__img{width:100%}
}

/* мини-маркиза — узкая полоса снизу */
.cp__marquee{
  margin-top:14px;
  border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);
  background:var(--paper);overflow:hidden;
}
.cp__marquee-track{
  display:inline-flex;gap:28px;white-space:nowrap;
  padding:6px 0;
  font-family:"Playfair Display",serif;font-style:italic;font-size:15px;
  animation:tick 60s linear infinite;
}
.cp__marquee-track span{display:inline-flex;align-items:center;gap:6px}

/* 404 / hidden */
.cardpage__empty{
  max-width:520px;margin:60px auto;
  text-align:center;padding:42px 30px;
  border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow);
}
.cardpage__empty-mark{
  font-family:"Playfair Display",serif;font-size:96px;line-height:1;
  color:var(--ink);margin-bottom:14px;font-style:italic;
}
.cardpage__empty div{font-family:"Playfair Display",serif;font-size:28px;line-height:1.1;margin-bottom:6px}
.cardpage__empty p{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);margin-top:10px;letter-spacing:.04em}
.cardpage__empty b{background:var(--bg-2);padding:0 6px;border:1.5px solid var(--ink);font-weight:700}

/* responsive — на узких уходит в колонку */
@media (max-width:780px){
  .cp__id{grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:12px}
  .cp__open{grid-column:1/-1;justify-self:stretch;text-align:center;justify-content:center}
  .cp__body{grid-template-columns:1fr}
}

/* ===== modal ===== */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:32px}
.modal[hidden]{display:none}
.modal__bg{position:absolute;inset:0;background:rgba(12,12,12,.72);cursor:pointer}
.modal__win{
  position:relative;z-index:1;
  width:min(880px,100%);max-height:calc(100vh - 64px);
  background:var(--paper);border:2px solid var(--ink);box-shadow:10px 10px 0 var(--ink);
  display:flex;flex-direction:column;
  animation:popin .18s cubic-bezier(.2,.9,.2,1.2);
}
@keyframes popin{from{transform:translate(8px,8px) scale(.98);opacity:0}to{transform:none;opacity:1}}

.modal__hd{
  display:flex;align-items:center;gap:10px;
  background:var(--ink);color:var(--bg);
  padding:10px 14px;
  font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;
  border-bottom:2px solid var(--ink);
  flex-shrink:0;
}
.modal__hd .card__type{border-color:var(--bg)}
.modal__hd .modal__num{color:var(--muted);margin-left:auto}
.modal__hd .modal__close{
  margin-left:8px;
  width:30px;height:30px;display:inline-grid;place-items:center;
  border:2px solid var(--bg);font-size:16px;line-height:1;font-weight:700;
  background:var(--ink);color:var(--bg);
  transition:transform .08s, background .12s, color .12s;
}
.modal__hd .modal__close:hover{background:var(--hot);color:var(--paper);transform:rotate(90deg)}

.modal__body{overflow:auto;padding:24px 28px 28px}
.modal__title{
  font-family:"Playfair Display",serif;font-weight:400;
  font-size:clamp(36px,5vw,64px);line-height:.98;letter-spacing:-.02em;
}
.modal__handle{
  display:inline-block;margin-top:6px;
  font-family:"JetBrains Mono",monospace;font-size:14px;
  background:var(--bg-2);border:1.5px solid var(--ink);padding:3px 8px;color:var(--ink);
}

.modal__metrics{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  border:2px solid var(--ink);margin:22px 0 0;
}
.modal__metric{
  padding:12px 14px;border-right:1px dashed var(--ink);
}
.modal__metric:last-child{border-right:0}
.modal__metric b{display:block;font-family:"JetBrains Mono",monospace;font-size:22px;font-weight:700;line-height:1}
.modal__metric span{display:block;margin-top:4px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.05em}

.modal__sect{margin-top:24px}
.modal__sect h4{
  display:inline-block;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.1em;
  background:var(--ink);color:var(--acid);padding:3px 8px;margin-bottom:10px;
}
.modal__sect p{font-size:15px;color:var(--ink-2);max-width:64ch}
.modal__sect p + p{margin-top:8px}

.modal__list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:0;border:2px solid var(--ink);margin-top:8px}
.modal__list li{
  padding:8px 12px;
  border-right:1px dashed var(--ink);border-bottom:1px dashed var(--ink);
  font-family:"JetBrains Mono",monospace;font-size:12px;
  display:flex;justify-content:space-between;gap:8px;
}
.modal__list li b{color:var(--ink);font-weight:700}
.modal__list li span{color:var(--muted)}

.modal__tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}

.modal__cta{
  display:flex;gap:12px;flex-wrap:wrap;
  margin-top:26px;padding-top:20px;border-top:2px dashed var(--ink);
}
.modal__cta .btn--big{padding:14px 22px;font-size:14px;flex:1;min-width:200px;justify-content:center}
.modal__report{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-left:auto;align-self:center}
.modal__report:hover{color:var(--hot)}

.modal__foot{
  padding:10px 14px;border-top:2px solid var(--ink);background:var(--bg-2);
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  flex-shrink:0;
}
.modal__foot b{color:var(--ink);font-weight:700}

.modal__nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  width:48px;height:48px;
  border:2px solid var(--ink);background:var(--paper);
  font-family:"Playfair Display",serif;font-size:24px;line-height:1;
  box-shadow:var(--shadow-sm);
  transition:transform .1s, background .12s;
}
.modal__nav--prev{left:24px}
.modal__nav--next{right:24px}
.modal__nav:hover{background:var(--acid);transform:translateY(-50%) translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.modal__nav--next:hover{transform:translateY(-50%) translate(-2px,-2px)}

/* card is now clickable */
.card{cursor:pointer}
.card__cta{cursor:pointer}

@media (max-width:680px){
  .modal{padding:0}
  .modal__win{max-height:100vh;height:100vh;box-shadow:none;border-left:0;border-right:0}
  .modal__nav{display:none}
}

/* ===== cursor ===== */
.cursor{
  position:fixed;left:0;top:0;width:28px;height:28px;
  pointer-events:none;z-index:9999;
  color:#fff;                       /* белый + difference = инверсия фона */
  transform:translate(-50%,-50%) rotate(0deg);
  transition:transform .15s cubic-bezier(.2,.8,.2,1), color .12s;
  mix-blend-mode:difference;
}
.cursor svg{display:block;width:100%;height:100%;overflow:visible}
.cursor svg line{stroke:currentColor;stroke-width:1.5;stroke-linecap:square}
.cursor svg circle{fill:currentColor}
.cursor.is-hot{
  color:var(--acid);
  transform:translate(-50%,-50%) rotate(45deg) scale(1.2);
}
.cursor.is-hot svg line{stroke-width:2}

/* selection */
::selection{background:var(--acid);color:var(--ink)}

/* ===== responsive ===== */
@media (max-width:1024px){
  .hero__grid{grid-template-columns:1fr}
  .cat__layout{grid-template-columns:1fr}
  .filters{position:static}
  .mani,.cab__inner{grid-template-columns:1fr;gap:24px}
}
@media (max-width:680px){
  .hdr{grid-template-columns:1fr auto}
  .hdr__nav{display:none}
  .ft{grid-template-columns:1fr;text-align:left}
  .ft__r,.ft__c{text-align:left;justify-content:flex-start}
  .form{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
}
/* ===== страница поста (post.html) ===== */
.pp{
  max-width:760px;margin:0 auto;
  padding:18px 24px 24px;
}
.pp__author{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:14px;align-items:center;
  padding:14px;
  border:2px solid var(--ink);background:var(--paper);
  box-shadow:var(--shadow-sm);
  margin-bottom:18px;
}
.pp__author-av{display:block;flex-shrink:0}
.pp__author-av .av{width:64px;height:64px;box-shadow:3px 3px 0 var(--ink)}
.pp__author-av .av .av__init{font-size:32px}
.pp__author-text{min-width:0}
.pp__author-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:4px}
.pp__date{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em}
.pp__author-name{
  display:block;
  font-family:"Playfair Display",serif;font-size:22px;line-height:1;letter-spacing:-.01em;
  color:var(--ink);text-decoration:none;margin-bottom:2px;
}
.pp__author-name:hover{background:var(--acid)}
.pp__handle{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted)}
.pp__back-card{padding:8px 12px;font-size:11px;white-space:nowrap}

.pp__img{
  width:100%;
  border:2px solid var(--ink);background:var(--bg-2);
  overflow:hidden;
  margin-bottom:18px;
  box-shadow:var(--shadow-sm);
}
.pp__img img{display:block;width:100%;height:auto;filter:contrast(1.05) saturate(.95)}

.pp__text{
  font-size:17px;line-height:1.55;color:var(--ink);
  white-space:pre-wrap;word-wrap:break-word;
  padding:16px 18px;
  border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);
}

.pp__foot{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap;
  padding:10px 14px;
  border:2px solid var(--ink);background:var(--bg-2);
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em;
  margin-top:14px;
}
.pp__foot b{color:var(--ink);font-weight:700;margin-left:4px}
.pp__foot-link{color:var(--ink);font-weight:700}

.pp__more{margin-top:30px}
.pp__more-hd{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  border-top:2px dashed var(--ink);padding-top:18px;margin-bottom:16px;
}
.pp__more-hd h3{
  font-family:"Playfair Display",serif;font-weight:400;
  font-size:24px;line-height:1;letter-spacing:-.01em;margin:0;
}
.pp__more-hd em{font-style:italic;background:var(--ink);color:var(--acid);padding:0 6px}
.pp__more-all{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink);
  border:2px solid var(--ink);background:var(--paper);padding:5px 9px;
  letter-spacing:.04em;font-weight:700;
}
.pp__more-all:hover{background:var(--acid)}
.pp__more-list{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}

@media (max-width:680px){
  .pp__author{grid-template-columns:auto 1fr}
  .pp__back-card{grid-column:1/-1;justify-self:start}
  .pp__text{font-size:16px;padding:14px}
}


/* баннер для владельца на странице карточки (когда статус не "approved") */
.cp__owner-banner{
  display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  border:2px solid var(--ink);background:#ffd400;color:var(--ink);
  padding:11px 14px;margin-bottom:14px;
  font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:700;letter-spacing:.04em;
}
.cp__owner-banner--rejected,
.cp__owner-banner--blocked{
  background:var(--hot);color:var(--paper);border-color:var(--hot);
}
.cp__owner-banner-tip{font-weight:400;opacity:.75;font-size:11px}

/* кнопка-стрелка «посмотреть» рядом с названием в таблице кабинета */
.cab__preview{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;line-height:1;
  margin-left:6px;
  font-family:"JetBrains Mono",monospace;font-size:13px;font-weight:700;
  color:var(--ink);background:var(--bg-2);border:1.5px solid var(--ink);
  vertical-align:middle;
  text-decoration:none;
}
.cab__preview:hover{background:var(--acid)}

/* owner-pending: твоя карточка, ещё не одобренная админом — видна тебе в каталоге */
.card.is-mine-pending{
  background:#fffae0;
  outline:2px dashed var(--ink);
  outline-offset:-2px;
}
.card.is-mine-pending::before{
  content:"⏳ ВАША · НА МОДЕРАЦИИ";
  position:absolute;top:-2px;left:-2px;
  background:#ffd400;color:var(--ink);
  padding:3px 8px;
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.1em;font-weight:700;
  z-index:2;
}

/* блок команд в формах */
.cab__add div[data-bot-only][hidden]{display:none}
.cmds-block, .ed__cmds-block{display:flex;flex-direction:column;gap:8px}
.cmds-lbl{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;color:var(--muted);
}
.cmds-rows{display:flex;flex-direction:column;gap:6px}
.cmds-row{display:grid;grid-template-columns:140px 1fr auto;gap:6px}
.cmds-row input{
  border:2px solid var(--ink);padding:8px 10px;background:var(--paper);
  font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--ink);
}
.cmds-row input:focus{box-shadow:inset 0 0 0 2px var(--acid)}
.cmds-row input[name="cmd[]"]{font-weight:700}
.cmds-rm{
  width:34px;border:2px solid var(--ink);background:var(--paper);
  font-size:16px;font-weight:700;line-height:1;cursor:pointer;
  display:inline-grid;place-items:center;
}
.cmds-rm:hover{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.cmds-add{
  align-self:flex-start;
  border:2px solid var(--ink);background:var(--paper);
  padding:7px 12px;
  font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.06em;
  cursor:pointer;box-shadow:var(--shadow-sm);
  transition:transform .08s, background .12s;
}
.cmds-add:hover{transform:translate(-2px,-2px);background:var(--acid)}

/* команды на странице карточки бота */
.cp__cmds{
  margin-top:10px;
  border:2px solid var(--ink);background:var(--paper);
  max-height:200px;overflow:auto;
}
.cp__cmds-hd{
  background:var(--ink);color:var(--bg);
  padding:6px 10px;
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.1em;
}
.cp__cmds ul{margin:0;padding:0;list-style:none}
.cp__cmds li{
  padding:6px 10px;border-top:1px dashed var(--ink);
  font-family:"JetBrains Mono",monospace;font-size:12px;line-height:1.4;color:var(--ink);
  display:flex;gap:6px;align-items:baseline;flex-wrap:wrap;word-break:break-word;
}
.cp__cmds li:first-child{border-top:0}
.cp__cmds li b{font-weight:700;white-space:nowrap;color:var(--ink)}
.cp__cmds li span{color:var(--ink-2);font-weight:400}

@media (max-width:560px){
  .cmds-row{grid-template-columns:1fr auto}
  .cmds-row input[name="cmd[]"]{grid-column:1/-1}
}

/* бейдж языка — рядом с типом */
.card__lang{
  display:inline-flex;align-items:center;
  font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:700;letter-spacing:.08em;
  background:var(--bg-2);color:var(--ink);
  border:1.5px solid var(--ink);
  padding:2px 6px;
}

/* кнопка «пройти модерацию» — для партнёрок в pending */
.cab__act--mod{
  background:var(--ink);color:var(--acid);border-color:var(--ink);
  text-decoration:none;
  display:inline-flex;align-items:center;
}
.cab__act--mod:hover{background:var(--acid);color:var(--ink);border-color:var(--ink)}

/* ===== подборки: список ===== */
.col-list-wrap{padding:24px 28px;border-bottom:2px solid var(--ink)}
.col-list{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));max-width:1400px;margin:0 auto}
.col-empty{padding:60px 30px;text-align:center;font-family:"JetBrains Mono",monospace;color:var(--muted);font-size:12px;border:2px dashed var(--ink);grid-column:1/-1}

.col-card{
  display:flex;flex-direction:column;
  border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);
  color:var(--ink);text-decoration:none;overflow:hidden;
  transition:transform .08s, box-shadow .08s;
}
.col-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.col-card__cover{aspect-ratio:2/1;background:var(--bg-2);overflow:hidden;border-bottom:2px solid var(--ink)}
.col-card__cover img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.col-card__cover--ghost{
  background:
    repeating-linear-gradient(135deg, transparent 0 18px, rgba(12,12,12,.07) 18px 19px),
    var(--bg-2);
  display:flex;align-items:center;justify-content:center;
}
.col-card__cover--ghost span{
  font-family:"Playfair Display",serif;font-style:italic;font-size:24px;
  color:var(--ink);opacity:.6;text-align:center;padding:0 14px;
}
.col-card__b{padding:14px;display:flex;flex-direction:column;gap:6px;flex:1}
.col-card__t{
  font-family:"Playfair Display",serif;font-weight:400;font-size:22px;line-height:1.15;
  margin:0;letter-spacing:-.01em;
}
.col-card__m{
  margin-top:auto;display:flex;justify-content:space-between;gap:8px;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em;
}
.col-card__by{color:var(--ink);font-weight:700}

/* ===== просмотр подборки ===== */
.col-view{max-width:880px;margin:0 auto;padding:24px 4px 48px}
.col-view__cover{
  width:100%;aspect-ratio:2/1;max-height:400px;
  border:2px solid var(--ink);background:var(--bg-2);overflow:hidden;
  box-shadow:var(--shadow-sm);margin-bottom:18px;
}
.col-view__cover img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.col-view__cover--ghost{
  background:
    repeating-linear-gradient(135deg, transparent 0 22px, rgba(12,12,12,.07) 22px 23px),
    var(--bg-2);
  display:flex;align-items:center;justify-content:center;
}
.col-view__cover--ghost span{
  font-family:"Playfair Display",serif;font-style:italic;font-size:clamp(40px, 7vw, 90px);
  color:var(--ink);opacity:.5;text-align:center;padding:0 24px;
}
.col-view__title{
  font-family:"Playfair Display",serif;font-weight:400;
  font-size:clamp(36px, 5vw, 60px);line-height:1;letter-spacing:-.02em;margin:0 0 10px;
}
.col-view__meta{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);letter-spacing:.04em;
  margin-bottom:18px;
}
.col-view__meta span:first-child{color:var(--ink);font-weight:700}
.col-view__edit, .col-view__del{
  background:var(--paper);border:1.5px solid var(--ink);padding:3px 7px;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink);
  text-decoration:none;cursor:pointer;font-weight:700;
}
.col-view__edit:hover{background:var(--acid)}
.col-view__del{color:var(--hot)}
.col-view__del:hover{background:var(--hot);color:var(--paper);border-color:var(--hot)}
.col-view__text{
  font-size:16px;line-height:1.5;color:var(--ink-2);
  padding:14px 16px;margin-bottom:18px;
  border-left:4px solid var(--ink);background:var(--bg-2);
}
.col-view__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.col-row{
  display:grid;grid-template-columns:40px auto 1fr auto;gap:14px;align-items:center;
  padding:12px;border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);
}
.col-row__num{
  font-family:"Playfair Display",serif;font-style:italic;font-size:36px;line-height:1;
  color:var(--ink);text-align:center;
}
.col-row__b{min-width:0}
.col-row__top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:2px}
.col-row__name{
  font-family:"Playfair Display",serif;font-size:20px;line-height:1.1;color:var(--ink);
  text-decoration:none;letter-spacing:-.01em;
}
.col-row__name:hover{background:var(--acid)}
.col-row__h{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.col-row__d{font-size:13px;color:var(--ink-2);margin:4px 0 0;line-height:1.4}
.col-row__open{white-space:nowrap;padding:8px 12px;font-size:11px}
.col-row--empty{
  padding:30px;text-align:center;font-family:"JetBrains Mono",monospace;
  color:var(--muted);font-size:12px;grid-template-columns:1fr;border:2px dashed var(--ink);box-shadow:none;
}

@media (max-width:680px){
  .col-row{grid-template-columns:32px auto 1fr;gap:10px}
  .col-row__open{grid-column:1/-1;justify-self:start}
  .col-view__meta{font-size:11px}
}

/* ===== редактор подборки ===== */
.col-edit{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.col-edit__sect{border:2px solid var(--ink);background:var(--paper);padding:18px;box-shadow:var(--shadow-sm)}
.col-edit__cover{
  width:100%;aspect-ratio:2/1;max-height:300px;
  border:2px dashed var(--ink);background:var(--paper);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  cursor:pointer;overflow:hidden;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.06em;
}
.col-edit__cover:hover{background:var(--acid);color:var(--ink)}
.col-edit__cover img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.col-edit__cover-plus{font-family:"Playfair Display",serif;font-size:40px;line-height:1;color:var(--ink)}

.col-edit__chosen{display:flex;flex-direction:column;gap:6px}
.col-pick-row{
  display:grid;grid-template-columns:32px auto 1fr auto;gap:10px;align-items:center;
  padding:8px 10px;border:1.5px solid var(--ink);background:var(--bg-2);
}
.col-pick-row__num{font-family:"Playfair Display",serif;font-style:italic;font-size:22px;text-align:center;color:var(--ink)}
.col-pick-row__b{min-width:0}
.col-pick-row__b b{font-size:14px}
.col-pick-row__acts{display:flex;gap:4px}
.col-pick-row__acts .cmds-rm{width:28px;height:28px;font-size:14px}
.col-pick-empty{
  padding:24px;text-align:center;font-family:"JetBrains Mono",monospace;font-size:12px;
  color:var(--muted);border:2px dashed var(--ink);
}

.col-edit__results{display:flex;flex-direction:column;gap:6px;margin-top:10px;max-height:360px;overflow-y:auto}
.col-pick-result{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:10px;align-items:center;
  padding:8px 10px;border:1.5px solid var(--ink);background:var(--paper);
  cursor:pointer;text-align:left;
  font-family:"Space Grotesk",sans-serif;
}
.col-pick-result:hover{background:var(--acid)}
.col-pick-result__b{min-width:0}
.col-pick-result__b b{font-size:13px;display:block}
.col-pick-result__add{
  font-size:18px;font-weight:700;color:var(--ink);
  width:24px;height:24px;border:1.5px solid var(--ink);display:inline-grid;place-items:center;
  background:var(--paper);
}
.col-pick-result:hover .col-pick-result__add{background:var(--ink);color:var(--acid)}

.col-edit__actions{display:flex;gap:10px;align-items:center}

@media (max-width:560px){
  .col-pick-result{grid-template-columns:auto 1fr auto;gap:8px}
  .col-pick-result .card__type{display:none}

/* статусы подборок в списке collections.html */
.col-card.is-mine-pending{background:#fffae0;outline:2px dashed var(--ink);outline-offset:-2px}
.col-card__bdg{
  display:inline-block;margin-left:8px;
  font-family:"JetBrains Mono",monospace;font-size:9px;font-weight:700;letter-spacing:.08em;
  padding:2px 5px;border:1.5px solid var(--ink);vertical-align:middle;
}
.col-card__bdg--pend{background:#ffd400;color:var(--ink)}
.col-card__bdg--rej{background:var(--hot);color:var(--paper);border-color:var(--hot)}

/* счётчик карточек рядом с темой в фильтре */
.filters__list-cnt{
  margin-left:auto;font-style:normal;
  font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);font-weight:400;
}

