mirror of
https://github.com/myronblair/jarvis
synced 2026-06-30 17:50:23 -05:00
Admin panel: full CSS consistency pass — Orbitron font, readable nav, align color vars to main page
This commit is contained in:
+24
-20
@@ -1037,12 +1037,16 @@ if ($action) {
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||
<title>JARVIS ADMIN</title>
|
||||
<link rel="preconnect" href="https://fonts.googleapis.com">
|
||||
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
||||
<link href="https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Rajdhani:wght@400;500;600;700&family=Share+Tech+Mono&display=swap" rel="stylesheet">
|
||||
<style>
|
||||
*{box-sizing:border-box;margin:0;padding:0}
|
||||
:root{
|
||||
--bg:#080b0f;--surface:#0d1117;--panel:#111820;--border:#1a2535;--border2:#243040;
|
||||
--cyan:#00d4ff;--green:#39ff14;--red:#ff3333;--yellow:#ffcc00;--orange:#ff8800;
|
||||
--text:#c8d8e8;--dim:#4a6080;--font:'Share Tech Mono',monospace;
|
||||
--bg:#000810;--surface:#000d1a;--panel:rgba(0,15,35,0.9);--border:rgba(0,212,255,0.15);--border2:rgba(0,212,255,0.25);
|
||||
--cyan:#00d4ff;--green:#00ff88;--red:#ff2244;--yellow:#ffd700;--orange:#ff6600;
|
||||
--text:#c8e6ff;--text-dim:rgba(200,230,255,0.5);--dim:rgba(0,212,255,0.45);
|
||||
--font-display:'Orbitron',monospace;--font:'Share Tech Mono',monospace;
|
||||
}
|
||||
body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:13px;min-height:100vh;display:flex;flex-direction:column}
|
||||
a{color:var(--cyan);text-decoration:none}
|
||||
@@ -1053,7 +1057,7 @@ a{color:var(--cyan);text-decoration:none}
|
||||
#loginBox h1{color:var(--cyan);font-size:1.4rem;letter-spacing:4px;margin-bottom:6px;text-align:center}
|
||||
#loginBox p{color:var(--dim);font-size:0.7rem;letter-spacing:2px;text-align:center;margin-bottom:28px}
|
||||
.field{margin-bottom:16px}
|
||||
.field label{display:block;color:var(--dim);font-size:0.65rem;letter-spacing:2px;margin-bottom:6px}
|
||||
.field label{display:block;color:var(--text-dim);font-size:0.65rem;letter-spacing:2px;margin-bottom:6px}
|
||||
.field input{width:100%;background:#060a0e;border:1px solid var(--border2);color:var(--text);padding:10px 12px;font-family:var(--font);font-size:13px;outline:none}
|
||||
.field input:focus{border-color:var(--cyan)}
|
||||
#loginErr{color:var(--red);font-size:0.7rem;text-align:center;min-height:16px;margin-bottom:8px}
|
||||
@@ -1069,37 +1073,37 @@ a{color:var(--cyan);text-decoration:none}
|
||||
/* ── LAYOUT ── */
|
||||
#app{display:none;flex:1;flex-direction:column}
|
||||
#topbar{background:var(--surface);border-bottom:1px solid var(--border2);padding:10px 20px;display:flex;align-items:center;justify-content:space-between}
|
||||
#topbar .logo{color:var(--cyan);font-size:1rem;letter-spacing:5px}
|
||||
#topbar .sub{color:var(--dim);font-size:0.6rem;letter-spacing:3px;margin-left:12px}
|
||||
#topbar .logo{color:var(--cyan);font-family:var(--font-display);font-size:1rem;letter-spacing:5px}
|
||||
#topbar .sub{color:var(--text-dim);font-size:0.6rem;letter-spacing:3px;margin-left:12px}
|
||||
#topbar .right{display:flex;align-items:center;gap:16px}
|
||||
#topbar .user{color:var(--dim);font-size:0.65rem;letter-spacing:1px}
|
||||
#topbar .user{color:var(--text-dim);font-size:0.65rem;letter-spacing:1px}
|
||||
#main{display:flex;flex:1;overflow:hidden}
|
||||
|
||||
/* ── SIDEBAR ── */
|
||||
#sidebar{width:180px;background:var(--surface);border-right:1px solid var(--border2);padding:16px 0;flex-shrink:0}
|
||||
.nav-item{display:block;padding:10px 20px;color:var(--dim);font-size:0.7rem;letter-spacing:2px;cursor:pointer;border-left:2px solid transparent;transition:all .15s}
|
||||
.nav-item:hover{color:var(--text);background:var(--panel)}
|
||||
.nav-item.active{color:var(--cyan);border-left-color:var(--cyan);background:var(--panel)}
|
||||
.nav-section{padding:16px 20px 6px;color:var(--border2);font-size:0.55rem;letter-spacing:3px}
|
||||
.nav-item{display:block;padding:10px 20px;color:var(--text-dim);font-size:0.7rem;letter-spacing:2px;cursor:pointer;border-left:2px solid transparent;transition:all .15s}
|
||||
.nav-item:hover{color:var(--text);background:rgba(0,212,255,0.06)}
|
||||
.nav-item.active{color:var(--cyan);border-left-color:var(--cyan);background:rgba(0,212,255,0.08)}
|
||||
.nav-section{padding:16px 20px 6px;color:rgba(200,230,255,0.35);font-size:0.5rem;letter-spacing:3px;text-transform:uppercase}
|
||||
|
||||
/* ── CONTENT ── */
|
||||
#content{flex:1;overflow-y:auto;padding:24px}
|
||||
.tab{display:none}.tab.active{display:block}
|
||||
.page-title{color:var(--cyan);font-size:0.9rem;letter-spacing:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:10px;display:flex;align-items:center;justify-content:space-between}
|
||||
.page-title{color:var(--cyan);font-family:var(--font-display);font-size:0.9rem;letter-spacing:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:10px;display:flex;align-items:center;justify-content:space-between}
|
||||
.page-title .actions{display:flex;gap:8px}
|
||||
|
||||
/* ── STAT CARDS ── */
|
||||
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:24px}
|
||||
.stat-card{background:var(--surface);border:1px solid var(--border);padding:16px}
|
||||
.stat-card .lbl{color:var(--dim);font-size:0.6rem;letter-spacing:2px;margin-bottom:8px}
|
||||
.stat-card .lbl{color:var(--text-dim);font-size:0.6rem;letter-spacing:2px;margin-bottom:8px}
|
||||
.stat-card .val{font-size:1.6rem;color:var(--cyan)}
|
||||
.stat-card .sub{color:var(--dim);font-size:0.65rem;margin-top:4px}
|
||||
.stat-card .sub{color:var(--text-dim);font-size:0.65rem;margin-top:4px}
|
||||
.stat-card .ok{color:var(--green)}.stat-card .warn{color:var(--yellow)}.stat-card .danger{color:var(--red)}
|
||||
|
||||
/* ── TABLE ── */
|
||||
.tbl-wrap{background:var(--surface);border:1px solid var(--border);overflow-x:auto}
|
||||
table{width:100%;border-collapse:collapse}
|
||||
th{color:var(--dim);font-size:0.6rem;letter-spacing:2px;padding:10px 12px;text-align:left;border-bottom:1px solid var(--border2);white-space:nowrap}
|
||||
th{color:var(--text-dim);font-size:0.6rem;letter-spacing:2px;padding:10px 12px;text-align:left;border-bottom:1px solid var(--border2);white-space:nowrap}
|
||||
td{padding:9px 12px;border-bottom:1px solid var(--border);font-size:0.75rem;vertical-align:middle}
|
||||
tr:last-child td{border-bottom:none}
|
||||
tr:hover td{background:rgba(0,212,255,0.03)}
|
||||
@@ -1126,14 +1130,14 @@ tr:hover td{background:rgba(0,212,255,0.03)}
|
||||
#modalBody{padding:20px;overflow-y:auto;flex:1}
|
||||
#modalFoot{padding:12px 20px;border-top:1px solid var(--border2);display:flex;justify-content:flex-end;gap:8px}
|
||||
.form-row{margin-bottom:14px}
|
||||
.form-row label{display:block;color:var(--dim);font-size:0.6rem;letter-spacing:2px;margin-bottom:5px}
|
||||
.form-row label{display:block;color:var(--text-dim);font-size:0.6rem;letter-spacing:2px;margin-bottom:5px}
|
||||
.form-row input,.form-row select,.form-row textarea{width:100%;background:#060a0e;border:1px solid var(--border2);color:var(--text);padding:8px 10px;font-family:var(--font);font-size:12px;outline:none;resize:vertical}
|
||||
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--cyan)}
|
||||
.form-row textarea{min-height:80px}
|
||||
|
||||
/* ── FILTERS ── */
|
||||
.filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
|
||||
.filters .lbl{color:var(--dim);font-size:0.6rem;letter-spacing:2px;margin-right:4px}
|
||||
.filters .lbl{color:var(--text-dim);font-size:0.6rem;letter-spacing:2px;margin-right:4px}
|
||||
.filter-btn{background:none;border:1px solid var(--border2);color:var(--dim);padding:4px 12px;font-family:var(--font);font-size:0.65rem;letter-spacing:1px;cursor:pointer}
|
||||
.filter-btn.active,.filter-btn:hover{border-color:var(--cyan);color:var(--cyan)}
|
||||
select.filter-sel{background:#060a0e;border:1px solid var(--border2);color:var(--text);padding:4px 8px;font-family:var(--font);font-size:0.65rem;outline:none}
|
||||
@@ -1147,15 +1151,15 @@ select.filter-sel:focus{border-color:var(--cyan)}
|
||||
@keyframes slideIn{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}
|
||||
|
||||
/* ── MISC ── */
|
||||
.empty{color:var(--dim);font-size:0.7rem;letter-spacing:1px;padding:30px;text-align:center}
|
||||
.empty{color:var(--text-dim);font-size:0.7rem;letter-spacing:1px;padding:30px;text-align:center}
|
||||
@keyframes agentIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}
|
||||
.agent-row{animation:agentIn .18s ease forwards;opacity:0}
|
||||
.loading{color:var(--dim);font-size:0.7rem;letter-spacing:2px;padding:30px;text-align:center;animation:pulse 1s infinite}
|
||||
.loading{color:var(--text-dim);font-size:0.7rem;letter-spacing:2px;padding:30px;text-align:center;animation:pulse 1s infinite}
|
||||
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
|
||||
.meter{height:4px;background:var(--border);margin-top:4px;position:relative}
|
||||
.meter-bar{height:100%;background:var(--cyan);transition:width .3s}
|
||||
.meter-bar.warn{background:var(--yellow)}.meter-bar.danger{background:var(--red)}
|
||||
.ts{color:var(--dim);font-size:0.65rem}
|
||||
.ts{color:var(--text-dim);font-size:0.65rem}
|
||||
.monospace{font-family:var(--font)}
|
||||
.trunc{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
|
||||
</style>
|
||||
|
||||
Reference in New Issue
Block a user