:root{
  --bg:#050910;
  --bg2:#08131d;
  --card:rgba(255,255,255,.075);
  --card2:rgba(255,255,255,.105);
  --line:rgba(255,255,255,.13);
  --line2:rgba(255,255,255,.19);
  --text:#f7fbff;
  --muted:#9fafbf;
  --muted2:#cad6e4;
  --green:#67e8b9;
  --blue:#73d7ff;
  --red:#fb7185;
  --shadow:0 22px 70px rgba(0,0,0,.36);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;min-height:100vh;background:radial-gradient(circle at 12% 10%,#173a52 0,#07101a 36%,#020509 100%);color:var(--text);font:16px/1.52 Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none}button,input{font:inherit}.hidden{display:none!important}
.bg-grid{position:fixed;inset:0;pointer-events:none;opacity:.09;background-image:linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(circle at top,black 0,transparent 76%)}
.orb{position:fixed;border-radius:999px;filter:blur(54px);pointer-events:none;opacity:.25}.orb-one{width:460px;height:460px;background:#22c55e;top:130px;left:-190px}.orb-two{width:560px;height:560px;background:#2563eb;top:50px;right:-250px}
.topbar{position:sticky;top:14px;z-index:40;width:min(1180px,calc(100% - 36px));margin:14px auto 0;display:flex;align-items:center;justify-content:flex-start;padding:12px 14px;border:1px solid var(--line);border-radius:22px;background:rgba(4,9,15,.78);backdrop-filter:blur(18px);box-shadow:0 12px 42px rgba(0,0,0,.24)}
.logo{display:flex;align-items:center;gap:12px;font-weight:950;letter-spacing:-.02em}.logo-mark{display:grid;place-items:center;width:39px;height:39px;border-radius:14px;background:linear-gradient(135deg,var(--green),var(--blue));color:#061019;font-weight:950}.topnav{display:none}
main{width:min(1180px,calc(100% - 36px));margin:0 auto;padding:52px 0 78px;position:relative}.hero{display:grid;grid-template-columns:1.06fr .94fr;gap:34px;align-items:center;min-height:calc(100vh - 130px)}
.chip{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;border:1px solid rgba(103,232,185,.25);background:rgba(103,232,185,.08);color:var(--green);font-weight:900}.chip span{width:8px;height:8px;border-radius:999px;background:var(--green);box-shadow:0 0 18px var(--green)}
h1{font-size:clamp(42px,6vw,78px);line-height:.94;margin:22px 0 20px;letter-spacing:-.065em;max-width:840px}.lead{font-size:clamp(18px,1.8vw,22px);color:var(--muted2);max-width:660px;margin:0 0 26px}.hero-buttons{display:flex;gap:12px;flex-wrap:wrap}.btn{border:0;cursor:pointer;border-radius:15px;padding:13px 17px;min-height:46px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:900;transition:.17s ease}.btn.primary{background:linear-gradient(135deg,var(--green),var(--blue));color:#041017;box-shadow:0 14px 38px rgba(115,215,255,.18)}.btn.primary:hover{transform:translateY(-1px);filter:saturate(1.08)}.btn.outline,.btn.soft{background:rgba(255,255,255,.08);border:1px solid var(--line);color:var(--text)}.btn.outline:hover,.btn.soft:hover{background:rgba(255,255,255,.13)}.btn.wide{width:100%}.btn.small{min-height:38px;padding:9px 13px}.btn.disabled,.btn:disabled{opacity:.5;pointer-events:none;cursor:not-allowed}
.mini-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:32px;max-width:660px}.mini-stats div,.login-card,.panel,.feature-grid article{border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.105),rgba(255,255,255,.055));border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(20px)}.mini-stats div{padding:15px}.mini-stats b{display:block;font-size:24px}.mini-stats span{display:block;color:var(--muted);font-size:13px;margin-top:3px}
.login-card{padding:24px}.tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:6px;border-radius:17px;background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.08);margin-bottom:20px}.tabs button{border:0;border-radius:13px;background:transparent;color:var(--muted);padding:12px;font-weight:950;cursor:pointer}.tabs button.active{background:linear-gradient(135deg,var(--green),var(--blue));color:#061019}.auth-view h2{font-size:30px;line-height:1.05;letter-spacing:-.04em;margin:0 0 10px}.auth-view p{margin:0 0 18px;color:var(--muted)}.auth-view label{display:block;margin:12px 0 7px;font-weight:850}.auth-view input{width:100%;border:1px solid var(--line);background:rgba(4,8,13,.58);color:var(--text);outline:none;border-radius:15px;padding:14px}.auth-view input:focus{border-color:rgba(103,232,185,.7);box-shadow:0 0 0 4px rgba(103,232,185,.08)}.auth-view .btn{margin-top:16px}.card-note{margin-top:16px;padding:14px;border-radius:18px;background:rgba(103,232,185,.075);border:1px solid rgba(103,232,185,.15);display:grid;gap:4px}.card-note span{color:var(--muted)}
.section-title{margin:58px 0 20px}.section-title span,.cabinet-head span,.muted-label{display:block;color:var(--green);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.13em}.section-title h2,.cabinet-head h2{font-size:clamp(32px,5vw,52px);line-height:1;letter-spacing:-.05em;margin:8px 0 0}.feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.feature-grid article{padding:22px}.feature-grid b{font-size:23px}.feature-grid p{color:var(--muted);margin:8px 0 0}
body.logged-in .hero,body.logged-in .features{display:none!important}body.logged-in main{width:min(1180px,calc(100% - 28px));padding-top:32px;padding-bottom:56px}body.logged-in .topbar{width:min(1180px,calc(100% - 28px));top:10px;margin-top:10px}.cabinet{padding-top:0}.cabinet-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:18px 0 16px}.cabinet-head h2{font-size:clamp(34px,4.2vw,58px)}.cabinet-grid{display:grid;grid-template-columns:1fr;gap:14px;align-items:start;min-width:0}.panel{padding:18px;border-radius:24px;min-width:0}.panel-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.panel h3{font-size:26px;line-height:1.08;letter-spacing:-.035em;margin:4px 0 0}.status{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;font-weight:950;font-size:12px;border:1px solid rgba(251,113,133,.25);background:rgba(251,113,133,.12);color:#fecdd3}.status.active{border-color:rgba(103,232,185,.28);background:rgba(103,232,185,.13);color:#c8fce8}.data-list{display:grid;gap:9px}.data-list div{display:flex;justify-content:space-between;gap:12px;padding:12px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.19)}.data-list span{color:var(--muted)}.data-list b{text-align:right}.row-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:14px}
/* ERM clean redesign 2026-05-04 */
.account-strip-panel{padding:14px;background:linear-gradient(135deg,rgba(255,255,255,.11),rgba(103,232,185,.045));border-color:rgba(255,255,255,.16);overflow:hidden}.account-strip{display:grid;grid-template-columns:minmax(230px,1.4fr) minmax(190px,1fr) minmax(110px,.55fr) minmax(105px,.55fr) minmax(135px,.75fr);gap:10px;align-items:stretch}.strip-cell{min-width:0;padding:14px;border-radius:18px;background:rgba(0,0,0,.21);border:1px solid rgba(255,255,255,.075);display:flex;flex-direction:column;justify-content:center;gap:4px}.strip-cell strong{display:block;font-size:20px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.strip-cell small{color:var(--muted);font-size:12px}.strip-user{position:relative;padding-right:76px}.strip-user .status{position:absolute;right:12px;top:50%;transform:translateY(-50%)}.strip-days{background:linear-gradient(135deg,rgba(103,232,185,.22),rgba(115,215,255,.13));border-color:rgba(103,232,185,.3)}.strip-days strong{font-size:28px;letter-spacing:-.035em}.code-cell strong{font-size:16px}.strip-actions{grid-column:1/-1;display:grid;grid-template-columns:54px minmax(150px,.8fr) minmax(180px,1fr) 54px;gap:9px}.renew-cta{background:linear-gradient(135deg,var(--green),var(--blue))!important;color:#061019!important;border:0!important}.icon-btn{min-height:52px;border:1px solid var(--line2);border-radius:16px;background:rgba(255,255,255,.08);color:var(--text);cursor:pointer;font-weight:950}.tg-icon{position:relative;font-size:0;overflow:visible;background:#229ED9!important;border-color:rgba(34,158,217,.55)!important}.tg-icon::before{content:"";position:absolute;inset:0;margin:auto;width:28px;height:28px;background:#fff;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'%3E%3Cpath d='M20.2 118.7 215.6 43.3c9.1-3.4 17.1 4.8 14 14.2l-33.3 155c-2.5 11.1-13.8 15.4-22.6 9.7l-53.4-39.4-25.8 24.9c-2.9 2.8-5.3 5.1-10.8 5.1l3.9-54.6 99.4-89.7c4.4-3.8-.9-6-6.8-2.1L57.6 143.7 5 127.3c-11.5-3.6-11.7-11.5 15.2-8.6z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'%3E%3Cpath d='M20.2 118.7 215.6 43.3c9.1-3.4 17.1 4.8 14 14.2l-33.3 155c-2.5 11.1-13.8 15.4-22.6 9.7l-53.4-39.4-25.8 24.9c-2.9 2.8-5.3 5.1-10.8 5.1l3.9-54.6 99.4-89.7c4.4-3.8-.9-6-6.8-2.1L57.6 143.7 5 127.3c-11.5-3.6-11.7-11.5 15.2-8.6z'/%3E%3C/svg%3E") center/contain no-repeat}.tg-icon.bound::after{content:"✓";position:absolute;right:-4px;bottom:-4px;width:20px;height:20px;display:grid;place-items:center;border-radius:999px;background:var(--green);color:#061019;border:3px solid #0a121b;font-size:12px;font-weight:1000}.renew-box{margin-top:10px;padding:13px;border-radius:18px;border:1px solid rgba(103,232,185,.18);background:rgba(0,0,0,.18)}.renew-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.renew-head b{display:block;font-size:20px}.renew-head small{display:block;color:var(--muted);font-size:12px}.renew-head strong{font-size:28px}.device-buttons{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin:10px 0}.device-buttons button{border:1px solid var(--line);background:rgba(255,255,255,.07);color:var(--text);border-radius:12px;padding:11px 0;font-weight:950;cursor:pointer}.device-buttons button.active{background:linear-gradient(135deg,var(--green),var(--blue));color:#061019;border-color:transparent}
.config-panel{overflow:hidden}.config-mode-top{display:grid;grid-template-columns:minmax(220px,1fr) minmax(340px,.8fr);gap:14px;align-items:center}.mode-switch{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:6px;border-radius:17px;background:rgba(0,0,0,.24);border:1px solid rgba(255,255,255,.08)}.mode-switch button{border:0;border-radius:12px;background:transparent;color:var(--muted);padding:12px 11px;font-weight:950;cursor:pointer}.mode-switch button.active{background:linear-gradient(135deg,var(--green),var(--blue));color:#061019}.setup-flow{display:grid;grid-template-columns:minmax(260px,.84fr) minmax(0,1.16fr);grid-template-areas:"device app" "protocol access";gap:12px;align-items:start}.device-step{grid-area:device}.protocol-step{grid-area:protocol}.app-step{grid-area:app}.access-step{grid-area:access}.setup-step{min-width:0;padding:14px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.09)}.step-title{display:flex;align-items:center;gap:9px;margin-bottom:12px}.step-title b{display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:linear-gradient(135deg,var(--green),var(--blue));color:#061019;font-size:15px}.step-title span{font-size:18px;font-weight:950}.choice-row{display:flex;flex-wrap:wrap;gap:8px}.choice-row button,.protocol-switch button{border:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.2);color:var(--muted2);border-radius:13px;padding:11px 14px;font-weight:950;cursor:pointer}.choice-row button.active,.choice-row button.suggested.active,.protocol-switch button.active{background:linear-gradient(135deg,var(--green),var(--blue));color:#061019;border-color:transparent}.choice-row button.suggested:not(.active){border-color:rgba(103,232,185,.35);color:#d8fff1}.protocol-choice{display:grid;grid-template-columns:1fr 1fr;padding:6px;border-radius:16px;background:rgba(0,0,0,.2)}.app-suggestion{display:grid;gap:10px}.app-line{display:flex;align-items:center;justify-content:space-between;gap:10px}.app-line span{color:var(--muted);font-size:13px}.app-line b{font-size:15px}.app-tags{display:flex;flex-wrap:wrap;gap:7px}.app-tags a,.app-tags em{font-style:normal;display:inline-flex;align-items:center;padding:8px 10px;border-radius:999px;background:rgba(103,232,185,.095);border:1px solid rgba(103,232,185,.18);color:#cdfdea;font-size:12px;font-weight:900}.app-suggestion p{margin:0;color:var(--muted);font-size:13px}.access-box{display:grid;gap:10px}.access-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.access-card{padding:13px;border-radius:17px;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.09);min-width:0}.access-card b{display:block;font-size:19px;line-height:1.1}.access-card span{display:block;color:var(--muted);font-size:12px;margin-top:4px;word-break:break-all}.server-access-card{display:grid;gap:10px}.server-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.server-title-row small{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:26px;padding:0 8px;border-radius:999px;background:rgba(103,232,185,.1);border:1px solid rgba(103,232,185,.18);color:var(--green);font-weight:950;font-size:10px}.compact-server-actions{display:grid;grid-template-columns:1fr 1fr;gap:7px}.compact-server-actions .mini-btn.primary{grid-column:1/-1}.mini-btn{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.075);color:var(--text);cursor:pointer;border-radius:12px;padding:10px 10px;font-weight:900;text-align:center;font-size:12px}.mini-btn:hover{background:rgba(255,255,255,.12)}.mini-btn.primary{background:linear-gradient(135deg,var(--green),var(--blue));color:#061019;border-color:transparent}.compact-qr,.server-qr{width:84px;height:84px;border-radius:12px;padding:5px;justify-self:center;background:#fff}.ovpn-access-card{display:grid;grid-template-columns:minmax(0,1fr) 170px;align-items:center;gap:10px}.expert-mode{min-width:0}.expert-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;padding:12px;border-radius:16px;background:rgba(0,0,0,.17);border:1px solid rgba(255,255,255,.08)}.expert-head b{display:block;font-size:17px}.expert-head span{display:block;color:var(--muted);font-size:13px}.expert-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.toast{position:fixed;z-index:90;left:50%;bottom:22px;max-width:calc(100% - 32px);transform:translate(-50%,30px);opacity:0;padding:13px 17px;border-radius:16px;background:#f8fafc;color:#081018;box-shadow:0 18px 50px rgba(0,0,0,.38);font-weight:900;text-align:center;transition:.22s ease}.toast.show{opacity:1;transform:translate(-50%,0)}
@media (max-width:1100px){.account-strip{grid-template-columns:1.4fr 1fr 110px 110px}.code-cell{display:none}.setup-flow{grid-template-columns:1fr;grid-template-areas:"device" "protocol" "app" "access"}.expert-grid{grid-template-columns:1fr 1fr}.config-mode-top{grid-template-columns:1fr}}
@media (max-width:780px){body.logged-in main,body.logged-in .topbar,.topbar,main{width:min(100% - 22px,1180px)}.hero{grid-template-columns:1fr;min-height:auto}.feature-grid,.mini-stats{grid-template-columns:1fr}.cabinet-head{align-items:center;margin-top:12px}.cabinet-head h2{font-size:34px}.account-strip{grid-template-columns:1fr 1fr}.strip-user,.strip-days{grid-column:1/-1}.strip-actions{grid-template-columns:52px 1fr 1fr 52px}.access-grid,.expert-grid{grid-template-columns:1fr}.expert-head{display:grid}.mode-switch{width:100%}.ovpn-access-card{grid-template-columns:1fr}.compact-qr,.server-qr{display:none}}
@media (max-width:520px){body{font-size:15px}.topbar{top:8px;margin-top:8px;padding:10px;border-radius:18px}.logo-mark{width:34px;height:34px}.logo{font-size:14px}body.logged-in main{padding-top:22px}.cabinet-head h2{font-size:32px}.panel{padding:13px;border-radius:20px}.account-strip{grid-template-columns:1fr;gap:8px}.strip-cell{padding:12px;border-radius:15px}.strip-user{padding-right:72px}.strip-days strong{font-size:26px}.strip-actions{grid-template-columns:48px 1fr 48px;grid-template-areas:"tg renew refresh" "cab cab cab"}.tg-icon{grid-area:tg}.renew-cta{grid-area:renew}.strip-actions #copyCabinetBtn{grid-area:cab}.strip-actions #refreshBtn{grid-area:refresh}.btn{min-height:44px;padding:11px 13px;border-radius:13px}.config-mode-top{gap:10px}.mode-switch button{padding:10px 8px;font-size:12px}.setup-step{padding:12px;border-radius:16px}.choice-row{display:grid;grid-template-columns:1fr 1fr}.device-choice button:last-child{grid-column:1/-1}.protocol-choice{grid-template-columns:1fr 1fr}.step-title span{font-size:17px}.app-line{display:grid}.compact-server-actions{grid-template-columns:1fr}.compact-server-actions .mini-btn.primary{grid-column:auto}.renew-head{align-items:flex-start}.orb{opacity:.16}}

/* ERM balance/payment/vless safety fix 2026-05-04 */
.renew-head strong,
#priceText{
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  gap:4px;
  line-height:1;
}
#payBtn.balance-ready{
  background:linear-gradient(135deg,#67e8b9,#86efac)!important;
}
.strip-cell strong#balanceText{
  color:#fff;
}
@media (max-width:520px){
  .renew-head{display:grid;grid-template-columns:1fr auto;align-items:center}
  .renew-head strong{font-size:26px}
}

/* ERM renewal months + captcha mini-fix 2026-05-04 */
.renew-pickers{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:10px 0 12px}
.renew-picker-group>span{display:block;color:var(--muted);font-size:12px;font-weight:850;margin:0 0 7px}
.month-buttons{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.month-buttons button{border:1px solid var(--line);background:rgba(255,255,255,.07);color:var(--text);border-radius:12px;padding:11px 0;font-weight:950;cursor:pointer}
.month-buttons button.active{background:linear-gradient(135deg,var(--green),var(--blue));color:#061019;border-color:transparent}
.renew-head small{max-width:520px}.balance-ready{box-shadow:0 0 0 1px rgba(103,232,185,.22),0 18px 46px rgba(103,232,185,.18)!important}
.captcha-box{display:grid;grid-template-columns:1fr 46px;gap:9px;align-items:end;margin-top:8px}.captcha-box label{margin:0 0 4px}.captcha-box span{display:flex;align-items:center;min-height:46px;border:1px solid var(--line);background:rgba(103,232,185,.08);border-radius:16px;padding:0 14px;color:var(--text);font-weight:950}.captcha-refresh{height:46px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.08);color:var(--text);cursor:pointer;font-weight:950}
#captchaAnswer{margin-top:9px}
@media (max-width:680px){.renew-pickers{grid-template-columns:1fr}.month-buttons,.device-buttons{grid-template-columns:repeat(5,1fr)}.captcha-box{grid-template-columns:1fr 44px}}

/* ERMTEAM dense background rows */
body {
  overflow-x: hidden;
}

.erm-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  background:
    radial-gradient(circle at 15% 15%, rgba(62, 232, 211, .12), transparent 30%),
    radial-gradient(circle at 85% 15%, rgba(57, 112, 255, .16), transparent 34%),
    radial-gradient(circle at 70% 90%, rgba(80, 210, 255, .10), transparent 30%),
    linear-gradient(135deg, #061622 0%, #02070e 48%, #071533 100%);
}

.erm-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(circle at center, transparent 0%, rgba(0, 0, 0, .16) 62%, rgba(0, 0, 0, .36) 100%),
    linear-gradient(180deg, rgba(0, 0, 0, .08), rgba(0, 0, 0, .34));
}

.erm-bg-line {
  position: absolute;
  z-index: 1;
  left: -8vw;
  width: 116vw;
  top: var(--top);
  height: var(--line-height);
  overflow: hidden;
  white-space: nowrap;
  transform: translateY(-50%);
  opacity: var(--line-opacity);
}

.erm-bg-track {
  display: flex;
  width: max-content;
  gap: var(--gap);
  animation: ermLineMove var(--duration) linear infinite;
  animation-delay: var(--delay);
  will-change: transform;
}

.erm-bg-line.reverse .erm-bg-track {
  animation-name: ermLineMoveReverse;
}

.erm-bg-word {
  flex: 0 0 auto;
  font-size: var(--size);
  line-height: var(--line-height);
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;

  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.92),
    rgba(80, 203, 255, .92),
    rgba(53, 115, 255, .9)
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  text-shadow:
    0 0 8px rgba(74, 220, 255, .20),
    0 0 18px rgba(40, 110, 255, .14);

  user-select: none;
}

.erm-bg-line:nth-child(2n) .erm-bg-word {
  background: linear-gradient(
    90deg,
    rgba(45, 105, 255, .9),
    rgba(78, 218, 255, .95),
    rgba(79, 245, 210, .9)
  );
  -webkit-background-clip: text;
  background-clip: text;
}

.erm-bg-line:nth-child(3n) .erm-bg-word {
  opacity: .78;
}

@keyframes ermLineMove {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    transform: translate3d(-50%, 0, 0);
  }
}

@keyframes ermLineMoveReverse {
  from {
    transform: translate3d(-50%, 0, 0);
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

.app,
.page,
.auth-shell,
.cabinet-shell,
main {
  position: relative;
  z-index: 1;
}

@media (max-width: 760px) {
  .erm-bg-line {
    left: -18vw;
    width: 136vw;
  }
}

/* Telegram Mini App polish */
body.telegram-miniapp .hero {
  padding-top: 18px;
}

body.telegram-miniapp.logged-in .hero,
body.telegram-miniapp.logged-in .features {
  display: none;
}

body.telegram-miniapp .cabinet {
  margin-top: 16px;
}

/* ERM final addon: referral + safe payment state */
.referral-box {
  margin-top: 12px;
  padding: 14px;
  border: 1px solid rgba(120, 255, 235, .16);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(18, 42, 55, .78), rgba(10, 18, 34, .82));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

.referral-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.referral-main b {
  display: block;
  margin: 2px 0 3px;
  font-size: 18px;
  color: var(--text, #f7fbff);
}

.referral-main small,
.referral-stats,
.referral-line {
  color: var(--muted, #9fb1c8);
}

.referral-line {
  margin-top: 10px;
  padding: 9px 10px;
  border-radius: 12px;
  background: rgba(3, 10, 20, .38);
  border: 1px solid rgba(255,255,255,.06);
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.referral-stats {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 9px;
  font-size: 12px;
}

.referral-stats b {
  color: #fff;
}

button:disabled,
.btn:disabled {
  opacity: .72;
  cursor: wait;
}

/* keep ERMTEAM background white, not gradient */
.erm-bg-word {
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: rgba(255, 255, 255, .74) !important;
  text-shadow:
    0 0 8px rgba(255, 255, 255, .12),
    0 0 18px rgba(80, 203, 255, .16) !important;
}

@media (max-width: 760px) {
  .referral-main {
    align-items: flex-start;
    flex-direction: column;
  }

  .referral-main .btn {
    width: 100%;
  }
}

/* ERM support cabinet button */
.support-cabinet-btn {
  border-color: rgba(116, 242, 223, .22) !important;
  background: rgba(116, 242, 223, .08) !important;
  color: #eaffff !important;
  white-space: nowrap;
}
.support-cabinet-btn:hover {
  background: rgba(116, 242, 223, .14) !important;
  transform: translateY(-1px);
}
@media (max-width: 760px) {
  .support-cabinet-btn {
    font-size: 0;
    width: 42px;
    min-width: 42px;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .support-cabinet-btn::before {
    content: "💬";
    font-size: 16px;
  }
}

/* ERM cabinet account layout stable support fix */
.account-strip-panel {
  overflow: visible !important;
}

.account-strip {
  align-items: stretch !important;
}

.strip-actions {
  grid-column: 1 / -1 !important;
  display: grid !important;
  grid-template-columns: 56px minmax(210px, 1.15fr) minmax(190px, 1fr) minmax(190px, .9fr) 56px !important;
  gap: 10px !important;
  align-items: stretch !important;
}

.strip-actions > * {
  min-width: 0 !important;
  width: 100% !important;
}

.strip-actions .btn,
.strip-actions .icon-btn {
  min-height: 54px !important;
  height: 100% !important;
  border-radius: 17px !important;
  white-space: normal !important;
  line-height: 1.15 !important;
  text-align: center !important;
}

.strip-actions #copyCabinetBtn {
  padding-left: 12px !important;
  padding-right: 12px !important;
}

.support-cabinet-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  font-size: 15px !important;
  min-width: 0 !important;
  width: 100% !important;
  border-color: rgba(116, 242, 223, .26) !important;
  background: rgba(116, 242, 223, .08) !important;
  color: #eaffff !important;
  text-decoration: none !important;
}

.support-cabinet-btn::before {
  content: none !important;
}

.support-cabinet-btn:hover {
  background: rgba(116, 242, 223, .14) !important;
  transform: translateY(-1px);
}

@media (max-width: 900px) {
  .strip-actions {
    grid-template-columns: 54px 1fr 1fr 54px !important;
    grid-template-areas:
      "tg renew renew refresh"
      "support support cab cab" !important;
  }
  .tg-icon { grid-area: tg !important; }
  .renew-cta { grid-area: renew !important; }
  .support-cabinet-btn { grid-area: support !important; }
  .strip-actions #copyCabinetBtn { grid-area: cab !important; }
  .strip-actions #refreshBtn { grid-area: refresh !important; }
}

@media (max-width: 560px) {
  body.logged-in main,
  body.logged-in .topbar,
  .topbar,
  main {
    width: min(100% - 18px, 1180px) !important;
  }

  .account-strip-panel {
    padding: 12px !important;
  }

  .account-strip {
    grid-template-columns: 1fr !important;
    gap: 9px !important;
  }

  .strip-user,
  .strip-days,
  .strip-cell,
  .code-cell {
    grid-column: auto !important;
    display: flex !important;
  }

  .strip-cell {
    padding: 13px !important;
  }

  .strip-actions {
    grid-template-columns: 48px 1fr 48px !important;
    grid-template-areas:
      "tg renew refresh"
      "support support support"
      "cab cab cab" !important;
    gap: 8px !important;
  }

  .strip-actions .btn,
  .strip-actions .icon-btn {
    min-height: 52px !important;
    border-radius: 15px !important;
  }

  .support-cabinet-btn {
    font-size: 15px !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .support-cabinet-btn::before {
    content: "💬" !important;
    font-size: 16px !important;
  }

  .cabinet-head {
    margin-top: 10px !important;
    margin-bottom: 10px !important;
  }

  .cabinet-head h2 {
    font-size: clamp(32px, 11vw, 46px) !important;
    line-height: .92 !important;
  }
}

/* ERM device upgrade mode */
.renew-mode-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 12px 0 10px;
}
.renew-mode-tabs button {
  border: 1px solid rgba(190,235,255,.14);
  border-radius: 14px;
  background: rgba(255,255,255,.055);
  color: rgba(244,251,255,.82);
  padding: 10px 12px;
  font-weight: 850;
  cursor: pointer;
}
.renew-mode-tabs button.active {
  background: linear-gradient(135deg, var(--cyan, #74f2df), var(--blue, #72d0ff));
  color: #00111b;
  border-color: transparent;
}
.renew-picker-group.hidden {
  display: none !important;
}
#payBtn:disabled {
  opacity: .55;
  cursor: not-allowed;
}
@media (max-width: 620px) {
  .renew-mode-tabs {
    grid-template-columns: 1fr;
  }
}

/* ERM device upgrade mode */
.renew-mode-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 12px 0 10px;
}
.renew-mode-tabs button {
  border: 1px solid rgba(190,235,255,.14);
  border-radius: 14px;
  background: rgba(255,255,255,.055);
  color: rgba(244,251,255,.82);
  padding: 10px 12px;
  font-weight: 850;
  cursor: pointer;
}
.renew-mode-tabs button.active {
  background: linear-gradient(135deg, var(--cyan, #74f2df), var(--blue, #72d0ff));
  color: #00111b;
  border-color: transparent;
}
.renew-picker-group.hidden {
  display: none !important;
}
#payBtn:disabled {
  opacity: .55;
  cursor: not-allowed;
}
@media (max-width: 620px) {
  .renew-mode-tabs {
    grid-template-columns: 1fr;
  }
}

/* ERM device manage mode hotfix */
.renew-mode-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 12px 0 10px;
}
.renew-mode-tabs button {
  border: 1px solid rgba(190,235,255,.18);
  border-radius: 14px;
  background: rgba(255,255,255,.055);
  color: rgba(244,251,255,.86);
  padding: 11px 12px;
  font-weight: 900;
  cursor: pointer;
}
.renew-mode-tabs button.active {
  background: linear-gradient(135deg, var(--cyan, #74f2df), var(--blue, #72d0ff));
  color: #00111b;
  border-color: transparent;
}
.renew-picker-group.hidden { display: none !important; }
#payBtn:disabled { opacity:.55; cursor:not-allowed; }
@media (max-width: 620px) { .renew-mode-tabs { grid-template-columns:1fr; } }

.expert-head-clean{justify-content:flex-start}
.simple-config-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:14px}
.feature-connect-card{display:grid;gap:16px;align-content:space-between;min-height:240px;padding:22px;border-radius:24px;border:1px solid rgba(255,255,255,.09);background:rgba(8,15,28,.72);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.feature-card-main{min-height:240px}
.feature-copy{display:grid;gap:10px}
.feature-kicker{display:inline-flex;align-items:center;justify-content:center;width:max-content;padding:7px 10px;border-radius:999px;background:rgba(103,232,185,.11);border:1px solid rgba(103,232,185,.18);color:#ccfff0;font-size:11px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}
.feature-connect-card b{display:block;font-size:42px;line-height:.96;letter-spacing:-.04em;margin:0}
.feature-connect-card p{margin:0;color:var(--muted2);font-size:15px;line-height:1.45;max-width:34ch}
.feature-main-btn{min-height:54px;font-size:16px}
.happ-feature-card{background:linear-gradient(135deg,rgba(103,232,185,.14),rgba(86,200,255,.10) 55%,rgba(9,16,28,.94));border-color:rgba(103,232,185,.16)}
.ovpn-feature-card{background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(86,200,255,.06),rgba(9,16,28,.94));border-color:rgba(255,255,255,.08)}
@media (max-width:1100px){.simple-config-grid{grid-template-columns:1fr}.feature-connect-card{min-height:220px}}
@media (max-width:780px){.feature-connect-card{padding:18px;border-radius:20px;min-height:auto}.feature-connect-card b{font-size:34px}.feature-main-btn{min-height:48px}}


.manual-vless-toggle{margin-top:2px}
.manual-vless-panel{padding:14px;border-radius:18px;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.09)}
.manual-vless-panel.hidden{display:none!important}
.manual-vless-panel p{margin:0 0 12px;color:var(--muted);font-size:13px;line-height:1.45}
.manual-vless-section{margin-top:14px;padding:14px;border-radius:20px;background:rgba(0,0,0,.16);border:1px solid rgba(255,255,255,.09)}
.manual-vless-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.manual-vless-head b{display:block;font-size:20px;line-height:1.1}
.manual-vless-head small{display:block;color:var(--muted);font-size:12px;max-width:64ch}
.manual-vless-grid{margin-top:10px}
.manual-global-row{margin-bottom:10px}
@media (max-width:780px){.manual-vless-head{display:grid}.manual-vless-head .btn{width:100%}}
body.telegram-miniapp .manual-vless-section{padding:12px;border-radius:18px}
body.telegram-miniapp .manual-vless-head{gap:10px}
body.telegram-miniapp .manual-vless-grid{grid-template-columns:1fr}

/* ERM email required before payment */
.email-required-box {
  margin: 0 0 14px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(255, 198, 87, .28);
  background: linear-gradient(135deg, rgba(255, 198, 87, .12), rgba(103, 232, 185, .055));
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(280px, .95fr);
  gap: 12px;
  align-items: end;
}
.email-required-box.hidden { display: none; }
.email-required-box b {
  display: block;
  font-size: 18px;
  margin-top: 2px;
}
.email-required-box small {
  display: block;
  color: var(--muted);
  margin-top: 4px;
}
.email-required-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}
.email-required-form input {
  min-height: 46px;
  width: 100%;
  border: 1px solid var(--line);
  background: rgba(4, 8, 13, .58);
  color: var(--text);
  outline: none;
  border-radius: 15px;
  padding: 12px 14px;
}
.email-required-form input:focus {
  border-color: rgba(103, 232, 185, .7);
  box-shadow: 0 0 0 4px rgba(103, 232, 185, .08);
}
@media (max-width: 760px) {
  .email-required-box,
  .email-required-form {
    grid-template-columns: 1fr;
  }
}

/* ERMTEAM_HAPP_ONLY_UI_2026_06_16 */
.protocol-step{display:none!important}
.setup-flow{grid-template-areas:"device app" "access access"}
.app-step,.access-step{min-height:100%}
@media (max-width:1100px){.setup-flow{grid-template-areas:"device" "app" "access"}}


/* ERMTEAM_RUBYPASS_CARD_2026_06_16 */
.route-info-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(220px,.38fr);
  gap:14px;
  align-items:center;
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(103,232,185,.2);
  background:linear-gradient(135deg,rgba(103,232,185,.09),rgba(114,234,255,.055)),rgba(8,15,28,.66);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.route-info-copy{display:grid;gap:8px;min-width:0}
.route-info-copy b{font-size:22px;line-height:1.08;color:var(--text)}
.route-info-copy p{margin:0;color:var(--muted2);font-size:14px;line-height:1.5;max-width:72ch}
.route-info-manual{
  display:grid;
  gap:9px;
  align-content:center;
  padding:12px;
  border-radius:16px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.08);
}
.route-info-manual span{color:var(--muted);font-size:12px;line-height:1.4}
@media (max-width:780px){.route-info-card{grid-template-columns:1fr;padding:15px}.route-info-copy b{font-size:20px}}

.payment-unavailable-note {
  margin-top: 8px;
  color: rgba(232, 241, 255, .68);
  font-size: 12px;
  line-height: 1.35;
  text-align: center;
}

#payBtn.external-payment-disabled {
  opacity: .55;
  cursor: not-allowed;
  box-shadow: none !important;
}


/* ERMTEAM_INCY_GUIDE_2026_06_24 */
.incy-guide-card{
  margin-top:14px;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(220px,.42fr);
  gap:14px;
  align-items:center;
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(114,234,255,.2);
  background:linear-gradient(135deg,rgba(114,234,255,.09),rgba(103,232,185,.055)),rgba(8,15,28,.66);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.incy-guide-card b{display:block;font-size:22px;line-height:1.08;color:var(--text);margin:8px 0 0}
.incy-guide-card p{margin:8px 0 0;color:var(--muted2);font-size:14px;line-height:1.5;max-width:72ch}
.incy-guide-card code{
  grid-column:1/-1;
  display:block;
  padding:11px 12px;
  border-radius:14px;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.08);
  color:var(--muted2);
  font-size:12px;
  word-break:break-all;
}
.incy-guide-actions{display:grid;gap:9px}
@media (max-width:780px){.incy-guide-card{grid-template-columns:1fr;padding:15px}.incy-guide-card b{font-size:20px}}
/* ERMTEAM_CLIENT_CHOICE_2026_06_24 */
.client-choice-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,.42fr);
  gap:14px;
  align-items:center;
  padding:16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(0,0,0,.18);
}
.client-choice-card b{display:block;margin-top:8px;font-size:22px;line-height:1.08}
.client-choice-card p{margin:7px 0 0;color:var(--muted2);font-size:14px;line-height:1.45}
.client-choice-switch{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  padding:6px;
  border-radius:16px;
  background:rgba(0,0,0,.24);
  border:1px solid rgba(255,255,255,.08);
}
.client-choice-switch button{
  border:0;
  border-radius:12px;
  background:transparent;
  color:var(--muted);
  padding:13px 12px;
  font-weight:950;
  cursor:pointer;
}
.client-choice-switch button.active{
  background:linear-gradient(135deg,var(--green),var(--blue));
  color:#061019;
}
@media (max-width:780px){.client-choice-card{grid-template-columns:1fr;padding:14px}}