/* RudeHolm — личный кабинет (северный стиль) */

.wrap{position:relative;z-index:1;min-height:calc(100vh - 52px)}
.lk-main{max-width:1100px;margin:0 auto;padding:20px 24px 72px}
.lk-tabs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:28px}
.lk-tab{padding:10px 20px;border:1px solid var(--border);background:rgba(0,0,0,.25);border-radius:999px;color:var(--muted);font-weight:600;cursor:pointer;font-family:inherit;transition:.2s;position:relative}
a.lk-tab{text-decoration:none;display:inline-block;color:var(--muted)}
a.lk-tab:hover{color:var(--text);border-color:rgba(255,255,255,.14)}
.lk-tab.on{background:color-mix(in srgb, var(--accent) 14%, transparent);border-color:var(--accent);color:var(--accent2)}
.lk-panel{display:none}
.lk-panel.on{display:block}
.cabinet-grid{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:22px}
.cabinet-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px}
.cabinet-guest{max-width:440px;margin:40px auto 0;text-align:center;padding:48px 28px;background:var(--card);border:1px dashed var(--border);border-radius:14px}
.lk-main.lk-auth-guest #cabinetUser{display:none!important}
.lk-main.lk-auth-user #cabinetGuest{display:none!important}
.lk-main.lk-auth-user #cabinetUser{display:block!important}
.prof-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.prof-ava{width:80px;height:80px;border-radius:12px;border:2px solid var(--accent);object-fit:cover}
.prof-rank{color:var(--muted);font-size:.88rem;margin-top:2px}
.cabinet-stat{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border);font-size:.92rem}
.cabinet-stat:last-of-type{border-bottom:none}
.cabinet-stat span{color:var(--muted);flex-shrink:0}
.cabinet-stat strong{color:var(--accent);font-weight:700;text-align:right;line-height:1.3}
.cabinet-balances{margin-bottom:4px;padding-bottom:4px;border-bottom:1px solid var(--border)}
.cabinet-balances .cabinet-stat:last-child{border-bottom:none}
.lk-trade-hint{
    margin:2px 0 14px;padding:8px 12px;border-radius:9px;text-align:center;
    background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.18);
    font-size:.76rem;color:var(--muted);line-height:1.4;
}
.lk-trade-hint a{color:var(--accent2);font-weight:600;text-decoration:none}
.lk-trade-hint a:hover{text-decoration:underline}
.lk-label{color:var(--muted);font-size:.85rem;margin:18px 0 8px;display:block}
.lk-input{width:100%;padding:11px 14px;background:rgba(0,0,0,.35);border:1px solid var(--border);border-radius:9px;color:var(--text);font-size:.95rem;font-family:inherit;outline:none}
.lk-input:focus{border-color:var(--accent)}
.row-flex{display:flex;gap:8px;align-items:stretch}
.row-flex .lk-input{margin:0;flex:1;min-width:0}
.row-flex .btn{flex-shrink:0;min-width:96px;padding:11px 16px;font-size:.85rem}
.cabinet-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}
.cabinet-actions .btn,.cabinet-actions a.btn{
    display:inline-flex;align-items:center;justify-content:center;width:100%;
    text-decoration:none;text-align:center;white-space:nowrap;
}
.friends-add{display:flex;gap:8px;margin-bottom:16px}
.friends-add .lk-input{margin:0}
.friends-section-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:16px 0 8px;font-weight:700}
.friend-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:10px;margin-bottom:8px;background:rgba(0,0,0,.2)}
.friend-row-name{font-weight:700}
.friend-dm-layout{display:grid;grid-template-columns:minmax(200px,260px) minmax(0,1fr);gap:12px;margin-top:12px;min-height:460px}
.friend-dm-sidebar{border:1px solid var(--border);border-radius:12px;background:rgba(0,0,0,.22);overflow:hidden;display:flex;flex-direction:column;max-height:min(68vh,560px)}
.friend-dm-sidebar-head{padding:10px 12px;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;border-bottom:1px solid var(--border)}
.friend-dm-list{overflow-y:auto;flex:1}
.friend-dm-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-bottom:1px solid rgba(255,255,255,.04);background:transparent;color:var(--text);cursor:pointer;text-align:left;font-family:inherit}
.friend-dm-item:hover,.friend-dm-item.on{background:rgba(201,162,84,.1)}
.friend-dm-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;background:rgba(255,255,255,.06);flex-shrink:0}
.friend-dm-meta{min-width:0;flex:1}
.friend-dm-name{font-weight:700;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.friend-dm-preview{font-size:.74rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.friend-dm-badge{min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--accent);color:#0b1220;font-size:.68rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.friend-dm-main{border:1px solid var(--border);border-radius:12px;background:rgba(0,0,0,.18);display:flex;flex-direction:column;min-height:460px;max-height:min(68vh,560px);min-width:0;overflow:hidden}
.friend-dm-empty,.friend-dm-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.88rem;padding:24px;text-align:center}
.friend-dm-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border)}
.friend-dm-head-name{font-weight:700}
.friend-dm-msgs{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:6px;align-items:stretch}
.friend-dm-msg{
    width:fit-content;max-width:min(72%,420px);padding:7px 11px 5px;border-radius:14px;
    font-size:.86rem;line-height:1.4;white-space:pre-wrap;overflow-wrap:break-word;word-break:normal;
}
.friend-dm-msg.mine{align-self:flex-end;background:rgba(201,162,84,.14);border:1px solid rgba(201,162,84,.28);border-bottom-right-radius:4px}
.friend-dm-msg.theirs{align-self:flex-start;background:rgba(255,255,255,.06);border:1px solid var(--border);border-bottom-left-radius:4px}
.friend-dm-msg time{display:block;margin-top:3px;font-size:.64rem;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.friend-dm-compose{display:flex;align-items:flex-end;gap:8px;padding:8px 12px 10px;border-top:1px solid var(--border);background:rgba(0,0,0,.12)}
.friend-dm-compose .lk-input{
    margin:0;flex:1;min-width:0;resize:none;overflow-y:auto;scrollbar-width:thin;
    min-height:36px;max-height:120px;height:36px;padding:8px 14px;line-height:1.35;border-radius:18px;
}
.friend-dm-compose .btn-dm-send{flex-shrink:0;width:40px;height:36px;padding:0;border-radius:50%;font-size:1rem;line-height:1;display:inline-flex;align-items:center;justify-content:center}
.friends-tab-badge{display:inline-flex;min-width:18px;height:18px;padding:0 5px;margin-left:6px;border-radius:999px;background:#f87171;color:#fff;font-size:.68rem;font-weight:800;vertical-align:middle;align-items:center;justify-content:center}
@media(max-width:760px){.friend-dm-layout{grid-template-columns:1fr}.friend-dm-sidebar,.friend-dm-main{max-height:none}}
.friend-guide-box{margin-top:16px;padding:14px;border:1px dashed rgba(201,162,84,.28);border-radius:10px;font-size:.88rem;line-height:1.55;color:var(--muted)}
.friend-guide-box ol{margin:10px 0 0 18px}
.friend-guide-box li{margin-bottom:6px}
.ref-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin:16px 0}
.ref-stat{padding:14px;border:1px solid var(--border);border-radius:10px;background:rgba(0,0,0,.22);text-align:center}
.ref-stat strong{display:block;font-size:1.35rem;color:var(--accent2);margin-bottom:4px}
.ref-stat span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.ref-link-box{display:flex;gap:8px;margin:12px 0 16px}
.ref-link-box .lk-input{margin:0;font-size:.82rem}
.ref-rewards{margin:0 0 16px;padding:12px 14px;border-radius:10px;background:rgba(201,162,84,.08);border:1px solid rgba(201,162,84,.22);font-size:.86rem;line-height:1.55;color:var(--muted)}
.ref-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;border:1px solid var(--border);border-radius:10px;margin-bottom:8px;background:rgba(0,0,0,.2);font-size:.88rem}
.ref-row-name{font-weight:700}
.ref-row-meta{font-size:.72rem;color:var(--muted)}
.cabinet-history{width:100%;border-collapse:collapse;font-size:.86rem}
.cabinet-history th,.cabinet-history td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}
.cabinet-history th{color:var(--muted);font-size:.75rem;text-transform:uppercase}
.hist-amt{font-weight:700;white-space:nowrap;font-variant-numeric:tabular-nums}
.hist-amt.in{color:var(--vk-ok,#6ee7a8)}
.hist-amt.out{color:#f87171}
.hist-type{display:inline-block;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:4px;margin-right:6px;vertical-align:middle}
.hist-type.in{background:rgba(74,222,128,.12);color:var(--vk-ok,#6ee7a8)}
.hist-type.out{background:rgba(248,113,113,.12);color:#f87171}
.prefix-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;align-items:stretch}
.prefix-card{
    display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
    min-height:132px;padding:16px 12px;border-radius:12px;border:1px solid var(--border);
    background:rgba(0,0,0,.25);text-align:center;transition:.2s;
}
.prefix-card.owned{cursor:pointer}
.prefix-card.owned:hover{border-color:var(--accent)}
.prefix-card.on{border-color:var(--accent);box-shadow:0 0 14px var(--accent-glow)}
.prefix-card.locked{opacity:.45}
.prefix-card .ico{font-size:2rem;line-height:1;margin-bottom:10px;flex-shrink:0}
.prefix-card .name{font-weight:700;font-size:.92rem;line-height:1.25}
.prefix-card.rainbow .name{
    background:linear-gradient(90deg,#f43f5e,#f97316,#eab308,#22c55e,#06b6d4,#8b5cf6,#ec4899,#f43f5e);
    background-size:200% auto;
    -webkit-background-clip:text;background-clip:text;color:transparent!important;
    animation:rainbow-shift 4s linear infinite;
}
@keyframes rainbow-shift{to{background-position:200% center}}
.prefix-card.golden .name{
    background:linear-gradient(90deg,#78350f,#b45309,#fbbf24,#fef3c7,#f59e0b,#fde68a,#d97706,#fcd34d,#78350f);
    background-size:200% auto;
    -webkit-background-clip:text;background-clip:text;color:transparent!important;
    animation:golden-shift 3s linear infinite;
}
.prefix-card.fire .name{
    background:linear-gradient(90deg,#ef4444,#f97316,#eab308,#fbbf24,#f97316,#ef4444);
    background-size:200% auto;
    -webkit-background-clip:text;background-clip:text;color:transparent!important;
    animation:fire-shift 3s linear infinite;
}
@keyframes fire-shift{to{background-position:200% center}}
.prefix-card.golden.owned{
    position:relative;isolation:isolate;
    border:2px solid transparent;
    background:
        linear-gradient(145deg,rgba(20,16,8,.92),rgba(0,0,0,.28)) padding-box,
        linear-gradient(90deg,#78350f,#fbbf24,#fef3c7,#f59e0b,#fcd34d,#fde68a,#78350f) border-box;
    background-size:100% 100%,300% 100%;
    animation:golden-border-shift 4s linear infinite;
    box-shadow:0 0 28px rgba(251,191,36,.24),0 0 56px rgba(251,191,36,.1),inset 0 0 22px rgba(251,191,36,.06);
}
.prefix-card.golden.owned::after{
    content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:0;
    background:radial-gradient(ellipse 85% 55% at 50% -15%,rgba(252,211,77,.38),transparent 58%);
    animation:apex-shimmer 3s ease-in-out infinite;
}
.prefix-card.golden.owned > *{position:relative;z-index:1}
.prefix-card.golden.on{
    border-color:#fcd34d;
    box-shadow:0 0 22px rgba(251,191,36,.45),0 0 48px rgba(252,211,77,.18),inset 0 0 18px rgba(251,191,36,.08);
}
@keyframes golden-shift{to{background-position:200% center}}
@keyframes golden-border-shift{to{background-position:0 0,300% 0}}
@keyframes apex-shimmer{0%,100%{opacity:.5}50%{opacity:1}}
.pfx-rank{
    display:inline-block;margin-top:6px;padding:2px 8px;border-radius:999px;
    font-size:.6rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
    border:1px solid transparent;
}
.pfx-rank--common{color:#94a3b8;border-color:rgba(148,163,184,.35);background:rgba(148,163,184,.08)}
.pfx-rank--uncommon{color:var(--vk-ok,#6ee7a8);border-color:rgba(74,222,128,.35);background:rgba(74,222,128,.08)}
.pfx-rank--rare{color:var(--vk-frost,#8ecae6);border-color:rgba(142,202,230,.35);background:rgba(142,202,230,.08)}
.pfx-rank--legendary{color:#fbbf24;border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.1)}
.pfx-rank--mythic{color:#c084fc;border-color:rgba(192,132,252,.4);background:rgba(192,132,252,.1)}
.pfx-rank--unique{color:#f472b6;border-color:rgba(244,114,182,.4);background:rgba(244,114,182,.1)}
.pfx-rank--apex{color:#fcd34d;border-color:rgba(252,211,77,.5);background:rgba(252,211,77,.12);box-shadow:0 0 10px rgba(252,211,77,.15)}
.pfx-rank-head{grid-column:1/-1;margin:14px 0 4px;font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.pfx-rank-head:first-child{margin-top:0}
.prefix-progress{font-size:1rem;font-weight:800;color:var(--accent2);margin:0 0 10px}
.prefix-progress:empty{display:none;margin:0}
.prefix-progress.is-loading{font-size:.82rem;font-weight:600;color:var(--muted)}
.pfx-loading{color:var(--muted);font-size:.88rem;padding:8px 0 12px;margin:0}
.prefix-progress small{display:block;font-size:.78rem;font-weight:600;color:var(--muted);margin-top:4px}
.pfx-sell-btn{
    margin-top:8px;padding:6px 10px;border-radius:8px;border:1px solid rgba(252,211,77,.45);
    background:rgba(252,211,77,.12);color:#fcd34d;font-size:.68rem;font-weight:700;cursor:pointer;
}
.pfx-sell-top{
    display:inline-block;margin-top:6px;padding:3px 8px;border-radius:999px;
    border:1px solid rgba(252,211,77,.4);background:rgba(252,211,77,.1);
    color:#fcd34d;font-size:.64rem;font-weight:800;letter-spacing:.02em;
}
.pfx-stats{margin-top:6px;width:100%;padding:5px 8px;border-radius:8px;background:rgba(0,0,0,.22);transition:padding .22s ease,background .22s ease,box-shadow .22s ease;cursor:pointer;user-select:none}
.pfx-stats-short{font-size:.62rem;line-height:1.35;color:var(--muted);opacity:.95;transition:opacity .18s ease,max-height .22s ease}
.pfx-stats-short::after{content:' · подробнее';color:var(--accent2);font-weight:600}
.pfx-stats-detail{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease}
.pfx-stats-detail-inner{overflow:hidden}
.pfx-stats-detail-inner div{font-size:.68rem;line-height:1.5;color:#e2e8f0;text-align:left;padding:1px 0}
.pfx-stats-detail-inner div+div{margin-top:2px}
.prefix-card:has(.pfx-stats){position:relative;z-index:1;transition:min-height .25s ease,border-color .2s,box-shadow .2s,transform .22s ease,z-index 0s}
.prefix-card:has(.pfx-stats).stats-open{z-index:8;transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.45)}
.prefix-card:has(.pfx-stats).stats-open .pfx-stats{padding:8px 10px;background:rgba(0,0,0,.42);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.prefix-card:has(.pfx-stats).stats-open .pfx-stats-short{opacity:0;max-height:0;overflow:hidden;margin:0;padding:0}
.prefix-card:has(.pfx-stats).stats-open .pfx-stats-short::after{content:none}
.prefix-card:has(.pfx-stats).stats-open .pfx-stats-detail{grid-template-rows:1fr}
.pfx-sell-btn:hover{background:rgba(252,211,77,.22)}
.prefix-card .pfx-hint{
    margin-top:auto;padding-top:10px;font-size:.72rem;line-height:1.35;
    color:var(--muted);max-width:100%;text-align:center;
}
.prefix-card.on .pfx-hint{color:var(--accent2)}
.prefix-card.none-card{border-style:dashed}
.prefix-card.none-card .ico{opacity:.75;font-size:1.6rem}
.pfx-quest-section{margin-top:28px;padding-top:22px;border-top:1px solid var(--border)}
.pfx-quest-section h4{margin:0 0 6px;font-size:1rem}
.pfx-quest-sub{color:var(--muted);font-size:.84rem;margin:0 0 14px;line-height:1.45}
.pfx-quest-rank{margin:16px 0 8px;font-size:.78rem;font-weight:800;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.pfx-quest-item{align-items:flex-start;transition:border-color .2s,box-shadow .2s,background .2s}
.pfx-quest-item.has-daily-reward{
    border-color:rgba(239,68,68,.4);
    background:rgba(239,68,68,.07);
    box-shadow:0 0 0 1px rgba(239,68,68,.12);
}
.pfx-quest-item.is-highlight{
    border-color:rgba(239,68,68,.65)!important;
    box-shadow:0 0 0 3px rgba(239,68,68,.28),0 8px 28px rgba(239,68,68,.12)!important;
}
.pfx-quest-reward{display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:.78rem;color:var(--accent);font-weight:700;text-align:right;position:relative}
.pfx-quest-reward .pfx-quest-ready-dot{margin-bottom:2px}
.pfx-quest-scroll-nav{
    position:fixed;right:0;top:50%;z-index:900;
    display:flex;align-items:center;gap:8px;
    padding:11px 16px 11px 13px;
    border:1px solid rgba(239,68,68,.45);border-right:none;
    border-radius:999px 0 0 999px;
    background:rgba(14,16,22,.96);
    box-shadow:-6px 0 28px rgba(0,0,0,.45);
    color:var(--text);font-family:inherit;font-size:.78rem;font-weight:700;
    cursor:pointer;
    opacity:0;visibility:hidden;pointer-events:none;
    transform:translateY(-50%) translateX(110%);
    transition:opacity .28s ease,transform .28s cubic-bezier(.34,1.2,.64,1),visibility .28s;
}
.pfx-quest-scroll-nav.is-visible{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(-50%) translateX(0)}
.pfx-quest-scroll-nav__dot{
    width:8px;height:8px;border-radius:50%;flex-shrink:0;position:relative;
    background:#ef4444;
}
.pfx-quest-scroll-nav__dot::after{
    content:'';position:absolute;inset:-3px;border-radius:50%;background:#ef4444;
    opacity:.3;animation:live-ring 2s ease-in-out infinite;
}
.pfx-quest-scroll-nav__text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.25;text-align:left}
.pfx-quest-scroll-nav__text small{font-size:.65rem;font-weight:600;color:var(--muted)}
@media(max-width:640px){
    .pfx-quest-scroll-nav{padding:10px 12px 10px 10px;font-size:.72rem}
    .pfx-quest-scroll-nav__text small{display:none}
}
.pfx-quest-reward small{font-size:.68rem;color:var(--muted);font-weight:600}
.pfx-rainbow-text{
    background:linear-gradient(90deg,#f43f5e,#f97316,#eab308,#22c55e,#06b6d4,#8b5cf6,#ec4899,#f43f5e);
    background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent!important;
    animation:rainbow-shift 4s linear infinite;font-weight:800;
}
.avatar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.settings-card{width:100%}
.settings-layout{display:grid;grid-template-columns:minmax(260px,340px) 1fr;gap:28px 32px;align-items:start}
.settings-col{display:flex;flex-direction:column;min-width:0}
.settings-col .avatar-grid{grid-template-columns:repeat(3,1fr)}
.settings-forms{display:flex;flex-direction:column;gap:0}
.lk-panel>.cabinet-card{width:100%}
@media(max-width:820px){.settings-layout{grid-template-columns:1fr}.settings-col .avatar-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:480px){.cabinet-actions{grid-template-columns:1fr}}
.avatar-opt{aspect-ratio:1;border-radius:12px;border:2px solid var(--border);background:rgba(0,0,0,.3);cursor:pointer;padding:4px}
.avatar-opt.on{border-color:var(--accent);box-shadow:0 0 14px var(--accent-glow)}
.avatar-opt img{width:100%;height:100%;object-fit:cover;border-radius:8px}
.settings-block{margin-top:22px;padding-top:20px;border-top:1px solid var(--border)}
.settings-block h4{margin:0 0 6px;font-size:.95rem}
.settings-block p{margin:0 0 12px;color:var(--muted);font-size:.82rem;line-height:1.45}
.settings-email{display:inline-block;padding:8px 12px;border-radius:8px;background:rgba(0,0,0,.25);border:1px solid var(--border);font-size:.88rem;margin-bottom:12px}
.settings-email.pending{border-color:rgba(251,191,36,.4);color:#fbbf24}
.auth-tabs{display:flex;gap:4px;background:rgba(0,0,0,.3);border-radius:10px;padding:4px;margin-bottom:18px}
.auth-tab{flex:1;padding:9px;border:none;background:transparent;color:var(--muted);font-weight:600;border-radius:8px;cursor:pointer;font-family:inherit}
.auth-tab.on{background:linear-gradient(135deg,var(--accent2),var(--accent));color:#1a1208}
.reg-method-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.reg-method{padding:8px 12px;border:1px solid var(--border);border-radius:999px;background:rgba(0,0,0,.2);color:var(--muted);font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit}
.reg-method.on{border-color:var(--accent);color:var(--accent2);background:rgba(201,162,84,.1)}
.social-auth{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.social-auth p{margin:0 0 10px;color:var(--muted);font-size:.82rem}
.social-btns{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.btn-vk{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 16px;border:none;border-radius:10px;background:#0077ff;color:#fff;font-weight:700;cursor:pointer;font-family:inherit;font-size:.95rem;text-decoration:none;transition:filter .2s,transform .15s}
.btn-vk:hover{filter:brightness(1.08)}
.btn-vk:active{transform:scale(.99)}
.btn-vk:disabled{opacity:.45;cursor:not-allowed}
.btn-vk svg{flex-shrink:0}
.link-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.link-row:last-child{border-bottom:none;padding-bottom:0}
.link-info{display:flex;align-items:center;gap:10px;min-width:0}
.link-info strong{font-size:.92rem}
.link-info span{font-size:.82rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.link-badge{font-size:.72rem;padding:3px 8px;border-radius:999px;background:rgba(201,162,84,.12);color:var(--vk-ok,#6ee7a8);flex-shrink:0}
.link-actions{display:flex;gap:8px;flex-shrink:0}
.btn-vk-sm{padding:8px 14px;font-size:.85rem;width:auto}
.btn-discord{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 14px;border:none;border-radius:10px;background:#5865f2;color:#fff;font-weight:700;cursor:pointer;font-family:inherit;font-size:.85rem;text-decoration:none;transition:filter .2s}
.btn-discord:hover{filter:brightness(1.08)}
.btn-discord-sm{padding:8px 14px;font-size:.85rem}
.social-btns-col{display:flex;flex-direction:column;gap:10px}
.tg-widget-wrap{min-height:44px;display:flex;justify-content:center}
.social-hint{font-size:.78rem;color:var(--muted);margin-top:8px;line-height:1.4}
.reg-legal-row{
    display:flex;align-items:flex-start;gap:10px;margin:12px 0 4px;
    font-size:.78rem;color:var(--muted);line-height:1.45;text-align:left;
}
.reg-legal-row input{margin-top:3px;flex-shrink:0}
.reg-legal-row a{color:var(--accent2);text-decoration:none}
.reg-legal-row a:hover{text-decoration:underline}
.banner{padding:12px;border-radius:10px;margin-bottom:14px;font-size:.9rem}
.banner.ok{background:rgba(110,231,168,.1);border:1px solid rgba(110,231,168,.28)}
.banner.warn{background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.35)}
.session-help-banner{text-align:left;line-height:1.5}
.session-help-banner strong{display:block;margin-bottom:8px;color:var(--text)}
.session-help-steps{margin:0 0 12px 18px;padding:0;font-size:.84rem;color:var(--muted)}
.session-help-steps li{margin-bottom:6px}
.session-help-steps a{color:var(--accent2)}
.session-help-dismiss{width:100%;margin-top:4px}
body.session-help-open{overflow:hidden}
.session-help-overlay{
    position:fixed;inset:0;z-index:5000;display:flex;align-items:center;justify-content:center;
    padding:max(16px,env(safe-area-inset-top)) 16px max(16px,env(safe-area-inset-bottom));
}
.session-help-overlay[hidden]{display:none!important}
.session-help-overlay__backdrop{position:absolute;inset:0;background:rgba(4,6,10,.88);backdrop-filter:blur(10px)}
.session-help-overlay__panel{
    position:relative;z-index:1;width:min(100%,560px);max-height:min(92vh,760px);overflow:auto;
    background:linear-gradient(165deg,rgba(22,28,38,.98),rgba(12,16,22,.98));
    border:1px solid rgba(251,191,36,.45);border-radius:18px;padding:24px 22px 20px;
    box-shadow:0 24px 80px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.04) inset;
    text-align:left;
}
.session-help-overlay__icon{font-size:2.4rem;line-height:1;margin-bottom:10px}
.session-help-overlay__title{margin:0 0 10px;font-size:clamp(1.15rem,4vw,1.45rem);color:#fbbf24;line-height:1.25}
.session-help-overlay__lead{margin:0 0 14px;font-size:.92rem;color:var(--text);line-height:1.5}
.session-help-overlay__steps{font-size:.88rem;color:var(--muted);margin:0 0 18px 20px;padding:0}
.session-help-overlay__steps li{margin-bottom:10px;line-height:1.45}
.session-help-overlay__steps code{font-size:.82rem;color:var(--accent2)}
.session-help-overlay__btn{width:100%;padding:14px;font-size:1rem;font-weight:700}
@media(max-width:480px){
    .session-help-overlay__panel{padding:18px 16px 16px;border-radius:14px}
    .session-help-overlay__steps{font-size:.84rem}
}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(50px);background:var(--card);border:1px solid var(--border);padding:12px 22px;border-radius:10px;z-index:100001;opacity:0;transition:all .3s;pointer-events:none;max-width:min(92vw,480px);box-shadow:0 12px 40px rgba(0,0,0,.45)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.dm-notify-stack{position:fixed;top:72px;right:16px;z-index:100002;display:flex;flex-direction:column;gap:10px;max-width:min(360px,calc(100vw - 32px));pointer-events:none}
.dm-notify-card{
    pointer-events:auto;text-align:left;padding:12px 36px 12px 14px;border-radius:12px;cursor:pointer;
    background:rgba(14,18,26,.97);border:1px solid rgba(201,162,84,.35);
    box-shadow:0 12px 40px rgba(0,0,0,.5);animation:dm-notify-in .25s ease;position:relative;
    font-family:inherit;color:var(--text);width:100%;
}
.dm-notify-card strong{display:block;margin-bottom:4px;color:var(--accent2);font-size:.88rem}
.dm-notify-card span{font-size:.82rem;color:var(--text);line-height:1.4;display:block}
.dm-notify-close{position:absolute;top:8px;right:8px;width:22px;height:22px;border:none;border-radius:6px;background:rgba(255,255,255,.06);color:var(--muted);cursor:pointer;font-size:.85rem;line-height:1}
.dm-notify-close:hover{color:var(--text);background:rgba(255,255,255,.1)}
@keyframes dm-notify-in{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:none}}
.auth-forgot{margin:-4px 0 10px;text-align:right}
.auth-forgot button{background:none;border:none;padding:0;color:var(--accent2);font-size:.78rem;cursor:pointer;font-family:inherit;text-decoration:underline}
.auth-modal{position:fixed;inset:0;z-index:4000;display:flex;align-items:center;justify-content:center;padding:16px;background:rgba(0,0,0,.65)}
.auth-modal[hidden]{display:none!important}
.auth-modal-box{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px;text-align:left;box-shadow:0 16px 48px rgba(0,0,0,.45)}
.auth-modal-box h3{margin:0 0 8px;font-size:1.05rem}
.auth-modal-box p{margin:0 0 14px;color:var(--muted);font-size:.84rem;line-height:1.45}
.auth-modal-tabs{display:flex;gap:6px;margin-bottom:14px}
.auth-modal-tab{flex:1;padding:8px;border:1px solid var(--border);background:rgba(0,0,0,.25);color:var(--muted);border-radius:8px;cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:600}
.auth-modal-tab.on{border-color:var(--accent);color:var(--accent2);background:color-mix(in srgb,var(--accent) 12%,transparent)}
.auth-modal-actions{display:flex;gap:10px;margin-top:14px}
.auth-modal-actions .btn{flex:1;padding:11px}
.auth-modal-count{font-size:1.4rem;font-weight:700;color:var(--accent2);margin:8px 0 4px;font-variant-numeric:tabular-nums}
@media(max-width:900px){.cabinet-grid{grid-template-columns:1fr}}
.retention-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.retention-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px}
.retention-card h3{margin:0 0 6px;font-size:1.05rem}
.retention-sub{color:var(--muted);font-size:.84rem;margin:0 0 16px;line-height:1.45}
.streak-row{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:16px}
.streak-day{text-align:center;padding:8px 4px;border-radius:10px;border:1px solid var(--border);background:rgba(0,0,0,.25);font-size:.7rem;line-height:1.3}
.streak-day small{display:block;color:var(--muted);margin-top:3px;font-size:.62rem}
.streak-day.done{border-color:rgba(110,231,168,.4);background:rgba(110,231,168,.08);color:var(--vk-ok,#6ee7a8)}
.streak-day.today{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow);color:var(--accent2)}
.quest-list{display:flex;flex-direction:column;gap:10px}
.quest-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:11px;border:1px solid var(--border);background:rgba(0,0,0,.22)}
.quest-item.done{opacity:.65}
.quest-ico{font-size:1.35rem;flex-shrink:0}
.quest-body{flex:1;min-width:0}
.quest-body strong{display:block;font-size:.9rem}
.quest-body span{font-size:.78rem;color:var(--muted)}
.quest-reward{font-weight:700;color:var(--accent);font-size:.85rem;white-space:nowrap}
.quest-actions{margin-top:8px;display:flex;flex-direction:column;gap:8px}
.quest-actions-row{display:flex;flex-wrap:wrap;gap:8px}
.quest-hint{display:block;font-size:.78rem;color:var(--muted);line-height:1.45}
.quest-item.soon{opacity:.55}
.quest-soon{font-size:.78rem;color:var(--muted);padding:4px 10px;border:1px solid var(--border);border-radius:8px}
.tg-code{display:inline-block;padding:8px 14px;border-radius:8px;background:rgba(0,0,0,.35);border:1px dashed var(--accent);font-family:monospace;font-size:1.05rem;letter-spacing:.12em;color:var(--accent2)}
.tg-auth-code{font-family:monospace;font-size:1.15rem;letter-spacing:.14em;color:var(--accent2);padding:4px 10px;border-radius:8px;background:rgba(0,0,0,.35);border:1px dashed var(--accent)}
.tg-open-link{display:inline-block;margin-top:10px;padding:10px 16px;border-radius:9px;background:linear-gradient(135deg,#2aabee,#229ed9);color:#fff;text-decoration:none;font-weight:700}
.auth-divider{text-align:center;color:var(--muted);font-size:.82rem;margin:14px 0;position:relative}
.auth-divider::before,.auth-divider::after{content:'';position:absolute;top:50%;width:38%;height:1px;background:var(--border)}
.auth-divider::before{left:0}.auth-divider::after{right:0}
.retention-progress{font-size:.82rem;color:var(--muted);margin-bottom:14px}
.retention-progress strong{color:var(--accent)}
@media(max-width:820px){.retention-grid{grid-template-columns:1fr}}

/* ── Viking polish ── */
body.vk-lk-page .cabinet-card,
body.vk-lk-page .retention-card,
body.vk-lk-page .auth-modal-box {
    position: relative;
    border-radius: var(--vk-radius);
    overflow: hidden;
}
body.vk-lk-page .cabinet-card::before,
body.vk-lk-page .retention-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--vk-amber), var(--vk-amber-bright), transparent);
    opacity: .85;
}
body.vk-lk-page .cabinet-guest {
    max-width: 480px;
    margin: 24px auto 0;
    padding: 40px 32px 36px;
    border: 1px solid rgba(201,162,84,.32);
    border-radius: var(--vk-radius);
    background: linear-gradient(165deg, rgba(201,162,84,.06), var(--vk-surface-2));
    box-shadow: 0 20px 56px rgba(0,0,0,.45), 0 0 40px rgba(201,162,84,.06);
}
body.vk-lk-page .vk-guest-icon {
    width: 56px; height: 56px; margin: 0 auto 16px;
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(201,162,84,.12);
    border: 1px solid rgba(201,162,84,.28);
    color: var(--vk-amber-bright);
    font-size: 1.5rem;
}
body.vk-lk-page .cabinet-guest h3 {
    font-family: var(--vk-serif);
    font-size: 1.45rem;
    color: var(--vk-amber-bright);
    margin: 0 0 10px;
}
body.vk-lk-page .prof-ava {
    border-radius: var(--vk-radius-sm);
    border: 2px solid var(--vk-amber);
    box-shadow: 0 0 20px rgba(201,162,84,.25);
}
body.vk-lk-page .lk-tabs {
    gap: 6px;
    padding: 6px;
    border-radius: 999px;
    background: rgba(0,0,0,.28);
    border: 1px solid var(--vk-line);
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    justify-content: flex-start;
}
body.vk-lk-page .lk-tabs::-webkit-scrollbar { display: none; }
body.vk-lk-page .lk-tab {
    border-radius: 999px;
    border: 1px solid transparent;
    background: transparent;
    white-space: nowrap;
    flex-shrink: 0;
}
body.vk-lk-page .lk-tab.on {
    background: rgba(201,162,84,.14);
    border-color: rgba(201,162,84,.45);
    color: var(--vk-amber-bright);
    box-shadow: 0 0 18px rgba(201,162,84,.12);
}
body.vk-lk-page .cabinet-stat strong { color: var(--vk-amber-bright); }
body.vk-lk-page .cabinet-card,
body.vk-lk-page .retention-card { border-radius: var(--vk-radius); padding: 24px; }
body.vk-lk-page .cabinet-card h3,
body.vk-lk-page .retention-card h3 {
    font-family: var(--vk-serif);
    color: var(--vk-amber-bright);
}
body.vk-lk-page .pfx-quest-item.has-daily-reward {
    border-color: rgba(201,162,84,.42);
    background: rgba(201,162,84,.07);
    box-shadow: 0 0 0 1px rgba(201,162,84,.1);
}
body.vk-lk-page .pfx-quest-item.is-highlight {
    border-color: rgba(232,200,120,.65) !important;
    box-shadow: 0 0 0 3px rgba(201,162,84,.22), 0 8px 28px rgba(201,162,84,.1) !important;
}
body.vk-lk-page .pfx-quest-scroll-nav {
    border-color: rgba(201,162,84,.45);
    background: rgba(14,18,26,.96);
}
body.vk-lk-page .pfx-quest-scroll-nav__dot,
body.vk-lk-page .pfx-quest-scroll-nav__dot::after { background: var(--vk-amber-bright); }
body.vk-lk-page .friends-tab-badge { background: var(--vk-amber); color: #1a1208; }
body.vk-lk-page .lk-input {
    border-radius: var(--vk-radius-sm);
    transition: border-color .2s, box-shadow .2s;
}
body.vk-lk-page .lk-input:focus {
    border-color: var(--vk-amber);
    box-shadow: 0 0 0 2px rgba(201,162,84,.14);
}
body.vk-lk-page .auth-tabs {
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-radius-sm);
}
body.vk-lk-page .auth-tab.on {
    background: linear-gradient(135deg, var(--vk-amber-bright), var(--vk-amber));
    color: #1a1208;
}
body.vk-lk-page .prefix-card { border-radius: var(--vk-radius-sm); }
body.vk-lk-page .prefix-card.on { border-color: var(--vk-amber); box-shadow: 0 0 18px rgba(201,162,84,.2); }
body.vk-lk-page .toast {
    border-color: var(--vk-line-gold);
    border-radius: var(--vk-radius-sm);
    background: rgba(14, 18, 26, .96);
}
