/* ВФОРУМЕ — глобальные стили.
   Источник: index.html (макет). Переменные/именование — без изменений. */

:root {
  --cp:#35524A; --cpl:#4D6B63; --cps:#6E8A80;
  --ca:#B48C67; --cal:#D2B49A;
  --bg:#F5F3ED; --sf:#FAF8F4; --cd:#FFFFFF;
  --t1:#232527; --t2:#66706C; --tm:#97A09B;
  --bd:#E5E0D7; --dv:#ECE7DF;
  --ok:#4C7A5B; --er:#B35A5A;
  --gp:linear-gradient(135deg,#35524A 0%,#46645B 45%,#6E8A80 100%);
  --ga:linear-gradient(135deg,#B48C67 0%,#D2B49A 100%);
  --fh:"Manrope",sans-serif; --fb:"Inter",sans-serif;
  --sc:0 2px 12px rgba(17,24,39,.05);
  --sh:0 10px 36px rgba(17,24,39,.10);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--fb);background:var(--bg);color:var(--t1);display:flex;min-height:100vh;font-size:14px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* ═══ SIDEBAR ═══ */
.sb{
  width:240px;min-width:240px;
  background:var(--cd);
  border-right:1px solid var(--bd);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
  overflow-y:auto;overflow-x:hidden;
}
.sb::-webkit-scrollbar{width:0}

.sb-logo{
  /* Компактный паддинг подобран чтобы общая высота блока (логотип 44px + 9+9 padding + 1px border = 63px)
     совпадала с высотой топбара (tbtn 40px + 11+11 padding + 1px border = 63px) → визуально одна верхняя линия */
  padding:9px 20px;
  display:flex;align-items:center;gap:12px;
  border-bottom:1px solid var(--dv);
  flex-shrink:0;
}
.logo-svg{width:44px;height:44px;flex-shrink:0}
.logo-t{font-family:var(--fh);font-size:14px;font-weight:800;color:var(--t1);letter-spacing:.04em;text-transform:uppercase;line-height:1.1}
.logo-s{font-size:10px;color:var(--tm);margin-top:2px;font-weight:500}

.sb-nav{padding:10px 0;flex:1}
.ni{
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;
  font-size:13px;font-weight:500;
  color:var(--t2);cursor:pointer;
  border-radius:10px;margin:1px 10px;
  transition:all .15s;position:relative;
  white-space:nowrap;
}
.ni:hover{background:var(--sf);color:var(--t1)}
.ni.on{background:var(--cp);color:#fff;font-weight:600}
.ni.on svg{stroke:#fff!important;opacity:1!important}
.ni svg{width:18px;height:18px;stroke:var(--tm);flex-shrink:0;opacity:.85}
.nb{
  margin-left:auto;
  background:var(--ca);color:#fff;
  font-size:10px;font-weight:700;
  padding:2px 7px;border-radius:999px;
  min-width:20px;text-align:center;
}
.ni.on .nb{background:rgba(255,255,255,.25)}
.sdiv{height:1px;background:var(--dv);margin:6px 18px}

.dot-bullet{
  width:6px;height:6px;border-radius:50%;
  background:var(--ca);position:absolute;left:0;top:50%;transform:translateY(-50%);
}
.ni.has-dot{padding-left:18px}

.sb-wgt{
  margin:10px 12px 14px;
  background:var(--sf);
  border:1px solid var(--bd);
  border-radius:16px;
  padding:14px 14px 12px;
  flex-shrink:0;
  text-align:center;
}
.wgt-lbl{font-size:11px;font-weight:600;color:var(--t2);margin-bottom:6px}
.net-svg{width:100%;display:block;margin:0 auto 4px;height:80px}
.wgt-num{font-family:var(--fh);font-size:28px;font-weight:800;color:var(--cp);line-height:1;margin-top:2px}
.wgt-sub{font-size:11px;color:var(--tm);margin-top:3px;margin-bottom:10px;line-height:1.4}
.btn-find{
  display:block;width:100%;
  background:var(--cp);color:#fff;
  border:none;border-radius:999px;
  padding:10px 0;font-size:13px;font-weight:600;
  cursor:pointer;text-align:center;
  font-family:var(--fb);transition:background .2s;
}
.btn-find:hover{background:var(--cpl)}

.sb-products{padding:0 12px 10px;margin-top:4px;border-top:1px solid var(--dv);flex-shrink:0}
.sb-products-lbl{font-size:10px;font-weight:700;color:var(--tm);text-transform:uppercase;letter-spacing:.08em;padding:10px 4px 6px}
.ni.ni-ext{background:rgba(180,140,103,.06);border:1px solid rgba(180,140,103,.20);color:var(--ca);font-weight:600;margin:0;padding:10px 14px}
.ni.ni-ext svg:first-of-type{stroke:var(--ca)!important;opacity:1!important}
.ni.ni-ext .ext-ic{margin-left:auto;width:13px;height:13px;stroke:var(--ca);opacity:.65;flex-shrink:0}
.ni.ni-ext:hover{background:rgba(180,140,103,.13);color:var(--ca)}
.sb-foot{padding:6px 0 12px;border-top:1px solid var(--dv);flex-shrink:0}

/* ═══ MAIN ═══ */
.mn{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}

.top{
  background:var(--cd);
  border-bottom:1px solid var(--bd);
  padding:11px 24px;
  display:flex;align-items:center;gap:14px;
  flex-shrink:0;
  position:sticky;top:0;z-index:10;
}
.srch{flex:1;max-width:680px;position:relative}
.srch input{
  width:100%;
  background:var(--sf);
  border:1px solid var(--bd);
  border-radius:999px;
  padding:10px 18px 10px 42px;
  font-family:var(--fb);font-size:13px;
  color:var(--t1);outline:none;
  transition:border .2s;
}
.srch input:focus{border-color:var(--cps);background:var(--cd)}
.srch input::placeholder{color:var(--tm)}
.srch-ic{position:absolute;left:14px;top:50%;transform:translateY(-50%);pointer-events:none}
.srch-ic svg{width:16px;height:16px;stroke:var(--tm)}
.top-r{margin-left:auto;display:flex;align-items:center;gap:12px}
.tbtn{
  width:40px;height:40px;border-radius:50%;
  background:var(--sf);border:1px solid var(--bd);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;position:relative;transition:background .15s;
}
.tbtn:hover{background:var(--bg)}
.tbtn svg{width:18px;height:18px;stroke:var(--t2)}
.tbn{
  position:absolute;top:-3px;right:-3px;
  background:var(--ca);color:#fff;
  font-size:10px;font-weight:700;
  min-width:18px;height:18px;
  border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--cd);padding:0 4px;
}
.tav{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,#d8b8a0 0%,#b88e6e 60%,#8a5e44 100%);
  display:flex;align-items:flex-end;justify-content:center;
  color:#fff;font-size:13px;font-weight:700;
  font-family:var(--fh);cursor:pointer;
  border:2px solid var(--bd);overflow:hidden;
  flex-shrink:0;position:relative;
}
.tav::before{
  content:"";position:absolute;top:18%;left:50%;transform:translateX(-50%);
  width:42%;height:42%;border-radius:50%;background:rgba(255,255,255,.55);
}
.tav::after{
  content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:75%;height:55%;border-radius:50% 50% 0 0;background:rgba(255,255,255,.5);
}
.tname{
  font-size:14px;font-weight:600;color:var(--t1);
  cursor:pointer;display:flex;align-items:center;gap:4px;margin-left:4px;
}
.tname svg{width:14px;height:14px;stroke:var(--tm)}

/* Topbar — auth buttons для гостей */
.top-auth{display:flex;align-items:center;gap:10px}
.top-auth .btn-login{
  background:transparent;color:var(--t2);
  border:1px solid var(--bd);border-radius:999px;
  padding:8px 18px;font-size:13px;font-weight:500;
  cursor:pointer;font-family:var(--fb);transition:all .15s;
}
.top-auth .btn-login:hover{border-color:var(--cps);color:var(--cp)}
.top-auth .btn-register{
  background:var(--cp);color:#fff;
  border:none;border-radius:999px;
  padding:9px 20px;font-size:13px;font-weight:600;
  cursor:pointer;font-family:var(--fb);transition:background .2s;
}
.top-auth .btn-register:hover{background:var(--cpl)}

.cw{flex:1;display:flex;min-width:0}

.fd{flex:1;min-width:0;padding:18px 24px 60px}

.frow{display:flex;align-items:center;gap:7px;margin-bottom:18px;flex-wrap:wrap}
.fch{
  padding:8px 16px;border-radius:999px;
  font-size:13px;font-weight:500;cursor:pointer;
  border:1px solid var(--bd);background:var(--cd);
  color:var(--t2);transition:all .15s;white-space:nowrap;
}
.fch:hover{border-color:var(--cps);color:var(--cp)}
.fch.on{background:var(--cp);color:#fff;border-color:var(--cp);font-weight:600}
.fflt{
  margin-left:auto;display:flex;align-items:center;gap:6px;
  font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;
  padding:6px 8px;
}
.fflt svg{width:16px;height:16px;stroke:var(--tm)}

.int-blk{
  background:var(--cd);
  border:1px solid var(--bd);
  border-radius:16px;
  padding:18px 22px 20px;
  margin-bottom:14px;
  box-shadow:var(--sc);
  position:relative;
}
.int-q{font-family:var(--fh);font-size:15px;font-weight:700;margin-bottom:4px;color:var(--t1)}
.int-s{font-size:12px;color:var(--tm);margin-bottom:16px}
.int-grid{
  display:grid;grid-template-columns:repeat(8,1fr) auto;gap:10px;align-items:flex-start;
}
.ich{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .15s}
.ich:hover .ich-ic{border-color:var(--ca);background:#fff}
.ich-ic{
  width:54px;height:54px;border-radius:50%;
  background:var(--cd);border:1.5px solid var(--cal);
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.ich-ic svg{width:22px;height:22px;stroke:var(--ca)}
.ich-lbl{font-size:12px;color:var(--t2);white-space:nowrap;text-align:center;line-height:1.2}
.ich-arr{
  width:38px;height:38px;border-radius:50%;
  background:var(--cd);border:1px solid var(--bd);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;margin-top:8px;
}
.ich-arr svg{width:16px;height:16px;stroke:var(--t2)}

.card{
  background:var(--cd);border:1px solid var(--bd);
  border-radius:16px;padding:18px 20px;
  margin-bottom:14px;box-shadow:var(--sc);
  transition:all .2s;
}
.card:hover{box-shadow:var(--sh);transform:translateY(-1px)}

.card-topbadge{padding:14px 20px 0}
.card.has-topbadge{padding-top:0}
.card-topbadge .evb{margin-bottom:14px}

.ch{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.cav{
  width:40px;height:40px;border-radius:50%;
  background:var(--gp);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:13px;font-weight:700;
  font-family:var(--fh);flex-shrink:0;overflow:hidden;position:relative;
}
.cav.photo-m1{background:radial-gradient(circle at 50% 35%,#f0d8c0 0%,#c89878 35%,#5e3a28 75%,#2a1810 100%)}
.cav.photo-w1{background:radial-gradient(circle at 50% 32%,#f6e0cc 0%,#d8a888 38%,#7a4a3a 80%,#3a2018 100%)}
.cav.photo-m2{background:radial-gradient(circle at 50% 32%,#e8c8a8 0%,#b88860 40%,#503020 80%,#1e1208 100%)}
.cav::after{content:"";position:absolute;top:14%;left:50%;transform:translateX(-50%);width:38%;height:34%;border-radius:50%;background:rgba(255,255,255,.18);filter:blur(2px)}
.cav span{position:relative;z-index:2;opacity:0;display:none}
.cm{flex:1;min-width:0}
.cn{font-size:14px;font-weight:600;color:var(--t1)}
.cg{font-size:12px;color:var(--tm);margin-top:2px}
.ct{font-size:12px;color:var(--tm);white-space:nowrap}
.cm3{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;margin-left:6px}
.cm3:hover{background:var(--sf)}
.cm3 svg{width:18px;height:18px;stroke:var(--tm)}

.cimg-big{
  width:100%;height:300px;border-radius:12px;
  margin-bottom:14px;overflow:hidden;position:relative;
  background:
    radial-gradient(ellipse 38% 30% at 50% 42%, #fff7c8 0%, #f5b870 18%, #c8682c 38%, transparent 70%),
    linear-gradient(180deg, #b8c5b0 0%, #9aa890 20%, #7a8a70 35%, #4e6a52 50%, #1e2a18 65%, #0a1208 100%);
}
.cimg-big::before{
  content:"";position:absolute;inset:50% 0 0 0;
  background:
    radial-gradient(ellipse 18% 8% at 50% 5%, rgba(255,210,140,.7), transparent 70%),
    linear-gradient(180deg, #50544a 0%, #2a3028 30%, #0a1008 100%);
  opacity:.85;
}
.cimg-big::after{
  content:"";position:absolute;left:0;right:0;bottom:14%;height:18%;
  background:
    radial-gradient(ellipse 3% 50% at 22% 50%, #1a1a18, transparent 70%),
    radial-gradient(ellipse 3% 55% at 30% 50%, #1a1a18, transparent 70%),
    radial-gradient(ellipse 3% 55% at 38% 50%, #1a1a18, transparent 70%),
    radial-gradient(ellipse 3% 58% at 46% 50%, #1a1a18, transparent 70%),
    radial-gradient(ellipse 3% 55% at 54% 50%, #1a1a18, transparent 70%),
    radial-gradient(ellipse 3% 55% at 62% 50%, #1a1a18, transparent 70%),
    radial-gradient(ellipse 3% 50% at 70% 50%, #1a1a18, transparent 70%);
}
.cimg-sm{
  width:200px;min-width:200px;height:140px;
  border-radius:12px;overflow:hidden;flex-shrink:0;
  position:relative;
}
.cimg-sm.rest{
  background:
    radial-gradient(ellipse 12% 8% at 30% 22%, #ffd080, transparent 70%),
    radial-gradient(ellipse 12% 8% at 55% 18%, #ffc870, transparent 70%),
    radial-gradient(ellipse 10% 6% at 78% 25%, #ffb858, transparent 70%),
    linear-gradient(170deg, #2e1a10 0%, #4a2a18 30%, #6a3e20 55%, #4a2a18 80%, #1e0e08 100%);
}
.cimg-sm.spk{
  background:
    radial-gradient(ellipse 28% 38% at 40% 45%, #2a3548 0%, transparent 70%),
    linear-gradient(160deg, #d8c8b0 0%, #b89878 30%, #6a5848 55%, #2e2418 100%);
  position:relative;
}
.cimg-sm.spk::after{
  content:"";position:absolute;left:30%;top:18%;width:32%;height:55%;
  border-radius:42% 42% 38% 38%;
  background:linear-gradient(180deg,#e8c8a8 0%,#b88e6e 40%,#3e2a1e 80%);
}
.cimg-sm.fst{
  background:linear-gradient(135deg,#0a2010 0%,#1e3a22 35%,#3a5a3e 60%,#6a8a62 100%);
}

.cbr{display:flex;gap:16px;align-items:flex-start}
.ctl{font-family:var(--fh);font-size:22px;font-weight:700;line-height:1.25;margin-bottom:8px;color:var(--t1);letter-spacing:-.01em}
.ctl.sm{font-size:17px;line-height:1.35}
.ctx{font-size:14px;color:var(--t2);line-height:1.6;margin-bottom:12px}
.ctags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px}
.tag{
  padding:5px 12px;
  background:var(--sf);border:1px solid var(--bd);
  border-radius:999px;font-size:12px;color:var(--t2);
}

.cft{display:flex;align-items:center;padding-top:12px;border-top:1px solid var(--dv);gap:6px}
.ca{
  display:flex;align-items:center;gap:6px;
  font-size:13px;color:var(--tm);cursor:pointer;
  padding:6px 12px;border-radius:8px;transition:all .15s;
}
.ca:hover{background:var(--sf);color:var(--t1)}
.ca.lk{color:var(--er)}
.ca.lk .heart-fill{fill:var(--er);stroke:var(--er)}
.ca svg{width:18px;height:18px;stroke:currentColor;flex-shrink:0}
.ca .num{font-weight:600;color:var(--t1)}
.ca.lk .num{color:var(--er)}
.cavs{margin-left:auto;display:flex;align-items:center}
.mav{
  width:30px;height:30px;border-radius:50%;
  border:2px solid var(--cd);
  margin-left:-8px;font-size:9px;color:#fff;
  font-weight:700;display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);overflow:hidden;position:relative;
}
.mav:first-child{margin-left:0}
.mav.p1{background:radial-gradient(circle at 50% 35%,#f0d8c0 0%,#c89878 40%,#5e3a28 80%)}
.mav.p2{background:radial-gradient(circle at 50% 35%,#f6e0cc 0%,#d8a888 40%,#7a4a3a 80%)}
.mav.p3{background:radial-gradient(circle at 50% 35%,#f0d0b8 0%,#c08868 40%,#604028 80%)}
.mav.p4{background:radial-gradient(circle at 50% 35%,#e8c8a8 0%,#b88860 40%,#503020 80%)}
.mav.mr{background:var(--sf);color:var(--t2);font-size:11px;font-weight:600;border-color:var(--bd)}

.evb{
  display:inline-flex;align-items:center;gap:7px;
  padding:5px 12px;border-radius:999px;
  font-size:12px;font-weight:600;
}
.evb.pt{background:rgba(76,122,91,.12);color:var(--ok)}
.evb.cm{background:rgba(180,140,103,.12);color:var(--ca)}
.evb-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.evb.pt .evb-dot{background:var(--ok)}
.evb.cm .evb-dot{background:var(--ca)}

.emeta{display:flex;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--tm);margin:10px 0 0}
.emeta span{display:flex;align-items:center;gap:5px}
.emeta svg{width:14px;height:14px;stroke:currentColor}

.eft{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--dv);margin-top:14px}
.att{display:flex;align-items:center;gap:10px}
.atxt{font-size:13px;color:var(--tm)}
.btn-g{
  background:var(--cp);color:#fff;border:none;
  border-radius:999px;padding:10px 24px;
  font-size:13px;font-weight:600;cursor:pointer;
  font-family:var(--fb);transition:background .2s;
}
.btn-g:hover{background:var(--cpl)}
.btn-o{
  background:transparent;color:var(--t2);
  border:1px solid var(--bd);border-radius:999px;
  padding:10px 20px;font-size:13px;font-weight:500;
  cursor:pointer;font-family:var(--fb);
}

/* ═══ RIGHT COLUMN ═══ */
.rc{
  width:320px;min-width:320px;
  padding:18px 24px 60px 0;
  display:flex;flex-direction:column;gap:14px;
}
/* Если правая колонка пустая (страница не задала @yield('right_column')) — скрываем её,
   чтобы основной контент не отгрызался 320 пикселями белого. */
.rc:empty{display:none}
.rc:empty{display:none}

.rs{
  background:var(--cd);
  border:1px solid var(--bd);
  border-radius:16px;
  padding:18px 20px;
  box-shadow:var(--sc);
}
.rs-title{
  font-family:var(--fh);font-size:15px;font-weight:700;
  color:var(--t1);margin-bottom:14px;
  display:flex;align-items:center;justify-content:space-between;
}
.rs-title a{font-size:12px;font-weight:500;color:var(--t2);text-decoration:none;display:flex;align-items:center;gap:4px}
.rs-title a svg{width:13px;height:13px;stroke:currentColor}

.eco-row{display:flex;align-items:center;gap:12px;padding:8px 0}
.eco-ic{
  width:36px;height:36px;border-radius:10px;
  background:var(--sf);border:1px solid var(--bd);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.eco-ic svg{width:17px;height:17px;stroke:var(--ca)}
.eco-info{display:flex;flex-direction:column;line-height:1.2}
.eco-num{font-family:var(--fh);font-size:18px;font-weight:800;color:var(--t1)}
.eco-lbl{font-size:12px;color:var(--tm);margin-top:2px}
.eco-see{
  display:inline-flex;align-items:center;gap:5px;
  font-size:13px;font-weight:500;color:var(--cp);
  text-decoration:none;margin-top:10px;
}
.eco-see svg{width:14px;height:14px;stroke:currentColor}

.ev-row{display:flex;gap:12px;padding:8px 0;cursor:pointer;align-items:center}
.ev-thumb{
  width:54px;min-width:54px;height:54px;
  border-radius:10px;overflow:hidden;flex-shrink:0;
  position:relative;
}
.ev-thumb.t1{background:linear-gradient(170deg,#a8c4b0 0%,#5e7a68 60%,#2a3a2e 100%)}
.ev-thumb.t1::after{content:"";position:absolute;left:38%;top:25%;width:24%;height:55%;background:linear-gradient(180deg,#2e2418 0%,#4a3828 80%);border-radius:30% 30% 20% 20%}
.ev-thumb.t2{background:radial-gradient(circle at 50% 50%,#8a6840 0%,#3a2818 70%);position:relative}
.ev-thumb.t2::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 30% 18% at 50% 55%, #d8a868, transparent 70%)}
.ev-thumb.t3{background:linear-gradient(135deg,#2a2018 0%,#5a4838 50%,#8a6a4a 100%)}
.ev-thumb.t3::after{content:"";position:absolute;inset:18% 22%;background:linear-gradient(180deg,rgba(255,200,140,.4),transparent);border-radius:6px}
.ev-dinfo{flex:1;display:flex;flex-direction:column;justify-content:center;line-height:1.2}
.ev-row-date{display:flex;flex-direction:column;align-items:center;min-width:36px;line-height:1}
.ev-date{font-family:var(--fh);font-size:18px;font-weight:800;color:var(--t1)}
.ev-mon{font-size:10px;font-weight:600;color:var(--tm);text-transform:uppercase;margin-top:2px;letter-spacing:.06em}
.ev-nm{font-size:13px;font-weight:600;color:var(--t1);line-height:1.3}
.ev-loc{font-size:12px;color:var(--tm);margin-top:3px}

.rec-row{display:flex;align-items:center;gap:12px;padding:8px 0}
.rec-ic{
  width:36px;height:36px;border-radius:10px;
  background:var(--sf);border:1px solid var(--bd);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.rec-ic svg{width:17px;height:17px;stroke:var(--ca)}
.rec-t{font-size:13px;font-weight:600;color:var(--t1)}
.rec-s{font-size:12px;color:var(--tm);margin-top:2px}

.fab{
  position:fixed;bottom:28px;right:28px;
  width:52px;height:52px;border-radius:50%;
  background:var(--cp);color:#fff;
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(53,82,74,.4);
  transition:all .2s;z-index:50;
}
.fab:hover{background:var(--cpl);transform:scale(1.08)}
.fab svg{width:24px;height:24px;stroke:#fff;stroke-width:2}

/* ═══ Stub-страницы (Фаза 2: «скоро здесь будет…») ═══ */
.stub{
  background:var(--cd);
  border:1px solid var(--bd);
  border-radius:16px;
  padding:48px 32px;
  text-align:center;
  box-shadow:var(--sc);
}
.stub h1{font-family:var(--fh);font-size:28px;font-weight:700;color:var(--t1);margin-bottom:12px}
.stub p{font-size:14px;color:var(--t2);line-height:1.6;max-width:480px;margin:0 auto}
.stub-icon-wrap{width:72px;height:72px;margin:0 auto 20px;border-radius:50%;background:var(--sf);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center}
.stub-icon-wrap svg{width:32px;height:32px;stroke:var(--ca);stroke-width:1.5}
.stub-status{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;background:rgba(76,122,91,.1);color:var(--ok);border-radius:999px;font-size:12px;font-weight:600;margin-top:20px}
.stub-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);animation:stub-pulse 1.8s infinite}
@keyframes stub-pulse{0%{box-shadow:0 0 0 0 rgba(76,122,91,.6)}70%{box-shadow:0 0 0 10px rgba(76,122,91,0)}100%{box-shadow:0 0 0 0 rgba(76,122,91,0)}}

/* ═══ Page header (заголовок раздела + actions справа) ═══ */
.pg-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:24px;flex-wrap:wrap}
.pg-title{font-family:var(--fh);font-size:32px;font-weight:800;color:var(--t1);letter-spacing:-.01em;line-height:1.1}
.pg-sub{font-size:14px;color:var(--tm);margin-top:6px}
.pg-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* ═══ Общие кнопки primary/ghost ═══ */
.btn-primary{background:var(--cp);color:#fff;border:none;border-radius:999px;padding:11px 22px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--fb);display:inline-flex;align-items:center;gap:7px;transition:background .2s}
.btn-primary:hover{background:var(--cpl)}
.btn-primary svg{width:16px;height:16px;stroke:#fff}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--bd);border-radius:999px;padding:10px 18px;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--fb);display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{border-color:var(--cps);color:var(--cp)}
.btn-ghost svg{width:15px;height:15px;stroke:currentColor}

/* ═══ Grid форум-групп ═══ */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}

/* ═══ Карточка форум-группы (.gcard) ═══ */
.gcard{background:var(--cd);border:1px solid var(--bd);border-radius:18px;overflow:hidden;box-shadow:var(--sc);transition:all .25s;cursor:pointer;display:flex;flex-direction:column}
.gcard:hover{box-shadow:var(--sh);transform:translateY(-2px);border-color:var(--cps)}
.gcard-cover{height:88px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.gcard-cover::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%, rgba(255,255,255,.18), transparent 60%)}
.gcover-1{background:var(--gp)}
.gcover-2{background:linear-gradient(135deg,#5e8472 0%,#446053 50%,#2e4439 100%)}
.gcover-3{background:linear-gradient(135deg,#b48c67 0%,#8a6648 60%,#5a4030 100%)}
.gcover-4{background:linear-gradient(135deg,#4d6b63 0%,#35524a 60%,#243a32 100%)}
.gcover-5{background:linear-gradient(135deg,#d2b49a 0%,#b48c67 50%,#7e5e44 100%)}
.gcover-6{background:linear-gradient(135deg,#6e8a80 0%,#4d6b63 50%,#2e4439 100%)}
.gcover-7{background:linear-gradient(135deg,#46645b 0%,#35524a 50%,#1e3028 100%)}
.gcover-8{background:linear-gradient(135deg,#8a6c50 0%,#604838 60%,#3a2818 100%)}
.gcover-9{background:linear-gradient(135deg,#7e9488 0%,#5a7468 60%,#3a4e44 100%)}
.gcard-initial{font-family:var(--fh);font-size:42px;font-weight:800;color:rgba(255,255,255,.95);letter-spacing:.02em;text-shadow:0 2px 12px rgba(0,0,0,.25);z-index:2;position:relative}
.gcard-orbit{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120%;height:200%;border:1.5px dashed rgba(255,255,255,.18);border-radius:50%;z-index:1;pointer-events:none}
.gcard-body{padding:16px 18px 18px;display:flex;flex-direction:column;flex:1}
.gcard-meta{display:flex;align-items:baseline;gap:8px;margin-bottom:4px;flex-wrap:wrap}
.gcard-name{font-family:var(--fh);font-size:18px;font-weight:800;color:var(--t1);letter-spacing:-.005em}
.gcard-region{font-size:12px;color:var(--tm);margin-bottom:10px;display:flex;align-items:center;gap:4px}
.gcard-region svg{width:13px;height:13px;stroke:currentColor}
.gcard-desc{font-size:13px;color:var(--t2);line-height:1.55;margin-bottom:12px;flex:1}
.gcard-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.gcard-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--dv);gap:10px}
.gcard-members{display:flex;align-items:center;gap:8px}
.gcard-avs{display:flex;align-items:center}
.gcard-avs .mav{width:24px;height:24px;margin-left:-6px;font-size:8px}
.gcard-mcnt{font-size:12px;color:var(--tm);font-weight:500}
.gcard-stat{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--tm)}
.gcard-stat svg{width:13px;height:13px;stroke:currentColor}
.gcard-btn{background:var(--cp);color:#fff;border:none;border-radius:999px;padding:7px 16px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:background .2s;white-space:nowrap}
.gcard-btn:hover{background:var(--cpl)}
.gcard-btn.subscribed{background:transparent;color:var(--cp);border:1px solid var(--cp)}
.gbadge{position:absolute;top:10px;right:10px;z-index:3;background:rgba(255,255,255,.92);color:var(--cp);font-size:10px;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase;backdrop-filter:blur(6px)}
.gbadge.invite{background:rgba(180,140,103,.92);color:#fff}

/* ═══ Breadcrumbs (страница группы и т.п.) ═══ */
.crumbs{padding:14px 32px 0;display:flex;align-items:center;gap:6px;font-size:13px;color:var(--tm)}
.crumbs a{color:var(--tm);transition:color .15s}
.crumbs a:hover{color:var(--cp)}
.crumbs svg{width:14px;height:14px;stroke:currentColor}
.crumbs .now{color:var(--t1);font-weight:500}

/* ═══ Group hero (страница одной форум-группы) ═══ */
.ghero{margin:14px 32px 0;background:var(--cd);border:1px solid var(--bd);border-radius:20px;overflow:hidden;box-shadow:var(--sc)}
.ghero-cover{height:180px;background:var(--gp);position:relative;overflow:hidden}
.ghero-cover::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 25% 30%, rgba(255,255,255,.22), transparent 60%), radial-gradient(circle at 75% 80%, rgba(180,140,103,.20), transparent 55%)}
.ghero-cover .orbit-bg{position:absolute;top:-40px;right:-60px;width:340px;height:340px;border:2px dashed rgba(255,255,255,.12);border-radius:50%;pointer-events:none}
.ghero-cover .orbit-bg2{position:absolute;top:20px;right:0;width:220px;height:220px;border:1.5px dashed rgba(180,140,103,.18);border-radius:50%;pointer-events:none}
.ghero-bottom{padding:18px 28px 22px;display:flex;align-items:flex-end;gap:22px;flex-wrap:wrap;position:relative}
.ghero-avatar{width:124px;height:124px;border-radius:50%;background:var(--gp);margin-top:-78px;border:6px solid var(--cd);box-shadow:0 6px 20px rgba(53,82,74,.25);display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0;overflow:hidden}
.ghero-avatar::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 25%, rgba(255,255,255,.20), transparent 60%)}
.ghero-initial{font-family:var(--fh);font-size:62px;font-weight:800;color:rgba(255,255,255,.95);text-shadow:0 3px 14px rgba(0,0,0,.22);z-index:2}
.ghero-info{flex:1;min-width:240px;padding-top:10px}
.ghero-name{font-family:var(--fh);font-size:30px;font-weight:800;color:var(--t1);letter-spacing:-.01em;line-height:1.15}
.ghero-name .pre{color:var(--tm);font-weight:600;font-size:14px;display:block;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.ghero-meta{display:flex;gap:18px;margin-top:8px;flex-wrap:wrap;font-size:13px;color:var(--t2)}
.ghero-meta span{display:flex;align-items:center;gap:5px}
.ghero-meta svg{width:14px;height:14px;stroke:currentColor}
.ghero-meta b{color:var(--t1);font-weight:600}
.ghero-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding-bottom:4px}
.btn-icon{width:40px;height:40px;border-radius:50%;background:var(--sf);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.btn-icon:hover{background:var(--bg);border-color:var(--cps)}
.btn-icon svg{width:18px;height:18px;stroke:var(--t2)}

/* ═══ Tab-полоса страницы группы ═══ */
.gtabs{margin:16px 32px 0;display:flex;gap:4px;border-bottom:1px solid var(--bd);overflow-x:auto;flex-wrap:nowrap}
.gtab{padding:12px 18px;font-size:14px;font-weight:600;color:var(--tm);position:relative;cursor:pointer;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;transition:color .15s}
.gtab:hover{color:var(--t1)}
.gtab.on{color:var(--cp)}
.gtab.on::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--cp);border-radius:2px 2px 0 0}
.gtab-cnt{font-size:11px;font-weight:700;color:var(--tm);background:var(--sf);border:1px solid var(--bd);padding:1px 7px;border-radius:999px}
.gtab.on .gtab-cnt{color:var(--cp);background:rgba(53,82,74,.08);border-color:rgba(53,82,74,.18)}

/* ═══ Composer (поле «Поделитесь чем-то с группой») ═══ */
.cmp{background:var(--cd);border:1px solid var(--bd);border-radius:16px;padding:16px 18px;box-shadow:var(--sc);display:flex;align-items:center;gap:12px}
.cmp-av{width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at 50% 32%,#f6e0cc 0%,#d8a888 38%,#7a4a3a 80%,#3a2018 100%);flex-shrink:0;position:relative}
.cmp-av::after{content:"";position:absolute;top:14%;left:50%;transform:translateX(-50%);width:38%;height:34%;border-radius:50%;background:rgba(255,255,255,.18);filter:blur(2px)}
.cmp-in{flex:1;background:var(--sf);border:1px solid var(--bd);border-radius:999px;padding:11px 18px;font-size:13px;color:var(--tm);cursor:text}
.cmp-acts{display:flex;align-items:center;gap:6px}
.cmp-act{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tm);transition:all .15s}
.cmp-act:hover{background:var(--sf);color:var(--cp)}
.cmp-act svg{width:18px;height:18px;stroke:currentColor}

/* ═══ Дополнительные варианты аватаров на ленте ═══ */
.cav.photo-w2{background:radial-gradient(circle at 50% 33%,#f4dcc8 0%,#cc9c7c 40%,#6a4030 80%,#2c1810 100%)}
.mav.p5{background:radial-gradient(circle at 50% 33%,#f4dcc8 0%,#cc9c7c 40%,#6a4030 80%)}
.mav-row{display:flex;align-items:center}

/* ═══ Внутреннее событие группы (cimg-internal — градиент-плейсхолдер) ═══ */
.cimg-internal{width:100%;height:160px;border-radius:12px;margin-bottom:12px;background:linear-gradient(135deg,#2a3548 0%,#4a5e78 50%,#6e8aa4 100%);position:relative;overflow:hidden}
.cimg-internal::after{content:"";position:absolute;inset:30% 0 30% 0;background:radial-gradient(ellipse 30% 80% at 20% 50%, rgba(255,255,255,.25), transparent),radial-gradient(ellipse 30% 80% at 50% 50%, rgba(255,255,255,.25), transparent),radial-gradient(ellipse 30% 80% at 80% 50%, rgba(255,255,255,.25), transparent)}

/* ═══ Сетка участников (правая колонка страницы группы) ═══ */
.mgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.mgrid .person{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;cursor:pointer}
.mgrid .pav{width:54px;height:54px;border-radius:50%;border:2px solid var(--cd);box-shadow:0 1px 4px rgba(0,0,0,.06);position:relative;overflow:hidden}
.mgrid .pav::after{content:"";position:absolute;top:14%;left:50%;transform:translateX(-50%);width:38%;height:34%;border-radius:50%;background:rgba(255,255,255,.18);filter:blur(2px)}
.mgrid .pav.p1{background:radial-gradient(circle at 50% 35%,#f0d8c0 0%,#c89878 40%,#5e3a28 80%)}
.mgrid .pav.p2{background:radial-gradient(circle at 50% 35%,#f6e0cc 0%,#d8a888 40%,#7a4a3a 80%)}
.mgrid .pav.p3{background:radial-gradient(circle at 50% 35%,#f0d0b8 0%,#c08868 40%,#604028 80%)}
.mgrid .pav.p4{background:radial-gradient(circle at 50% 35%,#e8c8a8 0%,#b88860 40%,#503020 80%)}
.mgrid .pav.p5{background:radial-gradient(circle at 50% 33%,#f4dcc8 0%,#cc9c7c 40%,#6a4030 80%)}
.mgrid .pav.p6{background:radial-gradient(circle at 50% 35%,#e0c4a0 0%,#a87a58 40%,#48301c 80%)}
.mgrid .pav.p7{background:radial-gradient(circle at 50% 35%,#eed0b0 0%,#c08660 40%,#5e3820 80%)}
.mgrid .pav.p8{background:radial-gradient(circle at 50% 35%,#f8e0c8 0%,#d09878 40%,#6c4028 80%)}
.mgrid .pname{font-size:11px;color:var(--t1);font-weight:500;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.see-all{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:500;color:var(--cp);margin-top:12px}
.see-all svg{width:14px;height:14px;stroke:currentColor}

/* ═══ Модераторы группы (правая колонка) ═══ */
.mod-row{display:flex;align-items:center;gap:12px;padding:8px 0}
.mod-av{width:42px;height:42px;border-radius:50%;flex-shrink:0;position:relative;overflow:hidden}
.mod-av::after{content:"";position:absolute;top:14%;left:50%;transform:translateX(-50%);width:38%;height:34%;border-radius:50%;background:rgba(255,255,255,.18);filter:blur(2px)}
.mod-av.m1{background:radial-gradient(circle at 50% 35%,#f0d8c0 0%,#c89878 40%,#5e3a28 80%)}
.mod-av.m2{background:radial-gradient(circle at 50% 33%,#f4dcc8 0%,#cc9c7c 40%,#6a4030 80%)}
.mod-info{flex:1;line-height:1.3}
.mod-nm{font-size:13px;font-weight:600;color:var(--t1)}
.mod-role{font-size:11px;color:var(--ca);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.mod-sub{font-size:12px;color:var(--tm);margin-top:2px}

/* ═══ Карточка «О группе» в правой колонке ═══ */
.about-card{background:var(--cd);border:1px solid var(--bd);border-radius:16px;padding:18px 20px;box-shadow:var(--sc)}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.about-stat{background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:12px 14px;text-align:center}
.about-stat-num{font-family:var(--fh);font-size:22px;font-weight:800;color:var(--cp);line-height:1}
.about-stat-lbl{font-size:11px;color:var(--tm);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}

/* ═══ Auth-страницы (login / register / forgot/reset password) ═══ */
.auth-body{font-family:var(--fb);background:var(--bg);color:var(--t1);min-height:100vh;-webkit-font-smoothing:antialiased;display:block}
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg)}
.auth-wrap{width:100%;max-width:440px}
.auth-brand{display:flex;align-items:center;gap:14px;justify-content:center;margin-bottom:28px;color:var(--t1)}
.auth-brand .logo-svg{width:48px;height:48px;flex-shrink:0}
.auth-brand-t{font-family:var(--fh);font-size:18px;font-weight:800;color:var(--t1);letter-spacing:.04em;text-transform:uppercase;line-height:1.1}
.auth-brand-s{font-size:11px;color:var(--tm);font-weight:500;margin-top:2px}
.auth-card{background:var(--cd);border:1px solid var(--bd);border-radius:20px;padding:36px 32px;box-shadow:var(--sh)}
.auth-title{font-family:var(--fh);font-size:24px;font-weight:800;color:var(--t1);margin-bottom:6px;letter-spacing:-.01em}
.auth-sub{font-size:14px;color:var(--tm);margin-bottom:24px;line-height:1.5}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-row{display:flex;flex-direction:column;gap:6px}
.auth-label{font-size:12px;font-weight:600;color:var(--t2);letter-spacing:.02em}
.auth-input{width:100%;background:var(--cd);border:1px solid var(--bd);border-radius:10px;padding:11px 14px;font-family:var(--fb);font-size:14px;color:var(--t1);outline:none;transition:border .15s,box-shadow .15s}
.auth-input:focus{border-color:var(--cp);box-shadow:0 0 0 3px rgba(53,82,74,.10)}
.auth-input::placeholder{color:var(--tm)}
.auth-error{font-size:12px;color:var(--er);margin-top:2px}
.auth-status{padding:12px 16px;border-radius:12px;background:rgba(76,122,91,.1);color:var(--ok);font-size:13px;margin-bottom:18px;border:1px solid rgba(76,122,91,.18)}
.auth-submit{background:var(--cp);color:#fff;border:none;border-radius:10px;padding:12px 22px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:background .2s;margin-top:8px}
.auth-submit:hover{background:var(--cpl)}
.auth-meta{display:flex;align-items:center;justify-content:space-between;margin-top:20px;font-size:13px;color:var(--tm);gap:12px;flex-wrap:wrap}
.auth-meta a{color:var(--cp);font-weight:500;transition:color .15s}
.auth-meta a:hover{color:var(--cpl);text-decoration:underline}
.auth-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--t2);cursor:pointer;user-select:none}
.auth-checkbox input{width:16px;height:16px;accent-color:var(--cp);cursor:pointer}

/* ═══ Кнопки Войти/Регистрация в топбаре ═══ */
.btn-login{padding:8px 16px;background:transparent;color:var(--t1);font-size:13px;font-weight:600;border-radius:999px;transition:background .15s}
.btn-login:hover{background:var(--sf)}
.btn-register{padding:8px 16px;background:var(--cp);color:#fff;font-size:13px;font-weight:600;border-radius:999px;transition:background .2s}
.btn-register:hover{background:var(--cpl)}
.top-auth{display:flex;align-items:center;gap:8px}
.btn-logout{padding:7px 14px;background:transparent;color:var(--t2);font-size:12px;font-weight:500;border:1px solid var(--bd);border-radius:999px;cursor:pointer;font-family:var(--fb);transition:all .15s;margin-left:6px}
.btn-logout:hover{border-color:var(--cps);color:var(--cp)}

/* ═══ Back-link (стрелка «Назад» в заголовке) ═══ */
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--tm);transition:color .15s;margin-bottom:8px}
.back-link:hover{color:var(--cp)}
.back-link svg{width:15px;height:15px;stroke:currentColor}

/* ═══ Страница «Люди» — поиск ═══ */
.people-search{display:flex;gap:10px;margin-bottom:18px;max-width:560px}
.people-search input{flex:1}
.people-search button{flex-shrink:0}
.people-results{display:flex;flex-direction:column;gap:6px;max-width:680px}
.person-card{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--cd);border:1px solid var(--bd);border-radius:14px;transition:all .15s;color:var(--t1)}
.person-card:hover{border-color:var(--cps);background:var(--sf);transform:translateY(-1px)}
.person-av{width:44px;height:44px;border-radius:50%;background:var(--gp);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:700;font-size:16px;flex-shrink:0}
.person-info{flex:1;min-width:0}
.person-name{font-size:14px;font-weight:600;color:var(--t1)}
.person-role{font-size:12px;color:var(--ca);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.person-arrow{width:18px;height:18px;stroke:var(--tm);flex-shrink:0}

/* ═══ Страница профиля чужого пользователя ═══ */
.profile-card{background:var(--cd);border:1px solid var(--bd);border-radius:20px;padding:36px 32px;text-align:center;box-shadow:var(--sc);max-width:480px}
.profile-av{width:96px;height:96px;border-radius:50%;background:var(--gp);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:800;font-size:36px;margin:0 auto 16px}
.profile-name{font-family:var(--fh);font-size:24px;font-weight:800;color:var(--t1);margin-bottom:4px}
.profile-role{font-size:12px;color:var(--ca);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:20px}
.profile-actions{display:flex;justify-content:center;gap:10px;margin-top:18px}

/* ═══ Chat layout (двухпанельный инбокс — список слева + чат справа) ═══ */
/* Чат заполняет всю высоту viewport'а за вычетом топбара (63px = 40px tbtn + 11+11 padding + 1px border).
   Раньше тут было 58px → чат торчал на 5px ниже viewport → появлялся вертикальный скролл всей страницы. */
.chat-layout{margin:-18px -24px -60px;height:calc(100vh - 63px);display:flex;background:var(--bg)}
.chat-list{width:320px;min-width:320px;background:var(--cd);border-right:1px solid var(--bd);display:flex;flex-direction:column;overflow:hidden}
/* Высота 63px = ровно высота топбара и блока логотипа → одна верхняя линия */
.chat-list-head{display:flex;align-items:center;justify-content:space-between;height:63px;box-sizing:border-box;padding:0 20px;border-bottom:1px solid var(--dv);flex-shrink:0}
.chat-list-head h2{font-family:var(--fh);font-size:18px;font-weight:800;color:var(--t1)}
.chat-new-btn{width:36px;height:36px;border-radius:50%;background:var(--sf);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;color:var(--t2);transition:all .15s}
.chat-new-btn:hover{background:var(--cp);color:#fff;border-color:var(--cp)}
.chat-new-btn svg{width:18px;height:18px;stroke:currentColor}
.chat-list-items{flex:1;overflow-y:auto;padding:6px 0}
.chat-list-empty{padding:32px 24px;text-align:center;color:var(--tm)}
.chat-list-empty svg{width:42px;height:42px;stroke:var(--tm);opacity:.5;margin:0 auto 10px}
.chat-list-empty p{font-size:13px;line-height:1.5}
.chat-list-empty a{color:var(--cp);font-weight:500}
.chat-list-item{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--dv);color:var(--t1);transition:background .15s;position:relative}
.chat-list-item:hover{background:var(--sf)}
.chat-list-item.active{background:var(--bg);border-left:3px solid var(--cp);padding-left:15px}
.chat-list-item.pending::before{content:"";position:absolute;left:6px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--ca)}
/* Непрочитанный чат — имя жирным, превью темнее, плюс sage-точка справа */
.chat-list-item.unread .cli-name{font-weight:700;color:var(--t1)}
.chat-list-item.unread .cli-preview{color:var(--t2);font-weight:500}
.chat-list-item.unread::after{content:"";position:absolute;right:14px;top:50%;transform:translateY(-50%);width:9px;height:9px;border-radius:50%;background:var(--cp);box-shadow:0 0 0 3px var(--cd)}
.chat-list-item.unread .cli-time{display:none}
.cli-av{width:44px;height:44px;border-radius:50%;background:var(--gp);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:700;font-size:16px;flex-shrink:0}
.cli-body{flex:1;min-width:0}
.cli-name{font-size:14px;font-weight:600;color:var(--t1);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cli-preview{font-size:12px;color:var(--tm);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.cli-time{font-size:11px;color:var(--tm);flex-shrink:0}
.cli-badge{font-size:10px;font-weight:700;color:#fff;background:var(--ca);padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}

/* Правая панель — активный чат */
.chat-panel{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg)}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;color:var(--tm)}
.chat-empty svg{width:64px;height:64px;stroke:var(--tm);opacity:.4;margin-bottom:14px}
.chat-empty h2{font-family:var(--fh);font-size:20px;font-weight:700;color:var(--t1);margin-bottom:6px}
.chat-empty a{color:var(--cp);font-weight:500}

/* Тоже 63px → выравнивается с «Чаты» и топбаром по нижнему краю */
.chat-header{display:flex;align-items:center;gap:12px;height:63px;box-sizing:border-box;padding:0 22px;background:var(--cd);border-bottom:1px solid var(--bd);flex-shrink:0}
.ch-av{width:40px;height:40px;border-radius:50%;background:var(--gp);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:700;font-size:14px;flex-shrink:0}
.ch-info{flex:1}
.ch-name{font-size:15px;font-weight:600;color:var(--t1);display:block;line-height:1.2}
.ch-name:hover{color:var(--cp)}
.ch-status{font-size:11px;color:var(--tm);margin-top:2px;text-transform:uppercase;letter-spacing:.04em}
.ch-status.declined{color:var(--er)}

.chat-request-banner{padding:14px 22px;background:rgba(180,140,103,.08);border-bottom:1px solid rgba(180,140,103,.2);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.crb-text{font-size:13px;color:var(--t1)}
.crb-actions{display:flex;gap:8px}

.chat-messages{flex:1;overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column;gap:6px}
.msg{display:flex;flex-direction:column;max-width:75%}
.msg.own{align-self:flex-end;align-items:flex-end}
.msg.other{align-self:flex-start;align-items:flex-start}
.msg.consecutive{margin-top:-2px}
.msg-author{font-size:11px;color:var(--tm);font-weight:600;margin-left:10px;margin-bottom:2px}
.msg-bubble{padding:9px 14px;border-radius:16px;position:relative;line-height:1.4;font-size:14px;word-wrap:break-word}
.msg.own .msg-bubble{background:var(--cp);color:#fff;border-bottom-right-radius:4px}
.msg.other .msg-bubble{background:var(--cd);color:var(--t1);border:1px solid var(--bd);border-bottom-left-radius:4px}
.msg.own.consecutive .msg-bubble{border-bottom-right-radius:16px;border-top-right-radius:4px}
.msg.other.consecutive .msg-bubble{border-bottom-left-radius:16px;border-top-left-radius:4px}
.msg-body{white-space:pre-wrap}
.msg-time{font-size:10px;opacity:.7;margin-top:2px;display:inline-block}
.msg.own .msg-time{color:rgba(255,255,255,.75)}
.msg.other .msg-time{color:var(--tm)}

.chat-input{display:flex;align-items:flex-end;gap:8px;padding:14px 22px;background:var(--cd);border-top:1px solid var(--bd);flex-shrink:0}
.ci-textarea{flex:1;background:var(--sf);border:1px solid var(--bd);border-radius:18px;padding:10px 16px;font-family:var(--fb);font-size:14px;color:var(--t1);outline:none;resize:none;max-height:140px;line-height:1.4;transition:border .15s}
.ci-textarea:focus{border-color:var(--cp)}
.ci-send{width:40px;height:40px;border-radius:50%;background:var(--cp);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}
.ci-send:hover{background:var(--cpl)}
.ci-send svg{width:18px;height:18px;stroke:#fff}

.chat-input-locked{padding:14px 22px;background:var(--sf);border-top:1px solid var(--bd);font-size:13px;color:var(--tm);display:flex;align-items:center;gap:8px}
.chat-input-locked svg{width:16px;height:16px;stroke:currentColor;flex-shrink:0}
.chat-input-locked.declined{color:var(--er)}

/* ═══ Кнопка-скрепка для прикрепления файла + превью выбранного файла ═══ */
.ci-attach,.ci-mic{width:40px;height:40px;border-radius:50%;background:transparent;border:none;color:var(--tm);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;padding:0}
.ci-attach:hover,.ci-mic:hover{background:var(--sf);color:var(--cp)}
.ci-attach svg,.ci-mic svg{width:20px;height:20px;stroke:currentColor}
.ci-mic.recording{color:#c0392b;background:rgba(192,57,43,.10);animation:recpulse 1.4s infinite}
@keyframes recpulse{0%,100%{box-shadow:0 0 0 0 rgba(192,57,43,.4)}50%{box-shadow:0 0 0 6px rgba(192,57,43,0)}}
.recording-timer{flex:1;display:flex;align-items:center;gap:8px;padding:0 14px;font-size:14px;font-weight:600;color:var(--er);font-variant-numeric:tabular-nums}
.rec-dot{width:10px;height:10px;border-radius:50%;background:#c0392b;animation:recblink 1s infinite}
@keyframes recblink{50%{opacity:.35}}
.msg-audio{max-width:320px;display:block}
.attach-preview{padding:8px 22px;background:var(--sf);border-top:1px solid var(--bd)}
.attach-preview-inner{display:flex;align-items:center;gap:12px;background:var(--cd);border:1px solid var(--bd);border-radius:10px;padding:8px 10px}
.attach-preview-img{width:44px;height:44px;border-radius:6px;object-fit:cover;flex-shrink:0}
.attach-preview-icon{width:30px;height:30px;stroke:var(--tm);flex-shrink:0;padding:3px}
.attach-preview-info{flex:1;min-width:0}
.attach-preview-name{font-size:13px;color:var(--t1);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.attach-preview-size{font-size:11px;color:var(--tm);margin-top:2px}
.attach-preview-cancel{width:28px;height:28px;border-radius:50%;background:transparent;border:none;color:var(--tm);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.attach-preview-cancel:hover{background:var(--sf);color:var(--er)}
.attach-preview-cancel svg{width:14px;height:14px;stroke:currentColor}

/* ═══ Прикрепления внутри сообщения (msg-attachments) ═══ */
.msg-attachments{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}
.msg-image,.msg-video{max-width:320px;max-height:240px;width:auto;border-radius:8px;display:block;cursor:pointer}
.msg-image{transition:transform .15s}
.msg-image:hover{transform:scale(.98)}

/* ═══ Lightbox для картинок (Alpine.js) ═══ */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:1000;display:flex;align-items:center;justify-content:center;padding:40px;cursor:zoom-out}
.lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;cursor:default;box-shadow:0 8px 40px rgba(0,0,0,.6)}
.lightbox-actions{position:absolute;top:20px;right:20px;display:flex;gap:8px}
.lightbox-btn{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.18);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background .15s}
.lightbox-btn:hover{background:rgba(255,255,255,.32)}
.lightbox-btn svg{width:22px;height:22px;stroke:currentColor}
.msg-video{background:#000}
.msg-file{display:flex;align-items:center;gap:10px;padding:8px 10px;background:rgba(53,82,74,.08);border-radius:8px;color:var(--t1);transition:background .15s;max-width:320px}
.msg.own .msg-file{background:rgba(255,255,255,.16);color:#fff}
.msg-file:hover{background:rgba(53,82,74,.14)}
.msg.own .msg-file:hover{background:rgba(255,255,255,.24)}
.msg-file > svg:first-child{width:22px;height:22px;stroke:var(--cp);flex-shrink:0}
.msg.own .msg-file > svg:first-child{stroke:#fff}
.msg-file-info{flex:1;min-width:0}
.msg-file-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-file-size{font-size:11px;opacity:.7;margin-top:1px}
.msg-file-dl{width:16px;height:16px;stroke:var(--tm);flex-shrink:0}
.msg.own .msg-file-dl{stroke:rgba(255,255,255,.7)}

/* Mobile-адаптив: на узком экране — single-pane (одна колонка видна по URL) */
@media (max-width: 760px) {
  .chat-layout{flex-direction:column}
  .chat-list{width:100%;min-width:0;max-height:100%;border-right:0;border-bottom:1px solid var(--bd)}
}

/* x-cloak: пока Alpine не инициализировался, скрываем динамические элементы (reply-preview и context-menu) */
[x-cloak]{display:none!important}

/* ═══ Reply (цитата исходного сообщения внутри пузыря) ═══ */
.msg-reply-quote{border-left:3px solid var(--cp);padding:5px 10px 5px 12px;margin:0 0 8px;background:rgba(53,82,74,.08);border-radius:6px;font-size:12px;line-height:1.4;max-width:100%;overflow:hidden}
.msg.own .msg-reply-quote{border-left-color:rgba(255,255,255,.6);background:rgba(255,255,255,.16)}
.msg-reply-quote-author{font-weight:700;font-size:11px;color:var(--cp);margin-bottom:2px;text-transform:none}
.msg.own .msg-reply-quote-author{color:rgba(255,255,255,.95)}
.msg-reply-quote-text{color:var(--t2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.msg.own .msg-reply-quote-text{color:rgba(255,255,255,.82)}

/* ═══ Контекст-меню (правый клик на сообщении) ═══ */
.msg-context-menu{position:fixed;background:var(--cd);border:1px solid var(--bd);border-radius:12px;box-shadow:var(--sh);padding:4px;z-index:200;min-width:160px}
.msg-context-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;background:transparent;border:none;text-align:left;font-size:13px;color:var(--t1);cursor:pointer;border-radius:8px;font-family:var(--fb)}
.msg-context-menu button:hover{background:var(--sf)}
.msg-context-menu button svg{width:16px;height:16px;stroke:var(--t2);flex-shrink:0}

/* ═══ Reply preview над инпутом (когда выбран reply через контекст-меню) ═══ */
.reply-preview{display:flex;align-items:center;gap:10px;padding:8px 22px;background:var(--sf);border-top:1px solid var(--bd)}
.reply-preview-bar{width:3px;align-self:stretch;background:var(--cp);border-radius:2px;flex-shrink:0}
.reply-preview-content{flex:1;min-width:0}
.reply-preview-author{font-size:11px;color:var(--cp);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.reply-preview-text{font-size:13px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.reply-preview-cancel{width:30px;height:30px;border-radius:50%;background:transparent;border:none;color:var(--tm);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.reply-preview-cancel:hover{background:var(--bd);color:var(--t1)}
.reply-preview-cancel svg{width:16px;height:16px;stroke:currentColor}

/* ═══ Group-чаты (отличия от DM) ═══ */
.chat-list-actions{display:flex;gap:6px}
.cli-av.group, .ch-av.group{background:var(--ga)}  /* бронзовый градиент для групп */

/* ═══ Presence: «в сети»-точка на аватаре + текст-статус в шапке ═══ */
.cli-av, .ch-av{position:relative}
.online-dot{position:absolute;right:-1px;bottom:-1px;width:12px;height:12px;border-radius:50%;background:#4caf50;border:2px solid var(--cd);box-shadow:0 0 0 1px rgba(76,175,80,.3)}
.online-dot-lg{width:13px;height:13px}
.ch-status.online{color:#3a8a44;font-weight:600;text-transform:none;letter-spacing:0;font-size:12px}

/* ═══ Read-receipts: одна/две галочки на собственных сообщениях ═══ */
.msg-check{display:inline-flex;align-items:center;margin-left:4px;vertical-align:middle}
.msg-check svg{width:14px;height:14px;stroke-width:2.5}
.msg.own .msg-check.delivered svg{stroke:rgba(255,255,255,.55)}
.msg.own .msg-check.read svg{stroke:#a5e6a5}  /* light sage-green */

/* ═══ Форма создания группы ═══ */
.participant-list{display:flex;flex-direction:column;gap:4px;max-height:380px;overflow-y:auto;padding:4px}
.participant-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--cd);border:1px solid var(--bd);border-radius:12px;cursor:pointer;transition:all .15s;position:relative}
.participant-item:hover{border-color:var(--cps);background:var(--sf)}
.participant-item input[type="checkbox"]{position:absolute;opacity:0;pointer-events:none}
.participant-item:has(input:checked){border-color:var(--cp);background:rgba(53,82,74,.06)}
.participant-av{width:36px;height:36px;border-radius:50%;background:var(--gp);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:700;font-size:13px;flex-shrink:0}
.participant-info{flex:1;min-width:0}
.participant-name{font-size:14px;font-weight:600;color:var(--t1)}
.participant-role{font-size:11px;color:var(--ca);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.participant-check{width:20px;height:20px;stroke:var(--cp);opacity:0;transition:opacity .15s;flex-shrink:0}
.participant-item:has(input:checked) .participant-check{opacity:1}
