:root{
  --bg0:#0e2029; --panel:#1c3849; --panel2:#244353; --card:#203d4f;
  --line:#345560; --line2:#476d80;
  --txt:#e9f4f1; --dim:#8aa6a3; --mut:#5f7d7d;
  --teal:#34c8b8; --teal2:#1f8fa6; --green:#2de58a; --gold:#f5c451; --amber:#ffc24b; --red:#ff6b78;
  --grad-teal:linear-gradient(135deg,#37cdbb,#1f86b0);
}
*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:clip;max-width:100vw}
body{font-family:'Vazirmatn',system-ui,sans-serif;background:var(--bg0);color:var(--txt);min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.7;font-size:14px;overflow-x:hidden;max-width:100%}
body::before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(900px 600px at 92% -5%,rgba(40,170,170,.18),transparent 55%),radial-gradient(700px 700px at 100% 100%,rgba(30,120,140,.12),transparent 55%),linear-gradient(160deg,#070e16,#0a1622 60%,#06131a)}
.stars{position:fixed;inset:0;z-index:-1;background-image:radial-gradient(1px 1px at 20% 30%,rgba(140,200,200,.5),transparent),radial-gradient(1px 1px at 70% 20%,rgba(140,200,200,.35),transparent),radial-gradient(1px 1px at 85% 60%,rgba(140,200,200,.4),transparent),radial-gradient(1px 1px at 40% 80%,rgba(140,200,200,.3),transparent);opacity:.55}
.app{max-width:980px;margin:0 auto;padding:18px}
.btn{border:none;border-radius:12px;padding:12px 22px;font-family:inherit;font-size:14px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.15s;background:var(--grad-teal);color:#04201f;box-shadow:0 10px 26px -10px rgba(52,200,184,.6)}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn.gold{background:linear-gradient(135deg,#f6cf63,#e0962f);box-shadow:0 10px 26px -10px rgba(245,196,81,.6);color:#2a1a04}
.btn.block{width:100%;justify-content:center}
.btn.pulse{animation:pls 1.5s infinite}
@keyframes pls{0%,100%{box-shadow:0 10px 26px -10px rgba(52,200,184,.5)}50%{box-shadow:0 10px 30px -2px rgba(52,200,184,1)}}

/* LOGIN */
#login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:18px;width:100vw;max-width:100vw;overflow-x:clip}
.lcard{width:100%;max-width:340px;min-width:0;background:var(--panel);border:1px solid var(--line);border-radius:24px;padding:36px 30px;text-align:center}
.lcard .o{width:60px;height:60px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#3df0a0,#159b6a);box-shadow:0 0 22px rgba(45,229,138,.6);margin:0 auto 10px}
.lcard .nm{font-size:18px;letter-spacing:3px;font-weight:800;margin-bottom:22px}
.lcard h1{font-size:19px;margin-bottom:6px}
.lcard p{color:var(--dim);font-size:13.5px;margin-bottom:22px}
.inp{width:100%;background:#0a1620;border:1.5px solid var(--line2);border-radius:13px;padding:14px;color:var(--txt);font-family:inherit;font-size:16px;outline:none;text-align:center;transition:.18s;margin-bottom:14px;letter-spacing:3px}
.inp:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(52,200,184,.12)}
.otp{display:flex;gap:9px;direction:ltr;justify-content:center;margin-bottom:16px}
.otp input{width:50px;height:58px;background:#0a1620;border:1.5px solid var(--line2);border-radius:13px;color:var(--txt);font-size:23px;font-weight:800;text-align:center;outline:none;transition:.18s}
.otp input:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(52,200,184,.12)}
.lnk{background:none;border:none;color:var(--mut);font-family:inherit;font-size:13px;cursor:pointer;margin-top:14px}
.lnk:hover{color:var(--teal)}
.step{display:none}.step.on{display:block;animation:fade .3s}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

#app{display:none}
.top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px}
.logo .o{width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#3df0a0,#159b6a);box-shadow:0 0 16px rgba(45,229,138,.6)}
.top-left{display:flex;align-items:center;gap:10px}
.pill{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:7px 12px;display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--mut)}
.pill .ph{direction:ltr;font-variant-numeric:tabular-nums;color:var(--txt);font-weight:600}
.av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#2a3f4a,#16242c);border:1px solid var(--line2);display:grid;place-items:center;color:var(--dim);cursor:pointer;transition:.2s;padding:0}
.av:hover{border-color:var(--teal);color:var(--teal)}
.av.open{border-color:var(--teal);color:var(--teal);transform:scale(1.05)}
.avwrap{position:relative}
.phpop{position:absolute;top:calc(100% + 10px);right:0;z-index:90;display:flex;align-items:center;gap:11px;padding:11px 15px;border-radius:16px;background:rgba(20,38,50,.55);backdrop-filter:blur(18px) saturate(1.3);-webkit-backdrop-filter:blur(18px) saturate(1.3);border:1px solid rgba(52,200,184,.3);box-shadow:0 18px 50px -18px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.05) inset;opacity:0;transform:translateY(-8px) scale(.96);transform-origin:top right;pointer-events:none;transition:.22s cubic-bezier(.2,.9,.25,1);white-space:nowrap}
.phpop.on{opacity:1;transform:none;pointer-events:auto}
.phpop .pic{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:rgba(52,200,184,.14);color:var(--teal);flex-shrink:0}
.phpop .ptx{display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.phpop .plbl{font-size:10.5px;font-weight:600;color:var(--mut)}
.phpop .pnum{direction:ltr;font-variant-numeric:tabular-nums;color:var(--txt);font-weight:700;font-size:14.5px;letter-spacing:.5px}

/* GUIDE BANNER */
.guide{display:flex;gap:14px;align-items:center;background:linear-gradient(100deg,rgba(255,107,120,.14),rgba(255,194,75,.08));border:1px solid rgba(255,107,120,.4);border-radius:18px;padding:16px 18px;margin-bottom:16px}
.guide.hide{display:none}
.guide .gi{width:46px;height:46px;border-radius:13px;background:rgba(255,107,120,.18);border:1px solid rgba(255,107,120,.4);display:grid;place-items:center;color:var(--red);flex-shrink:0;animation:pls2 1.6s infinite}
@keyframes pls2{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.guide .gt{flex:1}
.guide .gt b{font-size:15px;color:#ffd9dc;display:block;margin-bottom:2px}
.guide .gt span{font-size:13px;color:var(--dim)}
.guide .gt span b{color:var(--green);display:inline}

/* PLAN */
.planbar{background:linear-gradient(110deg,#0e2733,#0c1c2a);border:1px solid var(--line);border-radius:20px;padding:20px 22px;display:flex;align-items:center;gap:20px;justify-content:space-between;flex-wrap:wrap;margin-bottom:16px;position:relative;overflow:hidden}
.planbar::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--grad-teal)}
.planbar .pinfo{flex:1;min-width:220px}
.planbar .pname{font-size:18px;font-weight:800;display:flex;align-items:center;gap:9px;margin-bottom:6px}
.badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}
.badge.ok{color:var(--green);background:rgba(45,229,138,.12);border:1px solid rgba(45,229,138,.3)}
.planbar .days{color:var(--dim);font-size:13px;margin-bottom:10px}
.planbar .days b{color:var(--teal);font-size:20px;font-variant-numeric:tabular-nums}
.pbar{height:7px;border-radius:10px;background:#0a1620;overflow:hidden;max-width:340px}
.pbar i{display:block;height:100%;background:var(--grad-teal);border-radius:10px}

.panel{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px;transition:.2s;margin-bottom:16px}
.panel.spot{border-color:var(--teal);box-shadow:0 0 0 4px rgba(52,200,184,.15)}
.ph{display:flex;align-items:center;justify-content:flex-end;gap:9px;margin-bottom:15px;font-weight:800;font-size:15px}
.ph .ic{color:var(--teal)} .ph .bar{width:3px;height:18px;border-radius:3px;background:var(--teal);order:3}

/* ===== DNS HERO (full width, surprise!) ===== */
.dnshero{margin-bottom:16px;position:relative;transition:.3s}
.dnshero .sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.dnshero .sec-title{display:flex;align-items:center;gap:13px}
.dnshero .sec-title .icn{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(55,205,187,.22),rgba(31,134,176,.14));border:1px solid var(--line2);box-shadow:0 0 24px rgba(52,200,184,.18) inset;color:var(--teal)}
.dnshero .sec-title h2{font-size:21px;font-weight:800}
.dnshero .sec-title p{font-size:12.5px;color:var(--dim);margin-top:2px}
.dnshero .status-pill{display:flex;align-items:center;gap:9px;background:rgba(45,229,138,.08);border:1px solid rgba(45,229,138,.28);padding:8px 15px;border-radius:999px;font-size:13.5px;font-weight:700;color:var(--green)}
.dnshero .live-dot{position:relative;width:10px;height:10px;border-radius:50%;background:var(--green)}
.dnshero .live-dot::after{content:'';position:absolute;inset:-5px;border-radius:50%;border:2px solid var(--green);animation:hpulse 1.8s ease-out infinite;opacity:0}
@keyframes hpulse{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.9);opacity:0}}
.dnshero .lockbar{display:none;align-items:center;gap:10px;background:rgba(255,194,75,.1);border:1px solid rgba(255,194,75,.3);color:#ffe6b0;border-radius:13px;padding:11px 15px;font-size:13px;font-weight:700;margin-bottom:14px}
.dnshero.locked .lockbar{display:flex}
.dnshero.locked .cards,.dnshero.locked .mobdns{opacity:.4;filter:grayscale(.35);pointer-events:none}
.dnshero .cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dnshero .card{position:relative;border-radius:22px;padding:2px;background:linear-gradient(160deg,var(--line2),rgba(25,48,61,.4) 45%,var(--line2));transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.dnshero .card.reco{background:linear-gradient(140deg,rgba(55,205,187,.9),rgba(31,134,176,.55) 50%,rgba(245,196,81,.55));box-shadow:0 20px 60px -22px rgba(52,200,184,.45)}
.dnshero .card{cursor:pointer}
.dnshero .card:hover{transform:translateY(-5px)}
.dnshero .card:active{transform:scale(.985)}
.dnshero .copyhint{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--dim);background:rgba(255,255,255,.03);border:1px solid var(--line);padding:6px 11px;border-radius:999px;transition:.2s}
.dnshero .card:hover .copyhint{color:var(--teal);border-color:var(--teal)}
.dnshero .card-inner{position:relative;background:linear-gradient(170deg,#10242f,#0c1a25);border-radius:20px;padding:22px;overflow:hidden;height:100%}
.dnshero .card-inner::before{content:'';position:absolute;top:-40%;right:-10%;width:60%;height:80%;background:radial-gradient(circle,rgba(52,200,184,.16),transparent 70%);pointer-events:none}
.dnshero .card.reco .card-inner::before{background:radial-gradient(circle,rgba(52,200,184,.26),transparent 70%)}
.dnshero .reco-badge{position:absolute;top:16px;left:16px;display:flex;align-items:center;gap:7px;background:linear-gradient(135deg,#f5c451,#e7a93a);color:#1a1205;font-size:12px;font-weight:800;padding:6px 12px;border-radius:999px;box-shadow:0 6px 18px -6px rgba(245,196,81,.6);z-index:3}
.dnshero .card-top{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:2}
.dnshero .label-wrap{display:flex;align-items:center;gap:12px}
.dnshero .num-chip{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:18px;font-weight:800;color:var(--teal);background:rgba(52,200,184,.1);border:1px solid var(--line2)}
.dnshero .card.reco .num-chip{color:var(--gold);background:rgba(245,196,81,.12);border-color:rgba(245,196,81,.3)}
.dnshero .role{font-size:15px;font-weight:800}
.dnshero .sub{font-size:11px;color:var(--mut);letter-spacing:.5px;margin-top:2px}
.dnshero .region{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--dim);background:rgba(255,255,255,.03);border:1px solid var(--line);padding:6px 11px;border-radius:999px}
.dnshero .ip-wrap{position:relative;z-index:2;margin:16px 0 2px;text-align:center}
.dnshero .ip-cap{font-size:11px;color:var(--mut);letter-spacing:2px;margin-bottom:6px}
.dnshero .hip{font-family:ui-monospace,Menlo,monospace;font-size:42px;font-weight:800;line-height:1;background:linear-gradient(135deg,#f4fffd,#8df0e3 50%,#2fd4c2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 22px rgba(52,200,184,.45));direction:ltr;font-variant-numeric:tabular-nums}
.dnshero .card.reco .hip{background:linear-gradient(135deg,#fff7e6,#ffe7a8 45%,#3ce6cb);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 4px 24px rgba(245,196,81,.4))}
.dnshero .wave{position:relative;z-index:2;height:28px;margin:10px 0 2px;overflow:hidden;opacity:.8}
.dnshero .wave svg{width:100%;height:100%}
.dnshero .wave .ln{stroke:var(--teal);stroke-width:2;fill:none}
.dnshero .card.reco .wave .ln{stroke:#52e0cf}
.dnshero .meta-row{display:flex;align-items:center;justify-content:center;gap:14px;position:relative;z-index:2;margin:12px 0 18px}
.dnshero .pingv{display:flex;align-items:baseline;gap:4px;font-weight:800;direction:ltr}
.dnshero .pingv .val{font-size:25px;font-variant-numeric:tabular-nums;color:var(--green)}
.dnshero .pingv .unit{font-size:13px;color:var(--dim);font-weight:700}
.dnshero .sep{width:1px;height:24px;background:var(--line2)}
.dnshero .signal{display:flex;align-items:flex-end;gap:4px;height:24px}
.dnshero .signal i{width:5px;border-radius:3px;background:var(--green);display:block;animation:hbars 1.3s ease-in-out infinite;transform-origin:bottom}
.dnshero .signal i:nth-child(1){height:8px;animation-delay:0s}
.dnshero .signal i:nth-child(2){height:14px;animation-delay:.12s}
.dnshero .signal i:nth-child(3){height:19px;animation-delay:.24s}
.dnshero .signal i:nth-child(4){height:24px;animation-delay:.36s}
@keyframes hbars{0%,100%{transform:scaleY(.55);opacity:.6}50%{transform:scaleY(1);opacity:1}}
.dnshero .ping-tag{font-size:12px;color:var(--green);background:rgba(45,229,138,.12);border:1px solid rgba(45,229,138,.3);padding:6px 12px;border-radius:999px;font-weight:800;display:flex;align-items:center;gap:6px}
.dnshero .cbtn{width:100%;position:relative;z-index:2;border:none;cursor:pointer;font-family:inherit;font-size:15px;font-weight:800;color:#04201d;padding:14px;border-radius:13px;background:var(--grad-teal);display:flex;align-items:center;justify-content:center;gap:10px;transition:.2s;box-shadow:0 12px 30px -12px rgba(52,200,184,.55)}
.dnshero .cbtn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.dnshero .cbtn.ghost{background:rgba(255,255,255,.06);color:var(--txt);border:1px solid var(--line2);box-shadow:none}
.dnshero .cbtn.ghost:hover{background:rgba(52,200,184,.08);border-color:var(--teal)}
.dnshero .mobdns{margin-top:16px;background:linear-gradient(160deg,rgba(55,205,187,.08),rgba(31,134,176,.05));border:1px solid var(--line2);border-radius:18px;padding:16px 18px}
.dnshero .mobdns-head{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:800;margin-bottom:13px}
.dnshero .mobdns-head .mic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:rgba(52,200,184,.12);border:1px solid var(--line2);color:var(--teal);flex-shrink:0}
.dnshero .mobdns-rows{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dnshero .mobdns-row{display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:13px;padding:11px 13px}
.dnshero .mobdns-role{font-size:10.5px;color:var(--mut);letter-spacing:.5px;font-weight:700;min-width:64px}
.dnshero .mobdns-ip{flex:1;direction:ltr;font-variant-numeric:tabular-nums;font-weight:800;font-size:16px;color:var(--txt);font-family:ui-monospace,Menlo,monospace}
.dnshero .mcopy{flex-shrink:0;width:36px;height:36px;border-radius:10px;border:1px solid var(--line2);background:rgba(52,200,184,.08);color:var(--teal);cursor:pointer;display:grid;place-items:center;transition:.2s}
.dnshero .mcopy:hover{border-color:var(--teal);background:rgba(52,200,184,.16)}
@media(max-width:760px){.dnshero .mobdns-rows{grid-template-columns:1fr}}
@media(max-width:760px){.dnshero .cards{grid-template-columns:1fr}}

/* IP panel horizontal */
.iprow{display:flex;gap:16px;align-items:stretch;flex-wrap:wrap}
.iprow .ipnow{flex:1.1;min-width:230px}
.iprow .ipside{flex:1;min-width:230px;display:flex;flex-direction:column;justify-content:center}
.ipnow{background:var(--card);border:1px solid var(--line2);border-radius:13px;padding:16px;text-align:center;display:flex;flex-direction:column;justify-content:center}
.ipnow .lbl{font-size:12px;color:var(--mut);margin-bottom:6px}
.ipnow .v{font-size:30px;font-weight:800;direction:ltr;font-variant-numeric:tabular-nums;letter-spacing:.5px}
.ipnow .dv{font-size:12px;color:var(--dim);margin-top:4px}
.status{display:flex;align-items:center;gap:8px;justify-content:center;font-size:13px;font-weight:700;padding:11px;border-radius:11px;margin-bottom:12px}
.status.ok{color:#bdffe2;background:rgba(45,229,138,.1)} .status.warn{color:#ffd2d6;background:rgba(255,107,120,.12)}
.dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.hinttip{font-size:12px;color:var(--amber);text-align:center;margin-top:10px;display:none}
.hinttip.show{display:block}

table{width:100%;border-collapse:collapse;font-size:13px}
thead th{color:var(--mut);font-weight:600;font-size:12px;text-align:right;padding:10px 12px;border-bottom:1px solid var(--line)}
tbody td{padding:12px;border-bottom:1px solid var(--line);color:var(--dim);text-align:right}
tbody tr:last-child td{border-bottom:none}
td.ipc{direction:ltr;text-align:right;font-variant-numeric:tabular-nums;color:var(--txt)}
.devc{display:flex;align-items:center;gap:9px;flex-direction:row-reverse;justify-content:flex-end}
.devc .di{width:30px;height:30px;border-radius:8px;background:var(--card);border:1px solid var(--line2);display:grid;place-items:center;color:var(--teal);flex-shrink:0}
.st-ok{color:var(--green);background:rgba(45,229,138,.12);border:1px solid rgba(45,229,138,.3);padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700}
.st-old{color:var(--mut);background:#0a1620;border:1px solid var(--line);padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700}
.empty{text-align:center;color:var(--mut);font-size:13px;padding:18px}

/* elevated IP card */
.iprow2{display:grid;grid-template-columns:1.25fr 1fr;gap:16px}
@media(max-width:760px){.iprow2{grid-template-columns:1fr}}
.ipbig-card{position:relative;overflow:hidden;background:linear-gradient(160deg,#10242f,#0c1a25);border:1px solid var(--line2);border-radius:16px;padding:24px 22px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.ipbig-card::before{content:'';position:absolute;top:-30%;right:-10%;width:55%;height:80%;background:radial-gradient(circle,rgba(52,200,184,.14),transparent 70%);pointer-events:none}
.radar{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;opacity:.42}
.radar span{position:absolute;width:26px;height:26px;border-radius:50%;border:2px solid var(--teal);opacity:0;animation:radar 3s ease-out infinite}
.radar span:nth-child(2){animation-delay:1s}.radar span:nth-child(3){animation-delay:2s}
@keyframes radar{0%{transform:scale(.3);opacity:.6}100%{transform:scale(2.5);opacity:0}}
@keyframes radarLight{0%{transform:scale(.3);opacity:.7}100%{transform:scale(3.6);opacity:0}}
.ipbig-card .ipcap{font-size:11px;color:var(--mut);letter-spacing:2px;margin-bottom:9px;position:relative;z-index:2}
.ipbig-card .ipbig{font-family:ui-monospace,Menlo,monospace;font-size:34px;font-weight:800;line-height:1;background:linear-gradient(135deg,#f4fffd,#8df0e3 50%,#2fd4c2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 20px rgba(52,200,184,.4));direction:ltr;font-variant-numeric:tabular-nums;position:relative;z-index:2}
.ipbig-card .ipdev{display:inline-flex;align-items:center;gap:7px;margin-top:13px;font-size:12.5px;color:var(--dim);background:rgba(255,255,255,.03);border:1px solid var(--line);padding:6px 13px;border-radius:999px;position:relative;z-index:2}
.ipact{display:flex;flex-direction:column;justify-content:center}
.status2{display:flex;align-items:center;gap:9px;justify-content:center;font-size:13.5px;font-weight:700;padding:13px;border-radius:13px;margin-bottom:12px}
.status2.ok{color:#bdffe2;background:rgba(45,229,138,.1);border:1px solid rgba(45,229,138,.25)}
.status2.warn{color:#ffd2d6;background:rgba(255,107,120,.12);border:1px solid rgba(255,107,120,.3)}

/* elevated record rows */
.reclist{display:flex;flex-direction:column;gap:10px}
.recrow{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:13px 15px;transition:.2s}
.recrow:hover{transform:translateY(-2px);border-color:var(--line2)}
.recrow.active{border-color:rgba(45,229,138,.35);background:rgba(45,229,138,.05)}
.recrow .rnum{width:22px;color:var(--mut);font-size:13px;font-weight:700;text-align:center;flex-shrink:0}
.recrow .ri{width:38px;height:38px;border-radius:10px;background:rgba(52,200,184,.1);border:1px solid var(--line2);display:grid;place-items:center;color:var(--teal);flex-shrink:0}
.recrow .rmain{flex:1;min-width:0}
.recrow .rmain b{font-size:14px;display:block}
.recrow .rmain small{font-size:12px;color:var(--mut)}
.recrow .rip{font-size:14px;direction:ltr;font-variant-numeric:tabular-nums;color:var(--txt);font-family:ui-monospace,Menlo,monospace}
.recrow .rst{flex-shrink:0}
.reccount{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;color:var(--teal);background:rgba(52,200,184,.12);border:1px solid rgba(52,200,184,.3)}

/* modal */
.ov{position:fixed;inset:0;background:rgba(3,8,12,.78);backdrop-filter:blur(6px);z-index:50;display:none;align-items:center;justify-content:center;padding:20px}
.ov.on{display:flex;animation:fade .25s}
.sheet{width:100%;max-width:760px;background:var(--panel);border:1px solid var(--line);border-radius:22px;max-height:92vh;overflow:auto;padding:22px}
.sheet-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.sheet-h b{font-size:17px;font-weight:800}
.xbtn{width:36px;height:36px;border-radius:11px;border:1px solid var(--line2);background:none;color:var(--dim);cursor:pointer;display:grid;place-items:center}
.plans{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.plan{flex:1;min-width:180px;max-width:230px;background:linear-gradient(160deg,rgba(20,55,65,.5),rgba(10,30,40,.5));border:1px solid var(--line2);border-radius:16px;padding:20px 16px;display:flex;flex-direction:column;align-items:center;transition:.2s}
.plan:hover{transform:translateY(-4px)}
.plan.best{border-color:rgba(52,200,184,.5);box-shadow:0 16px 40px -18px rgba(52,200,184,.5)}
.plan .medal{font-size:24px;margin-bottom:6px}
.plan .head{width:100%;text-align:center;border-radius:13px;padding:12px;margin-bottom:14px;background:rgba(20,60,70,.5)}
.plan.best .head{background:var(--grad-teal);color:#042020}
.plan .head .nm{font-size:16px;font-weight:800;margin-bottom:4px}
.plan .head .pr{font-size:13px;font-weight:700}
.plan ul{list-style:none;width:100%;margin-bottom:16px;flex:1;font-size:12.5px}
.plan ul li{display:flex;gap:8px;flex-direction:row-reverse;justify-content:flex-start;padding:5px 0;color:var(--dim)}
.plan ul li .ck{color:var(--teal)}
.plan .btn{width:100%;justify-content:center;font-size:13px;padding:10px}
.payc{max-width:340px;text-align:center;padding:36px 28px}
.spin{width:54px;height:54px;border-radius:50%;border:4px solid rgba(52,200,184,.18);border-top-color:var(--teal);margin:0 auto 18px;animation:sp 1s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.scheck{width:66px;height:66px;border-radius:50%;background:rgba(45,229,138,.12);border:2px solid var(--green);display:grid;place-items:center;color:var(--green);margin:0 auto 16px}

/* register glass popup */
.regov{background:rgba(5,11,17,.93);backdrop-filter:blur(13px) saturate(1.1);-webkit-backdrop-filter:blur(13px) saturate(1.1)}
.regov .glasscard{width:min(460px,94vw);background:rgba(14,30,42,.5);backdrop-filter:blur(24px) saturate(1.3);-webkit-backdrop-filter:blur(24px) saturate(1.3);border:1px solid rgba(52,200,184,.28);border-radius:30px;padding:34px 28px;text-align:center;box-shadow:0 30px 80px -20px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.05) inset;animation:rise .5s cubic-bezier(.2,.9,.25,1) both}
@keyframes rise{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
.gsphere{position:relative;width:min(82vw,340px);aspect-ratio:1;margin:0 auto 8px}
.gsphere canvas{width:100%;height:100%;display:block}
.gring{position:absolute;inset:9%;border-radius:50%;border:3px solid transparent;border-top-color:rgba(52,200,184,.65);border-right-color:rgba(52,200,184,.25);animation:sp 1.05s linear infinite;pointer-events:none}
.regov h2{font-size:19px;font-weight:800;margin-top:8px;transition:color .4s}
.regov p{font-size:13px;color:var(--dim);margin-top:7px;max-width:32ch;margin-inline:auto}

/* WELCOME */
.wsheet{max-width:430px;text-align:right;padding:20px}
.wsheet .wtop{text-align:center;margin-bottom:12px}
.wicon-emblem{height:52px;width:52px;margin:0 auto 7px;display:block}
.wsheet h2{font-size:18px;font-weight:800;margin-bottom:3px}
.wsheet .wsub{color:var(--dim);font-size:12.5px}
.why{background:rgba(255,194,75,.08);border:1px solid rgba(255,194,75,.25);border-radius:13px;padding:11px 13px;margin-bottom:10px;font-size:12.5px;line-height:1.7}
.why b{color:var(--amber)}
.steps{display:flex;flex-direction:column;gap:8px;margin-bottom:11px}
.stp{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line2);border-radius:12px;padding:10px 12px}
.stp .num{width:30px;height:30px;border-radius:50%;background:var(--grad-teal);color:#042020;font-weight:800;display:grid;place-items:center;flex-shrink:0;font-size:14px}
.stp .stx{font-size:12.5px;line-height:1.55} .stp .stx b{color:var(--green)}
.warnline{display:flex;gap:9px;align-items:flex-start;font-size:12px;color:var(--dim);background:rgba(255,107,120,.08);border-radius:11px;padding:9px 12px;margin-bottom:12px;line-height:1.6}
.warnline svg{color:var(--red);flex-shrink:0;margin-top:2px}

.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%,80px);background:var(--panel);border:1px solid var(--green);border-radius:30px;padding:11px 22px;font-size:14px;font-weight:700;display:flex;gap:9px;align-items:center;box-shadow:0 14px 30px -10px rgba(0,0,0,.7);z-index:80;opacity:0;transition:.3s;color:var(--txt)}
.toast.show{transform:translate(-50%,0);opacity:1} .toast svg{color:var(--green)}
@media(max-width:760px){.iprow{flex-direction:column}}

/* ===== mobile ===== */
@media(max-width:600px){
  .app{padding:12px}
  .top{gap:8px}
  .logo{font-size:16px}
  .logo .o{width:26px;height:26px}
  .pill{padding:7px 11px;font-size:12px}
  .av{width:36px;height:36px}
  .guide{padding:13px;gap:11px}
  .guide .gi{width:40px;height:40px}
  .guide .gt b{font-size:14px}
  .guide .gt span{font-size:12px}
  .guide .btn{padding:9px 13px;font-size:12px;white-space:nowrap}
  .planbar{padding:16px;flex-direction:column;align-items:stretch;gap:13px}
  .planbar .btn.gold{width:100%;justify-content:center}
  .pbar{max-width:none}
  .panel{padding:14px}
  .dnshero .sec-title h2{font-size:17px}
  .dnshero .sec-title p{font-size:11.5px}
  .dnshero .sec-title .icn{width:40px;height:40px}
  .dnshero .card-inner{padding:18px 15px}
  .dnshero .hip{font-size:29px}
  .dnshero .ip-cap{font-size:10px}
  .dnshero .meta-row{gap:10px;margin:10px 0 14px}
  .dnshero .pingv .val{font-size:22px}
  .dnshero .cbtn{font-size:14px;padding:13px}
  .ipbig-card{padding:20px 14px}
  .ipbig-card .ipbig{font-size:27px}
  .status2{font-size:12.5px;padding:11px}
  .recrow{gap:10px;padding:11px 12px}
  .recrow .ri{width:34px;height:34px}
  .recrow .rmain b{font-size:13px}
  .recrow .rmain small{font-size:11px}
  .recrow .rip{font-size:12.5px}
  .reccount{font-size:10px}
  .lcard{padding:30px 22px;border-radius:22px}
  .lcard .nm{font-size:16px}
  .wsheet h2{font-size:18px}
  .why,.stp .stx,.warnline span{font-size:13px}
  .glasscard{padding:26px 20px}
  .gsphere{width:min(72vw,260px)}
}
@media(max-width:380px){
  .dnshero .hip{font-size:24px}
  .ipbig-card .ipbig{font-size:24px}
  .recrow .rnum{display:none}
  .dnshero .region,.dnshero .sub{font-size:11px}
}

/* ===== theme toggle button ===== */
.themebtn{width:42px;height:42px;border-radius:12px;border:1px solid var(--line2);background:var(--panel);color:var(--teal);cursor:pointer;display:grid;place-items:center;transition:.2s;flex-shrink:0}
.themebtn:hover{border-color:var(--teal);transform:rotate(15deg)}
.themebtn-fixed{position:fixed;top:16px;left:16px;z-index:85;box-shadow:0 8px 24px -10px rgba(0,0,0,.4)}
.themebtn .ic-sun{display:none}
[data-theme="light"] .themebtn .ic-moon{display:none}
[data-theme="light"] .themebtn .ic-sun{display:block}
.brand{display:flex;align-items:center;gap:9px;direction:ltr}
.emblem{height:42px;width:42px;object-fit:contain;mix-blend-mode:screen;flex-shrink:0}
.emblem-lg{height:70px;width:70px;margin:0 auto 10px}
[data-theme="light"] .emblem{filter:invert(1);mix-blend-mode:multiply}
.logo-img{height:26px;width:auto;display:block}
.lcard-logo{height:30px;margin:0 auto 18px}
[data-theme="light"] .logo-img{filter:invert(1) brightness(.82)}
@media(max-width:600px){.themebtn{width:38px;height:38px}.logo-img{height:23px}.emblem{height:38px;width:38px}.top{gap:7px}.lcard-logo{height:27px}.emblem-lg{height:60px;width:60px}}

/* ===== LIGHT THEME ===== */
[data-theme="light"]{
  --bg0:#eef3f2; --panel:#ffffff; --panel2:#f4f9f8; --card:#f6fbfa;
  --line:#d8e5e1; --line2:#c2d7d1;
  --txt:#102228; --dim:#557570; --mut:#8aa39d;
  --teal:#129488; --teal2:#1f8fa6; --green:#15a866; --gold:#cf8a26;
}
[data-theme="light"] body::before{background:
  radial-gradient(900px 600px at 92% -5%,rgba(40,175,160,.14),transparent 55%),
  radial-gradient(700px 700px at 100% 100%,rgba(30,150,150,.08),transparent 55%),
  linear-gradient(160deg,#eef3f2,#e7f1ef 60%,#eef3f2)}
[data-theme="light"] .stars{opacity:.2}
[data-theme="light"] .planbar{background:linear-gradient(110deg,#ffffff,#eef7f4)}
[data-theme="light"] .pbar{background:#e6efec}
[data-theme="light"] .inp,[data-theme="light"] .otp input{background:#f1f7f5}
[data-theme="light"] .av{background:linear-gradient(135deg,#dfeae7,#eef5f3);color:var(--dim)}
[data-theme="light"] .dnshero .card{background:linear-gradient(160deg,var(--line2),rgba(220,233,229,.6) 45%,var(--line2))}
[data-theme="light"] .dnshero .card-inner{background:linear-gradient(170deg,#ffffff,#f2faf8)}
[data-theme="light"] .ipbig-card{background:linear-gradient(160deg,#ffffff,#f2faf8)}
[data-theme="light"] .dnshero .hip,[data-theme="light"] .dnshero .card.reco .hip,[data-theme="light"] .ipbig-card .ipbig{background:linear-gradient(135deg,#0e8a7d,#11a890 55%,#0c95a2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:none}
[data-theme="light"] .dnshero .region,[data-theme="light"] .dnshero .cbtn.ghost{background:rgba(0,0,0,.035)}
[data-theme="light"] .status2.ok{color:#0a7d4e}
[data-theme="light"] .status2.warn{color:#c43d4a}
[data-theme="light"] .guide .gt b{color:#c43d4a}
[data-theme="light"] .guide .gt span b{color:#0a7d4e}
[data-theme="light"] .warnline span b{color:#c43d4a}
[data-theme="light"] .st-old{background:#eef3f1}
[data-theme="light"] .plan{background:linear-gradient(160deg,#f5faf8,#eef6f4)}
[data-theme="light"] .plan .head{background:#eef6f4}
[data-theme="light"] .panel,[data-theme="light"] .planbar,[data-theme="light"] .dnshero .card,[data-theme="light"] .guide{box-shadow:0 10px 26px -16px rgba(15,55,48,.3)}
[data-theme="light"] .cbtn.ghost,[data-theme="light"] .dnshero .copy-both .cbtn{background:rgba(18,148,136,.09);border-color:rgba(18,148,136,.4);color:#0d7d72}
[data-theme="light"] .lockbar{background:rgba(207,138,38,.12);border-color:rgba(207,138,38,.4);color:#92610f}
[data-theme="light"] .region{background:rgba(0,0,0,.045)}
[data-theme="light"] .recrow,[data-theme="light"] .dns,[data-theme="light"] .ipnow{border-color:var(--line2)}
[data-theme="light"] #regOv{background:rgba(214,230,226,.72)}
[data-theme="light"] .glasscard{background:rgba(255,255,255,.78);border-color:rgba(18,148,136,.28);box-shadow:0 30px 80px -22px rgba(18,70,60,.3)}
[data-theme="light"] .gring{border-top-color:rgba(18,148,136,.7);border-right-color:rgba(18,148,136,.28)}
[data-theme="light"] .radar{opacity:.6}
[data-theme="light"] .radar span{animation-name:radarLight}
[data-theme="light"] .phpop{background:rgba(255,255,255,.72);border-color:rgba(18,148,136,.28);box-shadow:0 18px 50px -20px rgba(18,70,60,.28)}
[data-theme="light"] .dnshero .mobdns{background:linear-gradient(160deg,rgba(18,148,136,.07),rgba(31,134,176,.04))}
[data-theme="light"] .dnshero .mobdns-row{background:rgba(0,0,0,.025)}
[data-theme="light"] .dnshero .copyhint{background:rgba(0,0,0,.035)}
