/* CHAT.PHP.SPB.RU — современный светлый скин (palette оригинала), layout «Premium». */
:root{
  --bg:#e7e7f2; --bg2:#dfe0ee;
  --brand1:#333366; --brand2:#666699; --lav:#9999CC;
  --accent:#5b8def; --accent2:#7aa7ff; --accent-d:#3f6fd0;
  --panel:#ffffff; --panel2:#f5f6fb; --panel3:#eef0f8;
  --line:#e0e1ee; --line2:#d3d5e6;
  --txt:#272a3d; --dim:#8b8fa8; --sys:#a6a9bd;
  --bubble:#ffffff; --bubble-me:#e9f0ff; --bubble-me-bd:#cfe0ff;
  --ok:#37b26b; --shadow:0 6px 22px rgba(60,64,120,.10); --radius:14px;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font:14px/1.45 -apple-system,Segoe UI,Roboto,Verdana,sans-serif;
  color:var(--txt);
  background:radial-gradient(1100px 700px at 80% -10%,#eceaff,transparent),linear-gradient(135deg,var(--bg),var(--bg2));
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:#c7c9dd;border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:#b3b6cf}

/* ---------------- ВХОД ---------------- */
#login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:20px}
.login-card{width:min(420px,94vw);background:var(--panel);border:1px solid var(--line);border-radius:20px;
  box-shadow:var(--shadow);padding:26px}
.brand{font:800 27px/1 "Arial Black",Arial;letter-spacing:-1px}
.brand .b1{color:var(--brand1)} .brand .b2{color:var(--accent)}
.brand-sub{color:var(--dim);font-size:12px;margin:6px 0 18px}
.fld{display:block;margin:10px 0}
.fld>span{display:block;font-size:12px;color:var(--dim);margin-bottom:5px}
.fld>span small{color:#b7bacd}
.fld input,.fld select,#loginChannel,#colorSelectLogin{
  width:100%;background:var(--panel2);border:1px solid var(--line2);border-radius:11px;
  color:var(--txt);padding:11px 12px;font-size:15px;outline:none;transition:.15s}
.fld input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(91,141,239,.12)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:end}
.fld.mini{margin:0}.fld.mini>span{margin-bottom:5px}
.colorfld{margin-top:10px}
.seg{display:flex;background:var(--panel2);border:1px solid var(--line2);border-radius:11px;overflow:hidden;height:44px}
.seg input{display:none}
.seg label{flex:1;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--dim);cursor:pointer}
.seg input:checked+label{background:var(--accent);color:#fff}
.btn-primary{width:100%;margin-top:16px;background:linear-gradient(180deg,var(--accent2),var(--accent));
  color:#fff;border:0;border-radius:12px;padding:13px;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 6px 16px rgba(91,141,239,.3)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-primary.sm{width:auto;padding:9px 16px;margin-top:10px;font-size:13px}
.login-err{color:#d23b3b;font-size:13px;text-align:center;min-height:16px;margin-top:12px}
.login-links{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:14px;font-size:12px;color:var(--dim)}
.login-links a{font-weight:600}
.login-foot{color:var(--dim);font-size:11px;text-align:center}

/* ---------------- ЧАТ: каркас ---------------- */
#chat{height:100vh;display:grid;grid-template-columns:248px 1fr 264px;background:transparent}
.side{background:var(--panel);display:flex;flex-direction:column;min-height:0}
.side-left{border-right:1px solid var(--line)}
.side-right{border-left:1px solid var(--line)}

/* левый сайдбар */
.side-brand{padding:16px 16px 12px}
.side-brand .b1{color:var(--brand1)} .side-brand .b2{color:var(--accent)}
.side-brand{font:800 18px/1 "Arial Black",Arial}
.side-online{font:400 11px/1 Verdana;color:var(--dim);margin-top:7px;display:flex;align-items:center;gap:5px}
.side-online .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(55,178,107,.18)}
.side-cap{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--dim);padding:10px 16px 6px;font-weight:700}
.chan-list{flex:1;overflow-y:auto;padding:0 10px}
.chan{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:11px;cursor:pointer;color:var(--txt);margin:2px 0;font-size:14px}
.chan:hover{background:var(--panel3)}
.chan.cur{background:var(--accent);color:#fff;box-shadow:0 4px 12px rgba(91,141,239,.28)}
.chan .hash{opacity:.6;font-weight:700}
.chan.cur .hash{opacity:.9}
.chan .nm{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chan .cnt{font-size:11px;background:var(--panel3);color:var(--dim);border-radius:9px;padding:1px 7px}
.chan.cur .cnt{background:rgba(255,255,255,.22);color:#fff}
.side-foot{border-top:1px solid var(--line);padding:10px}
.me-card{display:flex;align-items:center;gap:9px;padding:8px;border-radius:11px;cursor:pointer}
.me-card:hover{background:var(--panel3)}
.me-meta{display:flex;flex-direction:column;min-width:0}
.me-meta b{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.me-meta small{font-size:10px;color:var(--accent);text-transform:uppercase;letter-spacing:.4px}
.side-links{display:flex;gap:10px;justify-content:center;margin-top:8px;font-size:11px}

/* аватары */
.ava{width:34px;height:34px;min-width:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  color:#fff;font:700 12px/1 Verdana;text-transform:uppercase;box-shadow:inset 0 0 0 1px rgba(255,255,255,.25)}
.ava.sm{width:26px;height:26px;min-width:26px;font-size:10px}

/* ---------------- ЦЕНТР ---------------- */
.center{display:flex;flex-direction:column;min-width:0;background:var(--panel2)}
.topbar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--panel);border-bottom:1px solid var(--line)}
.topbar-title{font-weight:800;font-size:15px;white-space:nowrap}
.topbar-topic{color:var(--dim);font-size:13px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-right{display:flex;align-items:center;gap:10px}
.clock{font:600 12px/1 Verdana;color:var(--dim)}
.clock.dim{opacity:.6;font-weight:400}
.icon-btn{background:var(--panel2);border:1px solid var(--line);border-radius:10px;width:34px;height:34px;cursor:pointer;
  font-size:15px;color:var(--txt);display:inline-flex;align-items:center;justify-content:center}
.icon-btn:hover{background:var(--panel3);border-color:var(--line2)}
.only-mobile{display:none}

.stream{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:3px}

/* сообщения-бабблы */
.msg{display:flex;gap:10px;align-items:flex-start;padding:2px 0;animation:fade .14s}
@keyframes fade{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}
.msg .body{max-width:min(720px,82%)}
.msg .meta{display:flex;align-items:baseline;gap:8px;margin-bottom:1px}
.msg .nk{font-weight:700;cursor:pointer;font-size:13px}
.msg .nk.op::before{content:"@";color:#d98c00}
.msg .tm{color:var(--sys);font-size:10px}
.msg .bubble{background:var(--bubble);border:1px solid var(--line);border-radius:4px 14px 14px 14px;
  padding:8px 12px;font-size:14px;box-shadow:0 1px 2px rgba(60,64,120,.05);word-wrap:break-word;overflow-wrap:anywhere}
/* свои сообщения — тоже слева, лишь с лёгкой подсветкой баббла */
.msg.self .bubble{background:var(--bubble-me);border-color:var(--bubble-me-bd)}
.msg.act .bubble{font-style:italic;background:var(--panel3)}
.msg.sys{justify-content:center;color:var(--sys);font-size:12px;font-style:italic;padding:6px 0;gap:6px}
.msg.sys .body{max-width:100%;text-align:center}
.msg.sys .tm{display:none}
.msg .bubble img.sm{vertical-align:middle}
.msg .bubble img.sm[src*="sm1"]{width:16px;height:16px}
.msg .bubble img.sm.sm2{height:22px}

/* системные уведомления */
.notice{align-self:center;max-width:90%;background:#eef2ff;border:1px solid #d6e0ff;color:#3a5bbf;border-radius:12px;
  padding:7px 12px;font-size:12.5px;white-space:pre-wrap;margin:3px 0}
.notice.warn{background:#fff4e0;border-color:#ffe0ad;color:#a86413}
.notice.mute,.notice.error{background:#ffe9e9;border-color:#ffc9c9;color:#bb3838}
.notice.mail{background:#eafaf0;border-color:#bfe9cf;color:#1f8a4d}

/* композер */
.composer{background:var(--panel);border-top:1px solid var(--line);padding:8px 12px 10px}
.smbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:2px 2px 8px;overflow-x:auto}
.sm-row{display:inline-flex;gap:2px}
.sm-row img{width:18px;height:18px;cursor:pointer;border-radius:3px}
.sm-row img:hover{background:var(--panel3)}
.toolbtn{font-size:12px;color:var(--accent);border:1px solid var(--line2);background:var(--panel2);border-radius:8px;padding:3px 8px;white-space:nowrap}
.toolbtn:hover{background:#fff;text-decoration:none}
.toolbtn.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.toolsel{font-size:12px;border:1px solid var(--line2);background:var(--panel2);border-radius:8px;padding:3px;color:var(--txt)}
.sm2panel{display:flex;flex-wrap:wrap;gap:3px;padding:8px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;max-height:160px;overflow-y:auto;margin-bottom:8px}
.sm2panel img{height:22px;cursor:pointer;border-radius:4px;padding:2px}
.sm2panel img:hover{background:#fff;box-shadow:0 0 0 1px var(--accent)}
.inputrow{display:flex;align-items:center;gap:8px}
.colordot{width:42px;height:44px;border:1px solid var(--line2);border-radius:11px;background:var(--panel2);cursor:pointer;color:#fff;font-size:11px}
.msg-input{flex:1;background:var(--panel2);border:1px solid var(--line2);border-radius:12px;padding:12px 14px;font-size:15px;outline:none}
.msg-input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(91,141,239,.12)}
.btn-send{background:linear-gradient(180deg,var(--accent2),var(--accent));color:#fff;border:0;border-radius:12px;
  padding:0 20px;height:44px;font-weight:700;cursor:pointer;white-space:nowrap;box-shadow:0 4px 12px rgba(91,141,239,.3)}
.btn-send:hover{filter:brightness(1.06)}

/* ---------------- ПРАВЫЙ СПИСОК ---------------- */
.side-right .side-cap{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 8px}
.reload{font-size:15px;color:var(--dim)}
.user-list{flex:1;overflow-y:auto;padding:4px 8px}
.u{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:11px;cursor:pointer}
.u:hover{background:var(--panel3)}
.u.self{background:#eef4ff}
.u .ava{position:relative}
.u .pres{position:absolute;right:-1px;bottom:-1px;width:10px;height:10px;border-radius:50%;border:2px solid var(--panel);background:var(--ok)}
.u.away .pres{background:#c9ccda}
.u-main{flex:1;min-width:0}
.u-nick{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u-nick.op::before{content:"@";color:#d98c00}
.u-status{font-size:11px;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u.away{opacity:.6}
.u-ign{font-size:13px;opacity:.5}
.u-ign.on{opacity:1}

/* ---------------- контекстное меню ---------------- */
.ctxmenu{position:fixed;z-index:200;background:#fff;border:1px solid var(--line2);box-shadow:var(--shadow);
  border-radius:12px;min-width:184px;font-size:13px;padding:5px;overflow:hidden}
.ctxmenu .ci{padding:8px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px}
.ctxmenu .ci:hover{background:var(--accent);color:#fff}
.ctxmenu .ci.head{font-weight:700;color:var(--brand1);cursor:default;padding:6px 10px}
.ctxmenu .ci.head:hover{background:transparent;color:var(--brand1)}
.ctxmenu .sep{height:1px;background:var(--line);margin:4px 6px}
.ctxmenu .ci.adm{color:#c33}
.ctxmenu .ci.adm:hover{background:#c33;color:#fff}

/* ---------------- модалки ---------------- */
.modal{position:fixed;inset:0;background:rgba(40,42,70,.4);z-index:300;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.modal-box{background:#fff;border-radius:16px;width:min(380px,92vw);box-shadow:0 24px 60px rgba(0,0,0,.3);overflow:hidden}
.modal-head{background:linear-gradient(180deg,var(--accent2),var(--accent));color:#fff;font-weight:700;padding:12px 16px;display:flex;justify-content:space-between;align-items:center}
.modal-head .modal-x{color:#fff;font-size:18px}
.modal-body{padding:16px}
.modal-body h4{margin:12px 0 6px;color:var(--brand1)}
.whois-row{margin:4px 0;font-size:13px}.whois-row b{display:inline-block;min-width:140px;color:var(--dim)}
.whois-act{margin-top:12px;display:flex;gap:6px}
.m-inp{width:100%;background:var(--panel2);border:1px solid var(--line2);border-radius:10px;padding:9px 11px;margin:4px 0;font-size:14px;outline:none}
.m-inp:focus{border-color:var(--accent);background:#fff}
.ppmsg{font-size:12px;margin-top:6px;min-height:14px}

/* ---------------- плавающие приваты ---------------- */
#privWindows{position:fixed;right:280px;bottom:14px;display:flex;flex-direction:row-reverse;gap:10px;z-index:120;align-items:flex-end}
.pw{width:248px;background:#fff;border:1px solid var(--line2);border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}
.pw-head{background:linear-gradient(180deg,var(--accent2),var(--accent));color:#fff;font:700 12px/1 Verdana;padding:9px 11px;display:flex;justify-content:space-between;cursor:pointer}
.pw-head a{color:#fff;font-weight:700}
.pw-log{height:170px;overflow-y:auto;padding:8px 10px;font-size:12.5px;display:flex;flex-direction:column;gap:3px;background:var(--panel2)}
.pw-log .o{color:#6a6f88;text-align:right}
.pw-log .i{color:var(--txt)}
.pw-log .tm{color:var(--sys);font-size:10px;margin-right:3px}
.pw.min .pw-log,.pw.min .pw-input{display:none}
.pw-input{display:flex;border-top:1px solid var(--line)}
.pw-input input{flex:1;border:0;font-size:13px;padding:9px;outline:none;background:#fff}
.pw-input button{border:0;background:var(--accent);color:#fff;cursor:pointer;padding:0 12px;font-weight:700}

/* ---------------- адаптив ---------------- */
@media(max-width:920px){
  #chat{grid-template-columns:1fr}
  .only-mobile{display:inline-flex}
  .side{position:fixed;top:0;bottom:0;z-index:140;width:264px;transition:transform .22s;box-shadow:0 0 50px rgba(0,0,0,.25)}
  .side-left{left:0;transform:translateX(-100%)}
  .side-right{right:0;transform:translateX(100%)}
  .side-left.show{transform:none}
  .side-right.show{transform:none}
  #privWindows{right:8px;left:8px;flex-direction:column}
  .pw{width:auto}
  .msg .body{max-width:88%}
}
@media(max-width:520px){
  .topbar-topic{display:none}
  .btn-send{padding:0 12px}.btn-send span{display:none}
}
