@font-face{
  font-family:RPFont;
  src:url('/assets/fonts/PressStart2P-Regular.ttf') format('truetype'),local('Press Start 2P'),local('Consolas');
  font-display:swap;
}
@font-face{
  font-family:RedPointMono;
  src:url('/assets/fonts/RedPointMono.woff2') format('woff2'),url('/assets/fonts/RedPointMono.ttf') format('truetype');
  font-display:swap;
}

:root{
  --bg:#030406;
  --bg2:#090a0d;
  --panel:#07090d;
  --panel2:#0b0f14;
  --panel3:#11161d;
  --line:#8f1313;
  --line-soft:#4d0d0d;
  --text:#eaeaea;
  --muted:#9ea4ac;
  --red:#ff3030;
  --red-dark:#8a1212;
  --green:#39d36b;
  --amber:#f0a31a;
  --font:RPFont,'Press Start 2P',Consolas,monospace;
  --scale:1;
}

/* Chat-compatible skins: redpoint, cyberpunk, security. Persisted with rp_theme and rp_skin. */
body[data-skin="cyberpunk"], body.theme-cyberpunk{
  --bg:#050510; --bg2:#0a1024; --panel:#0a0f1f; --panel2:#10162c; --panel3:#141b35;
  --line:#00eaff; --line-soft:#203f65; --red:#ff2bd6; --red-dark:#7b126d; --green:#00eaff; --amber:#f7e54a;
  --text:#f5fbff; --muted:#9be7ff;
}
body[data-skin="security"], body.theme-security{
  --bg:#020303; --bg2:#050606; --panel:#090b0b; --panel2:#101111; --panel3:#151717;
  --line:#651616; --line-soft:#451212; --red:#e12626; --red-dark:#780e0e; --green:#32d35e; --amber:#f0a31a;
  --text:#e8ecec; --muted:#8a8f92;
}
body[data-skin="cyberpunk"] .rp-bg, body.theme-cyberpunk .rp-bg{
  background:radial-gradient(circle at 15% 18%,rgba(255,43,214,.24),transparent 30%),radial-gradient(circle at 82% 8%,rgba(0,234,255,.22),transparent 28%),linear-gradient(135deg,#050510,#0a1024 55%,#12051e);
}
body[data-skin="security"] .rp-bg, body.theme-security .rp-bg{
  background:linear-gradient(rgba(225,38,38,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(225,38,38,.035) 1px,transparent 1px),radial-gradient(circle at 50% 0,rgba(225,38,38,.14),transparent 38%);
  background-size:36px 36px,36px 36px,100% 100%; opacity:1;
}
body[data-skin="cyberpunk"] .brand-badge, body.theme-cyberpunk .brand-badge{background:linear-gradient(135deg,#ff2bd6,#00eaff);box-shadow:0 0 24px rgba(255,43,214,.55),0 0 48px rgba(0,234,255,.35);}
body[data-skin="security"] .brand-badge, body.theme-security .brand-badge{background:linear-gradient(135deg,#e12626,#5b0909);clip-path:polygon(50% 0,100% 24%,100% 76%,50% 100%,0 76%,0 24%);box-shadow:0 0 28px rgba(225,38,38,.35);}
body[data-skin="cyberpunk"] .btn, body.theme-cyberpunk .btn{background:linear-gradient(135deg,#ff2bd6,#6d3dff);border-color:#00eaff;box-shadow:0 0 14px rgba(255,43,214,.18);}
body[data-skin="security"] .btn, body.theme-security .btn{border-radius:3px;border-color:#8e1515;background:linear-gradient(180deg,#8e1515,#4a0707);box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);}
body[data-skin="cyberpunk"] .box, body[data-skin="cyberpunk"] .modal-card, body.theme-cyberpunk .box, body.theme-cyberpunk .modal-card{border-color:#00eaff;box-shadow:0 0 32px rgba(0,234,255,.12),0 24px 70px rgba(0,0,0,.55);}
body[data-skin="security"] .box, body[data-skin="security"] .modal-card, body.theme-security .box, body.theme-security .modal-card{border-radius:4px;border-color:#651616;box-shadow:inset 0 0 24px rgba(225,38,38,.04),0 12px 60px rgba(0,0,0,.5);}
body[data-skin="security"] input, body[data-skin="security"] select, body[data-skin="security"] textarea, body.theme-security input, body.theme-security select, body.theme-security textarea{border-radius:3px;border-color:#451212;background:#050606;}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:radial-gradient(circle at 70% 10%,rgba(255,48,48,.09),transparent 22%),linear-gradient(180deg,#020304,#06080b 55%,#030406);
  color:var(--text);
  font-family:var(--font);
  font-size:calc(12px * var(--scale));
  letter-spacing:.01em;
}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
a{color:inherit}
.hidden{display:none!important}

.rp-bg{
  position:fixed; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,48,48,.038) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,48,48,.028) 1px,transparent 1px),
    radial-gradient(circle at 20% 85%,rgba(255,48,48,.08),transparent 25%),
    radial-gradient(circle at 80% 10%,rgba(255,48,48,.05),transparent 18%);
  background-size:46px 46px,46px 46px,auto,auto;
  opacity:.42;
}
.rp-bg:after{
  content:""; position:absolute; inset:0;
  background:repeating-linear-gradient(180deg,rgba(255,255,255,.012),rgba(255,255,255,.012) 1px,transparent 1px,transparent 3px);
  opacity:.12;
}

.screen-wrap{padding:8px; min-height:100vh}
.window-shell{
  width:min(1500px,100%);
  margin:0 auto;
  min-height:calc(100vh - 16px);
  border:1px solid var(--line);
  background:rgba(3,5,7,.94);
  box-shadow:0 0 0 1px rgba(255,48,48,.18) inset,0 12px 44px rgba(0,0,0,.45);
  display:flex;
  flex-direction:column;
}
.window-titlebar{
  height:42px;
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 12px;
  background:linear-gradient(180deg,#050709,#020304);
}
.window-brand{display:flex; align-items:center; gap:10px; text-transform:uppercase; color:#f1f1f1; font-size:11px; letter-spacing:.08em}
.brand-badge{
  width:26px; height:26px; border:1px solid var(--line); color:var(--red);
  display:grid; place-items:center; background:#100406; font-size:10px; overflow:hidden;
}
.brand-badge img{width:100%; height:100%; display:block}
.window-controls{display:flex; gap:10px}
.window-controls span{
  width:18px; height:18px; border:1px solid var(--line); display:block; position:relative;
}
.window-controls span:nth-child(1)::before{content:""; position:absolute; left:4px; right:4px; bottom:4px; border-bottom:2px solid var(--red)}
.window-controls span:nth-child(2)::before{content:""; position:absolute; inset:4px; border:2px solid var(--red)}
.window-controls span:nth-child(3)::before,
.window-controls span:nth-child(3)::after{content:""; position:absolute; left:3px; right:3px; top:8px; border-top:2px solid var(--red); transform:rotate(45deg)}
.window-controls span:nth-child(3)::after{transform:rotate(-45deg)}

.hero-grid{
  display:grid;
  grid-template-columns:265px 1fr 380px;
  gap:18px;
  padding:16px;
  align-items:stretch;
}
.status-box,.box{
  border:1px solid var(--line);
  background:rgba(6,8,11,.95);
  box-shadow:0 0 0 1px rgba(255,48,48,.08) inset;
}
.status-box{padding:14px; display:flex; align-items:center; justify-content:space-between; gap:14px; min-height:120px}
.clock-box .status-icon{font-size:48px; color:var(--red); line-height:1; min-width:56px; text-align:center}
.status-label{font-size:10px; color:#f0f0f0; line-height:1.7}
.status-sub{font-size:9px; color:var(--muted); margin-top:6px}
.status-big{font-size:23px; color:var(--red); margin-top:14px; letter-spacing:.05em}
.box-title{
  color:var(--red);
  text-transform:uppercase;
  font-size:11px;
  letter-spacing:.1em;
  margin-bottom:12px;
}
.mini-list{display:flex; flex-direction:column; gap:10px; font-size:10px}
.mini-list div{display:flex; justify-content:space-between; gap:16px}
.mini-list span{color:var(--muted)}
.mini-list strong{color:#f0f0f0; text-align:right}
.shield-mark{font-size:56px; color:#ffd4d4; opacity:.9; line-height:1}
.hero-center{
  display:flex; align-items:center; justify-content:center; gap:18px;
  padding:8px 10px;
}
.hero-line{flex:1; max-width:170px; height:6px; position:relative}
.hero-line::before,
.hero-line::after{content:""; position:absolute; top:0; border-top:6px solid var(--red)}
.hero-line-left::before{left:0; right:28px}
.hero-line-left::after{right:0; width:0; border-left:18px solid var(--red); border-top:12px solid transparent; border-bottom:12px solid transparent; border-right:0; transform:translateY(-9px)}
.hero-line-right::before{left:28px; right:0}
.hero-line-right::after{left:0; width:0; border-right:18px solid var(--red); border-top:12px solid transparent; border-bottom:12px solid transparent; border-left:0; transform:translateY(-9px)}
.hero-copy{text-align:center}
.hero-copy h1{margin:0; color:var(--red); font-size:42px; letter-spacing:.1em}
.hero-copy h2{margin:10px 0 0; font-size:17px; color:#efefef; letter-spacing:.08em}
.hero-copy p{margin:14px 0 0; color:#7d7f86; font-size:12px; letter-spacing:.18em}

.nav-strip{
  display:flex; gap:0; padding:0 16px 12px; flex-wrap:wrap;
}
.tab,.navbtn{
  border:1px solid var(--line-soft);
  background:linear-gradient(180deg,#090b10,#05070a);
  color:#ddd;
  padding:14px 18px;
  text-transform:uppercase;
  font-size:11px;
  display:flex;
  align-items:center;
  gap:12px;
  min-height:56px;
  text-decoration:none;
}
.tab img,.navbtn img,.action-row img{width:22px; height:22px; filter:none; opacity:.42; transition:opacity .15s ease, filter .15s ease}
.btn img{width:20px; height:20px; filter:none; opacity:.78}
.nav-strip > * + *{border-left:0}
.tab:hover,.navbtn:hover,.action-row:hover{background:#130709; border-color:var(--line)}
.tab:hover img,.navbtn:hover img,.action-row:hover img{opacity:.82}
.tab.active,.navbtn.active,.action-row.active{color:var(--red); background:#130709; border-color:var(--line)}
.tab.active img,.navbtn.active img,.action-row.active img{filter:none; opacity:1}
.admin-navstrip .navbtn{min-width:175px; justify-content:center; flex:1}

.top-toolbar{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:0 16px 14px;
}
.top-toolbar h2{margin:0; font-size:16px}
.top-toolbar p{margin:8px 0 0; font-size:10px; color:var(--muted)}

.dashboard-layout,.admin-grid{
  display:grid;
  gap:16px;
  padding:0 16px 16px;
}
.auth-layout{grid-template-columns:320px 1fr 340px; align-items:start}
.admin-grid{grid-template-columns:320px 1fr 320px; align-items:start}
.single-focus-grid{grid-template-columns:1fr 320px}
.wide-center{min-width:0}
.double-stack{display:grid; gap:16px; margin-bottom:16px}
.dashboard-col,.admin-left,.admin-center,.admin-right{display:flex; flex-direction:column; gap:16px; min-width:0}
.box{padding:16px}

.action-stack{display:flex; flex-direction:column; gap:8px}
.action-row{
  width:100%; text-align:left; border:1px solid #2c2f36; background:#090c10; color:#f0f0f0; padding:14px;
  display:flex; align-items:flex-start; gap:12px; text-transform:none;
}
.action-row strong{display:block; font-size:12px; color:#f0f0f0; margin-bottom:4px}
.action-row small{display:block; font-size:10px; color:var(--muted); line-height:1.45}
.action-row.active{border-color:var(--line); background:#130709}

.label{
  display:block;
  color:var(--muted);
  text-transform:uppercase;
  font-size:10px;
  letter-spacing:.1em;
  margin:12px 0 7px;
}
input,select,textarea{
  width:100%;
  background:#05080d;
  color:#f0f0f0;
  border:1px solid #212631;
  padding:13px 12px;
  outline:none;
}
input::placeholder,textarea::placeholder{color:#666d77}
input:focus,select:focus,textarea:focus{border-color:var(--line)}
textarea{min-height:380px; resize:vertical; line-height:1.8}

.btn{
  border:1px solid var(--line);
  background:linear-gradient(180deg,#4b0d0d,#260707);
  color:#fff;
  padding:13px 18px;
  min-height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  text-transform:uppercase;
  font-size:11px;
}
.btn:hover{filter:brightness(1.1)}
.btn.alt{background:linear-gradient(180deg,#11161c,#0b0f14); border-color:#29303a}
.btn.icon{width:48px; min-width:48px; padding:0; font-size:11px}
.btn.full{width:100%; margin-top:14px}
.btn.danger{background:linear-gradient(180deg,#7d1010,#2f0909)}
button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--red); outline-offset:2px}
.toolbar{display:flex; gap:8px; flex-wrap:wrap; align-items:center}
.dual-buttons .btn{width:100%}

.info-grid{
  display:grid; gap:12px;
}
.compact-info{grid-template-columns:repeat(2,minmax(0,1fr))}
.info-grid div,.summary-list div{
  border-top:1px solid rgba(255,48,48,.08);
  padding-top:10px;
  display:flex; justify-content:space-between; gap:12px;
  font-size:10px;
}
.info-grid span,.summary-list span{color:var(--muted)}
.info-grid strong,.summary-list strong{color:#f0f0f0; text-align:right}
.summary-list{display:flex; flex-direction:column; gap:4px}

.metric-grid{display:grid; gap:12px}
.metric-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.metric-card{
  border:1px solid rgba(255,48,48,.18);
  background:#070a0e;
  padding:16px;
  min-height:120px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.metric-card span{color:var(--red); text-transform:uppercase; font-size:11px}
.metric-card strong{font-size:34px; color:#f0f0f0; margin:18px 0 12px}
.metric-card small{color:var(--muted); font-size:10px; line-height:1.5}

.table-wrap{overflow:auto; border:1px solid rgba(255,48,48,.14); background:#05070a}
.tall-table{max-height:440px}
.activity-wrap{max-height:300px}
.table{width:100%; border-collapse:collapse}
.table th,.table td{
  padding:10px 12px;
  border-bottom:1px solid rgba(255,48,48,.12);
  text-align:left;
  white-space:nowrap;
  font-size:11px;
}
.table th{color:var(--red); text-transform:uppercase; font-size:10px}
.table tbody tr:nth-child(even){background:rgba(255,255,255,.012)}
.compact-table td:nth-child(2){color:var(--red)}
.compact-table td:last-child{color:var(--green)}

.note-list{display:flex; flex-direction:column; gap:12px}
.note-item{border:1px solid rgba(255,48,48,.12); background:#090b0f; padding:12px}
.note-item strong{display:block; color:#f0f0f0; margin-bottom:8px; font-size:11px}
.note-item span{display:block; color:var(--muted); font-size:10px; line-height:1.55}
.hint{color:var(--muted); font-size:10px; line-height:1.6; margin:10px 0 0}
.feedback-line{
  border:1px solid rgba(255,48,48,.18);
  background:#090c10;
  color:#f0f0f0;
  padding:12px 14px;
  margin:0 0 12px;
  font-size:10px;
  line-height:1.55;
}
.feedback-line.ok{border-color:#246f3b; color:var(--green); background:#07110a}
.feedback-line.error{border-color:#8a1212; color:#ff7b7b; background:#140708}

.form-grid,.grid-form{display:grid; gap:10px}
.single-grid{grid-template-columns:1fr}
.two-col{grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px}
.full-span{grid-column:1/-1}
.split-bottom{display:grid; grid-template-columns:1fr 360px; gap:16px}
.content-frame{padding-bottom:16px; flex:1; display:flex; flex-direction:column}
.full-height-box{height:100%}
.status-banner{
  border:1px solid #246f3b; background:#07110a; color:var(--green); padding:14px; font-size:18px; text-align:center; margin-bottom:12px;
}
.status-ok{box-shadow:0 0 0 1px rgba(57,211,107,.14) inset}

.footer-bar{
  margin-top:auto;
  border-top:1px solid var(--line);
  padding:12px 16px;
  display:flex; gap:28px; flex-wrap:wrap;
  background:#05070a;
  color:#dddddd;
  font-size:10px;
}
.footer-bar strong{color:var(--red)}

.modal{
  position:fixed; inset:0; z-index:40; display:grid; place-items:center;
  background:rgba(0,0,0,.76);
}
.modal-card{
  width:min(560px,calc(100% - 24px));
  border:1px solid var(--line);
  background:#07090d;
  padding:22px;
  box-shadow:0 0 0 1px rgba(255,48,48,.16) inset;
}
.settings-brand{margin-bottom:12px}
.settings-brand p{margin:6px 0 0; color:var(--muted); font-size:10px}
.copy-toast{
  position:fixed; right:18px; bottom:18px; z-index:60;
  border:1px solid var(--line); background:#0a0d12; padding:12px 16px; color:#f0f0f0;
}

@media (max-width:1280px){
  .hero-grid{grid-template-columns:240px 1fr 320px}
  .auth-layout{grid-template-columns:280px 1fr 300px}
  .admin-grid{grid-template-columns:280px 1fr 280px}
  .split-bottom{grid-template-columns:1fr}
}

@media (max-width:1080px){
  .hero-grid,.auth-layout,.admin-grid,.single-focus-grid{grid-template-columns:1fr}
  .admin-navstrip .navbtn,.nav-strip .tab{flex:1 1 200px}
  .metric-grid-4,.compact-info,.two-col{grid-template-columns:1fr 1fr}
  .top-toolbar{flex-direction:column; align-items:flex-start}
}

@media (max-width:760px){
  .screen-wrap{padding:0}
  .window-shell{min-height:100vh}
  .window-titlebar{height:auto; padding:12px; gap:12px; flex-direction:column; align-items:flex-start}
  .hero-copy h1{font-size:28px}
  .hero-copy h2{font-size:13px}
  .metric-grid-4,.compact-info,.two-col{grid-template-columns:1fr}
  .nav-strip{padding:0 8px 8px}
  .dashboard-layout,.admin-grid,.top-toolbar,.content-frame,.hero-grid{padding-left:8px; padding-right:8px}
  .box,.status-box{padding:12px}
  .table th,.table td{font-size:10px; padding:8px}
  .footer-bar{gap:14px}
}

.settings-card{width:min(760px,calc(100vw - 32px));}
.settings-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; align-items:end;}
.check-row{display:flex; align-items:center; gap:12px; border:1px solid #252b35; background:#070a0e; min-height:48px; padding:12px; color:#ddd; font-size:10px;}
.check-row input{width:auto; accent-color:var(--red);}
.permissions-list .note-item strong{text-transform:uppercase;}
.context-menu{position:fixed; z-index:9999; min-width:230px; border:1px solid var(--line); background:rgba(5,7,10,.98); box-shadow:0 18px 44px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04) inset; padding:8px;}
.context-menu button{display:block; width:100%; text-align:left; padding:11px 12px; border:1px solid transparent; background:transparent; color:var(--text); font:inherit; font-size:10px; text-transform:uppercase;}
.context-menu button:hover{border-color:var(--line-soft); background:rgba(255,255,255,.05); color:var(--red);}
.context-menu hr{border:0; border-top:1px solid var(--line-soft); margin:7px 0;}
body[data-skin="security"] .hero-copy h1, body[data-skin="security"] .box-title, body[data-skin="security"] .metric-card span{color:#ff3c3c;text-transform:uppercase;letter-spacing:.04em;}
body[data-skin="cyberpunk"] .hero-copy h1, body[data-skin="cyberpunk"] .box-title, body[data-skin="cyberpunk"] .metric-card span{color:#f5fbff;}
@media (max-width:800px){.settings-grid{grid-template-columns:1fr}}
