/* ============================================
   RaskVPN Admin — Premium v6 (Monochrome Noir)
   Black / Graphite / Platinum
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800;900&family=Unbounded:wght@500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* surfaces — deep black to graphite */
  --bg:#08090b;
  --bg2:#0d0e11;
  --bg3:#121317;
  --bg4:#181a1f;
  --bg5:#1f2127;

  --line:rgba(255,255,255,.05);
  --line2:rgba(255,255,255,.10);
  --line3:rgba(255,255,255,.16);

  /* accent — platinum / silver (replaces emerald green) */
  --acc:#e9ecf1;
  --acc2:#c2c7d0;
  --acc3:#8d93a0;
  --acc-soft:rgba(233,236,241,.08);
  --acc-soft2:rgba(233,236,241,.14);
  --acc-glow:0 0 30px rgba(233,236,241,.12),0 0 80px rgba(233,236,241,.05);
  --acc-glow-sm:0 0 14px rgba(233,236,241,.18);

  /* brand gold (logo) */
  --gold1:#f4d27a;
  --gold2:#c89a3c;

  /* status (used sparingly) */
  --blue:#7aa8ff; --blue-soft:rgba(122,168,255,.10);
  --purple:#b69cff; --purple-soft:rgba(182,156,255,.10);
  --orange:#ffb066; --orange-soft:rgba(255,176,102,.10);
  --red:#ff6b85;   --red-soft:rgba(255,107,133,.10);
  --green:#7eef9e; --green-soft:rgba(126,239,158,.10);

  /* text */
  --t1:#f5f6f8;
  --t2:#a6abb6;
  --t3:#727682;
  --t4:#494d57;
  --t5:#22252b;

  --r:14px; --r2:18px; --r3:22px; --r4:28px;
  --sw:248px;
  --sp:.22s cubic-bezier(.4,0,.2,1);
  --sp-l:.45s cubic-bezier(.34,1.56,.64,1);
  --font:'Manrope',system-ui,-apple-system,sans-serif;
  --font-h:'Unbounded','Manrope',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
}

html{font-size:14px;scroll-behavior:smooth}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--t1);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}

/* ===== SOPHISTICATED LAYERED BACKGROUND ===== */
body::before{
  content:'';
  position:fixed;inset:0;
  background:
    radial-gradient(ellipse 1100px 700px at 12% -5%,rgba(122,168,255,.07),transparent 55%),
    radial-gradient(ellipse 900px 600px at 95% 8%,rgba(182,156,255,.06),transparent 55%),
    radial-gradient(ellipse 1000px 700px at 100% 100%,rgba(255,176,102,.05),transparent 60%),
    radial-gradient(ellipse 900px 700px at 0% 100%,rgba(126,239,158,.035),transparent 60%),
    radial-gradient(ellipse 600px 400px at 50% 50%,rgba(255,255,255,.02),transparent 70%);
  pointer-events:none;
  z-index:0;
  animation:bgDrift 22s ease-in-out infinite alternate;
}
body::after{
  content:'';
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 30%,transparent 80%);
  pointer-events:none;
  z-index:0;
}
@keyframes bgDrift{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(-20px,15px,0) scale(1.05)}
}

/* floating orbs background */
.orbs{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.orbs::before,.orbs::after{
  content:'';position:absolute;border-radius:50%;filter:blur(80px);opacity:.18;
  animation:orbMove 18s ease-in-out infinite alternate;
}
.orbs::before{width:520px;height:520px;background:radial-gradient(circle,#7aa8ff,transparent 70%);top:-10%;left:30%}
.orbs::after{width:440px;height:440px;background:radial-gradient(circle,#b69cff,transparent 70%);bottom:-15%;right:18%;animation-delay:-9s;animation-duration:24s}
@keyframes orbMove{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(80px,-50px) scale(1.15)}
}

.side,.main,.modal,.notif-pop{position:relative;z-index:2}

::selection{background:var(--acc-soft2);color:var(--t1)}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--t5);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--t4)}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:var(--font)}

/* ===== LOGO ===== */
.logo-svg{display:inline-block;flex-shrink:0;filter:drop-shadow(0 0 14px rgba(244,210,122,.40))}
.logo-svg svg{display:block}

/* ===== SIDEBAR ===== */
.side{
  position:fixed;inset:0 auto 0 0;
  width:var(--sw);
  background:linear-gradient(180deg,rgba(13,14,17,.92) 0%,rgba(8,9,11,.96) 100%);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  z-index:100;
}
.side-brand{padding:24px 22px;display:flex;align-items:center;gap:13px;border-bottom:1px solid var(--line)}
.side-brand h1{font-family:var(--font-h);font-size:14px;font-weight:700;letter-spacing:-.2px;background:linear-gradient(90deg,var(--gold1),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.side-brand small{display:block;font-size:9px;color:var(--t4);font-weight:600;letter-spacing:1.6px;margin-top:3px;text-transform:uppercase}

.side-nav{padding:18px 12px;flex:1;overflow-y:auto}
.side-sep{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;color:var(--t4);padding:18px 14px 10px}
.side-sep:first-child{padding-top:4px}

.sn{display:flex;align-items:center;gap:13px;padding:11px 14px;border-radius:12px;color:var(--t2);font-size:13px;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;margin-bottom:3px;will-change:transform}
.sn svg{width:18px;height:18px;stroke-width:1.8;flex-shrink:0;transition:all .35s cubic-bezier(.34,1.56,.64,1);opacity:.65}
.sn:hover{color:var(--t1);background:rgba(255,255,255,.035);transform:translateX(3px)}
.sn:hover svg{opacity:1;transform:scale(1.12)}
.sn.on{color:var(--t1);background:linear-gradient(90deg,rgba(255,255,255,.06),transparent 90%)}
.sn.on svg{opacity:1;stroke:var(--t1)}
.sn.on::before{content:'';position:absolute;left:-12px;top:7px;bottom:7px;width:3px;border-radius:0 4px 4px 0;background:linear-gradient(180deg,#fff,var(--acc3));box-shadow:var(--acc-glow-sm)}

.side-foot{padding:14px 12px;border-top:1px solid var(--line)}
.side-user{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.03);transition:background var(--sp);border:1px solid var(--line)}
.side-user:hover{background:rgba(255,255,255,.05)}
.side-user .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#fff,#a8aebb);color:#0a0c10;display:grid;place-items:center;font-weight:800;font-size:12px;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.side-user .info{flex:1;min-width:0}
.side-user .nm{font-size:12.5px;font-weight:700;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.side-user .role{font-size:10px;color:var(--t4);font-weight:600;text-transform:uppercase;letter-spacing:.8px;margin-top:1px}
.side-user .out{width:30px;height:30px;border-radius:8px;background:transparent;border:1px solid var(--line2);color:var(--t3);display:grid;place-items:center;transition:all var(--sp);flex-shrink:0}
.side-user .out:hover{background:var(--red-soft);color:var(--red);border-color:transparent}
.side-user .out svg{width:14px;height:14px;stroke-width:2;fill:none;stroke:currentColor}

/* lang */
.side-lang{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:11px;background:rgba(255,255,255,.025);border:1px solid var(--line);margin-bottom:10px;cursor:pointer;transition:all var(--sp);color:var(--t2);font-size:12px;font-weight:600}
.side-lang:hover{background:rgba(255,255,255,.05);border-color:var(--line2)}
.side-lang-l{display:flex;align-items:center;gap:9px}
.side-lang-flag{font-size:16px}
.side-lang svg{width:13px;height:13px;stroke:var(--t4);fill:none;stroke-width:2;transition:transform var(--sp)}

/* ===== MAIN ===== */
.main{margin-left:var(--sw);padding:28px 38px 64px;min-height:100vh}

/* ===== TOPBAR ===== */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 0 24px;gap:14px}
.topbar-l{display:flex;flex-direction:column;gap:2px}
.topbar-greet{font-family:var(--font-h);font-size:18px;font-weight:600;letter-spacing:-.4px;color:var(--t1)}
.topbar-sub{font-size:12px;color:var(--t3);font-weight:500}
.topbar-r{display:flex;align-items:center;gap:10px}

.topbar-icon-btn{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid var(--line);color:var(--t2);display:grid;place-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;cursor:pointer}
.topbar-icon-btn:hover{background:rgba(255,255,255,.08);color:var(--t1);border-color:var(--line2);transform:translateY(-2px)}
.topbar-icon-btn:active{transform:translateY(0) scale(.95)}
.topbar-icon-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2}
.topbar-icon-btn .dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 10px var(--red);animation:blink 1.8s ease infinite}

/* ===== NOTIFICATION DROPDOWN ===== */
.notif-wrap{position:relative}
.notif-pop{
  position:absolute;top:calc(100% + 10px);right:0;
  width:380px;max-height:520px;
  background:linear-gradient(180deg,rgba(18,19,23,.98),rgba(13,14,17,.99));
  border:1px solid var(--line2);border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.03);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:none;flex-direction:column;
  z-index:200;overflow:hidden;
  animation:notifIn .3s cubic-bezier(.34,1.56,.64,1);
}
.notif-pop.open{display:flex}
@keyframes notifIn{from{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:none}}
.notif-h{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);font-size:13px;font-weight:700;letter-spacing:-.2px}
.notif-clear{background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--t3);width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:14px;transition:all var(--sp)}
.notif-clear:hover{background:rgba(255,255,255,.08);color:var(--t1);transform:rotate(90deg)}
.notif-list{flex:1;overflow-y:auto;padding:6px}
.notif-item{display:flex;gap:12px;padding:12px 14px;border-radius:12px;cursor:pointer;transition:background var(--sp);align-items:flex-start}
.notif-item:hover{background:rgba(255,255,255,.04)}
.notif-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;font-size:15px;font-weight:800}
.notif-ic.info{background:var(--blue-soft);color:var(--blue)}
.notif-ic.success{background:var(--green-soft);color:var(--green)}
.notif-ic.warning{background:var(--orange-soft);color:var(--orange)}
.notif-ic.danger{background:var(--red-soft);color:var(--red)}
.notif-c{flex:1;min-width:0}
.notif-t{font-size:12.5px;font-weight:700;color:var(--t1);margin-bottom:2px}
.notif-x{font-size:11.5px;color:var(--t3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.notif-time{font-size:10px;color:var(--t4);margin-top:4px;font-family:var(--mono);font-weight:600;letter-spacing:.4px}
.notif-empty{padding:40px 20px;text-align:center;color:var(--t4);font-size:12.5px}

/* ===== HERO ===== */
.hero{
  position:relative;
  background:linear-gradient(135deg,rgba(18,19,23,.85) 0%,rgba(13,14,17,.92) 100%);
  border:1px solid var(--line);
  border-radius:var(--r4);
  padding:42px 48px;
  margin-bottom:24px;
  overflow:hidden;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.hero::before{content:'';position:absolute;top:-180px;right:-120px;width:520px;height:520px;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 60%);pointer-events:none;animation:heroPulse 8s ease-in-out infinite alternate}
.hero::after{content:'';position:absolute;bottom:-100px;left:-80px;width:380px;height:380px;background:radial-gradient(circle,rgba(122,168,255,.07),transparent 60%);pointer-events:none;animation:heroPulse 10s ease-in-out infinite alternate-reverse}
@keyframes heroPulse{0%{opacity:.4;transform:scale(1)}100%{opacity:1;transform:scale(1.18)}}

.hero-l{position:relative;z-index:2;flex:1;min-width:0}
.hero h1{font-family:var(--font-h);font-size:32px;font-weight:700;letter-spacing:-1.2px;line-height:1.1;color:var(--t1);margin-bottom:12px}
.hero h1 .acc{background:linear-gradient(90deg,#fff,var(--acc3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{color:var(--t2);font-size:14.5px;font-weight:500;max-width:520px;line-height:1.55}

.hero-r{position:relative;z-index:2;display:flex;gap:10px;flex-shrink:0;align-items:center}
.hero-icn-btn{width:54px;height:54px;border-radius:16px;background:rgba(255,255,255,.05);border:1px solid var(--line2);color:var(--t1);display:grid;place-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer}
.hero-icn-btn:hover{background:rgba(255,255,255,.10);box-shadow:var(--acc-glow-sm);transform:translateY(-2px) rotate(8deg)}
.hero-icn-btn:active{transform:translateY(0) scale(.95)}
.hero-icn-btn svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8}

/* ===== PAGE HEADER ===== */
.pg{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.pg h2{font-family:var(--font-h);font-size:20px;font-weight:600;letter-spacing:-.4px}
.pg .sub{color:var(--t3);font-size:13px;margin-top:5px;font-weight:500}

/* ===== STATS ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.st{position:relative;background:linear-gradient(180deg,rgba(18,19,23,.7),rgba(13,14,17,.85));border:1px solid var(--line);border-radius:var(--r3);padding:24px 26px;transition:all .4s cubic-bezier(.34,1.56,.64,1);overflow:hidden;will-change:transform;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.st::before{content:'';position:absolute;left:0;top:22px;bottom:22px;width:3px;border-radius:0 4px 4px 0;background:linear-gradient(180deg,#fff,var(--acc3));opacity:0;transition:all .3s}
.st::after{content:'';position:absolute;top:-50%;right:-30%;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.05),transparent 70%);opacity:0;transition:all .4s;pointer-events:none}
.st:hover{border-color:var(--line2);transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04)}
.st:hover::before{opacity:1}
.st:hover::after{opacity:1}
.st.c-blue::before{background:linear-gradient(180deg,#7aa8ff,#3b6ec7)}.st.c-blue::after{background:radial-gradient(circle,rgba(122,168,255,.10),transparent 70%)}
.st.c-purple::before{background:linear-gradient(180deg,#b69cff,#8767e0)}.st.c-purple::after{background:radial-gradient(circle,rgba(182,156,255,.10),transparent 70%)}
.st.c-orange::before{background:linear-gradient(180deg,#ffb066,#cf7d2c)}.st.c-orange::after{background:radial-gradient(circle,rgba(255,176,102,.10),transparent 70%)}

.st-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;position:relative;z-index:2}
.st-ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center}
.st-ic svg{width:20px;height:20px;stroke-width:1.8;fill:none}
.st-ic.green{background:rgba(255,255,255,.06);color:var(--t1)}
.st-ic.blue{background:var(--blue-soft);color:var(--blue)}
.st-ic.purple{background:var(--purple-soft);color:var(--purple)}
.st-ic.orange{background:var(--orange-soft);color:var(--orange)}

.st-tag{font-size:10.5px;font-weight:700;padding:4px 10px;border-radius:20px;background:rgba(255,255,255,.06);color:var(--t1);display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line)}
.st-tag svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2.5}

.st-v{font-size:34px;font-weight:800;letter-spacing:-1.5px;font-variant-numeric:tabular-nums;position:relative;z-index:2;background:linear-gradient(180deg,#fff,#bcc1cc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.st-l{color:var(--t3);font-size:12.5px;font-weight:600;margin-top:6px;position:relative;z-index:2}

.st-val{font-size:34px;font-weight:800;letter-spacing:-1.5px;font-variant-numeric:tabular-nums}
.st-lab{color:var(--t3);font-size:12.5px;font-weight:600;margin-top:6px}

/* ===== CARD ===== */
.card{background:linear-gradient(180deg,rgba(18,19,23,.7),rgba(13,14,17,.85));border:1px solid var(--line);border-radius:var(--r3);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);margin-bottom:20px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.card:hover{border-color:var(--line2);box-shadow:0 10px 30px rgba(0,0,0,.4)}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:20px 26px;border-bottom:1px solid var(--line)}
.card-h h3{font-family:var(--font-h);font-size:14px;font-weight:600;letter-spacing:-.2px;display:flex;align-items:center;gap:10px}
.card-h h3 svg{width:18px;height:18px;stroke:var(--t1);fill:none;stroke-width:2;opacity:.9}
.card-body{padding:24px 26px}

/* ===== GRID ===== */
.g2{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;margin-bottom:24px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.g4,.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}

.chart-box{padding:22px 24px 18px;height:300px}

/* ===== INFO LIST ===== */
.il{padding:6px 0}
.ilr{display:flex;align-items:center;justify-content:space-between;padding:14px 26px;transition:background var(--sp)}
.ilr:hover{background:rgba(255,255,255,.025)}
.il-l{display:flex;align-items:center;gap:13px;color:var(--t2);font-size:13px;font-weight:500}
.il-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:15px;font-weight:800;background:rgba(255,255,255,.05);color:var(--t1);border:1px solid var(--line)}
.il-v{font-weight:700;font-size:14px;font-family:var(--mono);letter-spacing:-.4px}

/* ===== LIVE ===== */
.live{display:inline-flex;align-items:center;gap:8px;font-size:10.5px;font-weight:800;color:var(--t1);letter-spacing:1.4px}
.live::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green);animation:blink 1.8s ease infinite}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.85)}}

/* ===== SERVERS ===== */
.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px}
.srv{background:linear-gradient(180deg,rgba(18,19,23,.7),rgba(13,14,17,.85));border:1px solid var(--line);border-radius:var(--r3);padding:26px 28px;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;will-change:transform;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.srv:hover{border-color:var(--line2);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.04)}
.srv-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.srv-name{display:flex;align-items:center;gap:14px}
.srv-flag{font-size:32px;line-height:1}
.srv-title{font-weight:700;font-size:15.5px;letter-spacing:-.3px}
.srv-loc{color:var(--t3);font-size:11.5px;margin-top:3px;font-weight:500}

.dot-status{display:inline-flex;align-items:center;gap:7px;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:5px 11px;border-radius:20px}
.dot-status .d{width:7px;height:7px;border-radius:50%}
.dot-status.on{color:var(--green);background:var(--green-soft)}.dot-status.on .d{background:var(--green);box-shadow:0 0 10px var(--green)}
.dot-status.off{color:var(--red);background:var(--red-soft)}.dot-status.off .d{background:var(--red)}

.srv-info{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.srv-info-item .lab{font-size:10px;color:var(--t4);margin-bottom:4px;text-transform:uppercase;letter-spacing:.8px;font-weight:700}
.srv-info-item .val{font-weight:700;font-size:14px;font-family:var(--mono);letter-spacing:-.3px}

.prog{height:5px;background:var(--t5);border-radius:3px;overflow:hidden;margin-bottom:8px}
.prog .bar{height:100%;border-radius:3px;background:linear-gradient(90deg,#fff,var(--acc3));transition:width .9s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px rgba(255,255,255,.20)}
.prog .bar.w{background:linear-gradient(90deg,var(--orange),#ffc89a);box-shadow:0 0 10px rgba(255,176,102,.5)}
.prog .bar.c{background:linear-gradient(90deg,var(--red),#ffa5b6);box-shadow:0 0 10px rgba(255,107,133,.5)}
.prog-t{display:flex;justify-content:space-between;font-size:11px;color:var(--t4);font-family:var(--mono);font-weight:600}

.srv-cfg{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.srv-cfg summary{font-size:12px;color:var(--t3);font-weight:700;cursor:pointer;transition:color var(--sp);list-style:none;display:flex;align-items:center;gap:8px}
.srv-cfg summary:hover{color:var(--t1)}
.srv-cfg summary::before{content:'+';font-size:14px;width:16px;text-align:center;transition:transform .2s;color:var(--t1)}
.srv-cfg[open] summary::before{transform:rotate(45deg)}
.srv-cfg-inner{margin-top:12px;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:14px 16px;font-family:var(--mono);font-size:11px;color:var(--t1);line-height:1.8;white-space:pre-wrap;word-break:break-all}

/* ===== ROW LIST ===== */
.rows{display:flex;flex-direction:column;gap:10px}
.row{background:linear-gradient(180deg,rgba(18,19,23,.7),rgba(13,14,17,.85));border:1px solid var(--line);border-left:3px solid var(--acc3);border-radius:var(--r2);padding:18px 22px;display:flex;align-items:center;gap:24px;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;will-change:transform}
.row:hover{border-color:var(--line2);background:linear-gradient(180deg,rgba(22,23,28,.9),rgba(15,16,20,.95));transform:translateX(4px);box-shadow:0 6px 20px rgba(0,0,0,.3)}
.row.is-red{border-left-color:var(--red)}
.row.is-orange{border-left-color:var(--orange)}
.row.is-blue{border-left-color:var(--blue)}
.row.is-green{border-left-color:var(--green)}
.row.is-gray{border-left-color:var(--t5)}
.row .row-ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0;background:rgba(255,255,255,.05);color:var(--t1);border:1px solid var(--line)}
.row.is-red .row-ic{background:var(--red-soft);color:var(--red);border-color:transparent}
.row.is-orange .row-ic{background:var(--orange-soft);color:var(--orange);border-color:transparent}
.row.is-blue .row-ic{background:var(--blue-soft);color:var(--blue);border-color:transparent}
.row.is-green .row-ic{background:var(--green-soft);color:var(--green);border-color:transparent}
.row .row-ic svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
.row .col{display:flex;flex-direction:column;gap:3px;min-width:0}
.row .col .lab{font-size:10px;color:var(--t4);font-weight:700;text-transform:uppercase;letter-spacing:.8px}
.row .col .val{font-size:13.5px;font-weight:700;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .col .val.acc{color:var(--t1)}
.row .col .val.red{color:var(--red)}
.row .col .val.green{color:var(--green)}
.row .col .val.mono{font-family:var(--mono);letter-spacing:-.3px}
.row .col-id{min-width:60px}
.row .col-status{min-width:120px}
.row .col-grow{flex:1}
.row .col-end{margin-left:auto;display:flex;gap:8px}

/* ===== TABLES ===== */
.tw{overflow-x:auto}
table,.table{width:100%;border-collapse:collapse}
thead th{text-align:left;padding:14px 22px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--t4);border-bottom:1px solid var(--line);white-space:nowrap;background:rgba(255,255,255,.015)}
tbody td{padding:16px 22px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
tbody tr{transition:background var(--sp)}
tbody tr:hover{background:rgba(255,255,255,.025)}
tbody tr:last-child td{border:none}
.dim{color:var(--t4);text-align:center;padding:30px}

.u-cell{display:flex;align-items:center;gap:13px}
.u-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#fff,#a8aebb);color:#0a0c10;display:grid;place-items:center;font-weight:800;font-size:13px;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.u-nm{font-weight:700;font-size:13.5px}
.u-id{font-size:10.5px;color:var(--t4);font-family:var(--mono);margin-top:2px;font-weight:500}

/* ===== BADGES ===== */
.b{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;font-size:10.5px;font-weight:700;letter-spacing:.4px;border:1px solid transparent}
.b.green{background:var(--green-soft);color:var(--green);border-color:rgba(126,239,158,.18)}
.b.red{background:var(--red-soft);color:var(--red);border-color:rgba(255,107,133,.18)}
.b.blue{background:var(--blue-soft);color:var(--blue);border-color:rgba(122,168,255,.18)}
.b.orange{background:var(--orange-soft);color:var(--orange);border-color:rgba(255,176,102,.18)}
.b.gray{background:rgba(255,255,255,.04);color:var(--t3);border-color:var(--line)}
.b.purple{background:var(--purple-soft);color:var(--purple);border-color:rgba(182,156,255,.18)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:12px;font-size:13px;font-weight:700;border:1px solid var(--line2);background:rgba(255,255,255,.04);color:var(--t1);transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;letter-spacing:-.1px;position:relative;overflow:hidden;will-change:transform}
.btn:hover{background:rgba(255,255,255,.08);border-color:var(--line3);transform:translateY(-1px)}
.btn:active{transform:translateY(1px) scale(.98);transition-duration:.08s}
.btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .25s}
.btn:hover svg{transform:translateX(2px)}

/* primary monochrome (white) */
.btn-acc,.btn-a{background:linear-gradient(135deg,#fff,#cdd1d9);color:#0a0c10;border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 14px rgba(255,255,255,.12),inset 0 1px 0 rgba(255,255,255,.5)}
.btn-acc:hover,.btn-a:hover{box-shadow:var(--acc-glow),inset 0 1px 0 rgba(255,255,255,.6);transform:translateY(-2px)}
.btn-acc:active,.btn-a:active{transform:translateY(0) scale(.98)}

.btn-r{background:var(--red-soft);color:var(--red);border-color:rgba(255,107,133,.20)}
.btn-r:hover{background:rgba(255,107,133,.20);box-shadow:0 0 18px rgba(255,107,133,.18);transform:translateY(-1px)}

.btn-g{background:transparent;border:1px solid var(--line2);color:var(--t2)}
.btn-g:hover{border-color:var(--line3);color:var(--t1);background:rgba(255,255,255,.04);transform:translateY(-1px)}

.btn-s{padding:8px 14px;font-size:11.5px;border-radius:10px}

/* ===== INPUTS ===== */
.inp,input[type=text],input[type=number],input[type=password],input[type=email],select,textarea{
  width:100%;padding:13px 18px;background:var(--bg);border:1px solid var(--line2);border-radius:12px;
  color:var(--t1);font-family:var(--font);font-size:13.5px;font-weight:500;outline:none;
  transition:all .2s cubic-bezier(.4,0,.2,1)
}
.inp:focus,input:focus,select:focus,textarea:focus{border-color:rgba(255,255,255,.30);box-shadow:0 0 0 4px rgba(255,255,255,.05);transform:translateY(-1px)}
.inp::placeholder,input::placeholder,textarea::placeholder{color:var(--t4)}
select.inp,select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23727682' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.fg{margin-bottom:18px}
.fg label{display:block;font-size:11.5px;font-weight:700;color:var(--t2);margin-bottom:8px;text-transform:uppercase;letter-spacing:.8px}

/* form rows for new pages */
.form-row{margin-bottom:16px}
.form-row label{display:block;font-size:11px;font-weight:700;color:var(--t3);margin-bottom:7px;text-transform:uppercase;letter-spacing:.8px}
.form-msg{min-height:18px;font-size:12px;font-weight:600;margin-bottom:10px}
.form-msg.ok{color:var(--green)}
.form-msg.err{color:var(--red)}

/* settings row with toggle */
.set-row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:6px 0}
.set-row-t{font-size:14px;font-weight:700;color:var(--t1);margin-bottom:3px}
.set-row-s{font-size:12px;color:var(--t3);font-weight:500}

/* toggle switch */
.switch{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0}
.switch .slider{position:absolute;cursor:pointer;inset:0;background:rgba(255,255,255,.08);border:1px solid var(--line2);border-radius:30px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}
.switch .slider::before{content:'';position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:linear-gradient(180deg,#fff,#bcc1cc);border-radius:50%;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 6px rgba(0,0,0,.4)}
.switch input:checked + .slider{background:linear-gradient(135deg,#fff,#a8aebb)}
.switch input:checked + .slider::before{transform:translateX(22px);background:#0a0c10}

.search{display:flex;align-items:center;gap:11px;background:var(--bg);border:1px solid var(--line2);border-radius:11px;padding:0 16px;transition:all .15s}
.search:focus-within{border-color:rgba(255,255,255,.30);box-shadow:0 0 0 4px rgba(255,255,255,.04)}
.search svg{width:16px;height:16px;stroke:var(--t4);fill:none;stroke-width:2;flex-shrink:0}
.search input{background:none;border:none;outline:none;color:var(--t1);font-family:var(--font);font-size:13px;font-weight:500;padding:11px 0;width:240px}
.search input::placeholder{color:var(--t4)}

/* ===== FOOTER ===== */
.tfoot{display:flex;align-items:center;justify-content:space-between;padding:18px 26px;border-top:1px solid var(--line)}
.tfoot .pg-i{color:var(--t4);font-size:12px;font-family:var(--mono);font-weight:600}

/* ===== EMPTY ===== */
.empty{text-align:center;padding:64px 20px}
.empty .ei{font-size:48px;margin-bottom:16px;display:block;opacity:.4}
.empty .et{font-size:15px;font-weight:700;color:var(--t2);margin-bottom:6px}
.empty .ed{color:var(--t4);font-size:12.5px}

/* ===== MODAL (legacy .mo + new .modal) ===== */
.mo,.modal{position:fixed;inset:0;display:none;place-items:center;z-index:1000;padding:20px}
.mo.open,.modal.open{display:grid;animation:moBg .25s ease}
.modal-bg{position:absolute;inset:0;background:rgba(5,7,10,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.mo{background:rgba(5,7,10,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
@keyframes moBg{from{opacity:0}to{opacity:1}}

.mo-box,.modal-card{background:linear-gradient(180deg,rgba(18,19,23,.98),rgba(13,14,17,.99));border:1px solid var(--line2);border-radius:var(--r3);padding:30px;width:600px;max-width:100%;max-height:90vh;overflow-y:auto;animation:mo-in .35s cubic-bezier(.34,1.56,.64,1);position:relative;box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04)}
.mo-box::before,.modal-card::before{content:'';position:absolute;top:-1px;left:30%;right:30%;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);border-radius:2px}
@keyframes mo-in{from{opacity:0;transform:scale(.94) translateY(14px)}to{opacity:1;transform:none}}

.mo-t,.modal-h{font-size:18px;font-weight:800;margin-bottom:22px;display:flex;align-items:center;justify-content:space-between;letter-spacing:-.4px;font-family:var(--font-h)}
.modal-h h2{font-family:var(--font-h);font-size:18px;font-weight:600;letter-spacing:-.3px}
.mo-x,.modal-x{width:34px;height:34px;border-radius:50%;border:1px solid var(--line2);background:none;color:var(--t3);display:grid;place-items:center;font-size:18px;transition:all var(--sp)}
.mo-x:hover,.modal-x:hover{background:var(--red-soft);color:var(--red);border-color:transparent;transform:rotate(90deg)}
.modal-body{margin-bottom:20px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding-top:20px;border-top:1px solid var(--line)}

.mo-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.mo-item{background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:11px;padding:15px 17px}
.mo-item .ml{font-size:10px;color:var(--t4);font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.mo-item .mv{font-size:14.5px;font-weight:700;font-family:var(--mono);letter-spacing:-.3px}
.mo-acts{display:flex;gap:10px;margin-top:22px;padding-top:22px;border-top:1px solid var(--line);flex-wrap:wrap}

/* ===== USER ACTIONS PANEL (admin user modal) ===== */
.ua-wrap{display:flex;flex-direction:column;width:100%;margin-top:22px;background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.ua-wrap .ua-sec + .ua-sec,.ua-wrap .ua-foot{border-top:1px solid var(--line)}
.ua-sec{padding:14px 18px}
.ua-h{display:flex;align-items:center;justify-content:space-between;font-size:10.5px;font-weight:800;color:var(--t3);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:12px}
.ua-h > span:first-child{display:inline-flex;align-items:center;gap:8px}
.ua-cur{font-family:var(--mono);font-weight:700;font-size:13px;color:var(--t1);text-transform:none;letter-spacing:0}
.ua-st{font-size:10.5px;font-weight:700;text-transform:none;letter-spacing:0;padding:3px 9px;border-radius:99px;border:1px solid transparent}
.ua-st.is-ok{background:rgba(80,200,140,.10);color:#7dd9a6;border-color:rgba(80,200,140,.25)}
.ua-st.is-bad{background:rgba(255,107,133,.10);color:#ff8aa3;border-color:rgba(255,107,133,.25)}
.ua-st.is-mute{background:rgba(255,255,255,.04);color:var(--t3);border-color:var(--line2)}
.ua-row{display:flex;flex-wrap:wrap;gap:8px}
.ua-foot{padding:14px 18px;background:rgba(255,75,110,.04);display:flex;justify-content:flex-end}
.ua-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:10px;font-size:12.5px;font-weight:700;letter-spacing:.2px;border:1px solid transparent;cursor:pointer;transition:all .15s ease;line-height:1;white-space:nowrap;font-family:inherit}
.ua-btn:hover{transform:translateY(-1px)}
.ua-btn:active{transform:translateY(0) scale(.98)}
.ua-btn svg{flex-shrink:0}
.ua-primary{background:linear-gradient(135deg,#fff,#cdd1d9);color:#0a0c10;border-color:rgba(255,255,255,.4);box-shadow:0 2px 8px rgba(255,255,255,.10)}
.ua-primary:hover{box-shadow:0 4px 16px rgba(255,255,255,.18)}
.ua-good{background:rgba(80,200,140,.12);color:#7dd9a6;border-color:rgba(80,200,140,.28)}
.ua-good:hover{background:rgba(80,200,140,.20);box-shadow:0 0 14px rgba(80,200,140,.18)}
.ua-warn{background:rgba(255,180,80,.10);color:#f3c871;border-color:rgba(255,180,80,.25)}
.ua-warn:hover{background:rgba(255,180,80,.18);box-shadow:0 0 14px rgba(255,180,80,.18)}
.ua-ghost{background:transparent;color:var(--t2);border-color:var(--line2)}
.ua-ghost:hover{color:var(--t1);border-color:var(--line3);background:rgba(255,255,255,.04)}
.ua-danger{background:rgba(255,75,110,.10);color:#ff7a92;border-color:rgba(255,75,110,.30)}
.ua-danger:hover{background:rgba(255,75,110,.20);box-shadow:0 0 16px rgba(255,75,110,.22)}

/* ===== KEY BLOCK ===== */
.keyb{background:var(--bg);border:1px solid var(--line2);border-radius:11px;padding:18px 110px 18px 20px;font-family:var(--mono);font-size:12px;color:var(--t1);word-break:break-all;line-height:1.8;position:relative;margin:12px 0;white-space:pre-wrap;min-height:48px;display:flex;align-items:center}
.keyb .cp{position:absolute;top:50%;right:10px;transform:translateY(-50%);background:rgba(255,255,255,.06);border:1px solid var(--line2);border-radius:8px;padding:6px 12px;font-size:10.5px;font-weight:700;color:var(--t1);cursor:pointer;font-family:var(--font);transition:all .15s;letter-spacing:.4px}
.keyb .cp:hover{background:#fff;color:#000;border-color:#fff}

/* ===== TABS ===== */
.tabs{display:inline-flex;gap:3px;background:var(--bg2);border:1px solid var(--line);border-radius:13px;padding:4px;margin-bottom:22px}
.tab{padding:9px 20px;border-radius:9px;font-size:12.5px;font-weight:700;color:var(--t3);background:none;border:none;transition:all var(--sp)}
.tab:hover{color:var(--t1)}
.tab.on{background:rgba(255,255,255,.08);color:var(--t1)}

/* ===== LOG ===== */
.log-wrap{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:0;max-height:580px;overflow-y:auto;font-family:var(--mono);font-size:11.5px;line-height:1.9}
.log-line{padding:8px 22px;border-bottom:1px solid rgba(255,255,255,.025);display:flex;gap:16px;transition:background .1s;align-items:center}
.log-line:hover{background:rgba(255,255,255,.025)}
.log-line:last-child{border:none}
.log-time{color:var(--t4);min-width:148px;flex-shrink:0;font-weight:500}
.log-level{min-width:60px;font-weight:800;flex-shrink:0;letter-spacing:.6px}
.log-level.info{color:var(--blue)}
.log-level.warn,.log-level.warning{color:var(--orange)}
.log-level.error{color:var(--red)}
.log-level.ok,.log-level.auth{color:var(--green)}
.log-msg{color:var(--t2)}

/* ===== LOGIN ===== */
.login-page{display:grid;place-items:center;min-height:100vh;background:#15171c;padding:24px;position:relative;overflow:hidden}
.login-page::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,#1a1c21 0%,#121419 100%);pointer-events:none}
.login-page::after{display:none}
.login-box{width:430px;max-width:100%;background:linear-gradient(180deg,rgba(18,19,23,.95),rgba(13,14,17,.98));border:1px solid var(--line2);border-radius:28px;padding:48px 42px;position:relative;z-index:2;box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.login-box::before{content:'';position:absolute;top:-1px;left:25%;right:25%;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);border-radius:2px}
.login-logo{text-align:center;margin-bottom:38px}
.login-logo .logo-svg{margin-bottom:20px}
.login-logo h2{font-family:var(--font-h);font-size:22px;font-weight:600;letter-spacing:-.3px;background:linear-gradient(90deg,var(--gold1),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.login-logo p{color:var(--t3);font-size:13px;margin-top:8px;font-weight:500}

.login-btn{width:100%;padding:15px;background:linear-gradient(135deg,#fff,#cdd1d9);color:#0a0c10;border:1px solid rgba(255,255,255,.5);border-radius:14px;font-family:var(--font);font-size:14px;font-weight:800;letter-spacing:.2px;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:8px;cursor:pointer;position:relative;overflow:hidden;box-shadow:0 4px 16px rgba(255,255,255,.12)}
.remember-me{display:flex;align-items:center;gap:8px;margin:8px 0 4px;font-size:13px;color:#a4a9b4;cursor:pointer;user-select:none}
.remember-me input{width:16px;height:16px;accent-color:#f4d27a;cursor:pointer}
.remember-me span{flex:1}
.login-btn:hover{box-shadow:var(--acc-glow);transform:translateY(-2px)}
.login-btn:active{transform:translateY(0) scale(.98);transition-duration:.08s}

.login-err{background:var(--red-soft);color:var(--red);padding:12px 16px;border-radius:11px;font-size:12.5px;font-weight:600;margin-bottom:18px;display:none;border:1px solid rgba(255,107,133,.18)}
.login-f{text-align:center;margin-top:36px;font-size:11px;color:var(--t4);font-family:var(--mono);letter-spacing:1px;font-weight:600}

/* ===== ANIMATIONS ===== */
.fade{animation:fadeUp .6s cubic-bezier(.34,1.56,.64,1) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.fade-d1{animation-delay:.08s}.fade-d2{animation-delay:.16s}.fade-d3{animation-delay:.24s}.fade-d4{animation-delay:.32s}

.float{animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.shimmer{background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);background-size:200% 100%;animation:shimmer 2.5s infinite}

/* ===== RESPONSIVE ===== */
@media(max-width:1280px){.stats,.grid-4{grid-template-columns:repeat(2,1fr)}.g2,.g3,.g4{grid-template-columns:1fr}}
@media(max-width:860px){.side{display:none}.main{margin-left:0;padding:18px}.stats,.grid-4{grid-template-columns:1fr}.srv-grid{grid-template-columns:1fr}.mo-grid{grid-template-columns:1fr}.hero{padding:26px 22px;flex-direction:column;align-items:flex-start}.hero h1{font-size:26px}.row{flex-wrap:wrap;gap:12px}.row .col-end{margin-left:0}.notif-pop{width:calc(100vw - 40px);right:-10px}}
