@font-face{font-family:RPFont;src:url("/assets/fonts/PressStart2P-Regular.ttf?v=10") format("truetype"),local("Press Start 2P"),local("Consolas");font-display:swap;}
:root{--bg:#06070a;--panel:#11141b;--panel2:#171b23;--border:#2b313d;--text:#f8fafc;--muted:#9aa6b8;--red:#ef2b2d;--red2:#991b1b;--green:#22c55e;--font:RPFont,"Press Start 2P",Consolas,Segoe UI,Arial,sans-serif}
*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top right,rgba(239,43,45,.15),transparent 30%),linear-gradient(180deg,#050609,#080a0e);color:var(--text);font-family:var(--font);min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}.hidden{display:none!important}.rp-bg{position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(239,43,45,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(239,43,45,.035) 1px,transparent 1px);background-size:42px 42px;opacity:.45}
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(500px,100%);background:rgba(17,20,27,.97);border:1px solid var(--border);border-radius:26px;padding:28px;box-shadow:0 24px 80px rgba(0,0,0,.45)}.brand{display:flex;align-items:center;gap:14px;margin-bottom:24px}.brand-mark{width:44px;height:44px;background:linear-gradient(135deg,#ff3838,#8b0000);box-shadow:0 0 30px rgba(239,43,45,.35)}.brand h1{margin:0;font-size:26px;letter-spacing:.03em}.brand p{margin:4px 0 0;color:var(--muted);font-size:13px}.label{display:block;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin:14px 0 7px}
input,select{width:100%;border:1px solid var(--border);background:#090c12;color:var(--text);border-radius:14px;padding:13px 14px;outline:none}input:focus,select:focus{border-color:#6b7280}.btn{border:0;border-radius:14px;background:linear-gradient(180deg,#ef4444,#991b1b);color:#fff;font-weight:900;padding:13px 16px}.btn:hover{filter:brightness(1.14)}.btn.alt{background:#151922;border:1px solid var(--border)}.btn.icon{width:44px;height:44px;padding:9px;display:grid;place-items:center}.btn.icon img{width:22px;height:22px}.btn.full{width:100%;margin-top:18px}.hint{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.5}
.shell{height:100vh;display:grid;grid-template-columns:82px 310px 1fr 360px}.rail{border-right:1px solid var(--border);background:#080a0e;display:flex;flex-direction:column;align-items:center;padding:16px 10px;gap:16px}.logo-square{width:36px;height:36px;background:linear-gradient(135deg,#ff3838,#8b0000)}.vertical-logo{writing-mode:vertical-rl;transform:rotate(180deg);font-weight:900;font-size:12px;letter-spacing:.22em}.railnav{display:flex;flex-direction:column;gap:10px}.navbtn{width:54px;height:54px;border:1px solid var(--border);border-radius:16px;background:#10131a;display:grid;place-items:center;position:relative;color:var(--text);text-decoration:none}.navbtn:hover,.clickable:hover{border-color:#7f1d1d;background:#1d1012;transform:translateY(-1px)}.navbtn img{width:28px;height:28px}.navbtn.active{border-color:#ef2b2d;background:#241012;box-shadow:0 0 0 2px rgba(239,43,45,.18)}.navbtn.active:after,.item.active:after{content:"";position:absolute;right:7px;top:7px;width:8px;height:8px;background:var(--red);border-radius:50%}
.sidebar,.rightbar{background:rgba(15,18,24,.96);border-right:1px solid var(--border);overflow:auto}.rightbar{border-right:0;border-left:1px solid var(--border)}.side-head,.topbar{padding:18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:12px}.side-head h2,.topbar h2{margin:0;font-size:19px}.side-head p,.topbar p{margin:4px 0 0;color:var(--muted);font-size:12px}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:78px;background:rgba(14,17,23,.96)}
.panel{margin:16px;background:linear-gradient(180deg,#121620,#0f1218);border:1px solid var(--border);border-radius:22px;box-shadow:0 18px 40px rgba(0,0,0,.25)}.panel-head{padding:16px 16px 0}.panel-head h3{margin:0;font-size:15px}.panel-head p{margin:6px 0 0;color:var(--muted);font-size:12px}.panel-body{padding:16px}.list{display:flex;flex-direction:column;gap:10px}.item{border:1px solid var(--border);border-radius:16px;background:#0b0e13;padding:12px;position:relative;transition:.12s}.item.clickable{cursor:pointer}.item strong{display:block}.item small{color:var(--muted);word-break:break-word}.item.active{border-color:#ef2b2d;background:#1b1012;box-shadow:0 0 0 2px rgba(239,43,45,.12)}.statusdot{display:inline-block;width:8px;height:8px;background:var(--green);border-radius:50%;margin-right:6px}.chat{height:calc(100vh - 78px);display:flex;flex-direction:column}.messages{flex:1;overflow:auto;padding:18px;display:flex;flex-direction:column;gap:10px}.bubble{max-width:72%;border:1px solid var(--border);border-radius:18px;padding:12px 14px;background:#111722}.bubble.mine{margin-left:auto;background:linear-gradient(180deg,#7f1d1d,#5d1313)}.meta{font-size:11px;color:#cbd5e1;margin-bottom:6px}.composer{border-top:1px solid var(--border);padding:14px;display:grid;grid-template-columns:1fr 50px 110px;gap:10px}.toolbar{display:flex;gap:8px;align-items:center}.settings-btn{position:fixed;right:18px;top:18px;z-index:3}
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.kpis{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.kpi{background:#0b0e13;border:1px solid var(--border);border-radius:18px;padding:14px}.kpi .name{color:var(--muted);font-size:11px;text-transform:uppercase}.kpi .num{font-size:28px;font-weight:900;margin-top:8px}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px;border-bottom:1px solid var(--border);text-align:left;font-size:13px}.table th{color:var(--muted);font-size:11px;text-transform:uppercase}.icon-grid,.emoji-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.icon-tile,.emoji-tile{border:1px solid var(--border);border-radius:16px;background:#0b0e13;padding:12px;text-align:center;cursor:pointer;min-height:82px}.icon-tile:hover,.emoji-tile:hover{border-color:#ef2b2d;background:#1b1012}.icon-tile img,.emoji-tile img{width:36px;height:36px}.icon-tile span,.emoji-tile span{display:block;margin-top:7px;font-size:11px;color:#d1d5db}.modal{position:fixed;inset:0;background:rgba(0,0,0,.72);display:grid;place-items:center;z-index:10}.modal-card{width:min(560px,calc(100% - 32px));background:#11141b;border:1px solid var(--border);border-radius:24px;padding:22px}.emoji-inline{width:22px;height:22px;vertical-align:-5px;margin:0 2px}.logbox{height:520px;overflow:auto;background:#080a0e;border:1px solid var(--border);border-radius:16px;padding:10px;font-size:12px;white-space:pre-wrap}.tabbar{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.tab{padding:9px 12px;border-radius:12px;background:#0b0e13;border:1px solid var(--border);color:var(--text)}.tab.active{border-color:var(--red);background:#1b1012}.rightpanel-title{display:flex;align-items:center;gap:10px;margin-bottom:12px}.rightpanel-title img{width:28px;height:28px}
@media(max-width:1100px){.shell{grid-template-columns:1fr;height:auto}.rail{flex-direction:row}.sidebar,.rightbar{border:0}.chat{height:70vh}.kpis{grid-template-columns:repeat(2,1fr)}.composer{grid-template-columns:1fr}.settings-btn{position:static}.icon-grid,.emoji-grid{grid-template-columns:repeat(3,1fr)}}
/* v9 GUI additions */
.context-menu{position:fixed;z-index:50;background:#0b0e13;border:1px solid var(--red);border-radius:14px;box-shadow:0 18px 60px rgba(0,0,0,.55);min-width:210px;padding:8px}
.context-menu button{display:block;width:100%;text-align:left;border:0;background:transparent;color:var(--text);padding:10px 12px;border-radius:10px}
.context-menu button:hover{background:#1b1012}
.preview-icon{width:96px;height:96px;display:block;margin:8px auto 14px}
.reader-layout{display:grid;grid-template-columns:330px 1fr;gap:14px;min-height:520px}
.reader-list{height:560px;overflow:auto}
.reader-messages{height:560px;overflow:auto;background:#080a0e;border:1px solid var(--border);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:10px}
.reader-msg{border:1px solid var(--border);border-radius:16px;background:#10141c;padding:11px}
.reader-msg .who{font-size:11px;color:#cbd5e1;margin-bottom:6px}
.reader-msg .text{white-space:pre-wrap;line-height:1.45}
.admin-wide-modal{width:min(1180px,calc(100% - 32px))}
.copy-toast{position:fixed;right:20px;bottom:20px;z-index:60;background:#10141c;border:1px solid var(--red);border-radius:14px;padding:12px 16px;color:var(--text)}
/* v9.2 interaction polish */
button,.btn,.navbtn,.item.clickable,.icon-tile,.emoji-tile,.tab,a.btn{transition:transform .12s ease,filter .12s ease,border-color .12s ease,background .12s ease,box-shadow .12s ease}
button:active,.btn:active,.navbtn:active,.item.clickable:active,.icon-tile:active,.emoji-tile:active,.tab:active,a.btn:active{transform:translateY(1px) scale(.99)}
button:focus-visible,.btn:focus-visible,.navbtn:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--red);outline-offset:2px}
.rc-enabled{cursor:context-menu}
.rc-enabled:before{content:"";position:absolute;left:7px;top:7px;width:6px;height:6px;border:1px solid var(--muted);border-radius:50%;opacity:.55}
.no-rc{cursor:default}
.table tr.rc-enabled{position:relative;cursor:context-menu}
.table tr.rc-enabled:hover td{background:#1b1012}
.context-menu .muted{color:var(--muted);font-size:11px;padding:8px 12px;border-bottom:1px solid var(--border);margin-bottom:4px}
.disabled-click{opacity:.45;cursor:not-allowed!important}
.disabled-click:hover{transform:none!important;filter:none!important;border-color:var(--border)!important;background:#10131a!important}


/* v10.2 mobile layout */
.mobile-only{display:none}
.mobile-header,.mobile-tabbar,.mobile-drawer,.mobile-overlay{display:none}
.mobile-header-actions{display:flex;align-items:center;gap:8px}
.mobile-header .btn{padding:10px 12px}
.badge{display:inline-grid;place-items:center;min-width:20px;height:20px;border-radius:10px;background:var(--red);color:white;font-size:11px;padding:0 6px;margin-left:6px}
.mobile-tabbar{gap:8px;padding:10px 12px;background:#0a0c11;border-bottom:1px solid var(--border)}
.mobile-tab{border:1px solid var(--border);background:#10131a;color:var(--text);border-radius:14px;padding:10px 8px;font-size:11px}
.mobile-tab.active{border-color:var(--red);background:#1b1012;box-shadow:0 0 0 2px rgba(239,43,45,.12)}
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:69}
.mobile-drawer{position:fixed;left:12px;right:12px;top:126px;max-height:calc(100vh - 150px);overflow:hidden;background:#11141b;border:1px solid var(--red);border-radius:18px;z-index:70;box-shadow:0 18px 50px rgba(0,0,0,.45)}
.mobile-drawer-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}
.mobile-drawer-head small{display:block;color:var(--muted);margin-top:4px}
.mobile-drawer .mobile-online-list{display:block;padding:12px;overflow:auto;max-height:calc(100vh - 230px)}
@media(max-width:760px){
  body{overflow:hidden}
  .desktop-only{display:none!important}
  .mobile-only{display:block}
  .settings-btn{display:none!important}
  .shell{display:grid;grid-template-columns:1fr;grid-template-rows:auto auto 1fr;height:100vh;overflow:hidden}
  .mobile-header{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#080a0e;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}
  .mobile-title{min-width:0;padding-right:10px}
  .mobile-title strong{font-size:15px;display:block;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mobile-title small{display:block;color:var(--muted);margin-top:4px;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mobile-tabbar{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));position:sticky;top:69px;z-index:29}
  .rail{display:none!important}
  .sidebar,.main,.rightbar{display:none!important;min-width:0;border:0;background:rgba(15,18,24,.96);overflow:auto}
  .sidebar.mobile-section-active,.main.mobile-section-active,.rightbar.mobile-section-active{display:block!important;height:calc(100vh - 124px)}
  .sidebar{padding-bottom:12px}
  .rightbar{padding-bottom:12px}
  .main.mobile-section-active{display:flex!important;flex-direction:column;overflow:hidden}
  .main.mobile-section-active .topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;height:auto;min-height:76px;padding:12px 14px;background:rgba(14,17,23,.98);border-bottom:1px solid var(--border)}
  .topbar h2{font-size:18px;line-height:1.05}
  .topbar p{font-size:11px}
  .toolbar{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
  .toolbar .btn{padding:10px 12px;font-size:12px}
  .panel{margin:12px;border-radius:18px}
  .panel-head{padding:14px 14px 0}
  .panel-body{padding:14px}
  .chat{height:auto;display:flex;flex-direction:column;min-height:0;flex:1}
  .messages{flex:1;overflow:auto;padding:12px;display:flex;flex-direction:column;gap:10px}
  .bubble{max-width:94%;font-size:13px;padding:11px 12px}
  .meta{font-size:10px}
  .composer{border-top:1px solid var(--border);padding:10px;display:grid;grid-template-columns:minmax(0,1fr) 48px 84px;gap:8px;background:rgba(14,17,23,.98)}
  .composer input{padding:11px 12px;font-size:12px;min-width:0}
  .composer .btn{padding:10px 12px;font-size:12px}
  .grid{grid-template-columns:1fr}
  .item{padding:12px}
  .item strong{font-size:14px;line-height:1.25}
  .item small{font-size:11px;line-height:1.35}
  .side-head{padding:14px;border-bottom:1px solid var(--border)}
  .side-head h2{font-size:18px}
  .side-head p{font-size:11px}
  .reader-layout{grid-template-columns:1fr}
  .reader-list,.reader-messages{height:300px}
  .mobile-overlay.open,.mobile-drawer.open{display:block}
}
