/* APX VPN — apx-dashboard (page) */

body.dashboard-page { display: flex; }

/* ── SIDEBAR ──────────────────────────────────────── */
.sidebar{
  width:var(--sb);flex-shrink:0;background:var(--card2);border-right:1px solid var(--b1);
  display:flex;flex-direction:column;padding:1.25rem .875rem;
  position:fixed;left:0;top:0;bottom:0;z-index:50;
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}
.sb-logo{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;margin-bottom:1.75rem;text-decoration:none;flex-shrink:0}
.sb-logo-ico{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#0d9488,#7c3aed);display:flex;align-items:center;justify-content:center;box-shadow:0 0 18px rgba(20,184,166,.28);flex-shrink:0}
.sb-logo span{font-size:.95rem;font-weight:900;color:var(--tx);letter-spacing:-.02em}
.sb-nav{flex:1;display:flex;flex-direction:column;gap:.2rem}
.sb-item{display:flex;align-items:center;gap:.7rem;padding:.7rem .875rem;border-radius:var(--r);color:var(--tx2);font-size:.85rem;font-weight:600;cursor:pointer;border:none;background:transparent;text-align:left;width:100%;transition:.18s;letter-spacing:-.01em}
.sb-item svg{flex-shrink:0;opacity:.65;transition:.18s}
.sb-item:hover{background:rgba(255,255,255,.05);color:var(--tx)}
.sb-item:hover svg{opacity:.9}
.sb-item.active{background:linear-gradient(135deg,rgba(20,184,166,.16),rgba(139,92,246,.1));color:var(--accL);border:1px solid rgba(20,184,166,.18)}
.sb-item.active svg{opacity:1}
.sb-item.danger{color:var(--err)}
.sb-item.danger:hover{background:rgba(239,68,68,.08)}
.sb-divider{height:1px;background:var(--b1);margin:.5rem 0}
.sb-user{padding:.85rem .875rem;background:rgba(255,255,255,.03);border:1px solid var(--b1);border-radius:var(--r);margin-top:.5rem}
.sb-user-name{font-size:.85rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.1rem}
.sb-user-email{font-size:.72rem;color:var(--tx3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── TOPBAR (mobile) ────────────────────────────── */
.topbar{display:none;position:fixed;top:0;left:0;right:0;z-index:60;background:rgba(7,7,8,.92);backdrop-filter:blur(24px);border-bottom:1px solid var(--b1);padding:0 1rem;height:56px;align-items:center;justify-content:space-between}
.tb-logo{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:900;color:var(--tx);text-decoration:none;letter-spacing:-.02em}
.tb-right{display:flex;align-items:center;gap:.5rem}
.burger{background:rgba(255,255,255,.06);border:1px solid var(--b1);border-radius:8px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx2)}
.burger:hover{background:rgba(255,255,255,.1);color:var(--tx)}
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:49}
.sb-overlay.open{display:block}
.sb-mobile-header{display:none;align-items:center;justify-content:space-between;padding:.6rem .875rem .25rem;margin-bottom:.25rem}
.sb-mobile-title{font-size:.78rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.08em}
.sb-close{background:rgba(255,255,255,.07);border:1px solid var(--b1);border-radius:8px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx2);transition:.18s}
.sb-close:hover{background:rgba(255,255,255,.12);color:var(--tx)}
@media(max-width:768px){.sb-mobile-header{display:flex}}

/* ── MAIN ────────────────────────────────────────── */
.main{flex:1;margin-left:var(--sb);padding:2rem;overflow-y:auto;min-height:100vh;max-width:calc(100vw - var(--sb))}
.page{display:none}
.page.active{display:block;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.pg-hd{margin-bottom:2rem}
.pg-title{font-size:clamp(1.4rem,3vw,1.75rem);font-weight:900;letter-spacing:-.04em;margin-bottom:.25rem}
.pg-sub{color:var(--tx2);font-size:.875rem;font-weight:500}
.grad-text{background:linear-gradient(135deg,var(--accL),var(--pur));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── CARDS / GRID ───────────────────────────────── */
.card{background:var(--card);border:1px solid var(--b1);border-radius:var(--rXL);padding:1.5rem;backdrop-filter:blur(20px)}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:.875rem}
.stat-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--rL);padding:1.1rem 1.35rem;backdrop-filter:blur(20px);transition:.2s}
.stat-card:hover{border-color:var(--b2)}
.sc-label{font-size:.7rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.3rem}
.sc-val{font-size:1.7rem;font-weight:900;letter-spacing:-.04em}

/* ── BUTTONS ─────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.65rem 1.2rem;border-radius:var(--r);font-size:.875rem;font-weight:700;cursor:pointer;border:none;transition:.2s;font-family:inherit;white-space:nowrap;letter-spacing:-.01em;text-decoration:none}
.btn-primary{background:var(--acc);color:#fff;box-shadow:0 0 20px var(--accG)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 32px var(--accG)}
.btn-primary:active{transform:none}
.btn-outline{background:transparent;color:var(--accL);border:1.5px solid var(--b2)}
.btn-outline:hover{background:var(--accG)}
.btn-ghost{background:rgba(255,255,255,.05);color:var(--tx2);border:1.5px solid var(--b1)}
.btn-ghost:hover{background:rgba(255,255,255,.08);color:var(--tx)}
.btn-sm{padding:.4rem .85rem;font-size:.78rem;border-radius:9px}
.btn-lg{padding:.85rem 1.75rem;font-size:.95rem;border-radius:14px}
.w-full{width:100%}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}

/* ── TG TRIAL BANNER ─────────────────────────────── */
.tg-trial-banner{
  display:flex;align-items:center;gap:1rem;
  margin-bottom:1.25rem;padding:1rem 1.15rem 1rem 1.25rem;
  border-radius:var(--rXL);
  background:linear-gradient(135deg,rgba(29,78,216,.18),rgba(139,92,246,.12));
  border:1px solid rgba(20,184,166,.22);
  text-decoration:none;color:inherit;
  position:relative;overflow:hidden;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.tg-trial-banner::before{
  content:'';position:absolute;right:-40px;top:50%;transform:translateY(-50%);
  width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle,rgba(20,184,166,.14),transparent 70%);
  pointer-events:none;
}
.tg-trial-banner:hover{
  border-color:rgba(96,165,250,.45);
  transform:translateY(-1px);
  box-shadow:0 8px 28px rgba(20,184,166,.12);
}
.tg-trial-banner:active{transform:none}
.tg-trial-ico{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,#229ED9,#0d9488);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 18px rgba(34,158,217,.25);
}
.tg-trial-body{flex:1;min-width:0;position:relative;z-index:1}
.tg-trial-tag{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ok);background:rgba(52,211,153,.12);
  border:1px solid rgba(52,211,153,.25);border-radius:999px;
  padding:.2rem .55rem;margin-bottom:.35rem;
}
.tg-trial-title{font-size:1rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.15rem}
.tg-trial-sub{font-size:.8rem;color:var(--tx2);font-weight:500;line-height:1.4}
.tg-trial-arrow{
  flex-shrink:0;width:36px;height:36px;border-radius:10px;
  background:rgba(255,255,255,.06);border:1px solid var(--b1);
  display:flex;align-items:center;justify-content:center;
  color:var(--accL);transition:.18s;
}
.tg-trial-banner:hover .tg-trial-arrow{background:rgba(20,184,166,.15);border-color:rgba(20,184,166,.3)}
@media(max-width:768px){
  .tg-trial-banner{padding:.9rem 1rem;gap:.75rem}
  .tg-trial-ico{width:40px;height:40px}
  .tg-trial-title{font-size:.92rem}
  .tg-trial-sub{font-size:.76rem}
}

/* ── SUB CARD ────────────────────────────────────── */
.sub-card{position:relative;overflow:hidden;border-radius:var(--rXL);padding:1.75rem;background:linear-gradient(135deg,rgba(29,78,216,.22),rgba(109,40,217,.18));border:1px solid rgba(20,184,166,.3);margin-bottom:1.25rem}
.sub-glow{position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(20,184,166,.12),transparent 70%);top:-100px;right:-60px;pointer-events:none}
.sub-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .8rem;border-radius:999px;font-size:.72rem;font-weight:800;margin-bottom:.85rem;letter-spacing:.04em}
.sub-badge.on{background:rgba(52,211,153,.14);color:var(--ok);border:1px solid rgba(52,211,153,.28)}
.sub-badge.off{background:rgba(239,68,68,.1);color:var(--err);border:1px solid rgba(239,68,68,.22)}
.sub-name{font-size:1.5rem;font-weight:900;margin-bottom:.25rem;letter-spacing:-.04em}
.sub-detail{color:var(--tx2);font-size:.85rem;margin-bottom:1.25rem;font-weight:500}
.sub-bar-wrap{background:rgba(255,255,255,.08);border-radius:999px;height:5px;margin-bottom:.4rem;overflow:hidden}
.sub-bar{height:100%;background:var(--acc);border-radius:999px;transition:width .8s ease}
.sub-lbl{display:flex;justify-content:space-between;font-size:.72rem;color:var(--tx3);font-weight:600;margin-bottom:1.25rem}

/* ── PLAN CARDS ──────────────────────────────────── */
.plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1.1rem}
.plan-card{background:var(--card);border:1.5px solid var(--b1);border-radius:var(--rXL);padding:1.5rem;position:relative;transition:.25s}
.plan-card:hover{border-color:var(--b2);box-shadow:0 0 28px var(--accG)}
.plan-card.hot{border-color:rgba(20,184,166,.28);background:linear-gradient(135deg,rgba(18,18,22,.92),rgba(20,32,65,.92))}
.plan-hot-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--acc);color:#fff;font-size:.66rem;font-weight:800;padding:.25rem .9rem;border-radius:999px;white-space:nowrap;letter-spacing:.06em}
.plan-label{font-size:.72rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}
.plan-price{display:flex;align-items:baseline;gap:.15rem;margin-bottom:.2rem}
.plan-price span{font-size:2.6rem;font-weight:900;letter-spacing:-.05em}
.plan-cur{font-size:1.2rem;font-weight:700;color:var(--tx2)}
.plan-per{font-size:.75rem;color:var(--tx3);font-weight:600;margin-bottom:1.25rem}
.plan-feats{list-style:none;display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.4rem}
.plan-feats li{font-size:.8rem;color:var(--tx2);display:flex;align-items:center;gap:.45rem;font-weight:500}
.gb-card{background:rgba(255,255,255,.03);border:1px solid var(--b1);border-radius:var(--rL);padding:1rem 1.15rem;margin-bottom:1.25rem}
.gb-card-hd{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}
.gb-card-title{font-size:.85rem;font-weight:800}
.gb-card-sub{font-size:.75rem;color:var(--tx3);font-weight:500;margin-top:.15rem}
.gb-bar-wrap{background:rgba(255,255,255,.08);border-radius:999px;height:6px;overflow:hidden;margin-bottom:.45rem}
.gb-bar{height:100%;background:linear-gradient(90deg,var(--pur),var(--acc));border-radius:999px;transition:width .6s ease}
.gb-meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--tx3);font-weight:600}
.pay-gb{margin-bottom:1.1rem}
.pay-gb-label{font-size:.72rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.55rem}
.pay-gb-row{display:flex;align-items:center;gap:.65rem}
.pay-gb-input{flex:1;background:rgba(255,255,255,.05);border:1.5px solid var(--b1);border-radius:10px;padding:.65rem .8rem;color:var(--tx);font-size:1rem;font-weight:700;font-family:inherit;outline:none;text-align:center}
.pay-gb-input:focus{border-color:var(--acc)}
.pay-gb-hint{font-size:.75rem;color:var(--tx3);margin-top:.45rem;line-height:1.45;font-weight:500}
.pay-breakdown{font-size:.78rem;color:var(--tx2);text-align:center;margin-bottom:1rem;line-height:1.5;font-weight:500}
.ck{color:var(--ok);font-size:.82rem;font-weight:800}

/* ── REFERRAL ─────────────────────────────────────── */
.ref-link-box{display:flex;gap:.6rem;align-items:center;background:rgba(255,255,255,.04);border:1.5px solid var(--b1);border-radius:var(--r);padding:.65rem .85rem;transition:.2s}
.ref-link-box:focus-within{border-color:var(--b2)}
.ref-link-input{flex:1;background:transparent;border:none;outline:none;color:var(--accL);font-size:.82rem;font-family:inherit;font-weight:600;min-width:0}
.ref-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem;margin:1.25rem 0}
.ref-stat.ref-money strong{font-size:1.35rem}
.ref-stat{background:rgba(255,255,255,.04);border:1px solid var(--b1);border-radius:var(--r);padding:.9rem;text-align:center}
.ref-stat strong{display:block;font-size:1.5rem;font-weight:900;margin-bottom:.15rem;letter-spacing:-.03em}
.ref-stat span{font-size:.7rem;color:var(--tx3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}

/* ── TABLE ────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl{width:100%;border-collapse:collapse;font-size:.83rem;min-width:480px}
.tbl th{padding:.7rem 1rem;text-align:left;color:var(--tx3);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--b1);white-space:nowrap}
.tbl td{padding:.8rem 1rem;border-bottom:1px solid rgba(255,255,255,.04);color:var(--tx2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:rgba(255,255,255,.02)}
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:7px;font-size:.72rem;font-weight:700}
.badge-ok{background:var(--okG);color:var(--ok)}
.badge-warn{background:rgba(245,158,11,.1);color:var(--warn)}
.badge-blue{background:rgba(20,184,166,.1);color:var(--accL)}

/* ── SERVER STATUS ────────────────────────────────── */
.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(268px,1fr));gap:.875rem}
.srv-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--rL);padding:1.1rem 1.35rem;transition:.2s;position:relative;overflow:hidden}
.srv-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}
.srv-card.ok::before{background:var(--ok)}
.srv-card.maint::before{background:var(--warn)}
.srv-card.down::before{background:var(--err)}
.srv-card.down{border-color:rgba(239,68,68,.15)}
.srv-card:hover{border-color:var(--b2);transform:translateY(-2px)}
.srv-badge.down{background:rgba(239,68,68,.1);color:var(--err);border:1px solid rgba(239,68,68,.2)}
.srv-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}
.srv-flag{font-size:1.4rem;line-height:1;flex-shrink:0}
.srv-name-wrap{display:flex;align-items:center;gap:.55rem}
.srv-name{font-size:.88rem;font-weight:800;letter-spacing:-.01em}
.srv-country{font-size:.72rem;color:var(--tx3);font-weight:500}
.srv-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:999px;font-size:.68rem;font-weight:800}
.srv-badge.ok{background:rgba(52,211,153,.1);color:var(--ok);border:1px solid rgba(52,211,153,.2)}
.srv-badge.maint{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.2)}
.srv-badge-dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.srv-badge.ok .srv-badge-dot{animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.srv-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.4rem;margin-bottom:.6rem}
.ssv{text-align:center;padding:.3rem}
.ssv-v{font-size:.88rem;font-weight:800;margin-bottom:.1rem}
.ssv-l{font-size:.62rem;color:var(--tx3);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.srv-load{height:3px;background:rgba(255,255,255,.08);border-radius:3px;overflow:hidden}
.srv-load-bar{height:100%;border-radius:3px;transition:width .6s ease}
.srv-filters{display:flex;gap:.2rem;background:rgba(255,255,255,.04);border:1px solid var(--b1);border-radius:10px;padding:3px;width:fit-content;flex-wrap:nowrap;overflow:hidden}
.sflt{padding:.38rem .8rem;border:none;background:transparent;color:var(--tx2);font-size:.76rem;font-weight:700;cursor:pointer;border-radius:7px;transition:.18s;font-family:inherit;white-space:nowrap}
.sflt.active{background:var(--acc);color:#fff}

/* ── INSTALL ──────────────────────────────────────── */
.install-tabs{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:1.75rem}
.itab{padding:.48rem 1.1rem;border-radius:999px;font-size:.82rem;font-weight:700;cursor:pointer;border:1.5px solid var(--b1);background:transparent;color:var(--tx2);transition:.18s;font-family:inherit}
.itab.active{background:var(--acc);border-color:transparent;color:#fff}
.itab:hover:not(.active){border-color:var(--b2);color:var(--tx)}
.steps{display:flex;flex-direction:column;gap:1rem}
.step{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 1.3rem;background:rgba(255,255,255,.03);border:1px solid var(--b1);border-radius:var(--rL);transition:.18s}
.step:hover{border-color:var(--b2)}
.step-num{width:34px;height:34px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:900;flex-shrink:0;box-shadow:0 0 14px var(--accG)}
.step-body h4{font-size:.88rem;font-weight:800;margin-bottom:.3rem;letter-spacing:-.01em}
.step-body p{font-size:.82rem;color:var(--tx2);line-height:1.65;font-weight:500}
.step-body code{background:rgba(20,184,166,.1);color:var(--accL);padding:.1rem .4rem;border-radius:5px;font-family:monospace;font-size:.8rem}

/* ── MODAL ────────────────────────────────────────── */
.modal-ov{position:fixed;inset:0;background:rgba(7,7,8,.85);backdrop-filter:blur(12px);z-index:300;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:.25s}
.modal-ov.open{opacity:1;pointer-events:all}
.modal{background:var(--card2);border:1px solid var(--b2);border-radius:var(--rXL);padding:2.25rem;padding-top:3rem;width:100%;max-width:420px;position:relative;transform:translateY(20px) scale(.97);transition:.25s;box-shadow:0 20px 60px rgba(0,0,0,.8)}
@keyframes spulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.4);opacity:0}}
.modal-ov.open .modal{transform:none}
.modal-close{position:absolute;top:1rem;right:1rem;z-index:2;background:rgba(255,255,255,.06);border:1px solid var(--b1);border-radius:8px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx2);transition:.18s}
.modal-close:hover{color:var(--tx);background:rgba(255,255,255,.1)}
.ferr{color:var(--err);font-size:.8rem;padding:.55rem .85rem;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:8px;font-weight:600;margin-bottom:.75rem;line-height:1.45}
.pay-amount{font-size:2.8rem;font-weight:900;text-align:center;margin:1.25rem 0 .4rem;letter-spacing:-.05em}
.pay-plan{text-align:center;color:var(--tx2);margin-bottom:1.5rem;font-size:.9rem;font-weight:500}
.pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:1.25rem}
.pay-method{padding:.8rem;border:1.5px solid var(--b1);border-radius:12px;background:rgba(255,255,255,.03);cursor:pointer;text-align:center;transition:.18s;font-size:.82rem;font-weight:700;color:var(--tx2);display:flex;flex-direction:column;align-items:center;gap:.35rem;font-family:inherit}
.pay-method:hover,.pay-method.sel{border-color:var(--b2);background:var(--accG);color:var(--tx)}
.pay-method .pm-ico{font-size:1.4rem}
.pay-demo-note{background:rgba(20,184,166,.06);border:1px solid rgba(20,184,166,.15);border-radius:9px;padding:.75rem;font-size:.78rem;color:var(--tx2);margin-bottom:1rem;line-height:1.55;font-weight:500}
.pay-label{font-size:.72rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.6rem;text-align:center}

/* ── SUPPORT WIDGET ──────────────────────────────── */
.sw-btn{position:fixed;bottom:1.75rem;right:1.75rem;z-index:200;width:56px;height:56px;border-radius:50%;background:var(--acc);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px var(--accG),0 0 0 0 rgba(20,184,166,.4);animation:swPulse 3s infinite;transition:.2s;color:#fff}
.sw-btn:hover{transform:scale(1.08);box-shadow:0 6px 32px var(--accG)}
@keyframes swPulse{0%,100%{box-shadow:0 4px 24px var(--accG),0 0 0 0 rgba(20,184,166,.4)}70%{box-shadow:0 4px 24px var(--accG),0 0 0 12px rgba(20,184,166,0)}}
.sw-badge{position:absolute;top:-3px;right:-3px;width:18px;height:18px;border-radius:50%;background:var(--err);color:#fff;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg)}
.sw-panel{
  position:fixed;bottom:calc(1.75rem + 70px);right:1.75rem;z-index:200;
  width:340px;max-height:520px;
  background:var(--card2);border:1px solid var(--b2);border-radius:var(--rXL);
  display:flex;flex-direction:column;
  box-shadow:0 16px 60px rgba(0,0,0,.7);
  transform:translateY(20px) scale(.95);opacity:0;pointer-events:none;
  transition:all .28s cubic-bezier(.34,1.2,.64,1);
  overflow:hidden;
}
.sw-panel.open{transform:none;opacity:1;pointer-events:all}
.sw-header{padding:1rem 1.25rem;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,rgba(29,78,216,.15),rgba(109,40,217,.1))}
.sw-header-info{}
.sw-title{font-size:.9rem;font-weight:800;letter-spacing:-.02em}
.sw-sub{font-size:.72rem;color:var(--ok);font-weight:600;display:flex;align-items:center;gap:.3rem;margin-top:.15rem}
.sw-sub::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--ok);flex-shrink:0;animation:blink 2s infinite}
.sw-close{background:rgba(255,255,255,.07);border:1px solid var(--b1);border-radius:7px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx2);transition:.18s;flex-shrink:0}
.sw-close:hover{background:rgba(255,255,255,.12);color:var(--tx)}
.sw-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.6rem;min-height:200px}
.sw-messages::-webkit-scrollbar{width:3px}
.sw-msg{max-width:85%;padding:.6rem .85rem;border-radius:12px;font-size:.82rem;line-height:1.55;font-weight:500;word-break:break-word}
.sw-msg.user{background:linear-gradient(135deg,var(--acc),var(--accD));color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.sw-msg.bot{background:rgba(255,255,255,.07);color:var(--tx2);align-self:flex-start;border-bottom-left-radius:4px}
.sw-msg.bot strong{display:block;font-size:.7rem;font-weight:800;color:var(--accL);margin-bottom:.2rem;text-transform:uppercase;letter-spacing:.04em}
.sw-msg-time{font-size:.62rem;opacity:.55;margin-top:.2rem;text-align:right}
.sw-empty{text-align:center;color:var(--tx3);font-size:.82rem;padding:2rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}
.sw-empty-ico{font-size:2rem}
.sw-input-row{padding:.875rem;border-top:1px solid var(--b1);display:flex;gap:.5rem;align-items:flex-end}
.sw-textarea{flex:1;background:rgba(255,255,255,.05);border:1.5px solid var(--b1);border-radius:10px;padding:.6rem .75rem;color:var(--tx);font-size:.83rem;font-family:inherit;resize:none;outline:none;line-height:1.5;max-height:100px;transition:.18s;font-weight:500}
.sw-textarea:focus{border-color:var(--acc);background:rgba(20,184,166,.06)}
.sw-textarea::placeholder{color:var(--tx3)}
.sw-send{width:38px;height:38px;border-radius:10px;background:var(--acc);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:.18s;box-shadow:0 0 14px var(--accG)}
.sw-send:hover{transform:scale(1.08)}
.sw-send:disabled{opacity:.4;cursor:not-allowed;transform:none}

/* ── NOTIFICATIONS PANEL ─────────────────────────── */
.notif-panel{position:fixed;top:0;right:0;bottom:0;width:340px;background:var(--card2);border-left:1px solid var(--b2);z-index:150;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.5)}
.notif-panel.open{transform:none}
.notif-bg{display:none;position:fixed;inset:0;z-index:149;background:rgba(0,0,0,.4)}
.notif-bg.open{display:block}
.notif-hd{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.notif-hd-left{font-size:.95rem;font-weight:900;letter-spacing:-.02em}
.notif-hd-right{display:flex;align-items:center;gap:.5rem}
.notif-read-all{font-size:.72rem;color:var(--accL);cursor:pointer;font-weight:600;background:none;border:none;font-family:inherit;padding:.2rem .4rem;border-radius:5px;transition:.15s}
.notif-read-all:hover{background:var(--accG)}
.notif-close{background:rgba(255,255,255,.07);border:1px solid var(--b1);border-radius:7px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx2);transition:.18s}
.notif-close:hover{background:rgba(255,255,255,.12);color:var(--tx)}
.notif-list{flex:1;overflow-y:auto;padding:.75rem}
.notif-list::-webkit-scrollbar{width:3px}
.notif-item{padding:.9rem 1rem;border-radius:var(--r);margin-bottom:.5rem;border:1px solid transparent;cursor:pointer;transition:.18s;position:relative}
.notif-item:hover{filter:brightness(1.08)}
.notif-item.unread::before{content:'';position:absolute;left:.5rem;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:var(--acc)}
.notif-item.info{background:rgba(20,184,166,.07);border-color:rgba(20,184,166,.15)}
.notif-item.success{background:rgba(52,211,153,.07);border-color:rgba(52,211,153,.15)}
.notif-item.warning{background:rgba(245,158,11,.07);border-color:rgba(245,158,11,.15)}
.notif-item.promo{background:linear-gradient(135deg,rgba(29,78,216,.1),rgba(109,40,217,.08));border-color:rgba(20,184,166,.2)}
.notif-item-title{font-size:.85rem;font-weight:800;margin-bottom:.25rem}
.notif-item-msg{font-size:.78rem;color:var(--tx2);line-height:1.55}
.notif-item-date{font-size:.66rem;color:var(--tx3);margin-top:.3rem}
.notif-empty{text-align:center;padding:2.5rem 1rem;color:var(--tx3);font-size:.85rem}
.notif-empty-ico{font-size:2rem;margin-bottom:.75rem}
@media(max-width:480px){.notif-panel{width:100%;border-left:none;border-top:1px solid var(--b2)}}

/* ── TOAST ────────────────────────────────────────── */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(80px);z-index:500;background:var(--card2);border:1px solid var(--b2);border-radius:14px;padding:.8rem 1.25rem;font-size:.875rem;font-weight:600;max-width:90vw;width:max-content;box-shadow:0 8px 32px rgba(0,0,0,.6);opacity:0;transition:all .35s cubic-bezier(.34,1.4,.64,1);pointer-events:none;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast.tok{border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.08);color:var(--ok)}
.toast.terr{border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.08);color:var(--err)}

/* ── FORM ───────────────────────────────────────── */
.fg{display:flex;flex-direction:column;gap:.35rem}
.fg label{font-size:.7rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em}

/* ── MOBILE ──────────────────────────────────────── */
@media(max-width:768px){
  :root{--sb:260px}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .topbar{display:flex}
  /* На мобиле скрываем лого в сайдбаре — оно уже есть в топбаре */
  .sidebar .sb-logo{display:none}
  /* Убираем лишний отступ сверху */
  .sidebar{padding-top:.75rem}
  .sb-nav{margin-top:.25rem}
  .main{margin-left:0;padding:1rem;padding-top:4.5rem;max-width:100vw}
  .pg-hd{margin-bottom:1.25rem}
  .sub-card{padding:1.25rem}
  .ref-stat-grid{grid-template-columns:repeat(2,1fr)}
  .plan-grid{grid-template-columns:1fr}
  .srv-grid{grid-template-columns:1fr}
  .grid-auto{grid-template-columns:1fr 1fr}
  .pay-methods{grid-template-columns:1fr 1fr}
  .sw-panel{width:calc(100vw - 2rem);right:1rem;bottom:calc(1rem + 68px)}
  .sw-btn{bottom:1rem;right:1rem;width:52px;height:52px}
  .install-tabs{gap:.3rem}
  .itab{font-size:.76rem;padding:.4rem .85rem}
  .srv-filters{font-size:.72rem}
}
@media(max-width:420px){
  .ref-stat-grid{grid-template-columns:1fr}
  .plan-price span{font-size:2.2rem}
  .modal{padding:1.5rem}
  .pay-methods{grid-template-columns:1fr}
}
