330 lines
23 KiB
CSS
330 lines
23 KiB
CSS
|
|
:root{
|
|
--bg:#0f172a;--bg2:#111827;--card:#020617;--accent:#3b82f6;
|
|
--accent-soft:rgba(59,130,246,.15);--border:#1f2937;--text:#e5e7eb;
|
|
--muted:#9ca3af;--danger:#ef4444;--success:#22c55e;--warn:#f59e0b;
|
|
}
|
|
*{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;}
|
|
.app{padding:10px;}
|
|
@media(min-width:768px){.app{padding:20px;}}
|
|
|
|
/* ── Shell ── */
|
|
.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;}
|
|
@media(min-width:768px){.shell{padding:20px;}}
|
|
|
|
/* ── Header ── */
|
|
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;}
|
|
.logo span{color:var(--accent);}
|
|
nav{display:flex;gap:4px;flex-wrap:wrap;}
|
|
.tab-btn{background:transparent;border:1px solid transparent;border-radius:999px;padding:5px 12px;font-size:.75rem;color:var(--muted);cursor:pointer;}
|
|
.tab-btn:hover{border-color:var(--border);color:var(--text);}
|
|
.tab-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);}
|
|
.hright{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--muted);}
|
|
.hright strong{color:var(--text);}
|
|
|
|
/* ── Cards / Grid ── */
|
|
.grid2{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:12px;}
|
|
@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;}
|
|
.card+.card{margin-top:12px;}
|
|
.card-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:6px;flex-wrap:wrap;}
|
|
.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;}
|
|
.badge-on{color:var(--success);font-size:.68rem;}
|
|
.badge-off{color:var(--muted);font-size:.68rem;}
|
|
|
|
/* ── Xray log / config editor ── */
|
|
.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;}
|
|
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;}
|
|
|
|
/* ── Mobile hardening ──
|
|
Keep the shell/cards inside the phone viewport and let wide tables scroll
|
|
inside their own card instead of pushing the whole panel sideways. */
|
|
html,body{width:100%;max-width:100%;overflow-x:hidden;}
|
|
.app,.shell,.tab-pane,.grid2,.grid2>*,.card,.tbl-wrap,.form-grid,.field,.metric{min-width:0;max-width:100%;}
|
|
.card-title{flex-wrap:wrap;min-width:0;}
|
|
.card-hdr>*{min-width:0;}
|
|
.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
|
|
────────────────────────────────────────────────────────────── */
|
|
:root{
|
|
--bg:#121212;
|
|
--bg2:#1b1b1c;
|
|
--panel:#222223;
|
|
--panel2:#282829;
|
|
--card:#242425;
|
|
--card2:#2a2a2c;
|
|
--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);}
|
|
body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;}
|
|
body.light-mode{
|
|
--bg:#f4f6fb;--bg2:#fff;--panel:#fff;--panel2:#f7f8fc;--card:#fff;--card2:#f8f9fd;
|
|
--border:rgba(15,23,42,.10);--text:#172033;--muted:#667085;--shadow:0 18px 45px rgba(31,41,55,.12);
|
|
}
|
|
.app{padding:0;background:linear-gradient(180deg,var(--bg),#101010);min-height:100vh;}
|
|
.shell{max-width:none;margin:0;background:transparent;border:0;border-radius:0;box-shadow:none;padding:0;min-height:100vh;}
|
|
.panel-layout{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh;background:var(--bg);}
|
|
.sidebar{position:sticky;top:0;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);}
|
|
.brand-block{height:112px;display:flex;align-items:center;gap:14px;padding:22px 22px;border-bottom:1px solid var(--border);}
|
|
.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));}
|
|
.brand-copy{display:flex;flex-direction:column;gap:2px;}
|
|
.brand-copy strong{font-size:1.05rem;letter-spacing:.02em;}
|
|
.brand-copy span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.18em;}
|
|
.side-nav{display:flex;flex-direction:column;gap:5px;padding:20px 16px;overflow-y:auto;flex:1;}
|
|
.nav-group-label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.16em;margin:14px 12px 4px;}
|
|
.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;}
|
|
.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);}
|
|
.nav-icon{width:25px;text-align:center;font-size:1.05rem;opacity:.94;}
|
|
.sidebar-foot{border-top:1px solid var(--border);padding:16px 18px;display:flex;align-items:center;gap:13px;background:rgba(0,0,0,.08);}
|
|
.avatar-dragon{width:42px;height:42px;border-radius:14px;background:#111;display:grid;place-items:center;font-size:1.45rem;}
|
|
.sidebar-foot strong{display:block;font-size:.93rem;}
|
|
.sidebar-foot span{display:block;color:var(--muted);font-size:.78rem;margin-top:2px;text-transform:capitalize;}
|
|
.workspace{min-width:0;display:flex;flex-direction:column;background:radial-gradient(circle at 35% -10%,rgba(90,73,245,.12),transparent 32%),var(--bg);}
|
|
.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;}
|
|
body.light-mode .topbar{background:rgba(255,255,255,.82);}
|
|
.topbar-left,.topbar-actions{display:flex;align-items:center;gap:14px;min-width:0;}
|
|
.topbar-title{display:flex;flex-direction:column;min-width:0;}
|
|
.topbar-title span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.18em;}
|
|
.topbar-title strong{font-size:1.08rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
|
|
.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;}
|
|
.icon-btn:hover,.toolbar-pill:hover{background:rgba(255,255,255,.09);}
|
|
.toolbar-pill{gap:8px;font-size:.85rem;}
|
|
.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;}
|
|
.user-pill strong{font-size:.88rem;max-width:120px;overflow:hidden;text-overflow:ellipsis;}
|
|
.workspace-main{padding:28px;min-width:0;}
|
|
.tab-pane{animation:fadeIn .18s ease-out;}
|
|
@keyframes fadeIn{from{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:none}}
|
|
.card{background:linear-gradient(180deg,var(--card2),var(--card));border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow);}
|
|
.card-title{font-size:1rem;font-weight:760;}
|
|
.card-hdr{margin-bottom:14px;}
|
|
.grid2{gap:18px;}
|
|
.card+.card{margin-top:18px;}
|
|
.chip{border-color:var(--border);background:rgba(255,255,255,.05);padding:4px 9px;font-size:.7rem;}
|
|
.chip.green{background:rgba(54,211,122,.12);}
|
|
.chip.warn{background:rgba(255,190,76,.12);}
|
|
.chip.red{background:rgba(255,112,112,.12);}
|
|
.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);}
|
|
.btn-sm{padding:7px 11px;font-size:.76rem;}
|
|
.btn-ghost{box-shadow:none;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);}
|
|
.btn-ghost:hover{border-color:rgba(90,73,245,.55);color:#fff;background:rgba(90,73,245,.12);}
|
|
.btn-danger{box-shadow:none;background:rgba(255,112,112,.12);border:1px solid rgba(255,112,112,.30);color:var(--danger);}
|
|
.btn-warn{box-shadow:none;background:rgba(255,190,76,.12);border:1px solid rgba(255,190,76,.30);color:var(--warn);}
|
|
.btn-light{background:#fff;color:#4e3dde;box-shadow:none;}
|
|
.btn-soft{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.2);box-shadow:none;color:#fff;}
|
|
.metrics{gap:12px;}
|
|
.metric{background:rgba(255,255,255,.045);border:1px solid var(--border);border-radius:15px;padding:14px;}
|
|
.m-label{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;}
|
|
.m-val{font-size:1.2rem;margin-top:5px;}
|
|
.tbl-wrap{border:1px solid var(--border);border-radius:15px;overflow:auto;background:rgba(255,255,255,.025);}
|
|
table{font-size:.82rem;}
|
|
thead{background:rgba(255,255,255,.04);}
|
|
th,td{padding:11px 12px;border-bottom:1px solid var(--border);}
|
|
th{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;}
|
|
tbody tr:hover{background:rgba(90,73,245,.08);}
|
|
.field label{font-size:.76rem;font-weight:680;}
|
|
.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;}
|
|
.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;}
|
|
.statusbar,.hint{font-size:.76rem;}
|
|
.overlay{background:radial-gradient(circle at top,rgba(90,73,245,.34),rgba(18,18,18,.96) 42%,#0b0b0c);}
|
|
.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;}
|
|
.ov-title{font-size:1.4rem;}
|
|
.welcome-card{background:linear-gradient(135deg,#5547f4,#af2ff4);border-radius:22px;padding:30px 28px;display:flex;justify-content:space-between;gap:20px;align-items:center;box-shadow:0 20px 55px rgba(90,73,245,.28);margin-bottom:22px;}
|
|
.welcome-kicker{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.75);margin-bottom:8px;}
|
|
.welcome-card h1{font-size:1.9rem;line-height:1.08;margin:0 0 7px;}
|
|
.welcome-card p{color:rgba(255,255,255,.82);font-size:1.02rem;margin:0;}
|
|
.welcome-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
|
|
.dash-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:20px;}
|
|
.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);}
|
|
.dash-card:after{content:"";position:absolute;right:-45px;top:-45px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.035);}
|
|
.dash-card-main{display:flex;flex-direction:column;gap:8px;z-index:1;}
|
|
.dash-label{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);}
|
|
.dash-card strong{font-size:2.45rem;line-height:1;}
|
|
.dash-card small{color:var(--muted);font-size:.88rem;}
|
|
.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);}
|
|
.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)}
|
|
.accent-orange{border-left-color:#ff9f43}.accent-orange .dash-icon{background:rgba(255,159,67,.38)}
|
|
.dashboard-lower{align-items:start;}
|
|
.quick-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
|
|
.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;}
|
|
.quick-action:hover{background:rgba(90,73,245,.12);border-color:rgba(90,73,245,.45);}
|
|
.quick-action strong{font-size:.92rem;}.quick-action span{font-size:.78rem;color:var(--muted);}
|
|
.quota-meter{height:12px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden;border:1px solid var(--border);}
|
|
.quota-meter span{display:block;height:100%;width:0%;border-radius:inherit;background:linear-gradient(90deg,#36d37a,#ffbe4c,#ff7070);transition:width .25s;}
|
|
.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;}
|
|
.drawer-backdrop{display:none;}
|
|
@media(max-width:1180px){.dash-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.panel-layout{grid-template-columns:250px minmax(0,1fr);}}
|
|
@media(max-width:820px){
|
|
.panel-layout{grid-template-columns:1fr;}
|
|
.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(82vw,300px);height:100vh;transform:translateX(-105%);transition:transform .22s ease;}
|
|
body.sidebar-open .sidebar{transform:translateX(0);}
|
|
.drawer-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.58);z-index:18;backdrop-filter:blur(4px);}
|
|
body.sidebar-open .drawer-backdrop{display:block;}
|
|
.topbar{height:auto;min-height:76px;padding:12px 14px;align-items:flex-start;}
|
|
.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;}
|
|
.welcome-card{padding:28px 22px;align-items:flex-start;flex-direction:column;}
|
|
.welcome-card h1{font-size:1.6rem;}
|
|
.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;}
|
|
.card{padding:16px;border-radius:18px;}
|
|
.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){
|
|
.topbar-title strong{font-size:.98rem}.topbar-title span{font-size:.62rem;}
|
|
.welcome-card{border-radius:20px;margin-bottom:16px;}.dash-card{padding:20px;}
|
|
.dash-card strong{font-size:2.2rem}.dash-icon{width:62px;height:62px;}
|
|
th,td{padding:10px 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;}
|
|
.welcome-actions .btn{white-space:nowrap;}
|
|
@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;}
|
|
}
|