*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
--bg:#000000;--card:#111115;--border:#222230;--text:#e8e8ed;--text2:#8a8a99;
--accent1:#7c5bf5;--accent2:#5b8cf5;--green:#34d399;--red:#f87171;--yellow:#fbbf24;
--grad:linear-gradient(135deg,#7c5bf5,#5b8cf5);
}
html,body{height:100%;overflow:hidden}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
.app{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:480px;margin:0 auto;position:relative;overflow:hidden}
.header{padding:18px 20px 14px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border);flex-shrink:0;background:rgba(0,0,0,0.7);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10;position:sticky;top:0}
.logo{display:flex;align-items:center;gap:0}
.logo svg{display:none}
.logo-text{font-family:'Unbounded',sans-serif;font-size:26px;font-weight:900;letter-spacing:2px;color:#fff}
.logo-badge{display:none}
.header-status{display:none}
.header-status .dot{width:7px;height:7px;border-radius:50%}

/* Quick tiles row */
.quick-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding-bottom:14px}
.quick-tile{aspect-ratio:1;border-radius:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s;position:relative;overflow:hidden;border:none;background:var(--card)}
.quick-tile:active{transform:scale(.96)}
.quick-tile-icon{display:none}
.quick-tile-label{display:none}
.quick-tile img{width:100%;height:100%;object-fit:cover;border-radius:18px;pointer-events:none}
.quick-tile-skel{aspect-ratio:1;border-radius:18px;background:linear-gradient(90deg,#1a1a2e 25%,#2a2a45 50%,#1a1a2e 75%);background-size:200% 100%;animation:shimmer 1.4s linear infinite}

/* Bento grid — 2 left + 1 right tall */
.bento{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:12px;margin-bottom:14px;position:relative}

/* Glass card base */
.bento-glass{border-radius:20px;padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;transition:transform .15s;overflow:hidden;position:relative;background:rgba(255,255,255,.04);border:none;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.bento-glass:active{transform:scale(.97)}

/* VPN power button */
.bento-vpn{grid-column:1;grid-row:1;background:#1a1a22;backdrop-filter:none;-webkit-backdrop-filter:none}
.bento-power{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease;margin-bottom:10px}
.bento-power.off{background:rgba(255,255,255,.05);border:2px solid rgba(255,255,255,.1)}
.bento-power.off svg{stroke:#444}
.bento-power.on{background:rgba(52,211,153,.1);border:2px solid rgba(52,211,153,.25);box-shadow:0 0 24px rgba(52,211,153,.12)}
.bento-power.on svg{stroke:#34d399}
@keyframes powerPulse{0%,100%{box-shadow:0 0 24px rgba(52,211,153,.12)}50%{box-shadow:0 0 32px rgba(52,211,153,.22)}}
.bento-power.on{animation:powerPulse 2.5s ease-in-out infinite}
.bento-vpn-title{font-size:13px;font-weight:700;color:#fff;line-height:1.3}
.bento-vpn-sub{font-size:10px;color:var(--text2);margin-top:4px}

/* Referral — wrapper with blurred glow behind */
.bento-ref-wrap{grid-column:1;grid-row:2;position:relative;overflow:visible}
.bento-ref{background:linear-gradient(135deg,#e85d4a,#f0836f)!important;border:none!important;width:100%;height:100%;position:relative;z-index:1;justify-content:space-between!important;padding:14px 12px!important;overflow:hidden}
.bento-ref::before{content:'';position:absolute;inset:-4px;background:url('tiles/tile-referral.webp') center 60%/cover no-repeat;animation:handshake 1.8s ease-in-out infinite;transform-origin:center center;pointer-events:none;z-index:0}
@keyframes handshake{0%{transform:translate(0,0) rotate(0deg)}10%{transform:translate(-1px,1px) rotate(-0.5deg)}20%{transform:translate(1px,-1px) rotate(0.5deg)}30%{transform:translate(-1px,0) rotate(-0.3deg)}40%{transform:translate(1px,1px) rotate(0.3deg)}50%{transform:translate(0,-1px) rotate(0deg)}60%{transform:translate(-1px,1px) rotate(-0.5deg)}70%{transform:translate(1px,0) rotate(0.3deg)}80%{transform:translate(0,0) rotate(0deg)}100%{transform:translate(0,0) rotate(0deg)}}
.bento-ref .bento-ref-badge{display:none}
.bento-ref .bento-ref-title{color:#fff;font-size:15px;font-weight:900;text-shadow:0 2px 6px rgba(0,0,0,.35);line-height:1.2;position:relative;z-index:1}
.bento-ref .bento-ref-sub{color:rgba(255,255,255,.85);font-size:10px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.3);margin-top:0;position:relative;z-index:1}
.bento-ref .bento-ref-level{background:rgba(0,0,0,.3);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-weight:700;border:none;text-shadow:0 1px 2px rgba(0,0,0,.3);margin-top:auto;align-self:flex-start;position:relative;z-index:1}
.bento-ref-badge{width:36px;height:36px;position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.bento-ref-badge svg{position:relative;z-index:1}
/* Sparkle particles */
.bento-ref-sparkles{position:absolute;inset:-20px;pointer-events:none}
.bento-ref-sparkle{position:absolute;width:4px;height:4px;border-radius:50%;background:#ffd700;opacity:0;box-shadow:0 0 4px currentColor}
.bento-ref-badge.has-refs .bento-ref-sparkle{animation:sparkleFloat 2.5s ease-in-out infinite}
@keyframes sparkleFloat{0%{opacity:0;transform:translate(0,0) scale(0)}15%{opacity:1;transform:scale(1.2)}50%{opacity:.8;transform:translate(calc(var(--sx)*.6),calc(var(--sy)*.6)) scale(1)}100%{opacity:0;transform:translate(var(--sx),var(--sy)) scale(0)}}
.bento-ref-title{font-size:13px;font-weight:700;color:#fff;line-height:1.3}
.bento-ref-sub{font-size:10px;color:var(--text2);margin-top:4px;font-weight:600}
.bento-ref-level{font-size:9px;color:var(--text2);margin-top:6px;padding:3px 8px;border-radius:6px;background:rgba(255,255,255,.06);display:inline-block}
.bento-ref-level b{color:#ffd700}

/* Subscription card right — Unicorn style */
.bento-sub{grid-column:2;grid-row:1/3;background:linear-gradient(160deg,#4f8cf7,#3b6de0);border:none;border-radius:20px;padding:18px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;position:relative;cursor:pointer;transition:transform .15s}
.bento-sub:active{transform:scale(.97)}
.bento-sub-header{flex:1}
.bento-sub-plan{font-size:20px;font-weight:900;color:#fff;line-height:1.2;white-space:pre-line}
.bento-sub-expires{font-size:11px;color:rgba(255,255,255,.6);margin-top:4px;font-weight:500}
.bento-sub-days{display:none;margin-top:12px}
.bento-sub-days-num{font-size:36px;font-weight:900;color:#fff;line-height:1}
.bento-sub-days-label{font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.bento-sub-progress{display:none;margin-top:10px;height:3px;border-radius:2px;background:rgba(255,255,255,.15);overflow:hidden}
.bento-sub-progress-bar{height:100%;border-radius:2px;transition:width .6s ease}
.bento-sub-traffic{display:none;font-size:11px;color:rgba(255,255,255,.6);margin-top:8px;font-weight:600}
.bento-sub-traffic b{color:#fff;font-weight:800}
.bento-sub-status{display:none;font-size:10px;color:rgba(255,255,255,.45);margin-top:4px;font-weight:500}
.bento-sub-cta{display:flex;align-items:flex-end;justify-content:flex-end;margin-top:auto}
.bento-sub-arrow{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.95);color:#3b6de0;display:flex;align-items:center;justify-content:center}
/* Plan color themes */
.bento-sub.active-sub .bento-sub-arrow{background:rgba(255,255,255,.12);color:#fff}
.bento-sub.sub-personal{background:linear-gradient(135deg,#1a6bb5,#2196F3)}
.bento-sub.sub-family{background:linear-gradient(135deg,#2e8b2e,#32cd32)}
.bento-sub.sub-trial{background:linear-gradient(135deg,#92400e,#b45309,#d97706)}
.bento-sub.sub-owner{background:linear-gradient(135deg,#059669,#10b981)}
.bento-sub.sub-expired{background:linear-gradient(160deg,#dc2626,#b91c1c,#ef4444)}
.bento-sub.sub-family-member{background:linear-gradient(160deg,#6366f1,#4f46e5,#818cf8)}
.bento-skel{border-radius:20px;background:linear-gradient(90deg,#1a1a2e 25%,#2a2a45 50%,#1a1a2e 75%);background-size:200% 100%;animation:shimmer 1.4s linear infinite}

/* Server card locked state */
.server-card.locked{position:relative;pointer-events:none}
.server-card.locked .server-split,.server-card.locked #deviceSubRow{filter:blur(6px);opacity:.4}
.server-card-lock{display:none;position:absolute;inset:0;z-index:5;flex-direction:column;align-items:center;justify-content:center;gap:6px;border-radius:16px}
.server-card.locked .server-card-lock{display:flex}
.server-card-lock svg{opacity:.5}
.server-card-lock span{font-size:13px;font-weight:700;color:var(--text2)}

.content{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 16px 8px;-webkit-overflow-scrolling:touch}
.content::-webkit-scrollbar{display:none}
.tab-content{display:none;animation:fadeUp .35s ease}
.tab-content.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Skeleton shimmer for loading values */
.skel-block{display:block;background:linear-gradient(90deg,#1a1a2e 25%,#2a2a45 50%,#1a1a2e 75%);background-size:200% 100%;animation:shimmer 1.4s linear infinite;border-radius:12px}
/* Full-page skeleton overlay */
#homeSkeleton{position:relative;z-index:10}
#tab-home{position:relative}
#tab-home.loading>*:not(#homeSkeleton){display:none!important}
#tab-home.loading>#homeSkeleton{display:block!important}
.app.skeleton-loading .tabbar{display:none!important}
.skeleton{color:transparent!important;-webkit-text-fill-color:transparent!important;background:linear-gradient(90deg,#1e1e2a 25%,#33334a 50%,#1e1e2a 75%)!important;background-size:200% 100%!important;animation:shimmer 1.4s linear infinite!important;border-radius:8px!important;min-width:48px;min-height:1.2em;display:inline-block}
.skeleton *{visibility:hidden}
.status-label.skeleton{min-width:110px}

/* Wave entrance for home cards — each starts invisible, JS reveals one by one */
#tab-home>.ref-banner,#tab-home>.card,#tab-home>#noKeyBlock,#tab-home>#hasKeyBlock,#tab-home>#familyManageBlock,#tab-home>#familyViewBlock,#tab-home>.greeting,#tab-home>.quick-tiles,#tab-home>.bento{opacity:0;transform:translateY(22px)}
.wave-card{opacity:0;transform:translateY(18px)}
.wave-card.visible{opacity:1!important;transform:translateY(0)!important;transition:opacity .55s cubic-bezier(.16,1,.3,1),transform .55s cubic-bezier(.16,1,.3,1)!important}

.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;margin-bottom:12px;transition:all .2s}

/* Server card — split layout: map left, info right, light blue */
.server-card{display:flex;flex-direction:column;overflow:hidden;padding:0;position:relative;border-color:var(--border);background:var(--card)}
.server-split{display:flex;min-height:130px}
.server-map-side{width:33%;max-width:160px;min-width:100px;min-height:140px;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border-right:1px solid var(--border)}
.server-map-contour{width:100%;height:100%}
.server-info-side{flex:1;padding:14px 20px 14px 16px;display:flex;flex-direction:column;justify-content:center;gap:10px}
.server-info-top{display:flex;align-items:flex-start;justify-content:space-between}
.server-country{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.2px}
.server-proto{font-size:9px;color:var(--text2);font-weight:600;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.server-status{width:10px;height:10px;flex-shrink:0;margin-top:4px}
.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.status-dot.online{background:#4ade80;box-shadow:0 0 10px #4ade8080,0 0 20px #4ade8040;animation:pulse 2s infinite}
.status-dot.offline{background:var(--red);box-shadow:0 0 10px #f8717180}
.server-metrics-col{display:flex;flex-direction:column;gap:6px}
.server-metric-row{display:flex;align-items:center;gap:6px}
.server-metric-label{font-size:10px;color:var(--text2);font-weight:600;flex:1}
.server-metric-val{font-size:14px;font-weight:800;font-family:'Inter',monospace;color:#fff;text-align:right;margin-left:auto}
.speed-unit{font-size:8px;font-weight:600;color:var(--text2);letter-spacing:.3px}
.speed-measuring{animation:speedDots 1.2s infinite}
@keyframes speedDots{0%,20%{opacity:.2}50%{opacity:1}80%,100%{opacity:.2}}
@keyframes devPulse{0%{box-shadow:0 0 0 0 #ef444480}70%{box-shadow:0 0 0 8px #ef444400}100%{box-shadow:0 0 0 0 #ef444400}}
.server-traffic-inline{display:flex;gap:12px;margin-top:2px}
.server-traffic-compact{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.server-traffic-item{display:flex;align-items:center;gap:3px;font-size:10px;font-weight:700;color:#ffffff60}
.server-help-btn{width:22px;height:22px;border-radius:50%;background:#ffffff15;border:1px solid #ffffff25;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .2s}
.server-help-btn:active{background:#ffffff15}
.server-help-btn svg{width:12px;height:12px}
.info-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s;display:flex;align-items:flex-end;justify-content:center}
.info-overlay.open{opacity:1;pointer-events:auto}
.info-sheet{width:100%;max-width:420px;background:var(--card);border-radius:20px 20px 0 0;padding:20px 20px 32px;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1)}
.info-overlay.open .info-sheet{transform:translateY(0)}
.info-sheet-handle{width:36px;height:4px;border-radius:2px;background:#ffffff20;margin:0 auto 16px}
.info-sheet h3{font-size:16px;font-weight:800;margin-bottom:14px;color:#fff}
.info-section{margin-bottom:14px}
.info-section-title{font-size:12px;font-weight:700;color:var(--accent);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.info-section p{font-size:12px;color:var(--text2);line-height:1.5;margin:0}

.greeting{font-size:16px;font-weight:700;margin-bottom:14px}
.greeting-sub{font-size:12px;color:var(--text2);font-weight:500;margin-left:6px}

.sub-card{display:flex;align-items:center;gap:14px;border-color:#7c5bf530}
.sub-card-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#7c5bf520,#5b8cf515);border:1px solid #7c5bf530;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sub-card-info{flex:1}
.sub-card-title{font-size:14px;font-weight:700;margin-bottom:2px}
.sub-card-desc{font-size:12px;color:var(--text2)}
.sub-card-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:8px;flex-shrink:0}
.sub-card-badge.active{background:#34d39915;color:var(--green);border:1px solid #34d39930}

.traffic-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.traffic-item{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center}
.traffic-val{font-size:18px;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.traffic-label{font-size:10px;color:var(--text2);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}

.btn-primary{width:100%;padding:15px;border:none;border-radius:14px;background:var(--grad);color:#fff;font-size:15px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;position:relative;overflow:hidden}
.btn-primary:active{transform:scale(.98);opacity:.9}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#fff2,transparent);pointer-events:none}
.btn-secondary{width:100%;padding:13px;border:1px solid var(--border);border-radius:12px;background:var(--card);color:var(--text);font-size:14px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}
.btn-secondary:active{transform:scale(.98);background:#22222a}
.btn-sm{padding:10px 16px;font-size:13px;border-radius:10px;width:auto}
.btn-copy{background:linear-gradient(135deg,#7c5bf515,#5b8cf510);border:1px solid #7c5bf540;color:var(--accent2)}
.btn-copy.copied{border-color:var(--green);color:var(--green);background:#34d39910}
.btn-trial{width:100%;padding:14px;border:none;border-radius:12px;background:linear-gradient(135deg,#667eea,#5a67d8,#7c5bf5);color:#fff;font-size:14px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;position:relative;overflow:hidden;transition:all .2s}
.btn-trial:active{transform:scale(.98);opacity:.9}
.btn-trial:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-trial::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,#fff3,transparent);animation:trialShimmer 2.5s ease-in-out infinite}
@keyframes trialShimmer{0%{left:-100%}50%{left:120%}100%{left:120%}}

.key-card{border-color:#7c5bf540}
.key-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.key-title{font-size:15px;font-weight:700}
.key-active{font-size:11px;font-weight:600;color:var(--green);background:#34d39915;border:1px solid #34d39930;padding:2px 8px;border-radius:6px}
.key-proto{font-size:11px;color:var(--text2);margin-bottom:14px}
.key-actions{display:flex;flex-direction:column;gap:8px}
.qr-wrap{background:#fff;border-radius:12px;padding:16px;margin-top:12px;display:flex;justify-content:center;display:none}
.qr-wrap.show{display:flex;animation:fadeUp .3s ease}
.qr-wrap canvas,.qr-wrap img{border-radius:4px}

.setup-guide{margin-top:12px;border:1px solid var(--border);border-radius:14px;background:var(--card);overflow:hidden;max-height:0;opacity:0;transform:translateY(16px);transition:max-height .5s cubic-bezier(.4,0,.2,1),opacity .4s ease,transform .4s ease;pointer-events:none}
.setup-guide.show{max-height:500px;opacity:1;transform:translateY(0);pointer-events:auto}
.setup-guide-title{font-size:13px;font-weight:700;padding:14px 16px 0;color:var(--text);display:flex;align-items:center;gap:8px}
.setup-guide-title svg{flex-shrink:0}
.setup-guide-tabs{display:flex;gap:6px;padding:10px 16px 0;flex-wrap:wrap}
.sg-tab{padding:6px 12px;border-radius:8px;font-size:11px;font-weight:600;border:1px solid var(--border);background:transparent;color:var(--text2);cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s}
.sg-tab.active{background:var(--grad);border-color:transparent;color:#fff}
.sg-tab:active{transform:scale(.96)}
.sg-body{padding:12px 16px 14px}
.sg-steps{display:flex;flex-direction:column;gap:2px}
.sg-dl{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:linear-gradient(135deg,#7c5bf510,#5b8cf508);border:1px solid #7c5bf525;cursor:pointer;margin-bottom:8px;transition:all .2s}
.sg-dl:active{transform:scale(.98);opacity:.8}
.sg-dl-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--grad);flex-shrink:0}
.sg-dl-text{flex:1}
.sg-dl-name{font-size:12px;font-weight:600;color:var(--text)}
.sg-dl-sub{font-size:10px;color:var(--text2);margin-top:1px}
.sg-dl-arrow{color:var(--text2)}
.sg-dl.green{background:linear-gradient(135deg,#34d39910,#05966908);border-color:#34d39925}
.sg-dl.green .sg-dl-icon{background:linear-gradient(135deg,#059669,#34d399)}

.dl-card{display:flex;align-items:center;gap:14px;cursor:pointer}
.dl-card:active{transform:scale(.99)}
.dl-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dl-icon.ios{background:linear-gradient(135deg,#333,#1a1a1a);border:1px solid #444}
.dl-icon.android{background:linear-gradient(135deg,#1b3a1b,#0d1f0d);border:1px solid #2a4a2a}
.dl-icon.windows{background:linear-gradient(135deg,#1a2540,#0d1520);border:1px solid #2a3550}
.dl-icon.macos{background:linear-gradient(135deg,#2a2030,#1a1520);border:1px solid #3a2a45}
.dl-info{flex:1}
.dl-name{font-size:14px;font-weight:600;margin-bottom:2px}
.dl-app{font-size:12px;color:var(--text2)}
.dl-btn{padding:8px 16px;border-radius:10px;background:var(--grad);border:none;color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;flex-shrink:0}
.dl-btn:active{opacity:.8}

.acc{border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:8px;background:var(--card)}
.acc-head{padding:16px 18px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}
.acc-head-left{display:flex;align-items:center;gap:10px}
.acc-head-left span{font-size:14px;font-weight:600}
.acc-chevron{transition:transform .25s;flex-shrink:0}
.acc.open .acc-chevron{transform:rotate(90deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.acc.open .acc-body{max-height:500px}
.acc-inner{padding:0 18px 16px}
.step{display:flex;gap:12px;padding:8px 0}
.step-num{width:24px;height:24px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;margin-top:1px}
.step-text{font-size:13px;color:var(--text2);line-height:1.55}

.avatar-area{display:flex;flex-direction:column;align-items:center;gap:10px;padding:8px 0 16px}
.avatar{width:64px;height:64px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;color:#fff}
.avatar-name{font-size:18px;font-weight:700}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid #2a2a3520}
.info-row:last-child{border-bottom:none}
.info-label{font-size:13px;color:var(--text2);display:flex;align-items:center;gap:8px}
.info-val{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;text-align:right;max-width:55%}

.sec-title{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.sec-sub{font-size:13px;color:var(--text2);margin-bottom:16px;line-height:1.5}

.plan-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;margin-bottom:12px;cursor:pointer;transition:all .3s;position:relative}
.plan-card:active{transform:scale(.99)}
.plan-card.selected{border-color:var(--accent1);background:linear-gradient(135deg,#7c5bf508,#5b8cf506);box-shadow:0 0 24px #7c5bf520,inset 0 0 0 1px #7c5bf530}
.plan-name{font-size:17px;font-weight:800;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.plan-desc{font-size:12px;color:var(--text2);margin-bottom:10px}
.plan-price{font-size:28px;font-weight:800;margin-top:8px}
.plan-price span{font-size:13px;font-weight:500;color:var(--text2)}
.plan-badge{position:absolute;top:14px;right:14px;font-size:10px;font-weight:700;padding:4px 10px;border-radius:8px}
.plan-badge.popular{background:linear-gradient(135deg,#7c5bf530,#667eea20);color:#a78bfa;border:1px solid #7c5bf540}
.plan-badge.corp{background:linear-gradient(135deg,#f59e0b20,#f9731618);color:#fbbf24;border:1px solid #f59e0b40}
.plan-features{list-style:none;padding:0;margin:0 0 4px}
.plan-features li{font-size:12px;color:var(--text2);padding:3px 0;display:flex;align-items:flex-start;gap:8px;line-height:1.4}
.plan-features li::before{content:'';display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent1);flex-shrink:0;margin-top:5px}
.plan-features .accent{color:var(--accent2);font-weight:600}
.dur-tabs{display:flex;gap:6px;margin-bottom:16px;background:var(--card);border-radius:12px;padding:4px;border:1px solid var(--border)}
.dur-tab{flex:1;text-align:center;padding:8px 4px;border-radius:10px;cursor:pointer;font-size:12px;font-weight:600;color:var(--text2);transition:all .2s;position:relative}
.dur-tab:active{transform:scale(.97)}
.dur-tab.active{background:var(--grad);color:#fff}
.dur-tab .dur-save{display:block;font-size:9px;font-weight:700;color:var(--green);margin-top:2px}
.dur-tab.active .dur-save{color:#a7f3d0}
.plan-old-price{font-size:13px;color:var(--text2);text-decoration:line-through;margin-right:6px;font-weight:500}
.plan-total{font-size:11px;color:var(--text2);margin-top:4px}
/* Wizard */
@keyframes wizSlideIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes wizSlideOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-30px)}}
@keyframes wizFadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.wiz-step-enter{animation:wizSlideIn .3s ease forwards}
.wiz-step-exit{animation:wizSlideOut .2s ease forwards}
.wiz-cards{display:flex;flex-direction:column;gap:10px}
.wiz-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column;gap:4px;animation:wizFadeUp .3s ease backwards}
.wiz-card:nth-child(2){animation-delay:.08s}
.wiz-card:nth-child(3){animation-delay:.16s}
.wiz-card:active{transform:scale(.98);opacity:.9}
.wiz-card.selected{border-color:var(--border);background:var(--card)}
.wiz-card.popular{border-color:#7c5bf560;background:linear-gradient(135deg,#7c5bf518,#667eea10);box-shadow:0 0 20px #7c5bf515,inset 0 1px 0 #ffffff08}
.wiz-card.popular.selected{border-color:#7c5bf560;background:linear-gradient(135deg,#7c5bf518,#667eea10);box-shadow:0 0 20px #7c5bf515}
#wizPersonal{background:linear-gradient(135deg,#1a6bb5,#2196F3);overflow:hidden;border:none;min-height:180px;padding:16px 18px;background:url('tiles/Lone.webp') right center/cover no-repeat,linear-gradient(135deg,#1a6bb5,#2196F3)}
#wizPersonal.selected{background:url('tiles/Lone.webp') right center/cover no-repeat;border:2px solid var(--accent)}
#wizPersonal .wiz-card-icon{display:none}
#wizPersonal .wiz-card-title{color:#fff;font-size:20px;font-weight:900;text-shadow:0 2px 8px rgba(0,0,0,.4);position:relative;z-index:1}
#wizPersonal .wiz-card-desc{color:rgba(255,255,255,.85);font-size:12px;text-shadow:0 1px 4px rgba(0,0,0,.3);position:relative;z-index:1}
#wizPersonal .wiz-card-price{color:#fff;font-size:13px;text-shadow:0 1px 4px rgba(0,0,0,.3);position:relative;z-index:1;margin-top:4px}
#wizPersonal .wiz-card-price b{color:#fff;font-size:36px;font-weight:900;text-shadow:0 2px 12px rgba(0,0,0,.35)}
#wizPersonal .wiz-card-features{position:relative;z-index:1;max-width:55%}
#wizPersonal .wiz-card-features span{background:rgba(255,255,255,.35);color:#fff;border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);text-shadow:0 1px 3px rgba(0,0,0,.4);font-weight:600}
#wizFamily{background:linear-gradient(135deg,#2eb82e,#32cd32);overflow:hidden;border:none;min-height:180px;padding:16px 18px;align-items:flex-end;background:url('tiles/Family.webp') left center/cover no-repeat,linear-gradient(135deg,#2eb82e,#32cd32)}
#wizFamily.selected{background:url('tiles/Family.webp') left center/cover no-repeat;border:2px solid var(--accent)}
#wizFamily .wiz-card-icon{display:none}
#wizFamily .wiz-card-title{color:#fff;font-size:20px;font-weight:900;text-shadow:0 2px 8px rgba(0,0,0,.4);position:relative;z-index:1;text-align:right}
#wizFamily .wiz-card-desc{color:rgba(255,255,255,.85);font-size:9px;text-shadow:0 1px 4px rgba(0,0,0,.3);position:relative;z-index:1;text-align:right;max-width:45%}
#wizFamily .wiz-card-price{color:#fff;font-size:13px;text-shadow:0 1px 4px rgba(0,0,0,.3);position:relative;z-index:1;margin-top:4px;text-align:right}
#wizFamily .wiz-card-price b{color:#fff;font-size:36px;font-weight:900;text-shadow:0 2px 12px rgba(0,0,0,.35)}
#wizFamily .wiz-card-subtitle{color:rgba(255,255,255,.9);text-shadow:0 1px 4px rgba(0,0,0,.3);position:relative;z-index:1;text-align:right}
#wizFamily .wiz-popular-tag{align-self:flex-end}
#wizFamily .wiz-card-features{position:relative;z-index:1;justify-content:flex-end}
#wizFamily .wiz-card-features span{background:rgba(255,255,255,.35);color:#fff;border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);text-shadow:0 1px 3px rgba(0,0,0,.4);font-weight:600}
#wizCorporate{background:linear-gradient(135deg,#8b2252,#a0306a);overflow:hidden;border:none;min-height:180px;padding:16px 18px;background:url('tiles/Corp.webp') right center/cover no-repeat,linear-gradient(135deg,#8b2252,#a0306a)}
#wizCorporate.selected{background:url('tiles/Corp.webp') right center/cover no-repeat;border:2px solid var(--accent)}
#wizCorporate .wiz-card-icon{display:none}
#wizCorporate .wiz-card-title{color:#fff;font-size:20px;font-weight:900;text-shadow:0 2px 8px rgba(0,0,0,.4);position:relative;z-index:1}
#wizCorporate .wiz-card-desc{color:rgba(255,255,255,.85);font-size:12px;text-shadow:0 1px 4px rgba(0,0,0,.3);position:relative;z-index:1}
#wizCorporate .wiz-card-price{color:#fff;font-size:13px;text-shadow:0 1px 4px rgba(0,0,0,.3);position:relative;z-index:1;margin-top:4px}
#wizCorporate .wiz-card-price b{color:#fff;font-size:36px;font-weight:900;text-shadow:0 2px 12px rgba(0,0,0,.35)}
#wizCorporate .wiz-card-features{position:relative;z-index:1;max-width:55%}
#wizCorporate .wiz-card-features span{background:rgba(255,255,255,.35);color:#fff;border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);text-shadow:0 1px 3px rgba(0,0,0,.4);font-weight:600}
.wiz-popular-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff;background:linear-gradient(135deg,#7c5bf5,#667eea);border-radius:8px;padding:5px 14px;width:fit-content;position:relative;z-index:1}
.wiz-popular-tag.pulse{animation:popularPulse 2s ease-in-out infinite}
@keyframes popularPulse{0%,100%{box-shadow:0 0 0 0 rgba(124,91,245,.5)}50%{box-shadow:0 0 0 8px rgba(124,91,245,0)}}
.wiz-card-subtitle{font-size:12px;color:#a78bfa;font-weight:600;margin-top:2px}
.wiz-card-icon{color:var(--accent2);margin-bottom:2px}
.wiz-card.popular .wiz-card-icon{color:#a78bfa}
.wiz-card-title{font-size:18px;font-weight:800;color:#fff}
.wiz-card-desc{font-size:13px;color:var(--text2)}
.wiz-card-price{font-size:13px;color:var(--text2);margin-top:2px}
.wiz-card-price b{font-size:18px;color:#4ade80;font-weight:800}
.wiz-card-features{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.wiz-card-features span{font-size:10px;color:var(--text2);background:#ffffff08;border:1px solid #ffffff10;border-radius:6px;padding:3px 8px}
.wiz-back{background:none;border:1px solid var(--border);border-radius:10px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .2s}
.wiz-back:active{background:#ffffff10}
.wiz-dur-list{display:flex;flex-direction:column;gap:8px}
.wiz-dur-item{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:space-between;animation:wizFadeUp .3s ease backwards}
.wiz-dur-item:nth-child(2){animation-delay:.06s}
.wiz-dur-item:nth-child(3){animation-delay:.12s}
.wiz-dur-item:nth-child(4){animation-delay:.18s}
.wiz-dur-item:active{transform:scale(.98)}
.wiz-dur-item.selected{border-color:var(--border);background:var(--card)}
.wiz-dur-item.best{border-color:#4ade8040}
.wiz-dur-left{display:flex;flex-direction:column;gap:2px}
.wiz-dur-period{font-size:15px;font-weight:700;color:#fff}
.wiz-dur-monthly{font-size:12px;color:var(--text2)}
.wiz-dur-right{text-align:right}
.wiz-dur-total{font-size:16px;font-weight:800;color:#fff}
.wiz-dur-save{font-size:11px;font-weight:700;color:#4ade80;margin-top:2px}
.wiz-summary{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px}
.wiz-sum-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #ffffff08}
.wiz-sum-row:last-child{border-bottom:none}
.wiz-sum-label{font-size:13px;color:var(--text2)}
.wiz-sum-val{font-size:13px;font-weight:700;color:#fff}
.wiz-sum-total{display:flex;justify-content:space-between;padding:12px 0 0;margin-top:4px;border-top:1px solid var(--border)}
.wiz-sum-total .wiz-sum-label{font-size:15px;font-weight:700;color:#fff}
.wiz-sum-total .wiz-sum-val{font-size:20px;font-weight:900;color:#4ade80}
.wiz-buy-btn{width:100%;margin-top:14px;padding:14px;border:none;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;background:linear-gradient(135deg,#34d399,#059669);color:#fff;transition:all .2s;box-shadow:0 4px 15px #34d39930}
.wiz-buy-btn:active{transform:scale(.97);opacity:.9}
.wiz-buy-btn.gift-mode{background:linear-gradient(135deg,#667eea,#4f46e5);box-shadow:0 4px 15px #4f46e530}
/* Gift toggle */
.gift-toggle{display:flex;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:3px;margin-bottom:16px;position:relative;overflow:hidden}
.gift-toggle-btn{flex:1;padding:10px 0;text-align:center;font-size:13px;font-weight:600;border:none;background:transparent;color:var(--text2);cursor:pointer;border-radius:10px;transition:all .25s ease;position:relative;z-index:1;font-family:'Inter',sans-serif}
.gift-toggle-btn.active{color:#fff}
.gift-toggle-slider{position:absolute;top:3px;left:3px;width:calc(50% - 3px);height:calc(100% - 6px);border-radius:10px;background:linear-gradient(135deg,#34d399,#059669);transition:all .3s cubic-bezier(.4,0,.2,1);z-index:0}
.gift-toggle-slider.gift{left:calc(50%);background:linear-gradient(135deg,#667eea,#4f46e5)}
/* Gift result sheet */
.gift-link-box{background:#ffffff10;border:1px solid var(--border);border-radius:12px;padding:12px;font-family:monospace;font-size:13px;word-break:break-all;color:var(--text);user-select:all;margin-bottom:16px}
.addon-buy-btn{background:linear-gradient(135deg,#667eea,#7c5bf5);color:#fff;border:none;border-radius:10px;padding:8px 14px;font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:4px;font-family:'Inter',sans-serif;transition:all .2s;white-space:nowrap}
.addon-buy-btn:active{transform:scale(.95);opacity:.8}
.addon-device-btn{background:var(--card);color:var(--accent2);border:1px solid var(--accent1);border-radius:10px;padding:8px 14px;font-size:12px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s;white-space:nowrap}
.addon-device-btn:active{transform:scale(.95);background:var(--accent1);color:#fff}
/* VPN Setup accordion */
.vpn-setup-card{cursor:pointer;transition:all .2s}
.vpn-setup-card:active{transform:scale(.98);opacity:.9}
/* Full-screen VPN settings panel */
.vsp{position:fixed;inset:0;z-index:9000;background:#0f1115;transform:translateX(100%);transition:transform .4s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;overflow:hidden}
.vsp.open{transform:translateX(0)}
.vsp-header{display:flex;align-items:center;gap:12px;padding:14px 16px;flex-shrink:0;min-height:52px}
.vsp-back{width:36px;height:36px;border-radius:10px;border:none;background:#ffffff08;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}
.vsp-back:active{background:#ffffff15}
.vsp-title{font-size:17px;font-weight:800;flex:1}
.vsp-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 16px calc(16px + env(safe-area-inset-bottom))}
/* Accordion items */
.vpn-acc-item{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:10px;border-left:3px solid var(--border);transition:border-color .3s,box-shadow .3s}
.vpn-acc-item:active{background:#ffffff06}
.vpn-acc-item[data-accent="purple"]{border-left-color:#7c5bf5}
.vpn-acc-item[data-accent="blue"]{border-left-color:#5bc0de}
.vpn-acc-item[data-accent="green"]{border-left-color:#34d399}
.vpn-acc-item[data-accent="orange"]{border-left-color:#f59e0b}
.vpn-acc-item[data-accent="violet"]{border-left-color:#a78bfa}
.vpn-acc-header{display:flex;align-items:center;gap:12px;padding:16px;cursor:pointer;-webkit-tap-highlight-color:rgba(255,255,255,.05)}
.vpn-acc-header .vpn-acc-title{font-weight:700;font-size:14px;flex:1}
.vpn-acc-header .vpn-acc-desc{font-size:11px;color:var(--text2);margin-top:2px;font-weight:400}
.vpn-acc-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vpn-acc-chevron{transition:transform .35s cubic-bezier(.32,.72,0,1);flex-shrink:0}
.vpn-acc-chevron.open{transform:rotate(180deg)}
.vpn-acc-body{display:grid;grid-template-rows:0fr;overflow:hidden;transition:grid-template-rows .5s cubic-bezier(.4,0,.2,1)}
.vpn-acc-body.open{grid-template-rows:1fr}
.vpn-acc-inner{min-height:0;overflow:hidden}
.vpn-acc-pad{padding:0 16px 16px}
#vpnSetupContent{display:none}
/* Platform switcher */
.tl-platform-switcher{display:flex;gap:6px;margin-bottom:12px;padding:4px;background:var(--card);border-radius:12px;border:1px solid var(--border)}
.tl-plat-btn{flex:1;padding:8px 4px;border:none;border-radius:8px;background:transparent;color:var(--text2);font-size:11px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .2s}
.tl-plat-btn.active{background:#059669;color:#fff;box-shadow:0 2px 8px #05966930}
.tl-plat-btn:not(.active):active{background:#ffffff10}
/* Timeline (Tribute-style) */
.tl{display:flex;flex-direction:column;gap:0;padding:4px 0}
.tl-step{display:flex;gap:14px;position:relative}
.tl-rail{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:32px}
.tl-circle{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;border:2px solid var(--border);background:var(--card);transition:all .4s ease;position:relative;z-index:1}
.tl-step.done .tl-circle{border-color:#059669;background:#059669;color:#fff}
.tl-step.active .tl-circle{border-color:#059669;background:#059669;color:#fff;box-shadow:0 0 12px #05966940}
.tl-line{width:2px;flex:1;min-height:12px;background:var(--border);transition:background .4s ease}
.tl-step.done .tl-line{background:#059669}
.tl-body{flex:1;padding-bottom:16px}
.tl-step:last-child .tl-body{padding-bottom:0}
.tl-step:last-child .tl-line{display:none}
.tl-title{font-size:14px;font-weight:700;color:var(--text);line-height:32px}
.tl-step.done .tl-title{color:#34d399}
.tl-desc{font-size:12px;color:var(--text2);margin-top:4px;line-height:1.5}
.tl-action{margin-top:10px}
.tl-btn{width:100%;padding:12px;border:none;border-radius:12px;font-size:14px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}
.tl-btn:active{transform:scale(.97);opacity:.85}
.tl-btn.primary{background:linear-gradient(135deg,#059669,#047857);color:#fff;box-shadow:0 2px 12px #05966930}
.tl-btn.secondary{background:var(--card);border:1px solid var(--border);color:var(--text)}
.tl-btn.ghost{background:transparent;border:1px solid var(--border);color:var(--text2);font-size:13px;font-weight:600;padding:10px 12px}
.tl-check{width:16px;height:16px}
.tl-or{text-align:center;font-size:11px;color:var(--text2);margin:8px 0}
.copy-guide{max-height:0;overflow:hidden;opacity:0;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,margin .3s ease;margin-top:0}
.copy-guide.show{max-height:300px;opacity:1;margin-top:10px}
/* QR Sheet (bottom sheet) */
.sheet-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9999;opacity:0;transition:opacity .3s;pointer-events:none}
.sheet-overlay.show{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:10000;background:var(--bg-secondary,#1a1b20);border-radius:20px 20px 0 0;padding:20px 20px calc(20px + env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}
.sheet.show{transform:translateY(0)}
.sheet-handle{width:36px;height:4px;border-radius:2px;background:#ffffff20;margin:0 auto 16px}
.sheet-title{font-size:16px;font-weight:700;text-align:center;margin-bottom:16px}
.sheet-qr{display:flex;justify-content:center;background:#fff;border-radius:12px;padding:16px;margin-bottom:12px}
.sheet-close{width:100%;padding:12px;border:none;border-radius:12px;background:#ffffff10;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif}

/* VPN Connect Sheet */
.vpn-sheet-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9999;opacity:0;transition:opacity .3s;pointer-events:none}
.vpn-sheet-overlay.show{opacity:1;pointer-events:auto}
.vpn-sheet{position:fixed;left:0;right:0;bottom:0;z-index:10000;background:#13141a;border-radius:20px 20px 0 0;max-height:92vh;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}
.vpn-sheet.show{transform:translateY(0)}
.vpn-sheet-handle{width:36px;height:4px;border-radius:2px;background:#ffffff20;margin:12px auto 0;flex-shrink:0}
.vpn-sheet-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 20px calc(20px + env(safe-area-inset-bottom))}
.vpn-sheet-locked{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}
.vpn-sheet-lock-icon{width:72px;height:72px;border-radius:50%;background:rgba(255,255,255,.04);border:2px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;margin-bottom:20px;animation:lockBounce 2s ease-in-out infinite}
@keyframes lockBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.vpn-sheet-lock-title{font-size:18px;font-weight:800;color:#fff;margin-bottom:8px}
.vpn-sheet-lock-desc{font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:24px}
.vpn-sheet-lock-btn{padding:14px 32px;border:none;border-radius:14px;background:linear-gradient(135deg,#4f8cf7,#3b6de0);color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;transition:opacity .2s}
.vpn-sheet-lock-btn:active{opacity:.8}
/* Active state — timeline steps */
.vpn-sheet-title{font-size:17px;font-weight:800;margin-bottom:16px}
.vpn-sheet-step{display:flex;gap:14px;margin-bottom:20px}
.vpn-sheet-step-num{width:32px;height:32px;border-radius:50%;background:rgba(52,211,153,.1);border:2px solid #34d399;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#34d399;flex-shrink:0}
.vpn-sheet-step-num.done{background:#34d399;color:#000}
.vpn-sheet-step-num.done svg{display:block}
.vpn-sheet-step-content{flex:1;padding-top:4px}
.vpn-sheet-step-name{font-size:14px;font-weight:700;color:#fff;margin-bottom:4px}
.vpn-sheet-step-desc{font-size:12px;color:var(--text2);line-height:1.4}
.vpn-sheet-step-btn{margin-top:10px;padding:10px 16px;border:none;border-radius:10px;background:#34d399;color:#000;font-size:13px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;display:inline-flex;align-items:center;gap:6px;transition:opacity .2s}
.vpn-sheet-step-btn:active{opacity:.8}
.vpn-sheet-step-btn.outline{background:transparent;border:1px solid var(--border);color:var(--text)}

.sub-info{background:linear-gradient(135deg,#7c5bf510,#5b8cf508);border:1px solid #7c5bf530;border-radius:14px;padding:16px;margin-bottom:16px}
.sub-info-row{display:flex;justify-content:space-between;padding:6px 0}
.sub-info-label{font-size:13px;color:var(--text2)}
.sub-info-val{font-size:13px;font-weight:600}

.sub-status-card{border-radius:16px;padding:20px;margin-bottom:16px;text-align:center;position:relative;overflow:hidden}
.sub-status-card.trial{background:linear-gradient(135deg,#e65c00,#f9a825);border:none}
.sub-status-card.trial .sub-status-title{color:#fff}
.sub-status-card.trial .sub-badge.trial{background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3)}
.sub-status-card.trial .sub-countdown{background:none;-webkit-background-clip:unset;-webkit-text-fill-color:#fff;color:#fff}
.sub-status-card.trial .sub-countdown-label{color:rgba(255,255,255,.7)}
.sub-status-card.trial .sub-progress{background:rgba(255,255,255,.2)}
.sub-status-card.trial .sub-progress-fill{background:rgba(255,255,255,.8)}
.sub-status-card.trial .sub-expire{color:rgba(255,255,255,.6)}
.sub-status-card.active{background:linear-gradient(135deg,#34d39908,#34d39904);border:1px solid #34d39930}
.sub-status-card.plan-personal{background:linear-gradient(135deg,#1a6bb5,#2196F3);border:none}
.sub-status-card.plan-family{background:linear-gradient(135deg,#2e8b2e,#32cd32);border:none}
.sub-status-card.plan-corporate{background:linear-gradient(135deg,#8b2252,#a0306a);border:none}
.sub-status-card[class*="plan-"] .sub-status-title{color:#fff}
.sub-status-card[class*="plan-"] .sub-badge.active{background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3)}
.sub-status-card[class*="plan-"] .sub-countdown{background:none;-webkit-background-clip:unset;-webkit-text-fill-color:#fff;color:#fff}
.sub-status-card[class*="plan-"] .sub-countdown-label{color:rgba(255,255,255,.7)}
.sub-status-card[class*="plan-"] .sub-progress{background:rgba(255,255,255,.2)}
.sub-status-card[class*="plan-"] .sub-progress-fill{background:rgba(255,255,255,.8)}
.sub-status-card[class*="plan-"] .sub-expire{color:rgba(255,255,255,.6)}
.sub-status-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.sub-status-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.sub-badge{font-size:10px;font-weight:700;padding:3px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}
.sub-badge.trial{background:#f59e0b20;color:#f59e0b;border:1px solid #f59e0b40}
.sub-badge.active{background:#34d39920;color:#34d399;border:1px solid #34d39940}
.sub-countdown{font-size:44px;font-weight:800;letter-spacing:-1px;line-height:1}
.sub-countdown.trial{background:linear-gradient(135deg,#f59e0b,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.sub-countdown.active{background:linear-gradient(135deg,#34d399,#6ee7b7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.sub-countdown-label{font-size:13px;color:var(--text2);margin-top:4px;font-weight:500}
.sub-progress{height:4px;border-radius:2px;background:#ffffff10;margin:16px 0 12px;overflow:hidden}
.sub-progress-fill{height:100%;border-radius:2px;transition:width .5s ease}
.sub-progress-fill.trial{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.sub-progress-fill.active{background:linear-gradient(90deg,#34d399,#6ee7b7)}
.sub-expire{font-size:12px;color:var(--text2)}
.sub-cta{margin-top:14px}
.sub-cta button{width:100%;padding:12px;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s}
.sub-cta button:active{transform:scale(.98);opacity:.9}
.sub-cta-trial{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff}
.sub-cta-renew{background:linear-gradient(135deg,#34d399,#059669);color:#fff}

/* Subscription Popup — Apple Wallet */
.sub-popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,0);z-index:9000;pointer-events:none;transition:background .4s ease}
.sub-popup-overlay.open{background:rgba(0,0,0,.75);pointer-events:auto}
.sub-popup-card{position:fixed;overflow-y:auto;overflow-x:hidden;padding:20px;-webkit-overflow-scrolling:touch;will-change:transform,top,left,width,height,border-radius;transition:top .6s cubic-bezier(.4,0,.2,1),left .6s cubic-bezier(.4,0,.2,1),width .6s cubic-bezier(.4,0,.2,1),height .6s cubic-bezier(.4,0,.2,1),border-radius .6s cubic-bezier(.4,0,.2,1),opacity .3s}
.sub-popup-card.morphing{overflow:hidden}
.sub-popup-card>*{opacity:0;transform:translateY(6px);transition:opacity .25s ease,transform .25s ease}
.sub-popup-overlay.open .sub-popup-card>*{opacity:1;transform:translateY(0)}
.sub-popup-overlay.open .sub-popup-card>.wallet-close{transition-delay:.3s}
.sub-popup-overlay.open .sub-popup-card>.wallet-brand{transition-delay:.35s}
.sub-popup-overlay.open .sub-popup-card>.wallet-plan{transition-delay:.38s}
.sub-popup-overlay.open .sub-popup-card>.wallet-status{transition-delay:.4s}
.sub-popup-overlay.open .sub-popup-card>.wallet-countdown{transition-delay:.42s}
.sub-popup-overlay.open .sub-popup-card>.wallet-progress{transition-delay:.44s}
.sub-popup-overlay.open .sub-popup-card>.wallet-info-row{transition-delay:.46s}
.sub-popup-overlay.open .sub-popup-card>.wallet-tear{transition-delay:.5s}
.sub-popup-overlay.open .sub-popup-card>#popupDeviceList{transition-delay:.55s}
.sub-popup-overlay.open .sub-popup-card>.wallet-expand{transition-delay:.6s}
.sub-popup-overlay.open .sub-popup-card>.wallet-setting{transition-delay:.65s}
.sub-popup-card.plan-personal{background:linear-gradient(135deg,#1a6bb5,#2196F3);--plan-accent:#60a5fa;--plan-accent-bg:rgba(96,165,250,.15);--plan-accent-border:rgba(96,165,250,.4)}
.sub-popup-card.plan-family{background:linear-gradient(135deg,#2e8b2e,#32cd32);--plan-accent:#4ade80;--plan-accent-bg:rgba(74,222,128,.15);--plan-accent-border:rgba(74,222,128,.4)}
.sub-popup-card.plan-corporate{background:linear-gradient(135deg,#8b2252,#a0306a);--plan-accent:#f472b6;--plan-accent-bg:rgba(244,114,182,.15);--plan-accent-border:rgba(244,114,182,.4)}
.sub-popup-card.plan-trial{background:linear-gradient(135deg,#92400e,#b45309,#d97706);--plan-accent:#fbbf24;--plan-accent-bg:rgba(251,191,36,.15);--plan-accent-border:rgba(251,191,36,.4)}
.sub-popup-card.plan-owner{background:linear-gradient(135deg,#059669,#10b981);--plan-accent:#34d399;--plan-accent-bg:rgba(52,211,153,.15);--plan-accent-border:rgba(52,211,153,.4)}

/* Wallet elements */
.wallet-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;backdrop-filter:blur(4px)}
.wallet-close:active{background:rgba(255,255,255,.3);transform:scale(.9)}
.wallet-brand{font-size:11px;font-weight:800;color:rgba(255,255,255,.4);letter-spacing:4px;text-align:center;margin-bottom:16px}
.wallet-plan{font-size:17px;font-weight:700;color:#fff;text-align:center}
.wallet-status{font-size:12px;color:rgba(255,255,255,.7);text-align:center;margin-top:4px}
.wallet-countdown{font-size:36px;font-weight:900;color:#fff;text-align:center;line-height:1;margin:16px 0 4px;letter-spacing:-1px}
.wallet-progress{height:4px;background:rgba(255,255,255,.15);border-radius:2px;margin:10px 0;overflow:hidden}
.wallet-progress-bar{height:100%;background:var(--plan-accent,rgba(255,255,255,.7));border-radius:2px;transition:width .6s ease}
.wallet-info-row{display:flex;justify-content:space-between;margin:8px 0 0}
.wallet-info-item{text-align:center;flex:1}
.wallet-info-value{font-size:13px;font-weight:700;color:#fff}
.wallet-info-label{font-size:10px;color:rgba(255,255,255,.45);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.wallet-tear{border:none;height:1px;margin:14px -20px;background:repeating-linear-gradient(90deg,transparent,transparent 4px,rgba(255,255,255,.1) 4px,rgba(255,255,255,.1) 8px)}
.wallet-device{display:flex;align-items:center;justify-content:space-between;padding:8px 0;animation:walletDeviceIn .4s ease both}
@keyframes walletDeviceIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.wallet-slot{animation:walletSlotIn .4s ease both}
@keyframes walletSlotIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.wallet-device-left{display:flex;align-items:center;gap:10px}
.wallet-device-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7)}
.wallet-device-name{font-size:13px;font-weight:600;color:#fff}
.wallet-device-meta{font-size:10px;color:rgba(255,255,255,.4);margin-top:1px}
.wallet-device-right{font-size:10px;font-weight:600;color:rgba(255,255,255,.5)}
.wallet-device-right.online{color:#4ade80}
.wallet-device-actions{display:flex;gap:8px;margin-left:8px}
.wallet-device-btn{background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;padding:4px;font-size:11px}
.wallet-device-btn:active{color:#fff}
.wallet-slot{display:flex;align-items:center;justify-content:space-between;padding:8px 0;cursor:pointer}
.wallet-slot-left{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.3)}
.wallet-slot-circle{width:32px;height:32px;border:1px dashed rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center}
.wallet-slot-label{font-size:12px;color:rgba(255,255,255,.3)}
.wallet-slot-add{font-size:11px;font-weight:600;color:rgba(0,0,0,.8);background:#fff;border:none;border-radius:8px;padding:6px 14px;cursor:pointer}
.wallet-slot-add:active{opacity:.7;transform:scale(.95)}
.wallet-expand{text-align:center;font-size:12px;color:#fff;padding:8px 0;cursor:pointer;font-weight:600;text-decoration:underline;text-decoration-color:rgba(255,255,255,.3);text-underline-offset:3px}
.wallet-expand:active{opacity:.7}
.wallet-setting{display:flex;justify-content:space-between;align-items:center;padding:4px 0}
.wallet-limit-block{background:rgba(0,0,0,.15);border-radius:12px;overflow:hidden;margin-top:0;padding:0 14px;max-height:0;opacity:0;transition:max-height .5s ease,opacity .4s ease,padding .5s ease,margin-top .5s ease}
.wallet-limit-block.open{max-height:180px;opacity:1;padding:14px;margin-top:8px}
.wallet-limit-row{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:10px}
.wallet-limit-minus,.wallet-limit-plus{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif}
.wallet-limit-minus:active,.wallet-limit-plus:active{background:rgba(255,255,255,.25)}
.wallet-limit-num{font-size:28px;font-weight:800;color:#fff;min-width:30px;text-align:center}
.wallet-limit-info{display:flex;flex-direction:column;gap:2px;font-size:11px;color:rgba(255,255,255,.5);text-align:center;margin-bottom:10px}
.wallet-limit-info b{color:rgba(255,255,255,.8)}
.wallet-limit-buy{width:100%;padding:12px;background:#fff;border:none;border-radius:10px;color:#000;font-size:14px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif}
.wallet-limit-buy:active{opacity:.8;transform:scale(.97)}
.wallet-setting span{font-size:13px;color:rgba(255,255,255,.7)}

/* Device Picker */
.dp-overlay{position:fixed;inset:0;background:rgba(0,0,0,0);z-index:9500;display:flex;align-items:flex-end;justify-content:center;pointer-events:none;transition:background .3s}
.dp-overlay.open{background:rgba(0,0,0,.6);pointer-events:auto}
.dp-sheet{width:100%;max-width:400px;background:#1a1a2e;border-radius:20px 20px 0 0;padding:24px 20px 32px;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,1,.23,1)}
.dp-overlay.open .dp-sheet{transform:translateY(0)}
.dp-title{font-size:16px;font-weight:700;color:#fff;text-align:center;margin-bottom:18px}
.dp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.dp-platform{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:12px;background:rgba(255,255,255,.05);border:2px solid transparent;cursor:pointer;color:rgba(255,255,255,.5);transition:all .2s}
.dp-platform.active{border-color:var(--dp-accent,var(--green));color:#fff;background:var(--dp-accent-bg,rgba(52,211,153,.1))}
.dp-platform:active{transform:scale(.95)}
.dp-platform-label{font-size:11px;font-weight:600}
.dp-input-wrap{margin-bottom:14px}
.dp-input{width:100%;padding:12px 14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:12px;color:#fff;font-size:14px;font-weight:500;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s;box-sizing:border-box}
.dp-input:focus{border-color:var(--dp-accent,var(--green))}
.dp-input::placeholder{color:rgba(255,255,255,.3)}
.dp-confirm{width:100%;padding:14px;background:var(--dp-accent,var(--green));border:none;border-radius:12px;color:#000;font-size:15px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s}
.dp-confirm:active{transform:scale(.97);opacity:.9}
.dp-confirm:disabled{opacity:.5}

/* Subscription Cabinet — inside gradient card */
.cab-divider{height:1px;background:rgba(255,255,255,.12);margin:16px 0}
.cab-section-inline{margin-top:0}
.cab-section-header-inline{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.cab-section-header-inline span:first-child{font-size:13px;font-weight:700;color:rgba(255,255,255,.9);text-transform:uppercase;letter-spacing:.5px}
.cab-section-header-inline span:last-child{font-size:13px;font-weight:700;color:rgba(255,255,255,.6)}
.cab-actions-inline{display:flex;gap:8px;margin-bottom:12px}
.cab-action-pill{flex:1;background:rgba(255,255,255,.12);border:none;border-radius:10px;padding:10px 6px;text-align:center;font-size:12px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;backdrop-filter:blur(4px)}
.cab-action-pill:active{background:rgba(255,255,255,.2);transform:scale(.96)}
.cab-autorenew-row{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.1)}
.cab-autorenew-row span{font-size:13px;color:rgba(255,255,255,.7)}
.cab-toggle{position:relative;display:inline-block;width:44px;height:24px;cursor:pointer}
.cab-toggle input{opacity:0;width:0;height:0}
.cab-toggle-slider{position:absolute;inset:0;background:#333;border-radius:12px;transition:background .2s}
.cab-toggle-slider::before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s}
.cab-toggle input:checked+.cab-toggle-slider{background:var(--green)}
.cab-toggle input:checked+.cab-toggle-slider::before{transform:translateX(20px)}
.cab-device-card{background:rgba(255,255,255,.08);border:none;border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:12px;margin-bottom:8px;backdrop-filter:blur(4px)}
.cab-device-icon{font-size:22px;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border-radius:10px}
.cab-device-info{flex:1;min-width:0}
.cab-device-name{font-size:13px;font-weight:600;color:#fff;margin-bottom:1px}
.cab-device-meta{font-size:11px;color:rgba(255,255,255,.5)}
.cab-device-actions{display:flex;gap:6px;flex-shrink:0}
.cab-device-del{background:none;border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.6);border-radius:8px;padding:5px 10px;font-size:10px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s}
.cab-device-del:active{background:rgba(239,68,68,.3);border-color:#ef4444;color:#ef4444}
.cab-add-device-btn-inline{width:100%;padding:10px;background:rgba(255,255,255,.06);border:1px dashed rgba(255,255,255,.2);border-radius:10px;color:rgba(255,255,255,.5);font-size:12px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s;font-family:'Inter',sans-serif;margin-top:4px}
.cab-add-device-btn-inline:active{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.4);color:#fff}
.cab-expand-limit-btn{width:100%;padding:10px;background:none;border:none;color:rgba(255,255,255,.45);font-size:12px;font-weight:600;cursor:pointer;text-align:center;font-family:'Inter',sans-serif;margin-top:6px;transition:color .2s}
.cab-expand-limit-btn:active{color:rgba(255,255,255,.8)}
.cab-payment-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.cab-payment-item:last-child{border-bottom:none}
.cab-payment-plan{font-size:13px;font-weight:600;color:#fff}
.cab-payment-date{font-size:11px;color:rgba(255,255,255,.4);margin-top:2px}
.cab-payment-amount{font-size:14px;font-weight:700;color:#fff}
.cab-empty-inline{text-align:center;padding:16px;color:rgba(255,255,255,.35);font-size:12px}

/* Proxy Sheet */
.px-header{text-align:center;margin-bottom:20px;opacity:0;transform:translateY(12px);transition:all .5s .1s}
.vpn-sheet.show .px-header{opacity:1;transform:translateY(0)}
.px-icon{width:64px;height:64px;border-radius:20px;background:linear-gradient(135deg,#2AABEE,#229ED9);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:0 8px 32px rgba(42,171,238,.3);position:relative;overflow:hidden}
.px-icon::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2),transparent);border-radius:20px}
.px-title{font-size:20px;font-weight:800;color:#fff;letter-spacing:-.3px}
.px-sub{font-size:13px;color:var(--text2);margin-top:6px;line-height:1.5}

/* QR block */
.px-qr-wrap{opacity:0;transform:scale(.9);transition:all .5s .2s}
.vpn-sheet.show .px-qr-wrap{opacity:1;transform:scale(1)}
.px-qr-card{background:linear-gradient(135deg,#ffffff08,#ffffff04);border:1px solid var(--border);border-radius:20px;padding:20px;text-align:center;position:relative;overflow:hidden}
.px-qr-card::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent,rgba(42,171,238,.06),transparent,rgba(42,171,238,.06),transparent);animation:pxSpin 6s linear infinite}
@keyframes pxSpin{to{transform:rotate(360deg)}}
.px-qr-inner{position:relative;z-index:1}
.px-qr-box{width:180px;height:180px;margin:0 auto 12px;background:#fff;border-radius:14px;padding:10px;box-shadow:0 4px 24px rgba(0,0,0,.3)}
.px-qr-box canvas,.px-qr-box img{border-radius:6px!important}
.px-qr-hint{font-size:11px;color:var(--text2);line-height:1.5}

/* Server cards */
.px-servers{display:flex;flex-direction:column;gap:10px;margin-top:16px;opacity:0;transform:translateY(15px);transition:all .5s .3s}
.vpn-sheet.show .px-servers{opacity:1;transform:translateY(0)}
.px-srv{background:linear-gradient(135deg,#ffffff06,#ffffff03);border:1px solid var(--border);border-radius:16px;padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s}
.px-srv:active{transform:scale(.98);border-color:rgba(42,171,238,.4)}
.px-srv-flag{font-size:24px;line-height:1}
.px-srv-info{flex:1;min-width:0}
.px-srv-name{font-size:14px;font-weight:700;color:#fff}
.px-srv-loc{font-size:11px;color:var(--text2);margin-top:2px}
.px-srv-dot{width:8px;height:8px;border-radius:50%;background:#34d399;box-shadow:0 0 8px rgba(52,211,153,.5);flex-shrink:0}
.px-srv-btn{padding:7px 14px;border-radius:10px;background:linear-gradient(135deg,#2AABEE,#229ED9);color:#fff;font-size:12px;font-weight:700;border:none;cursor:pointer;white-space:nowrap;font-family:'Inter',sans-serif;transition:all .15s}
.px-srv-btn:active{transform:scale(.95);opacity:.8}

/* Action buttons */
.px-actions{display:flex;gap:10px;margin-top:16px;opacity:0;transform:translateY(15px);transition:all .5s .4s}
.vpn-sheet.show .px-actions{opacity:1;transform:translateY(0)}
.px-btn{flex:1;padding:14px;border:none;border-radius:14px;color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}
.px-btn:active{transform:scale(.97)}
.px-btn--connect{background:linear-gradient(135deg,#2AABEE,#229ED9);box-shadow:0 4px 20px rgba(42,171,238,.3)}
.px-btn--share{background:linear-gradient(135deg,#ffffff10,#ffffff06);border:1px solid var(--border)}
.px-btn--share:active{border-color:rgba(42,171,238,.4)}

/* Free badge */
.px-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;background:linear-gradient(135deg,rgba(52,211,153,.15),rgba(52,211,153,.05));border:1px solid rgba(52,211,153,.2);font-size:11px;font-weight:700;color:#34d399;margin-top:10px}

/* Floating particles */
.px-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;border-radius:20px}
.px-particle{position:absolute;width:3px;height:3px;border-radius:50%;background:rgba(42,171,238,.4);animation:pxFloat 3s ease-in-out infinite}
@keyframes pxFloat{0%{opacity:0;transform:translateY(20px)}50%{opacity:1}100%{opacity:0;transform:translateY(-20px)}}

/* Admin */
.admin-user{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}
.admin-user:last-child{border-bottom:none}
.admin-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.admin-avatar.owner{background:var(--grad)}
.admin-avatar.family{background:linear-gradient(135deg,#34d399,#059669)}
.admin-avatar.user{background:linear-gradient(135deg,#8a8a99,#555)}
.admin-user-info{flex:1;min-width:0}
.admin-user-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-user-meta{font-size:11px;color:var(--text2)}
.admin-user-traffic{font-size:11px;color:var(--accent2);font-weight:600}
.admin-user-actions{display:flex;gap:6px;flex-shrink:0}
.admin-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--card);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.admin-btn:active{transform:scale(.9)}
.admin-btn.remove{border-color:#f8717140}
.admin-btn.remove:active{background:#f8717120}

.admin-add{display:flex;gap:8px;margin-bottom:16px}
.admin-input{flex:1;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:#12121a;color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s}
.admin-input:focus{border-color:var(--accent1)}
.admin-input::placeholder{color:#555}
.admin-add-btn{padding:12px 20px;border-radius:12px;background:var(--grad);border:none;color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;white-space:nowrap;flex-shrink:0}
.admin-add-btn:active{opacity:.8}
.admin-add-btn:disabled{opacity:.5}

.admin-user-sub{font-size:11px;color:var(--green);font-weight:600}
.admin-user-sub.expired{color:var(--red)}
.admin-user-refs{font-size:11px;color:var(--accent1)}
.admin-detail{background:#12121a;border:1px solid var(--border);border-radius:12px;margin:0 0 8px;padding:14px;display:none}
.admin-detail.open{display:block}
.admin-detail-section{margin-bottom:12px}
.admin-detail-section:last-child{margin-bottom:0}
.admin-detail-title{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.admin-detail-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:12px}
.admin-detail-row .label{color:var(--text2)}
.admin-detail-row .val{font-weight:600}
.admin-detail-row .val.active{color:var(--green)}
.admin-detail-row .val.expired{color:var(--red)}
.admin-revoke-btn{padding:6px 12px;border-radius:8px;background:#f8717120;border:1px solid #f8717140;color:#f87171;font-size:11px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif}
.admin-revoke-btn:active{opacity:.7}
.admin-info-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--card);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.admin-info-btn:active{transform:scale(.9)}

.adm-monitor{background:linear-gradient(135deg,#0f1a2e,#121520);border:1px solid #667eea30;border-radius:16px;padding:16px;margin-bottom:16px}
.adm-monitor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.adm-monitor-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700}
.adm-monitor-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2)}
.adm-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.adm-dot-online{background:#22c55e;box-shadow:0 0 6px #22c55e80}
.adm-dot-offline{background:#ef4444;box-shadow:0 0 6px #ef444480}
.adm-dot-loading{background:#888;animation:adm-pulse 1.2s infinite}
@keyframes adm-pulse{0%,100%{opacity:.4}50%{opacity:1}}
.adm-monitor-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.adm-metric{background:#0a0e18;border-radius:12px;padding:12px}
.adm-metric-header{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}
.adm-metric-val{font-size:16px;font-weight:800;color:var(--text);margin-bottom:6px}
.adm-metric-bar{height:6px;background:#1a1a2e;border-radius:3px;overflow:hidden}
.adm-metric-fill{height:100%;border-radius:3px;transition:width .6s ease}
.adm-fill-cpu{background:linear-gradient(90deg,#667eea,#7c5bf5)}
.adm-fill-ram{background:linear-gradient(90deg,#22c55e,#16a34a)}
.adm-fill-disk{background:linear-gradient(90deg,#f59e0b,#d97706)}
.adm-fill-cpu.high{background:linear-gradient(90deg,#ef4444,#dc2626)}
.adm-fill-ram.high{background:linear-gradient(90deg,#ef4444,#dc2626)}
.adm-fill-disk.high{background:linear-gradient(90deg,#ef4444,#dc2626)}
.adm-monitor-footer{display:flex;gap:12px;padding-top:12px;border-top:1px solid #ffffff08}
.adm-footer-item{flex:1;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2)}
.adm-footer-item b{color:var(--text);font-weight:700}
.admin-stat{display:flex;gap:8px;margin-bottom:16px}
.admin-stat-item{flex:1;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px;text-align:center}
.admin-stat-val{font-size:20px;font-weight:800}
.admin-stat-label{font-size:10px;color:var(--text2);margin-top:2px;text-transform:uppercase;letter-spacing:.3px}

.ref-card{background:linear-gradient(135deg,#1a1530,#151520);border:1px solid #7c5bf530;border-radius:14px;padding:16px;margin-top:12px}
.ref-title{font-size:14px;font-weight:700;margin-bottom:6px}
.ref-desc{font-size:12px;color:var(--text2);margin-bottom:12px;line-height:1.5}
.ref-link{font-size:12px;color:var(--accent2);word-break:break-all;background:#12121a;padding:10px;border-radius:8px;margin-bottom:8px}

.ref-banner{background:linear-gradient(135deg,#13102a,#0e1028);border:1px solid #7c5bf520;border-radius:16px;padding:16px;margin-bottom:12px;position:relative;overflow:hidden;cursor:pointer;transition:transform .15s}
.ref-banner:active{transform:scale(.98)}
.ref-banner-bg{position:absolute;top:-40px;right:-40px;width:140px;height:140px;background:radial-gradient(circle,#667eea10,transparent 70%);pointer-events:none}
.ref-banner-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.ref-banner-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.ref-banner-desc{font-size:12px;color:var(--text2);margin-bottom:12px}
.ref-banner-levels{display:flex;gap:4px;margin-bottom:10px}
.ref-banner-level{display:flex;flex-direction:column;align-items:center;flex:1;padding:8px 2px;background:#0a0a18;border-radius:10px;border:1px solid #ffffff06;transition:all .4s ease;position:relative}
.ref-banner-level.ref-glow{border-color:var(--glow-color);box-shadow:0 0 12px var(--glow-color),0 0 24px color-mix(in srgb,var(--glow-color) 40%,transparent),inset 0 0 8px color-mix(in srgb,var(--glow-color) 15%,transparent);animation:refGlow 2.5s ease-in-out infinite;background:color-mix(in srgb,var(--glow-color) 8%,#0a0a18)}
@keyframes refGlow{0%,100%{box-shadow:0 0 12px var(--glow-color),0 0 24px color-mix(in srgb,var(--glow-color) 40%,transparent),inset 0 0 8px color-mix(in srgb,var(--glow-color) 15%,transparent)}50%{box-shadow:0 0 18px var(--glow-color),0 0 36px color-mix(in srgb,var(--glow-color) 50%,transparent),inset 0 0 12px color-mix(in srgb,var(--glow-color) 20%,transparent)}}
.ref-banner-level.ref-reached{opacity:.4}
.ref-banner-level-disc{font-size:10px;font-weight:800;margin-top:4px;letter-spacing:.3px}
.ref-banner-my{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#667eea0a;border:1px solid #667eea15;border-radius:10px}
.ref-banner-my-text{font-size:12px;color:var(--text2);flex:1}
.ref-banner-my-text b{color:var(--text)}
.ref-banner-copy{display:flex;align-items:center;gap:5px;background:linear-gradient(135deg,#667eea,#7c5bf5);border:none;border-radius:8px;padding:6px 12px;color:#fff;font-size:11px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;white-space:nowrap;transition:opacity .2s}
.ref-banner-copy:active{opacity:.7}
.ref-section{margin-top:12px}
.ref-level-card{background:linear-gradient(135deg,#1a1530,#151520);border:1px solid #7c5bf530;border-radius:16px;padding:18px;margin-bottom:12px}
.ref-level-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.ref-level-badge{display:flex;align-items:center;gap:10px}
.ref-level-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:#12121a}
.ref-level-name{font-size:18px;font-weight:800;color:var(--text)}
.ref-level-discount{font-size:13px;font-weight:700;color:var(--accent2);background:#667eea20;padding:4px 10px;border-radius:8px}
.ref-progress{margin-bottom:14px}
.ref-progress-bar{height:8px;background:#1a1a2e;border-radius:4px;overflow:hidden;margin-top:6px}
.ref-progress-fill{height:100%;border-radius:4px;transition:width .5s ease;background:linear-gradient(90deg,#667eea,#7c5bf5)}
.ref-progress-text{font-size:11px;color:var(--text2);display:flex;justify-content:space-between}
.ref-stats{display:flex;gap:8px}
.ref-stat{flex:1;text-align:center;background:#12121a;border-radius:10px;padding:10px 6px}
.ref-stat-val{font-size:18px;font-weight:800;color:var(--text)}
.ref-stat-label{font-size:10px;color:var(--text2);margin-top:2px;text-transform:uppercase;letter-spacing:.3px}
.ref-section-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.ref-section-header .ref-title{margin-bottom:0}
.ref-invite-card{position:relative;overflow:hidden}
.ref-invite-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.ref-invite-header .ref-title{margin-bottom:0}
.ref-copy-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;border-radius:12px;background:linear-gradient(135deg,#667eea,#7c5bf5);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .2s}
.ref-copy-btn:active{opacity:.8}
.ref-levels-list{margin-top:0}
.ref-level-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;margin-bottom:6px;background:#12121a;transition:all .2s}
.ref-level-item.active{background:#667eea15;border:1px solid #667eea40}
.ref-level-item.reached{opacity:.55}
.ref-level-item-icon{min-width:34px;height:34px;border-radius:10px;background:#0f0f1a;display:flex;align-items:center;justify-content:center}
.ref-level-item-info{flex:1}
.ref-level-item-name{font-size:13px;font-weight:700}
.ref-level-item-desc{font-size:11px;color:var(--text2);margin-top:1px}
.ref-level-item-check{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#22c55e20}
.ref-level-item-check svg{width:14px;height:14px}
.ref-people-list{margin-top:12px}
.ref-person{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;background:#12121a;margin-bottom:6px}
.ref-person:last-child{margin-bottom:0}
.ref-person-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#7c5bf5);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;flex-shrink:0}
.ref-person-info{flex:1;min-width:0}
.ref-person-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ref-person-sub{font-size:11px;color:var(--text2);margin-top:1px}
.ref-person-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px;flex-shrink:0}
.ref-person-badge.active{color:#22c55e;background:#22c55e15}
.ref-person-badge.inactive{color:var(--text2);background:#ffffff08}

/* Referral Bottom Sheet */
.ref-sheet{position:fixed;left:0;right:0;bottom:0;z-index:10000;background:#12131a;border-radius:24px 24px 0 0;max-height:92vh;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}
.ref-sheet.show{transform:translateY(0)}
.ref-sheet .sheet-handle{width:36px;height:4px;border-radius:2px;background:#ffffff15;margin:12px auto 0;flex-shrink:0}
.ref-sheet-scroll{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 16px 24px;flex:1;overscroll-behavior:contain}

/* Hero */
.ref-sheet-hero{text-align:center;padding:20px 0 24px;position:relative}
.ref-sheet-hero-glow{display:none}
.ref-sheet-hero-emoji{font-size:52px;margin-bottom:8px;position:relative;animation:refHeroFloat 3s ease-in-out infinite}
@keyframes refHeroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.ref-sheet-hero-level{font-size:13px;font-weight:700;color:var(--text2);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px;position:relative}
.ref-sheet-hero-discount{font-size:44px;font-weight:900;color:#fff;position:relative;letter-spacing:-1px}

/* Cards */
.ref-sheet-card{background:#1a1b24;border:1px solid #ffffff08;border-radius:16px;padding:14px 16px;margin-bottom:12px}

/* Progress */
.ref-sheet-progress-text{display:flex;justify-content:space-between;font-size:12px;color:var(--text2);margin-bottom:8px}
.ref-sheet-progress-bar{height:6px;background:#0f0f18;border-radius:3px;overflow:hidden}
.ref-sheet-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#2AABEE,#5bc4f0);transition:width .6s cubic-bezier(.4,0,.2,1)}

/* Stats */
.ref-sheet-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.ref-sheet-stat{text-align:center;background:#1a1b24;border:1px solid #ffffff08;border-radius:16px;padding:14px 6px}
.ref-sheet-stat-accent{background:linear-gradient(135deg,#1a2535,#162040);border-color:#2AABEE20}
.ref-sheet-stat-val{font-size:22px;font-weight:800;color:var(--text)}
.ref-sheet-stat-label{font-size:10px;color:var(--text2);margin-top:3px;text-transform:uppercase;letter-spacing:.5px;font-weight:500}

/* Share buttons */
.ref-sheet-share{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.ref-sheet-btn-main{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;border:none;border-radius:14px;background:linear-gradient(135deg,#2AABEE,#229ED9);color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:Inter,sans-serif;position:relative;overflow:hidden;transition:all .2s}
.ref-sheet-btn-main:active{transform:scale(.98);opacity:.9}
.ref-sheet-btn-main::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#fff2,transparent);pointer-events:none}
.ref-sheet-btn-copy{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border:1px solid #ffffff12;border-radius:14px;background:#1a1b24;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;font-family:Inter,sans-serif;transition:all .15s}
.ref-sheet-btn-copy:active{background:#22232e;transform:scale(.97)}

/* How it works */
.ref-sheet-how{margin-bottom:14px}
.ref-sheet-how-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:12px}
.ref-sheet-how-steps{display:flex;flex-direction:column;gap:10px}
.ref-sheet-step{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text2)}
.ref-sheet-step-num{width:28px;height:28px;border-radius:50%;background:#ffffff10;color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid #ffffff15}

/* Sections */
.ref-sheet-section{margin-bottom:16px}
.ref-sheet-section:last-child{margin-bottom:0}
.ref-sheet-section-title{font-size:13px;font-weight:700;color:var(--text2);letter-spacing:.5px;text-transform:uppercase;margin-bottom:10px;padding-left:2px}

/* Levels */
.ref-sheet-levels{display:flex;flex-direction:column;gap:6px}
.ref-sheet-lv{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:#1a1b24;border:1px solid #ffffff06;transition:all .25s}
.ref-sheet-lv.active{background:linear-gradient(135deg,#667eea12,#a78bfa08);border-color:#667eea35;box-shadow:0 0 20px #667eea15}
.ref-sheet-lv.reached{opacity:.45}
.ref-sheet-lv-icon{min-width:36px;height:36px;border-radius:12px;background:#12131a;display:flex;align-items:center;justify-content:center}
.ref-sheet-lv-info{flex:1}
.ref-sheet-lv-name{font-size:14px;font-weight:700}
.ref-sheet-lv-desc{font-size:11px;color:var(--text2);margin-top:2px}
.ref-sheet-lv-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:8px;flex-shrink:0}
.ref-sheet-lv-check{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#22c55e15;flex-shrink:0}

/* People */
.ref-sheet-people{display:flex;flex-direction:column;gap:6px}

.loader{width:20px;height:20px;border:2px solid #fff4;border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;display:inline-block}

.awg-card{border-color:#34d39940;margin-top:12px}
.awg-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.awg-title{font-size:15px;font-weight:700}
.awg-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;background:#34d39915;color:var(--green);border:1px solid #34d39930}
.awg-proto{font-size:11px;color:var(--text2);margin-bottom:14px}
.awg-actions{display:flex;flex-direction:column;gap:8px}
.awg-tabs{display:flex;gap:4px;margin-bottom:12px;background:var(--bg-secondary);border-radius:10px;padding:3px}
.awg-tab{flex:1;padding:8px 6px;border:none;border-radius:8px;background:transparent;color:var(--text2);font-size:12px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;transition:all .2s;text-align:center}
.awg-tab.active{background:var(--bg-card);color:var(--text);box-shadow:0 1px 3px #0003}
.awg-tab-gaming.active{color:#34d399}
.awg-mode-hint{font-size:11px;color:var(--text2);line-height:1.5;margin-bottom:10px;padding:8px 10px;background:var(--bg-secondary);border-radius:8px}
.btn-gaming{background:linear-gradient(135deg,#059669,#34d399);width:100%;padding:15px;border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;position:relative;overflow:hidden}
.btn-gaming:active{transform:scale(.98);opacity:.9}
.btn-gaming:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-gaming::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#fff2,transparent);pointer-events:none}
.proxy-card{border-color:#2AABEE30;background:linear-gradient(135deg,var(--card) 0%,#2AABEE0a 100%)}
.proxy-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.proxy-icon-wrap{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#2AABEE,#229ED9);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proxy-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.btn-proxy-item{background:linear-gradient(135deg,#2AABEE20,#229ED915);border:1px solid #2AABEE40;border-radius:12px;color:#fff;font-size:13px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 10px;transition:all .2s}
.btn-proxy-item:active{transform:scale(.97);opacity:.85;background:linear-gradient(135deg,#2AABEE35,#229ED925)}
.btn-support{background:linear-gradient(135deg,#667eea,#5a67d8);width:100%;padding:15px;border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;position:relative;overflow:hidden}
.btn-support:active{transform:scale(.98);opacity:.9}

.tabbar{display:flex;justify-content:space-around;padding:8px 8px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:#13131aF0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);flex-shrink:0;transform:translateY(100%);opacity:0;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .35s ease}
.tabbar.visible{transform:translateY(0);opacity:1}
.tab{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 12px;border-radius:10px;cursor:pointer;transition:all .15s;border:none;background:none;font-family:'Inter',sans-serif;position:relative}
.tab svg{transition:all .15s}
.tab-label{font-size:10px;font-weight:600;transition:color .15s}
.tab.active svg{color:var(--accent1)}
.tab.active .tab-label{color:var(--accent1)}
.tab:not(.active) svg{color:#8a8a99}
.tab:not(.active) .tab-label{color:#8a8a99}
.tab.active::before{content:'';position:absolute;top:-8px;width:20px;height:2px;border-radius:1px;background:var(--accent1);box-shadow:0 0 8px #7c5bf560}
.tab-hidden{display:none!important}

.fam-member{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.fam-member:last-child{border-bottom:none}
.fam-member-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#34d399,#059669);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}
.fam-member-info{flex:1;min-width:0}
.fam-member-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fam-member-meta{font-size:11px;color:var(--text2)}
.fam-member-medal{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.fam-member-rm{width:28px;height:28px;border-radius:8px;border:1px solid #f8717130;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.fam-member-rm:active{background:#f8717115}

.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:#1a1a24;border:1px solid var(--border);color:var(--text);padding:10px 20px;border-radius:12px;font-size:13px;font-weight:600;opacity:0;transition:all .3s;z-index:100;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* --- Onboarding overlay --- */
.onb-overlay{position:fixed;inset:0;z-index:9998;pointer-events:all;opacity:0;transition:opacity .35s}
.onb-overlay.visible{opacity:1}
.onb-spotlight{position:absolute;z-index:9999;border-radius:18px;box-shadow:0 0 0 4000px rgba(0,0,0,.82);pointer-events:none;transition:all .4s cubic-bezier(.4,0,.2,1)}
.onb-spotlight.pulse{animation:onbPulse 2s ease-in-out infinite}
@keyframes onbPulse{0%,100%{box-shadow:0 0 0 4000px rgba(0,0,0,.82),0 0 0 0 rgba(5,150,105,.4)}50%{box-shadow:0 0 0 4000px rgba(0,0,0,.82),0 0 0 12px rgba(5,150,105,.25)}}
.onb-tooltip{position:absolute;z-index:10000;background:linear-gradient(135deg,#0d1117,#161b22);border:1px solid #059669;border-radius:16px;padding:16px 18px;max-width:280px;pointer-events:all;opacity:0;transform:translateY(10px);transition:all .35s cubic-bezier(.4,0,.2,1) .15s}
.onb-overlay.visible .onb-tooltip{opacity:1;transform:translateY(0)}
.onb-tooltip-arrow{position:absolute;width:12px;height:12px;background:linear-gradient(135deg,#0d1117,#161b22);border:1px solid #059669;transform:rotate(45deg);border-radius:2px}
.onb-tooltip-arrow.top{top:-7px;left:50%;margin-left:-6px;border-right:0;border-bottom:0}
.onb-tooltip-arrow.bottom{bottom:-7px;left:50%;margin-left:-6px;border-left:0;border-top:0}
.onb-tooltip h4{margin:0 0 6px;font-size:15px;font-weight:700;color:#34d399}
.onb-tooltip p{margin:0 0 14px;font-size:13px;color:#9ca3af;line-height:1.45}
.onb-tooltip-btn{display:block;width:100%;padding:10px;border:none;border-radius:10px;background:#059669;color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:Inter,sans-serif;transition:background .2s}
.onb-tooltip-btn:active{background:#047857}
.onb-tooltip-skip{display:block;text-align:center;margin-top:8px;font-size:11px;color:#6b7280;cursor:pointer;background:none;border:none;font-family:Inter,sans-serif}
.onb-tooltip-skip:active{color:#9ca3af}
.onb-counter{font-size:10px;color:#6b7280;text-align:right;margin-bottom:6px}
.geo-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:22px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;border:1px solid transparent;padding:0;background:none}
.geo-btn.active{background:#667eea25;border-color:#667eea60;box-shadow:0 0 8px #667eea30}
.geo-btn:not(.active):hover{background:#ffffff10}
.geo-fallback-flag{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:42px;line-height:1}
