New panel

This commit is contained in:
2026-05-10 18:42:38 -03:00
parent 603ae906a1
commit 391db7708f
3 changed files with 400 additions and 328 deletions

View File

@@ -1,331 +1,404 @@
/* DragonCore Command - original black-only admin panel */
:root{ :root{
--bg:#0f172a;--bg2:#111827;--card:#020617;--accent:#3b82f6; color-scheme:dark;
--accent-soft:rgba(59,130,246,.15);--border:#1f2937;--text:#e5e7eb; --bg:#020305;
--muted:#9ca3af;--danger:#ef4444;--success:#22c55e;--warn:#f59e0b; --bg-2:#07090d;
--panel:#0a0d12;
--panel-2:#0d1118;
--card:#0c1017;
--card-bg:#0c1017;
--card-2:#101620;
--card-3:#121a25;
--input-bg:#070b11;
--line:#1b2636;
--line-2:#27364b;
--border:rgba(148,163,184,.14);
--text:#f3f7ff;
--text-2:#d6dfec;
--muted:#8390a3;
--muted-2:#657386;
--accent:#22d3ee;
--accent-2:#8b5cf6;
--accent-3:#14f195;
--accent-soft:rgba(34,211,238,.13);
--success:#31d67b;
--danger:#ff5b69;
--warn:#ffc857;
--radius-xl:24px;
--radius-lg:18px;
--radius-md:14px;
--shadow:0 22px 70px rgba(0,0,0,.48);
--glow:0 0 0 1px rgba(34,211,238,.05),0 0 42px rgba(34,211,238,.10);
} }
*{box-sizing:border-box;margin:0;padding:0;} *{box-sizing:border-box;margin:0;padding:0;}
body{font-family:system-ui,-apple-system,"Segoe UI",sans-serif;background:radial-gradient(circle at top,#1e293b,#020617 50%);color:var(--text);min-height:100vh;} html,body{width:100%;min-height:100%;overflow-x:hidden;background:var(--bg);}
.app{padding:10px;} body{
@media(min-width:768px){.app{padding:20px;}} font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
color:var(--text);
/* ── Shell ── */ min-height:100vh;
.shell{max-width:1100px;margin:0 auto;background:linear-gradient(145deg,rgba(15,23,42,.97),rgba(15,23,42,.99));border-radius:16px;border:1px solid rgba(148,163,184,.1);box-shadow:0 18px 60px rgba(15,23,42,.9);padding:14px;} background:
@media(min-width:768px){.shell{padding:20px;}} radial-gradient(circle at 18% -10%,rgba(34,211,238,.16),transparent 34%),
radial-gradient(circle at 92% 12%,rgba(139,92,246,.18),transparent 34%),
/* ── Header ── */ linear-gradient(180deg,#020305 0%,#05070b 46%,#020305 100%);
header{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border);} }
.logo{font-size:1.1rem;font-weight:700;letter-spacing:.03em;} body::before{
.logo span{color:var(--accent);} content:"";
nav{display:flex;gap:4px;flex-wrap:wrap;} position:fixed;
.tab-btn{background:transparent;border:1px solid transparent;border-radius:999px;padding:5px 12px;font-size:.75rem;color:var(--muted);cursor:pointer;} inset:0;
.tab-btn:hover{border-color:var(--border);color:var(--text);} pointer-events:none;
.tab-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);} opacity:.28;
.hright{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--muted);} background-image:
.hright strong{color:var(--text);} linear-gradient(rgba(255,255,255,.032) 1px,transparent 1px),
linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);
/* ── Cards / Grid ── */ background-size:54px 54px;
.grid2{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:12px;} mask-image:linear-gradient(to bottom,rgba(0,0,0,.8),transparent 80%);
@media(max-width:860px){.grid2{grid-template-columns:1fr;}} }
.card{background:radial-gradient(circle at top left,rgba(59,130,246,.07),var(--card));border-radius:14px;border:1px solid rgba(31,41,55,.95);padding:12px;position:relative;} button,input,select,textarea{font:inherit;}
.card+.card{margin-top:12px;} button{appearance:none;}
.card-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:6px;flex-wrap:wrap;} a{color:inherit;}
.card-title{font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:6px;}
.chip{font-size:.62rem;padding:2px 7px;border-radius:999px;background:rgba(15,23,42,.85);border:1px solid rgba(55,65,81,.9);color:var(--muted);}
.chip.green{border-color:rgba(34,197,94,.5);color:var(--success);}
.chip.red{border-color:rgba(239,68,68,.5);color:var(--danger);}
.chip.warn{border-color:rgba(245,158,11,.5);color:var(--warn);}
/* ── Buttons ── */
.btn{border:none;border-radius:999px;padding:5px 11px;font-size:.72rem;font-weight:500;background:var(--accent);color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:opacity .15s;}
.btn:hover{opacity:.85;}
.btn:disabled{opacity:.45;cursor:default;}
.btn-ghost{background:transparent;border:1px solid rgba(55,65,81,.9);color:var(--muted);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn-danger{background:rgba(239,68,68,.08);color:var(--danger);border:1px solid rgba(248,113,113,.4);}
.btn-warn{background:rgba(245,158,11,.08);color:var(--warn);border:1px solid rgba(245,158,11,.4);}
.btn-sm{padding:3px 9px;font-size:.68rem;}
/* ── Tables ── */
.tbl-wrap{overflow-x:auto;margin:4px 0;}
table{width:100%;border-collapse:collapse;font-size:.73rem;}
thead{background:rgba(15,23,42,.9);}
th,td{padding:6px 7px;text-align:left;border-bottom:1px solid rgba(31,41,55,.95);white-space:nowrap;}
th{font-weight:500;color:var(--muted);font-size:.68rem;}
tbody tr:hover{background:rgba(15,23,42,.85);}
/* ── Metrics ── */
.metrics{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 10px;}
.metric{flex:1 1 80px;min-width:80px;padding:8px;border-radius:10px;background:rgba(15,23,42,.9);border:1px solid rgba(31,41,55,.9);}
.m-label{font-size:.68rem;color:var(--muted);}
.m-val{font-size:.9rem;font-weight:600;margin-top:2px;}
.bar{height:5px;border-radius:999px;background:rgba(31,41,55,.9);overflow:hidden;margin-top:5px;}
.bar-inner{height:100%;background:linear-gradient(90deg,#22c55e,#eab308,#ef4444);transition:width .25s;}
/* ── Forms ── */
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:8px;}
@media(max-width:600px){.form-grid{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:3px;}
.field label{font-size:.68rem;color:var(--muted);}
.field input,.field select,.field textarea{border-radius:8px;border:1px solid rgba(55,65,81,.9);padding:6px 10px;background:rgba(15,23,42,.9);color:var(--text);font-size:.73rem;outline:none;font-family:inherit;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 1px rgba(59,130,246,.4);}
.field-row{display:flex;gap:6px;align-items:center;}
.field-row input{flex:1 1 0;}
.hint{font-size:.68rem;color:var(--muted);}
.form-actions{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.statusbar{margin-top:6px;font-size:.68rem;color:var(--muted);display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap;}
/* ── Tabs ── */
.tab-pane{display:none;}
.tab-pane.active{display:block;}
/* ── Collapsible ── */
.collapsible.collapsed{display:none;}
/* ── Login overlay ── */
.overlay{position:fixed;inset:0;background:radial-gradient(circle at top,rgba(15,23,42,.98),rgba(15,23,42,.995));display:flex;align-items:center;justify-content:center;z-index:30;}
.overlay-inner{width:100%;max-width:340px;margin:0 14px;padding:22px;border-radius:16px;background:linear-gradient(145deg,rgba(15,23,42,.98),rgba(2,6,23,1));border:1px solid rgba(55,65,81,.9);box-shadow:0 20px 60px rgba(15,23,42,1);}
.ov-title{font-size:1.05rem;font-weight:700;margin-bottom:4px;}
.ov-sub{font-size:.8rem;color:var(--muted);margin-bottom:14px;}
.ov-field{width:100%;margin:6px 0;border-radius:8px;border:1px solid rgba(55,65,81,.9);background:rgba(15,23,42,.9);color:var(--text);padding:8px 12px;font-size:.82rem;outline:none;}
.ov-field:focus{border-color:var(--accent);}
.hidden{display:none!important;} .hidden{display:none!important;}
.badge-on{color:var(--success);font-size:.68rem;} .i18n-pending body{visibility:hidden;}
.badge-off{color:var(--muted);font-size:.68rem;}
/* ── Xray log / config editor ── */ .app{min-height:100vh;padding:0;background:transparent;}
.code-area{width:100%;background:rgba(15,23,42,.9);color:#e5e7eb;border:1px solid rgba(55,65,81,.9);border-radius:8px;padding:10px;font-family:monospace;font-size:.7rem;resize:vertical;outline:none;} .shell{min-height:100vh;width:100%;max-width:none;margin:0;padding:0;background:transparent;border:0;box-shadow:none;}
pre.log-box{background:rgba(15,23,42,.9);color:#9ca3af;border:1px solid rgba(55,65,81,.9);border-radius:8px;padding:10px;font-size:.68rem;overflow-y:auto;max-height:180px;white-space:pre-wrap;word-break:break-all;} .panel-layout{min-height:100vh;display:block;background:transparent;}
@supports (min-height:100dvh){.app,.shell,.panel-layout{min-height:100dvh;}}
/* ── Mobile hardening ── /* Desktop shell alignment: keep sidebar and content aligned so the brand panel does not look clipped */
Keep the shell/cards inside the phone viewport and let wide tables scroll @media(min-width:901px){
inside their own card instead of pushing the whole panel sideways. */ .panel-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:18px;padding:18px;}
html,body{width:100%;max-width:100%;overflow-x:hidden;} .sidebar{position:sticky;left:auto;top:18px;bottom:auto;width:300px;height:calc(100vh - 36px);max-height:calc(100vh - 36px);}
.app,.shell,.tab-pane,.grid2,.grid2>*,.card,.tbl-wrap,.form-grid,.field,.metric{min-width:0;max-width:100%;} @supports (height:100dvh){.sidebar{height:calc(100dvh - 36px);max-height:calc(100dvh - 36px);}}
.card-title{flex-wrap:wrap;min-width:0;} .workspace{margin-left:0;min-height:calc(100vh - 36px);border:1px solid rgba(148,163,184,.10);border-radius:28px;overflow:hidden;background:linear-gradient(180deg,rgba(6,9,14,.52),rgba(2,3,5,.18));box-shadow:var(--shadow);}
.card-hdr>*{min-width:0;} @supports (min-height:100dvh){.workspace{min-height:calc(100dvh - 36px);}}
.field input,.field select,.field textarea,.ov-field,.code-area{max-width:100%;min-width:0;}
@media(max-width:640px){
.app{padding:8px;}
.shell{width:100%;padding:12px;border-radius:16px;overflow:hidden;}
header{align-items:flex-start;}
header nav{order:2;width:100%;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;}
.tab-btn{flex:0 0 auto;padding:5px 10px;}
.hright{order:3;width:100%;flex-wrap:wrap;}
.grid2{display:block;}
.grid2>.card+.card,.grid2>div+.card,.grid2>.card+div,.grid2>div+div{margin-top:12px;}
.card{width:100%;padding:12px;overflow:hidden;}
.card-hdr{align-items:flex-start;}
.card-hdr>div[style*="display:flex"],.card-hdr .form-actions{flex-wrap:wrap;}
.metrics{display:grid;grid-template-columns:1fr;gap:8px;}
.metric{width:100%;}
.tbl-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;}
.tbl-wrap table{width:max-content;min-width:100%;}
table{font-size:.7rem;}
th,td{padding:6px 8px;}
.statusbar{display:block;}
.statusbar>span{display:block;margin-top:3px;}
.field-row{flex-wrap:wrap;}
.field-row input{flex:1 1 160px;min-width:0;}
.field-row .btn{flex:0 0 auto;}
/* Override inline 2-column grids in Xray/TLS forms on phones. */
.form-grid[style*="grid-template-columns"],
#wzVlessFields,#wzSSFields,#wzCertSrcFile,#wzCertSrcPaste>div,
#tlsLEFields,#tlsCustomFields,#tlsPasteFields .form-grid{grid-template-columns:1fr!important;}
} }
/* ──────────────────────────────────────────────────────────────
DragonCore professional panel shell /* Login */
────────────────────────────────────────────────────────────── */ .overlay{
:root{ position:fixed;inset:0;z-index:50;
--bg:#121212; display:flex;align-items:center;justify-content:center;
--bg2:#1b1b1c; padding:22px;
--panel:#222223; background:
--panel2:#282829; radial-gradient(circle at 50% 0%,rgba(34,211,238,.18),transparent 38%),
--card:#242425; radial-gradient(circle at 12% 86%,rgba(139,92,246,.18),transparent 35%),
--card2:#2a2a2c; rgba(2,3,5,.96);
--accent:#5a49f5;
--accent2:#ae2ff3;
--accent-soft:rgba(90,73,245,.18);
--border:rgba(255,255,255,.08);
--text:#f6f7fb;
--muted:#a2a2aa;
--danger:#ff7070;
--success:#36d37a;
--warn:#ffbe4c;
--shadow:0 18px 50px rgba(0,0,0,.35);
} }
html,body{background:var(--bg);color:var(--text);} .overlay-inner{
body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;} width:min(100%,390px);
body.light-mode{ position:relative;
--bg:#f4f6fb;--bg2:#fff;--panel:#fff;--panel2:#f7f8fc;--card:#fff;--card2:#f8f9fd; padding:28px;
--border:rgba(15,23,42,.10);--text:#172033;--muted:#667085;--shadow:0 18px 45px rgba(31,41,55,.12); border-radius:28px;
border:1px solid rgba(148,163,184,.14);
background:linear-gradient(180deg,rgba(14,20,30,.96),rgba(6,9,14,.98));
box-shadow:0 32px 90px rgba(0,0,0,.72),0 0 80px rgba(34,211,238,.08);
overflow:hidden;
} }
.app{padding:0;background:linear-gradient(180deg,var(--bg),#101010);min-height:100vh;} .overlay-inner::before{
.shell{max-width:none;margin:0;background:transparent;border:0;border-radius:0;box-shadow:none;padding:0;min-height:100vh;} content:"";position:absolute;left:0;right:0;top:0;height:3px;
.panel-layout{display:block;min-height:100vh;background:var(--bg);} background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent-3));
@supports (min-height:100dvh){.panel-layout{min-height:100dvh;}} }
.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;height:100vh;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:20;box-shadow:18px 0 45px rgba(0,0,0,.18);} .ov-title{font-size:1.28rem;line-height:1.1;font-weight:850;letter-spacing:.01em;margin-bottom:8px;}
@supports (height:100dvh){.sidebar{height:100dvh;}} .ov-sub{font-size:.88rem;line-height:1.5;color:var(--muted);margin-bottom:20px;}
.brand-block{height:112px;display:flex;align-items:center;gap:14px;padding:22px 22px;border-bottom:1px solid var(--border);} .ov-field,
.brand-mark{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(90,73,245,.18),rgba(174,47,243,.18));font-size:2rem;filter:drop-shadow(0 10px 18px rgba(0,0,0,.35));} .field input,.field select,.field textarea,.code-area{
.brand-copy{display:flex;flex-direction:column;gap:2px;} width:100%;min-width:0;outline:0;color:var(--text);
.brand-copy strong{font-size:1.05rem;letter-spacing:.02em;} border:1px solid var(--line);
.brand-copy span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.18em;} background:linear-gradient(180deg,var(--input-bg),#06090f);
.side-nav{display:flex;flex-direction:column;gap:5px;padding:20px 16px;overflow-y:auto;flex:1;} border-radius:14px;
.nav-group-label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.16em;margin:14px 12px 4px;} padding:11px 13px;
.side-nav .tab-btn{width:100%;justify-content:flex-start;text-align:left;border-radius:13px;padding:12px 13px;color:#d9d9df;border:1px solid transparent;background:transparent;font-size:.92rem;font-weight:650;display:flex;align-items:center;gap:12px;} transition:border-color .16s ease,box-shadow .16s ease,background .16s ease;
.side-nav .tab-btn:hover{background:rgba(255,255,255,.04);border-color:var(--border);color:#fff;} }
.side-nav .tab-btn.active{background:linear-gradient(135deg,rgba(90,73,245,.72),rgba(59,54,136,.78));color:#fff;border-color:rgba(255,255,255,.08);box-shadow:0 12px 28px rgba(90,73,245,.22);} .ov-field{margin:7px 0;}
.nav-icon{width:25px;text-align:center;font-size:1.05rem;opacity:.94;} .ov-field::placeholder,input::placeholder,textarea::placeholder{color:#526073;}
.workspace{min-width:0;margin-left:280px;display:flex;flex-direction:column;min-height:100vh;background:radial-gradient(circle at 35% -10%,rgba(90,73,245,.12),transparent 32%),var(--bg);} .ov-field:focus,
.field input:focus,.field select:focus,.field textarea:focus,.code-area:focus{
border-color:rgba(34,211,238,.62);
box-shadow:0 0 0 3px rgba(34,211,238,.10),0 0 32px rgba(34,211,238,.08);
}
input[type="datetime-local"],input[type="date"],input[type="time"]{color-scheme:dark;}
input[type="checkbox"]{accent-color:var(--accent);}
select{color-scheme:dark;}
/* Shell */
.sidebar{
position:fixed;left:18px;top:18px;bottom:18px;z-index:25;
width:284px;display:flex;flex-direction:column;overflow:hidden;
border:1px solid rgba(148,163,184,.12);
border-radius:28px;
background:linear-gradient(180deg,rgba(12,16,23,.94),rgba(5,8,13,.96));
box-shadow:var(--shadow),var(--glow);
backdrop-filter:blur(18px);
}
.brand-block{height:116px;display:flex;align-items:center;gap:14px;padding:22px 28px 22px 22px;border-bottom:1px solid rgba(148,163,184,.10);}
.brand-mark{
width:58px;height:58px;display:grid;place-items:center;border-radius:20px;
color:#061015;font-size:1rem;font-weight:950;letter-spacing:-.05em;
background:linear-gradient(135deg,var(--accent),var(--accent-3));
box-shadow:0 16px 44px rgba(34,211,238,.18),inset 0 1px 0 rgba(255,255,255,.45);
}
.brand-copy{display:flex;flex-direction:column;gap:5px;min-width:0;}
.brand-copy strong{font-size:1.08rem;font-weight:900;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.brand-copy span{font-size:.7rem;text-transform:uppercase;letter-spacing:.22em;color:var(--muted);white-space:nowrap;}
.side-nav{flex:1;display:flex;flex-direction:column;gap:7px;padding:18px 14px 20px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent;}
.nav-group-label{margin:18px 12px 5px;color:var(--muted-2);font-size:.68rem;text-transform:uppercase;letter-spacing:.2em;font-weight:800;}
.tab-btn{
display:inline-flex;align-items:center;justify-content:center;gap:10px;
border:1px solid transparent;border-radius:999px;background:transparent;color:var(--muted);
padding:8px 13px;font-size:.82rem;font-weight:760;cursor:pointer;
transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease;
}
.tab-btn:hover{color:var(--text);border-color:rgba(148,163,184,.16);background:rgba(255,255,255,.035);}
.side-nav .tab-btn{width:100%;justify-content:flex-start;border-radius:18px;padding:12px 13px;color:var(--text-2);font-size:.92rem;}
.side-nav .tab-btn.active{
color:#fff;border-color:rgba(34,211,238,.28);
background:
linear-gradient(135deg,rgba(34,211,238,.18),rgba(139,92,246,.13)),
rgba(255,255,255,.045);
box-shadow:inset 3px 0 0 var(--accent),0 14px 28px rgba(0,0,0,.22);
}
.nav-icon{width:26px;height:26px;display:grid;place-items:center;border-radius:10px;background:rgba(255,255,255,.05);font-size:.95rem;}
.side-nav .tab-btn.active .nav-icon{background:rgba(34,211,238,.15);color:var(--accent);}
.workspace{margin-left:320px;min-height:100vh;display:flex;flex-direction:column;min-width:0;}
@supports (min-height:100dvh){.workspace{min-height:100dvh;}} @supports (min-height:100dvh){.workspace{min-height:100dvh;}}
.topbar{height:84px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:0 26px;border-bottom:1px solid var(--border);background:rgba(31,31,32,.86);backdrop-filter:blur(18px);position:sticky;top:0;z-index:15;margin:0;} .topbar{
body.light-mode .topbar{background:rgba(255,255,255,.82);} position:sticky;top:0;z-index:18;
.topbar-left,.topbar-actions{display:flex;align-items:center;gap:14px;min-width:0;} height:92px;margin:0;padding:18px 30px;
.topbar-title{display:flex;flex-direction:column;min-width:0;} display:flex;align-items:center;justify-content:space-between;gap:18px;
.topbar-title span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.18em;} border-bottom:1px solid rgba(148,163,184,.10);
.topbar-title strong{font-size:1.08rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} background:linear-gradient(180deg,rgba(2,3,5,.88),rgba(2,3,5,.66));
.icon-btn,.toolbar-pill{border:0;background:rgba(255,255,255,.05);color:var(--text);border:1px solid var(--border);height:42px;min-width:42px;padding:0 12px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer;} backdrop-filter:blur(18px);
.icon-btn:hover,.toolbar-pill:hover{background:rgba(255,255,255,.09);} }
.toolbar-pill{gap:8px;font-size:.85rem;} .topbar-left,.topbar-actions{display:flex;align-items:center;gap:12px;min-width:0;}
.user-pill{height:42px;border:1px solid var(--border);background:rgba(255,255,255,.04);border-radius:999px;display:flex;align-items:center;gap:8px;padding:0 12px;} .topbar-title{display:flex;flex-direction:column;gap:4px;min-width:0;}
.user-pill strong{font-size:.88rem;max-width:120px;overflow:hidden;text-overflow:ellipsis;} .topbar-title span{font-size:.68rem;line-height:1;text-transform:uppercase;letter-spacing:.22em;color:var(--accent);font-weight:850;}
.workspace-main{padding:28px;min-width:0;} .topbar-title strong{font-size:1.18rem;line-height:1.15;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tab-pane{animation:fadeIn .18s ease-out;} .icon-btn,
@keyframes fadeIn{from{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:none}} .language-select,
.card{background:linear-gradient(180deg,var(--card2),var(--card));border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow);} .user-pill{
.card-title{font-size:1rem;font-weight:760;} min-height:42px;border:1px solid rgba(148,163,184,.14);border-radius:15px;
.card-hdr{margin-bottom:14px;} background:rgba(255,255,255,.045);color:var(--text);
.grid2{gap:18px;} box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.icon-btn{width:42px;display:none;align-items:center;justify-content:center;cursor:pointer;}
.language-select{padding:0 12px;font-size:.8rem;font-weight:800;outline:0;}
.user-pill{display:flex;align-items:center;gap:8px;padding:0 12px;max-width:230px;}
.user-pill strong{font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.workspace-main{width:100%;min-width:0;padding:30px;}
/* Cards and dashboard */
.tab-pane{display:none;animation:fadeIn .2s ease both;}
.tab-pane.active{display:block;}
@keyframes fadeIn{from{opacity:.35;transform:translateY(8px)}to{opacity:1;transform:none}}
.card{
min-width:0;position:relative;overflow:hidden;
border:1px solid rgba(148,163,184,.12);
border-radius:var(--radius-xl);
background:linear-gradient(180deg,rgba(16,22,32,.94),rgba(9,13,19,.96));
box-shadow:0 20px 58px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.025);
padding:18px;
}
.card::before{
content:"";position:absolute;left:0;right:0;top:0;height:1px;
background:linear-gradient(90deg,transparent,rgba(34,211,238,.28),transparent);
pointer-events:none;
}
.card+.card{margin-top:18px;} .card+.card{margin-top:18px;}
.chip{border-color:var(--border);background:rgba(255,255,255,.05);padding:4px 9px;font-size:.7rem;} .card-hdr{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:15px;min-width:0;}
.chip.green{background:rgba(54,211,122,.12);} .card-title{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0;font-size:1rem;font-weight:900;letter-spacing:.005em;}
.chip.warn{background:rgba(255,190,76,.12);} .card-actions,.form-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.chip.red{background:rgba(255,112,112,.12);} .grid2{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.62fr);gap:18px;align-items:start;}
.btn{border-radius:12px;padding:9px 14px;font-size:.82rem;background:linear-gradient(135deg,var(--accent),#3b82f6);font-weight:750;box-shadow:0 10px 24px rgba(90,73,245,.22);} .dashboard-lower{margin-top:18px;}
.btn-sm{padding:7px 11px;font-size:.76rem;} .dash-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;}
.btn-ghost{box-shadow:none;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);} .dash-card{
.btn-ghost:hover{border-color:rgba(90,73,245,.55);color:#fff;background:rgba(90,73,245,.12);} position:relative;min-height:154px;overflow:hidden;
.btn-danger{box-shadow:none;background:rgba(255,112,112,.12);border:1px solid rgba(255,112,112,.30);color:var(--danger);} border:1px solid rgba(148,163,184,.12);
.btn-warn{box-shadow:none;background:rgba(255,190,76,.12);border:1px solid rgba(255,190,76,.30);color:var(--warn);} border-radius:28px;padding:20px;
.btn-light{background:#fff;color:#4e3dde;box-shadow:none;} background:
.btn-soft{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.2);box-shadow:none;color:#fff;} radial-gradient(circle at 90% 0%,rgba(255,255,255,.08),transparent 34%),
.metrics{gap:12px;} linear-gradient(180deg,rgba(16,22,32,.95),rgba(8,12,18,.98));
.metric{background:rgba(255,255,255,.045);border:1px solid var(--border);border-radius:15px;padding:14px;} box-shadow:0 20px 60px rgba(0,0,0,.28);
.m-label{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;} }
.m-val{font-size:1.2rem;margin-top:5px;} .dash-card::after{content:"";position:absolute;inset:auto -35px -52px auto;width:140px;height:140px;border-radius:999px;background:var(--accent-soft);filter:blur(2px);}
.tbl-wrap{border:1px solid var(--border);border-radius:15px;overflow:auto;background:rgba(255,255,255,.025);} .dash-card-main{position:relative;z-index:1;display:flex;flex-direction:column;gap:8px;}
table{font-size:.82rem;} .dash-label{color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;font-weight:850;}
thead{background:rgba(255,255,255,.04);} .dash-card strong{font-size:2rem;letter-spacing:-.05em;line-height:1.05;}
th,td{padding:11px 12px;border-bottom:1px solid var(--border);} .dash-card small{font-size:.78rem;line-height:1.35;color:var(--muted);}
th{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;} .dash-icon{
tbody tr:hover{background:rgba(90,73,245,.08);} position:absolute;right:17px;top:17px;width:44px;height:44px;border-radius:17px;
.field label{font-size:.76rem;font-weight:680;} display:grid;place-items:center;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.075);
.field input,.field select,.field textarea,.ov-field,.code-area{border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.045);color:var(--text);padding:10px 12px;font-size:.84rem;} color:var(--accent);font-size:1.15rem;
.field input:focus,.field select:focus,.field textarea:focus,.ov-field:focus,.code-area:focus{border-color:rgba(90,73,245,.70);box-shadow:0 0 0 3px rgba(90,73,245,.15);} }
.form-grid{gap:12px;} .accent-blue{--accent-soft:rgba(34,211,238,.13);}
.statusbar,.hint{font-size:.76rem;} .accent-green{--accent-soft:rgba(20,241,149,.12);}
.overlay{background:radial-gradient(circle at top,rgba(90,73,245,.34),rgba(18,18,18,.96) 42%,#0b0b0c);} .accent-purple{--accent-soft:rgba(139,92,246,.14);}
.overlay-inner{border-radius:24px;background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--border);box-shadow:0 30px 80px rgba(0,0,0,.5);padding:28px;} .accent-orange{--accent-soft:rgba(255,200,87,.13);}
.ov-title{font-size:1.4rem;} .quick-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.dash-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:20px;} .quick-action{
.dash-card{position:relative;overflow:hidden;min-height:156px;background:linear-gradient(180deg,var(--card2),var(--card));border:1px solid var(--border);border-left:6px solid rgba(90,73,245,.8);border-radius:20px;padding:22px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow);} text-align:left;border:1px solid rgba(148,163,184,.12);border-radius:18px;
.dash-card:after{content:"";position:absolute;right:-45px;top:-45px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.035);} background:rgba(255,255,255,.035);color:var(--text);padding:14px;cursor:pointer;
.dash-card-main{display:flex;flex-direction:column;gap:8px;z-index:1;} transition:transform .16s ease,border-color .16s ease,background .16s ease;
.dash-label{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);} }
.dash-card strong{font-size:2.45rem;line-height:1;} .quick-action:hover{transform:translateY(-1px);border-color:rgba(34,211,238,.28);background:rgba(34,211,238,.06);}
.dash-card small{color:var(--muted);font-size:.88rem;} .quick-action strong{display:block;font-size:.9rem;margin-bottom:5px;}
.dash-icon{width:68px;height:68px;border-radius:999px;display:grid;place-items:center;font-size:1.7rem;color:#fff;z-index:1;background:rgba(90,73,245,.38);} .quick-action span{display:block;color:var(--muted);font-size:.77rem;line-height:1.35;}
.accent-green{border-left-color:#25c266}.accent-green .dash-icon{background:rgba(37,194,102,.38)}
.accent-purple{border-left-color:#af2ff4}.accent-purple .dash-icon{background:rgba(175,47,244,.38)} /* UI pieces */
.accent-orange{border-left-color:#ff9f43}.accent-orange .dash-icon{background:rgba(255,159,67,.38)} .btn{
.dashboard-lower{align-items:start;} display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:40px;
.quick-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;} border:1px solid rgba(34,211,238,.22);border-radius:14px;
.quick-action{border:1px solid var(--border);background:rgba(255,255,255,.04);border-radius:16px;color:var(--text);padding:16px;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:5px;} padding:9px 14px;cursor:pointer;
.quick-action:hover{background:rgba(90,73,245,.12);border-color:rgba(90,73,245,.45);} color:#031014;font-weight:900;font-size:.82rem;
.quick-action strong{font-size:.92rem;}.quick-action span{font-size:.78rem;color:var(--muted);} background:linear-gradient(135deg,var(--accent),var(--accent-3));
.quota-meter{height:12px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden;border:1px solid var(--border);} box-shadow:0 12px 30px rgba(34,211,238,.16);
.quota-meter span{display:block;height:100%;width:0%;border-radius:inherit;background:linear-gradient(90deg,#36d37a,#ffbe4c,#ff7070);transition:width .25s;} transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease,color .15s ease;
.badge-on{color:var(--success);font-weight:750}.badge-off{color:var(--muted);font-weight:700} }
pre.log-box{background:#121214;border-color:var(--border);border-radius:15px;} .btn:hover{transform:translateY(-1px);box-shadow:0 16px 36px rgba(34,211,238,.22);}
.drawer-backdrop{display:none;} .btn-sm{min-height:34px;padding:7px 11px;font-size:.75rem;border-radius:12px;}
@media(max-width:1180px){.dash-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.sidebar{width:250px;}.workspace{margin-left:250px;}} .btn-ghost{color:var(--text-2);background:rgba(255,255,255,.045);border-color:rgba(148,163,184,.14);box-shadow:none;}
@media(max-width:820px){ .btn-ghost:hover{color:var(--text);background:rgba(34,211,238,.075);border-color:rgba(34,211,238,.28);box-shadow:none;}
.panel-layout{display:block;} .btn-danger{color:#ffdce1;background:rgba(255,91,105,.12);border-color:rgba(255,91,105,.34);box-shadow:none;}
.btn-danger:hover{background:rgba(255,91,105,.18);box-shadow:none;}
.btn-warn{color:#fff3cf;background:rgba(255,200,87,.12);border-color:rgba(255,200,87,.34);box-shadow:none;}
.btn-light,.btn-soft{color:var(--text);background:rgba(255,255,255,.07);border-color:rgba(148,163,184,.16);box-shadow:none;}
.chip{
display:inline-flex;align-items:center;justify-content:center;gap:5px;
border:1px solid rgba(148,163,184,.14);border-radius:999px;
padding:4px 9px;background:rgba(255,255,255,.045);color:var(--text-2);
font-size:.69rem;font-weight:900;letter-spacing:.02em;white-space:nowrap;
}
.chip.green{color:#9ff4bf;border-color:rgba(49,214,123,.25);background:rgba(49,214,123,.10);}
.chip.warn{color:#ffe3a1;border-color:rgba(255,200,87,.28);background:rgba(255,200,87,.10);}
.chip.red{color:#ffc6cc;border-color:rgba(255,91,105,.28);background:rgba(255,91,105,.10);}
.hint{font-size:.76rem;line-height:1.45;color:var(--muted);}
.statusbar{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:.76rem;}
.badge-on,.badge-off{display:inline-flex;align-items:center;gap:6px;font-size:.73rem;font-weight:900;}
.badge-on{color:var(--success);}
.badge-off{color:var(--muted);}
.badge-on::before,.badge-off::before{content:"";width:7px;height:7px;border-radius:999px;background:currentColor;box-shadow:0 0 14px currentColor;}
/* Metrics */
.metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:11px;}
.metric{min-width:0;border:1px solid rgba(148,163,184,.11);border-radius:18px;background:rgba(255,255,255,.035);padding:14px;}
.m-label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;font-weight:850;}
.m-val{margin-top:7px;font-size:1.14rem;line-height:1.15;font-weight:950;color:var(--text);word-break:break-word;}
/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px;}
.field{display:flex;flex-direction:column;gap:6px;min-width:0;}
.field label{color:var(--text-2);font-size:.75rem;font-weight:850;letter-spacing:.01em;}
.field-row{display:flex;align-items:center;gap:8px;min-width:0;}
.field-row input{flex:1 1 auto;}
.form-actions{margin-top:13px;}
.collapsible.collapsed{display:none;}
textarea{resize:vertical;}
.code-area{font-family:"SFMono-Regular",Consolas,"Liberation Mono",monospace;font-size:.75rem;line-height:1.45;min-height:160px;}
pre.log-box,.log-box{
display:block;width:100%;max-height:260px;overflow:auto;white-space:pre-wrap;word-break:break-word;
color:#b7c3d4;background:#05080d;border:1px solid rgba(148,163,184,.13);border-radius:18px;
padding:14px;font-family:"SFMono-Regular",Consolas,"Liberation Mono",monospace;font-size:.73rem;line-height:1.5;
}
/* Tables */
.tbl-wrap{width:100%;overflow:auto;border:1px solid rgba(148,163,184,.12);border-radius:20px;background:rgba(3,6,10,.55);}
table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px;font-size:.8rem;}
th,td{padding:11px 12px;text-align:left;vertical-align:middle;border-bottom:1px solid rgba(148,163,184,.09);}
th{position:sticky;top:0;z-index:1;background:#080c12;color:var(--muted);font-size:.69rem;text-transform:uppercase;letter-spacing:.12em;font-weight:950;}
tbody tr{transition:background .14s ease;}
tbody tr:hover{background:rgba(34,211,238,.045);}
tbody tr:last-child td{border-bottom:0;}
td{color:var(--text-2);}
td .btn+ .btn{margin-left:6px;}
.table-meter,.mini-meter,.quota-meter,.bar{position:relative;display:block;overflow:hidden;background:rgba(148,163,184,.12);border-radius:999px;}
.mini-meter{height:7px;margin-top:8px;}
.quota-meter{height:12px;margin:14px 0 9px;}
.table-meter{height:6px;margin-top:6px;max-width:170px;}
.bar{height:8px;margin-top:8px;}
.table-meter span,.mini-meter span,.quota-meter span,.bar-inner{display:block;height:100%;width:0;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent-3));box-shadow:0 0 18px rgba(34,211,238,.24);transition:width .25s ease;}
/* Save/config helpers */
.save-bar{
position:sticky;bottom:18px;z-index:10;
margin-top:18px;padding:14px 16px;
display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
border:1px solid rgba(148,163,184,.14);border-radius:22px;
background:linear-gradient(180deg,rgba(14,20,30,.92),rgba(7,10,16,.94));
box-shadow:0 22px 60px rgba(0,0,0,.42);
backdrop-filter:blur(16px);
}
.save-bar-actions{margin:0;}
.mini-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px;}
.mini-summary span{display:flex;flex-direction:column;gap:5px;border:1px solid rgba(148,163,184,.12);border-radius:16px;padding:12px;background:rgba(255,255,255,.035);}
.mini-summary strong{font-size:1rem;}
.mini-summary small{color:var(--muted);font-size:.72rem;}
.reseller-helper-card{margin-bottom:18px;}
hr{border:0;border-top:1px solid rgba(148,163,184,.12);margin:14px 0;}
/* Desktop shell alignment override */
@media(min-width:901px){
.panel-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:18px;padding:18px;}
.sidebar{position:sticky;left:auto;top:18px;bottom:auto;width:300px;height:calc(100vh - 36px);max-height:calc(100vh - 36px);}
@supports (height:100dvh){.sidebar{height:calc(100dvh - 36px);max-height:calc(100dvh - 36px);}}
.workspace{margin-left:0;min-height:calc(100vh - 36px);border:1px solid rgba(148,163,184,.10);border-radius:28px;overflow:hidden;background:linear-gradient(180deg,rgba(6,9,14,.52),rgba(2,3,5,.18));box-shadow:var(--shadow);}
@supports (min-height:100dvh){.workspace{min-height:calc(100dvh - 36px);}}
}
/* Layout stability fixes: keep wide pages from leaving broken empty columns */
@media(min-width:1321px){
.dash-grid{grid-template-columns:repeat(12,minmax(0,1fr));}
.dash-grid>.dash-card{grid-column:span 3;}
.dash-grid>.dash-resource{grid-column:span 4;}
#mainApp.role-superadmin .dashboard-lower{grid-template-columns:1fr;}
#mainApp.role-superadmin .dashboard-lower>.card:not(.hidden){grid-column:1/-1;}
#mainApp.role-superadmin .dashboard-lower .quick-actions{grid-template-columns:repeat(4,minmax(0,1fr));}
#mainApp.role-reseller .dashboard-lower{grid-template-columns:minmax(0,1fr) minmax(360px,.62fr);}
}
@supports selector(:has(*)){
.dashboard-lower:has(#dashboardQuotaCard.hidden){grid-template-columns:1fr;}
.dashboard-lower:has(#dashboardQuotaCard.hidden)>.card:not(.hidden){grid-column:1/-1;}
}
/* Mobile drawer */
.drawer-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.58);z-index:22;backdrop-filter:blur(2px);}
body.drawer-open .drawer-backdrop,body.sidebar-open .drawer-backdrop{display:block;}
@media(max-width:1320px){
.dash-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
.grid2{grid-template-columns:1fr;}
.metrics{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:900px){
.panel-layout{display:block;padding:0;}
.workspace{border:0;border-radius:0;overflow:visible;background:transparent;box-shadow:none;}
.sidebar{left:12px;top:12px;bottom:12px;transform:translateX(calc(-100% - 24px));transition:transform .2s ease;width:min(86vw,310px);}
body.drawer-open .sidebar,body.sidebar-open .sidebar,.sidebar.open{transform:translateX(0);}
.workspace{margin-left:0;} .workspace{margin-left:0;}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(82vw,300px);height:100vh;transform:translateX(-105%);transition:transform .22s ease;} .icon-btn{display:inline-flex;}
body.sidebar-open .sidebar{transform:translateX(0);} .topbar{height:auto;min-height:78px;padding:16px;align-items:flex-start;}
.drawer-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.58);z-index:18;backdrop-filter:blur(4px);} .topbar-actions{margin-left:auto;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
body.sidebar-open .drawer-backdrop{display:block;} .workspace-main{padding:18px 14px 26px;}
.topbar{height:auto;min-height:76px;padding:12px 14px;align-items:flex-start;} .dash-grid{grid-template-columns:1fr;gap:12px;}
.topbar-actions{gap:8px;justify-content:flex-end;flex-wrap:wrap;}
.toolbar-pill,.topbar-actions .icon-btn,.user-pill{display:none;}
.workspace-main{padding:18px 14px 28px;}
.dash-grid{grid-template-columns:1fr;gap:14px;}
.dash-card{min-height:148px;}
.grid2{display:block;}
.grid2>div+div,.grid2>.card+div,.grid2>div+.card,.grid2>.card+.card{margin-top:16px;}
.quick-actions{grid-template-columns:1fr;} .quick-actions{grid-template-columns:1fr;}
.card{padding:16px;border-radius:18px;} .language-select,.user-pill{min-height:38px;}
.tbl-wrap table{min-width:780px;}
.form-grid,.form-grid[style*="grid-template-columns"],#wzVlessFields,#wzSSFields,#wzCertSrcFile,#wzCertSrcPaste>div,#tlsLEFields,#tlsCustomFields,#tlsPasteFields .form-grid{grid-template-columns:1fr!important;}
} }
@media(max-width:520px){ @media(max-width:640px){
.topbar-title strong{font-size:.98rem}.topbar-title span{font-size:.62rem;} .topbar{display:grid;grid-template-columns:1fr;gap:12px;}
.dash-card{padding:20px;} .topbar-left,.topbar-actions{width:100%;}
.dash-card strong{font-size:2.2rem}.dash-icon{width:62px;height:62px;} .topbar-actions{justify-content:flex-start;}
th,td{padding:10px 10px;} .topbar-title strong{font-size:1.02rem;}
.user-pill{max-width:100%;}
.form-grid,.metrics,.mini-summary{grid-template-columns:1fr!important;}
.card{border-radius:20px;padding:14px;}
.dash-card{min-height:132px;border-radius:22px;padding:17px;}
.dash-card strong{font-size:1.65rem;}
.card-hdr{align-items:flex-start;flex-direction:column;}
.field-row{flex-wrap:wrap;}
.field-row .btn{flex:0 0 auto;}
.save-bar{bottom:10px;border-radius:18px;}
table{font-size:.76rem;}
th,td{padding:9px 10px;}
} }
/* Better reseller counters and quota summaries */
.reseller-helper-card{margin-bottom:14px;background:linear-gradient(135deg,rgba(90,73,245,.16),rgba(54,211,122,.06)),var(--card);}
.mini-meter{width:100%;height:8px;background:rgba(255,255,255,.07);border:1px solid var(--border);border-radius:999px;overflow:hidden;margin-top:2px;max-width:210px;}
.mini-meter span{display:block;height:100%;width:0%;border-radius:inherit;background:linear-gradient(90deg,#36d37a,#ffbe4c,#ff7070);transition:width .25s ease;}
.mini-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px;}
.mini-summary span{display:flex;flex-direction:column;gap:3px;background:rgba(255,255,255,.045);border:1px solid var(--border);border-radius:14px;padding:12px;min-width:0;}
.mini-summary strong{font-size:1.05rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mini-summary small{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;}
.quota-good{color:var(--success)!important}.quota-warn{color:var(--warn)!important}.quota-danger{color:var(--danger)!important}
@media(max-width:620px){.mini-summary{grid-template-columns:1fr}.mini-meter{max-width:none}}
.table-meter{height:6px;min-width:130px;max-width:220px;background:rgba(255,255,255,.07);border:1px solid var(--border);border-radius:999px;overflow:hidden;margin-top:6px;}
.table-meter span{display:block;height:100%;background:linear-gradient(90deg,#36d37a,#ffbe4c,#ff7070);border-radius:inherit;}
/* Final responsive hardening */
.card-hdr{align-items:flex-start;max-width:100%;}
.card-hdr .card-title{flex:1 1 220px;min-width:0;}
.card-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;max-width:100%;min-width:0;}
.card-actions .btn{white-space:nowrap;}
.dashboard-meter{max-width:230px;}
.save-bar{margin-top:18px;padding:14px 16px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,var(--card2),var(--card));box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.save-bar-actions{justify-content:flex-start;}
.topbar-actions{min-width:0;}
@media(max-width:820px){
.card-hdr .card-title{flex-basis:100%;}
.card-actions{width:100%;justify-content:flex-start;}
.card-actions .btn{flex:1 1 auto;justify-content:center;}
.save-bar{align-items:stretch;}
.save-bar-actions{width:100%;}
.save-bar-actions .btn{flex:1 1 130px;}
.welcome-actions{width:100%;justify-content:flex-start;}
.welcome-actions .btn{flex:1 1 150px;justify-content:center;}
}
@media(max-width:420px){
.topbar-left{min-width:0;}
.workspace-main{padding-left:10px;padding-right:10px;}
.dash-card{min-height:132px;padding:18px;}
.dash-card small{font-size:.78rem;}
.dash-icon{width:54px;height:54px;font-size:1.35rem;}
.btn{padding:9px 11px;}
}
/* Xray client table updates in place; this tiny state avoids visual flicker during background polling. */
#inboundsContainer.xray-refreshing{opacity:.985;}
#inboundsContainer [data-cell]{transition:background-color .12s ease;}
/* Language switcher */
.language-select{height:36px;border:1px solid var(--border);background:rgba(255,255,255,.045);color:var(--text);border-radius:12px;padding:0 10px;font-size:.78rem;font-weight:750;outline:none;cursor:pointer;}
.language-select:focus{border-color:rgba(90,73,245,.70);box-shadow:0 0 0 3px rgba(90,73,245,.15);}
.light-mode .language-select{background:#fff;color:#111827;}
@media(max-width:640px){.language-select{height:34px;padding:0 8px;font-size:.72rem;}}

View File

@@ -189,7 +189,6 @@ const roleChip = document.getElementById("roleChip");
const logoutBtn = document.getElementById("logoutBtn"); const logoutBtn = document.getElementById("logoutBtn");
const menuToggle = document.getElementById("menuToggle"); const menuToggle = document.getElementById("menuToggle");
const drawerBackdrop = document.getElementById("drawerBackdrop"); const drawerBackdrop = document.getElementById("drawerBackdrop");
const themeToggle = document.getElementById("themeToggle");
const languageSelect = document.getElementById("languageSelect"); const languageSelect = document.getElementById("languageSelect");
const pageTitle = document.getElementById("pageTitle"); const pageTitle = document.getElementById("pageTitle");
const pageEyebrow = document.getElementById("pageEyebrow"); const pageEyebrow = document.getElementById("pageEyebrow");
@@ -487,7 +486,6 @@ function selectTab(tab) {
document.querySelectorAll(".tab-btn").forEach(btn => btn.addEventListener("click", () => selectTab(btn.dataset.tab))); document.querySelectorAll(".tab-btn").forEach(btn => btn.addEventListener("click", () => selectTab(btn.dataset.tab)));
menuToggle?.addEventListener("click", () => document.body.classList.add("sidebar-open")); menuToggle?.addEventListener("click", () => document.body.classList.add("sidebar-open"));
drawerBackdrop?.addEventListener("click", () => document.body.classList.remove("sidebar-open")); drawerBackdrop?.addEventListener("click", () => document.body.classList.remove("sidebar-open"));
themeToggle?.addEventListener("click", () => document.body.classList.toggle("light-mode"));
languageSelect?.addEventListener("change", () => { applyLanguage(languageSelect.value); renderDashboardCounters(); }); languageSelect?.addEventListener("change", () => { applyLanguage(languageSelect.value); renderDashboardCounters(); });
document.querySelectorAll(".quick-action[data-jump]").forEach(btn => btn.addEventListener("click", () => selectTab(btn.dataset.jump))); document.querySelectorAll(".quick-action[data-jump]").forEach(btn => btn.addEventListener("click", () => selectTab(btn.dataset.jump)));
applyLanguage(currentLang, { persist: false }); applyLanguage(currentLang, { persist: false });
@@ -545,6 +543,8 @@ function clearTimers() {
function initAfterLogin() { function initAfterLogin() {
meUsername.textContent = currentUser; meUsername.textContent = currentUser;
mainApp.classList.remove("role-superadmin", "role-reseller");
mainApp.classList.add(currentRole === "superadmin" ? "role-superadmin" : "role-reseller");
roleChip.innerHTML = currentRole === "superadmin" roleChip.innerHTML = currentRole === "superadmin"
? `<span class="chip green">superadmin</span>` ? `<span class="chip green">superadmin</span>`
: `<span class="chip warn">reseller</span>`; : `<span class="chip warn">reseller</span>`;

View File

@@ -2,7 +2,7 @@
<html lang="en" class="i18n-pending"> <html lang="en" class="i18n-pending">
<head> <head>
<meta charset="UTF-8"/> <meta charset="UTF-8"/>
<title>DragonCore Panel</title> <title>DragonCore Command</title>
<meta name="viewport" content="width=device-width,initial-scale=1"/> <meta name="viewport" content="width=device-width,initial-scale=1"/>
<style>html.i18n-pending body{visibility:hidden}</style> <style>html.i18n-pending body{visibility:hidden}</style>
<script> <script>
@@ -16,7 +16,7 @@
setTimeout(function(){document.documentElement.classList.remove("i18n-pending");},2500); setTimeout(function(){document.documentElement.classList.remove("i18n-pending");},2500);
})(); })();
</script> </script>
<link rel="stylesheet" href="assets/app.css?v=20260510i18n1"/> <link rel="stylesheet" href="assets/app.css?v=20260510black3"/>
</head> </head>
<body> <body>
<div class="app"> <div class="app">
@@ -25,8 +25,8 @@
<!-- Login overlay --> <!-- Login overlay -->
<div class="overlay" id="loginOverlay"> <div class="overlay" id="loginOverlay">
<div class="overlay-inner"> <div class="overlay-inner">
<div class="ov-title">SSH Panel</div> <div class="ov-title">DragonCore Command</div>
<div class="ov-sub">Sign in with your admin or reseller credentials.</div> <div class="ov-sub">Access the private control node with admin or reseller credentials.</div>
<input id="loginUser" class="ov-field" placeholder="Username" autocomplete="username"/> <input id="loginUser" class="ov-field" placeholder="Username" autocomplete="username"/>
<input id="loginPass" class="ov-field" type="password" placeholder="Password" autocomplete="current-password"/> <input id="loginPass" class="ov-field" type="password" placeholder="Password" autocomplete="current-password"/>
<button class="btn" id="loginBtn" style="width:100%;margin-top:6px;justify-content:center;">Sign in</button> <button class="btn" id="loginBtn" style="width:100%;margin-top:6px;justify-content:center;">Sign in</button>
@@ -39,10 +39,10 @@
<div class="panel-layout"> <div class="panel-layout">
<aside class="sidebar" id="sidebar"> <aside class="sidebar" id="sidebar">
<div class="brand-block"> <div class="brand-block">
<div class="brand-mark">🐉</div> <div class="brand-mark">DC</div>
<div class="brand-copy"> <div class="brand-copy">
<strong>DragonCore</strong> <strong>DragonCore</strong>
<span>VPN Control</span> <span>Command Node</span>
</div> </div>
</div> </div>
<nav id="mainNav" class="side-nav"> <nav id="mainNav" class="side-nav">
@@ -69,7 +69,6 @@
</div> </div>
</div> </div>
<div class="topbar-actions"> <div class="topbar-actions">
<button class="icon-btn" id="themeToggle" type="button" title="Alternar tema"></button>
<select id="languageSelect" class="language-select" title="Language" aria-label="Language"> <select id="languageSelect" class="language-select" title="Language" aria-label="Language">
<option value="pt-BR">PT-BR</option> <option value="pt-BR">PT-BR</option>
<option value="en-US">EN-US</option> <option value="en-US">EN-US</option>
@@ -128,7 +127,7 @@
</div> </div>
<div class="dash-icon"></div> <div class="dash-icon"></div>
</div> </div>
<div class="dash-card accent-blue superadmin-only hidden"> <div class="dash-card dash-resource accent-blue superadmin-only hidden">
<div class="dash-card-main"> <div class="dash-card-main">
<span class="dash-label">CPU</span> <span class="dash-label">CPU</span>
<strong id="dashCpuVal">--%</strong> <strong id="dashCpuVal">--%</strong>
@@ -137,7 +136,7 @@
</div> </div>
<div class="dash-icon"></div> <div class="dash-icon"></div>
</div> </div>
<div class="dash-card accent-green superadmin-only hidden"> <div class="dash-card dash-resource accent-green superadmin-only hidden">
<div class="dash-card-main"> <div class="dash-card-main">
<span class="dash-label">RAM</span> <span class="dash-label">RAM</span>
<strong id="dashRamVal">--%</strong> <strong id="dashRamVal">--%</strong>
@@ -146,7 +145,7 @@
</div> </div>
<div class="dash-icon"></div> <div class="dash-icon"></div>
</div> </div>
<div class="dash-card accent-purple superadmin-only hidden"> <div class="dash-card dash-resource accent-purple superadmin-only hidden">
<div class="dash-card-main"> <div class="dash-card-main">
<span class="dash-label">Rede</span> <span class="dash-label">Rede</span>
<strong id="dashNetVal">--</strong> <strong id="dashNetVal">--</strong>
@@ -873,6 +872,6 @@
</div><!-- /shell --> </div><!-- /shell -->
</div><!-- /app --> </div><!-- /app -->
<script defer src="assets/app.js?v=20260510i18n1"></script> <script defer src="assets/app.js?v=20260510black2"></script>
</body> </body>
</html> </html>