/* ===== Кабинет SanGuard ===== */
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,.admin-form input,.admin-form select,.promo-row 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,.admin-form input:focus,.admin-form select:focus,.promo-row input:focus{border-color:rgba(35,130,28,.55);background:rgba(35,130,28,.05)}
.admin-form select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--green) 50%),linear-gradient(135deg,var(--green) 50%,transparent 50%);background-position:calc(100% - 18px) 22px,calc(100% - 12px) 22px;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.auth-card .btn{width:100%;margin-top:4px}
.auth-ref{margin:-6px 0 16px;padding:10px 12px;border:1px solid rgba(35,130,28,.24);border-radius:12px;background:rgba(35,130,28,.07);color:var(--green-soft);font-size:.84rem;font-weight:800}
.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(35,130,28,.16),rgba(35,130,28,.06));color:#fff;box-shadow:inset 0 0 0 1px rgba(35,130,28,.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}
.admin-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.admin-card-head h3{margin:0}
.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(35,130,28,.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}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.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(35,130,28,.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='%2386C98E' 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(35,130,28,.14);color:var(--green);font-weight:800;font-size:.9rem}
.step-num.ok2{background:rgba(35,130,28,.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(35,130,28,.4);background:rgba(35,130,28,.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}
.ref-card{display:grid;gap:10px}
.ref-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:4px}
.ref-stats>div{padding:13px 14px;border:1px solid var(--line);border-radius:13px;background:rgba(255,255,255,.02)}
.ref-stats span{display:block;font-size:.78rem;margin-bottom:3px}
.ref-stats strong{font-family:Unbounded,sans-serif;font-size:1rem;color:var(--green-soft)}
.contest-line{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:2px;color:var(--muted);font-size:.9rem;font-weight:800}
.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}
.trial-box{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;padding:16px;border:1px solid rgba(35,130,28,.26);border-radius:15px;background:rgba(35,130,28,.06)}
.trial-box strong{display:block;font-family:Unbounded,sans-serif;font-size:1rem}
.trial-box span{display:block;font-size:.88rem}
.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(35,130,28,.4)}
.pp.active{border-color:var(--green);background:rgba(35,130,28,.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;display:flex;align-items:center;justify-content:center;gap:7px;flex-wrap:wrap}
.term-pick button small{font-size:.72rem;line-height:1;padding:3px 6px;border-radius:999px;background:rgba(35,130,28,.13);color:var(--green-soft);font-weight:800}
.term-pick button:hover{border-color:rgba(35,130,28,.4)}
.term-pick button.active{border-color:var(--green);background:rgba(35,130,28,.1);color:#fff}
.promo-row{display:grid;grid-template-columns:1fr auto;gap:10px;margin-bottom:10px}
.promo-note{margin:0 0 14px;color:var(--green-soft);font-size:.88rem;font-weight:700}
.promo-note.bad{color:#ffb1a1}
.co-discount{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;color:var(--green-soft)}
.co-discount span{color:var(--muted)}
.co-discount strong{font-family:Unbounded,sans-serif}
.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}

/* ADMIN */
.admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.stat-card{padding:18px}
.stat-card span{display:block;font-size:.82rem}
.stat-card strong{display:block;margin-top:4px;font-family:Unbounded,sans-serif;font-size:1.35rem;color:var(--green-soft)}
.admin-form{display:grid;grid-template-columns:repeat(5,minmax(0,1fr)) auto;gap:10px;align-items:end;margin:12px 0 16px}
.admin-field{display:grid;gap:6px;min-width:0}
.admin-field span{color:#dce9e3;font-weight:800;font-size:.82rem}
.admin-field small{min-height:32px;color:var(--muted2);font-size:.74rem;line-height:1.35}
.admin-form .btn{align-self:center;margin-top:22px}
[data-promo-form]{grid-template-columns:132px 180px 132px 132px 132px 170px;gap:16px 12px;align-items:start;justify-content:start}
[data-promo-form] .admin-field:nth-of-type(6){grid-column:auto}
[data-promo-form] .admin-field-action{align-self:start;width:132px;padding-top:25px}
[data-promo-form] .admin-field-action .btn{min-height:50px;margin-top:0}
[data-grant-form]{grid-template-columns:minmax(220px,220px) minmax(220px,220px) minmax(220px,220px) minmax(220px,220px);gap:12px;align-items:start;justify-content:start}
[data-grant-form]>.btn{align-self:start;width:220px;min-height:50px;margin-top:29px}
.admin-list{display:grid;gap:10px;margin-top:12px}
.admin-item{display:grid;gap:4px;padding:13px 14px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.02)}
.admin-item strong{font-family:Unbounded,sans-serif;font-size:.95rem}
.admin-item span{color:var(--muted);font-size:.86rem}
.admin-field-action{align-self:end}
.admin-field-action .btn{width:100%;margin-top:0}
.promo-admin-item{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px}
.btn-xs{min-height:36px;padding:0 12px;font-size:.78rem;border-radius:10px}
.btn-danger{border-color:rgba(255,117,92,.28);background:rgba(255,117,92,.07);color:#ffc4b8}
.btn-danger:hover{border-color:rgba(255,117,92,.5);background:rgba(255,117,92,.12);color:#fff}
.contest-adjust-form{grid-template-columns:minmax(200px,240px) minmax(120px,140px) minmax(260px,1fr) 160px}
.contest-reason{min-width:0}
.contest-admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}
.contest-admin-grid>b,.contest-admin-grid b{display:block;margin:0 0 8px;color:#dce9e3;font-size:.86rem}
.contest-admin-row,.contest-event-row{display:grid;gap:3px;padding:11px 12px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.018);margin-top:8px}
.contest-admin-row strong,.contest-event-row strong{font-family:Unbounded,sans-serif;font-size:.82rem;overflow-wrap:anywhere}
.contest-admin-row span,.contest-event-row span{color:var(--muted);font-size:.78rem;line-height:1.35;overflow-wrap:anywhere}
.admin-table{display:grid;gap:8px;margin-top:12px}
.admin-row{display:grid;grid-template-columns:minmax(180px,1.4fr) .8fr .8fr .8fr;gap:10px;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.02);font-size:.9rem}
.admin-row b{word-break:break-all}
.admin-row span{color:var(--muted)}
.receipt-row{grid-template-columns:minmax(210px,1.35fr) .65fr .8fr 1fr auto;align-items:start}
.receipt-row>div{min-width:0}
.receipt-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.users-toolbar{display:grid;grid-template-columns:minmax(240px,1fr) minmax(220px,.45fr) auto;gap:10px;align-items:end;margin-bottom:12px}
.users-search{display:grid;gap:6px}
.users-search span{color:#dce9e3;font-weight:800;font-size:.82rem}
.users-search input,.users-search select{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}
.users-search select{appearance:none;padding-right:38px;background-image:linear-gradient(45deg,transparent 50%,var(--green) 50%),linear-gradient(135deg,var(--green) 50%,transparent 50%);background-position:calc(100% - 20px) 22px,calc(100% - 14px) 22px;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.users-search input:focus,.users-search select:focus{border-color:rgba(35,130,28,.55);background-color:rgba(35,130,28,.05)}
.users-meta{margin:4px 0 10px;color:var(--muted2);font-size:.84rem}
.users-table{gap:9px}
.user-row{grid-template-columns:minmax(210px,1.35fr) .62fr .62fr .9fr .78fr;align-items:start}
.user-email{display:grid;gap:4px;color:var(--ink)}
.user-email b{word-break:break-all}
.user-email small{color:var(--muted2);font-size:.75rem;line-height:1.35}
.devices-cell{display:grid;gap:4px}
.devices-cell strong{font-family:Unbounded,sans-serif;font-size:.95rem;color:var(--green-soft)}
.devices-cell small{display:grid;gap:3px;color:var(--muted2);font-size:.75rem;line-height:1.35}
.device-line{display:flex;align-items:center;gap:7px;min-width:0}
.device-dot{width:7px;height:7px;border-radius:50%;flex:0 0 7px;background:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.12)}
.device-dot.online{background:var(--green-soft);box-shadow:0 0 0 3px rgba(112,255,166,.12)}
.device-name{min-width:0;overflow-wrap:anywhere}
.pager{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:14px}
.pager span{color:var(--muted);font-weight:800;font-size:.88rem}
.analytics-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.analytics-list{display:grid;gap:9px;margin-top:12px}
.analytics-row{display:grid;gap:3px;padding:13px 14px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.02)}
.analytics-row span{color:var(--muted);font-size:.84rem}
.analytics-row strong{font-family:Unbounded,sans-serif;font-size:1rem;color:var(--green-soft)}
.analytics-row em{color:var(--muted2);font-style:normal;font-size:.78rem}

/* BUILDS */
.build-card{display:grid;gap:16px}
.build-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.build-head h3{margin-bottom:5px}
.build-badge{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border:1px solid rgba(35,130,28,.34);border-radius:999px;background:rgba(35,130,28,.08);color:var(--green-soft);font-family:Unbounded,sans-serif;font-size:.78rem;font-weight:800;white-space:nowrap}
.build-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.build-grid>div{display:grid;gap:4px;padding:14px;border:1px solid var(--line);border-radius:13px;background:rgba(255,255,255,.02)}
.build-grid span{font-size:.8rem}
.build-grid strong{font-family:Unbounded,sans-serif;font-size:.92rem}
.build-actions{display:flex;gap:10px;flex-wrap:wrap}
.build-actions .btn{min-height:46px}
.build-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.build-mini{display:grid;gap:5px;padding:16px;border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.02);transition:.18s}
.build-mini:hover{border-color:rgba(35,130,28,.4);background:rgba(35,130,28,.06)}
.build-mini b{font-family:Unbounded,sans-serif;font-size:.95rem;color:var(--ink)}
.build-mini span{color:var(--muted);font-size:.82rem}
.build-mini.muted-card{opacity:.72}
.build-mini.muted-card:hover{border-color:var(--line);background:rgba(255,255,255,.02)}

/* MODALS */
.modal-backdrop{position:fixed;inset:0;z-index:70;display:grid;place-items:center;padding:20px;background:rgba(0,0,0,.62);backdrop-filter:blur(8px)}
.modal-card{width:min(780px,100%);max-height:min(760px,calc(100vh - 40px));overflow:auto;border:1px solid var(--line2);border-radius:22px;background:rgba(8,18,15,.96);box-shadow:0 26px 80px rgba(0,0,0,.55);padding:22px}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}
.modal-head h3{margin:0 0 4px;font-size:1.18rem}
.modal-close{width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line2);border-radius:12px;background:rgba(255,255,255,.03);color:var(--ink);font-size:1.6rem;line-height:1;cursor:pointer}
.modal-close:hover{border-color:rgba(35,130,28,.4);background:rgba(35,130,28,.07)}
.promo-history-list{max-height:560px;overflow:auto;padding-right:2px}
.leaderboard-list{display:grid;gap:9px}
.leaderboard-row{padding:14px 15px;border:1px solid var(--line);border-radius:13px;background:rgba(255,255,255,.025)}
.leaderboard-row strong{display:block;font-family:Unbounded,sans-serif;font-size:.95rem;line-height:1.35;overflow-wrap:anywhere}
.leaderboard-row span{color:var(--muted)}

/* 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,#1C8248,#23821C);color:#f4fff7;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}
  .admin-grid{grid-template-columns:1fr 1fr}
  .admin-form{grid-template-columns:1fr 1fr}
  [data-promo-form]{grid-template-columns:1fr 1fr}
  [data-promo-form] .admin-field:nth-of-type(6),[data-promo-form] .admin-field-action{grid-column:auto}
  [data-promo-form] .admin-field-action{padding-top:25px}
  .admin-row,.user-row,.receipt-row,.promo-admin-item{grid-template-columns:1fr}
  .contest-admin-grid{grid-template-columns:1fr}
  .contest-adjust-form{grid-template-columns:1fr 1fr}
  .receipt-actions{justify-content:flex-start}
  .analytics-grid{grid-template-columns:1fr}
  .build-grid,.build-list{grid-template-columns:1fr 1fr}
  .ref-stats{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){
  .dl-grid,.term-pick,.promo-row,.trial-box,.users-toolbar,.ref-stats{grid-template-columns:1fr}
  .trial-box{display:grid}
  .admin-grid,.admin-form,[data-promo-form],[data-grant-form]{grid-template-columns:1fr}
  .contest-line{display:grid;align-items:start}
  .contest-adjust-form{grid-template-columns:1fr}
  [data-promo-form] .admin-field-action{width:100%;padding-top:0}
  [data-grant-form]>.btn{width:100%;margin-top:0}
  .build-head,.build-actions{display:grid}
  .build-grid,.build-list{grid-template-columns:1fr}
  .pager{justify-content:stretch}
  .pager .btn{flex:1}
}
