/* ===== Кабинет SanVPN ===== */
body.cab{min-height:100vh}
[hidden]{display:none!important}

/* AUTH */
.auth-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;padding:40px 20px}
.auth-brand{margin-bottom:4px}
.auth-card{width:min(420px,100%);border:1px solid var(--line2);border-radius:var(--r-lg);background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(12px);padding:30px}
.auth-card h1{font-size:1.6rem}
.auth-sub{color:var(--muted);margin:8px 0 20px;font-weight:500}
.auth-card form{display:grid;gap:11px}
.auth-card input,.pass-form input{width:100%;min-height:50px;padding:0 16px;border:1px solid var(--line2);border-radius:12px;background:rgba(255,255,255,.03);color:var(--ink);font:inherit;outline:0;transition:border-color .2s,background .2s}
.auth-card input:focus,.pass-form input:focus{border-color:rgba(39,224,109,.55);background:rgba(39,224,109,.05)}
.auth-card .btn{width:100%;margin-top:4px}
.auth-switch{display:flex;gap:8px;justify-content:center;margin-top:16px;color:var(--muted);font-size:.92rem}
.auth-switch button{background:0;border:0;color:var(--green);font-weight:700;cursor:pointer;font-size:.92rem}
.auth-back{display:block;text-align:center;margin-top:14px;color:var(--muted2);font-size:.85rem}

/* APP SHELL */
.cab-app{display:grid;grid-template-columns:264px 1fr;gap:22px;max-width:1180px;margin:0 auto;padding:28px 22px 60px;min-height:100vh}
.cab-side{position:sticky;top:22px;align-self:start;display:flex;flex-direction:column;gap:6px;
  border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(12px);padding:18px}
.cab-user{padding:6px 10px 16px;border-bottom:1px solid var(--line);margin-bottom:8px}
.cab-user strong{display:block;font-size:.95rem;word-break:break-all}
.cab-user span{color:var(--muted2);font-size:.8rem}
.cab-link{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:0;border-radius:12px;background:0;color:var(--muted);font:inherit;font-weight:700;font-size:.95rem;cursor:pointer;text-align:left;transition:.18s}
.cab-link svg{width:20px;height:20px;flex:0 0 auto;fill:currentColor;opacity:.9}
.cab-link:hover{background:rgba(255,255,255,.04);color:var(--ink)}
.cab-link.active{background:linear-gradient(135deg,rgba(39,224,109,.16),rgba(39,224,109,.06));color:#fff;box-shadow:inset 0 0 0 1px rgba(39,224,109,.25)}
.cab-logout{margin-top:8px;border-top:1px solid var(--line);border-radius:0 0 12px 12px;padding-top:16px;color:var(--muted2)}
.cab-logout:hover{color:#ff8e7a}

.cab-main{display:grid;gap:18px;align-content:start}
.cab-pane{display:none;gap:18px;grid-auto-rows:min-content}
.cab-pane.active{display:grid}
.pane-title{font-size:1.7rem}
.pane-sub{margin:6px 0 6px}
.cab-card{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(10px);padding:24px}
.cab-card h3{font-size:1.1rem;margin:0 0 6px}
.muted{color:var(--muted)} .small{font-size:.85rem} .center{text-align:center}

/* SUB STATUS */
.sub-status .ss-head{display:flex;align-items:center;gap:14px}
.ss-ic{width:46px;height:46px;flex:0 0 auto;display:grid;place-items:center;border-radius:13px;background:rgba(39,224,109,.12);color:var(--green)}
.ss-ic.off{background:rgba(255,255,255,.05);color:var(--muted)}
.ss-ic svg{width:24px;height:24px}
.sub-status strong{font-size:1.2rem;font-family:Unbounded,sans-serif;font-weight:700}
.ss-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
.ss-grid>div{padding:14px 16px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.02)}
.ss-grid span{display:block;font-size:.82rem;margin-bottom:4px}
.ss-grid strong{font-size:1.05rem}
.sub-status .btn{margin-top:18px}

/* COPY / QR */
.copy-row{display:flex;gap:10px;align-items:center;margin-top:12px;flex-wrap:wrap}
.copy-row code{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:13px 14px;border:1px solid var(--line2);border-radius:11px;background:rgba(0,0,0,.25);color:var(--green-soft);font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.85rem}
.btn-sm{min-height:42px;padding:0 16px;font-size:.88rem}
.qr{margin-top:16px}
.qr img,.qr canvas,.qr table{background:#fff;padding:10px;border-radius:12px;width:148px;height:148px}
.note{margin-top:12px;color:var(--green-soft);font-size:.85rem;font-weight:600}

/* INCLUDE */
.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.incl-grid span{position:relative;padding:12px 14px 12px 38px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.02);font-size:.92rem;font-weight:600}
.incl-grid span::before{content:"";position:absolute;left:12px;top:13px;width:16px;height:16px;border-radius:50%;background:rgba(39,224,109,.14) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 13l4 4 10-11' fill='none' stroke='%2327e06d' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/11px no-repeat}

/* SETUP */
.step-card .step-h{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.step-num{width:30px;height:30px;flex:0 0 auto;display:grid;place-items:center;border-radius:9px;background:rgba(39,224,109,.14);color:var(--green);font-weight:800;font-size:.9rem}
.step-num.ok2{background:rgba(39,224,109,.16)} .step-num.ok2 svg{width:18px;height:18px}
.step-card strong{font-size:1.05rem}
.dl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dl{display:flex;flex-direction:column;gap:3px;padding:14px;border:1px solid var(--line);border-radius:13px;background:rgba(255,255,255,.02);transition:.18s}
.dl:hover{border-color:rgba(39,224,109,.4);background:rgba(39,224,109,.06)}
.dl b{font-size:.95rem} .dl span{color:var(--green-soft);font-size:.82rem;font-weight:600}
.or{display:flex;align-items:center;gap:12px;color:var(--muted2);font-size:.82rem;margin:16px 0}
.or::before,.or::after{content:"";flex:1;height:1px;background:var(--line)}
.step-card .btn{width:100%}

/* PROFILE */
.prof-row{display:flex;justify-content:space-between;gap:12px;align-items:center}
.prof-row strong{word-break:break-all}
.pass-form{display:grid;gap:11px;margin-top:6px}

/* CHECKOUT */
.co-step{font-weight:800;margin:6px 0 12px;font-family:Unbounded,sans-serif;font-size:.95rem}
.plan-pick{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.pp{position:relative;padding:18px;border:1px solid var(--line2);border-radius:15px;background:rgba(255,255,255,.02);cursor:pointer;transition:.18s}
.pp:hover{border-color:rgba(39,224,109,.4)}
.pp.active{border-color:var(--green);background:rgba(39,224,109,.08);box-shadow:0 0 0 1px var(--green)}
.pp b{display:block;font-size:1.15rem;font-family:Unbounded,sans-serif}
.pp span{color:var(--muted);font-size:.85rem}
.term-pick{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:22px}
.term-pick button{min-height:46px;border:1px solid var(--line2);border-radius:12px;background:rgba(255,255,255,.02);color:var(--muted);font:inherit;font-weight:700;cursor:pointer;transition:.18s}
.term-pick button:hover{border-color:rgba(39,224,109,.4)}
.term-pick button.active{border-color:var(--green);background:rgba(39,224,109,.1);color:#fff}
.co-total{display:flex;justify-content:space-between;align-items:baseline;padding:16px 0;border-top:1px solid var(--line);margin-top:6px}
.co-total span{color:var(--muted)}
.co-total strong{font-family:Unbounded,sans-serif;font-size:1.8rem;font-variant-numeric:tabular-nums;color:var(--green-soft)}
.co-pay{width:100%;margin-top:6px}
.co-error{margin-top:12px;padding:12px 14px;border:1px solid rgba(255,120,90,.4);border-radius:12px;background:rgba(255,120,90,.08);color:#ffb1a1;font-size:.9rem}

/* TOAST */
.toast{position:fixed;right:18px;bottom:18px;z-index:80;max-width:min(360px,calc(100% - 36px));padding:13px 16px;border-radius:13px;
  background:linear-gradient(135deg,#5cf09a,#27e06d);color:#04140a;font-weight:800;box-shadow:0 16px 40px rgba(0,0,0,.4);opacity:0;transform:translateY(14px);pointer-events:none;transition:.2s}
.toast.show{opacity:1;transform:none}

@media (max-width:860px){
  .cab-app{grid-template-columns:1fr}
  .cab-side{position:static;flex-direction:row;flex-wrap:wrap;align-items:center}
  .cab-user{width:100%;border-bottom:1px solid var(--line)}
  .cab-link{width:auto}.cab-logout{margin-left:auto;border:0;border-radius:12px;padding-top:12px}
  .dl-grid,.plan-pick,.term-pick,.incl-grid,.ss-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){.dl-grid,.term-pick{grid-template-columns:1fr}}
