/* ============================================================
   ASGARD — Real-estate tokenization platform
   Identity: deep sapphire (Asgard night) + Bifrost orange bridge
   Display: Sora · Body: Inter · Data: tabular Inter
   ============================================================ */
:root{
  /* surfaces */
  --abyss:#0B1020;            /* deepest */
  --sapphire-1:#0E1530;       /* sidebar top */
  --sapphire-2:#151D42;       /* sidebar bottom */
  --page:#F4F6FB;             /* app background */
  --surface:#FFFFFF;          /* cards */
  --surface-2:#F8FAFE;        /* inset */
  --line:#E5E9F2;             /* hairline */
  --line-2:#EEF1F8;
  /* ink */
  --ink:#16203A;
  --ink-2:#34405E;
  --ink-soft:#48536E;
  --muted:#6B7794;
  --faint:#9AA4BC;
  /* bifrost accent (primary / orange) */
  --bifrost-1:#FF7A3D;
  --bifrost-2:#FF9D5C;
  --bifrost-ink:#B4451A;
  --bifrost-wash:#FFF1E8;
  /* aurora (secondary / indigo-violet) */
  --aurora-1:#5B6CF0;
  --aurora-2:#8A6CF0;
  --aurora-wash:#EEF0FF;
  /* states */
  --success:#12B981; --success-wash:#E6F8F1;
  --danger:#EF4444;  --danger-wash:#FDECEC;
  --warning:#F59E0B; --warning-wash:#FEF4E3;
  --info:#3B82F6;    --info-wash:#EAF2FE;
  /* geometry */
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:22px;
  --shadow-sm:0 1px 2px rgba(16,24,52,.06), 0 1px 3px rgba(16,24,52,.04);
  --shadow:0 4px 16px rgba(16,24,52,.07), 0 1px 4px rgba(16,24,52,.05);
  --shadow-lg:0 18px 50px rgba(11,16,32,.22);
  --bridge:linear-gradient(90deg,#FF7A3D 0%,#FF5DA2 28%,#8A6CF0 58%,#5B6CF0 80%,#3FC9F4 100%);
  --sidebar-w:248px; --topbar-h:66px;
  --ff-display:'Sora',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --ff-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--ff-body); color:var(--ink); background:var(--page);
  font-size:14px; line-height:1.5; -webkit-font-smoothing:antialiased;
  font-feature-settings:"cv05","ss01"; min-height:100vh;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;color:var(--ink);margin:0;letter-spacing:-.01em}
::selection{background:var(--bifrost-2);color:#fff}

/* scrollbars */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:#cdd5e6;border-radius:20px;border:2px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:#b3bdd6;background-clip:content-box}

/* ===================== AUTH SCREENS ===================== */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth-art{
  position:relative;overflow:hidden;
  background:radial-gradient(120% 120% at 15% 10%,#1b2553 0%,#0E1530 55%,#080d1e 100%);
  color:#fff;padding:54px 60px;display:flex;flex-direction:column;justify-content:space-between;
}
.auth-art::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(60% 50% at 85% 18%,rgba(255,122,61,.20),transparent 60%),
    radial-gradient(50% 45% at 12% 88%,rgba(91,108,240,.28),transparent 60%);}
.auth-art .bridge-line{position:absolute;left:0;right:0;top:0;height:4px;background:var(--bridge)}
.auth-brand{display:flex;align-items:center;gap:12px;position:relative;z-index:2}
.auth-brand .mark{width:42px;height:42px}
.auth-brand b{font-family:var(--ff-display);font-size:22px;letter-spacing:.14em;font-weight:700}
.auth-hero{position:relative;z-index:2;max-width:460px}
.auth-hero .eyebrow{font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:#9fb0e8;margin-bottom:18px}
.auth-hero h1{font-size:42px;line-height:1.08;color:#fff;letter-spacing:-.02em}
.auth-hero h1 .grad{background:var(--bridge);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.auth-hero p{color:#aab6da;font-size:15px;margin-top:18px;line-height:1.6}
.auth-stats{display:flex;gap:30px;position:relative;z-index:2}
.auth-stats .s b{font-family:var(--ff-display);font-size:26px;display:block}
.auth-stats .s span{color:#8e9bc6;font-size:12px}
.auth-pane{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--surface)}
.auth-card{width:100%;max-width:392px}
.auth-card h2{font-size:25px;margin-bottom:6px}
.auth-card .sub{color:var(--muted);margin-bottom:26px}
.auth-card .field{margin-bottom:15px}
.auth-switch{margin-top:22px;text-align:center;color:var(--muted);font-size:13.5px}
.auth-switch a{color:var(--bifrost-ink);font-weight:600}
.ref-chip{display:flex;align-items:center;gap:8px;background:var(--bifrost-wash);border:1px solid #ffd9c2;
  color:var(--bifrost-ink);padding:9px 13px;border-radius:var(--r);font-size:12.5px;font-weight:600;margin-bottom:18px}

/* ===================== APP SHELL ===================== */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{
  background:linear-gradient(180deg,var(--sapphire-1),var(--sapphire-2));
  color:#c4cce6;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden;
}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:20px 22px 18px}
.sidebar .brand .mark{width:34px;height:34px;flex:none}
.sidebar .brand b{font-family:var(--ff-display);font-size:18px;letter-spacing:.16em;color:#fff;font-weight:700}
.sidebar .brand .bridge{height:3px;border-radius:3px;width:34px;background:var(--bridge);margin-top:3px}
.nav{flex:1;overflow-y:auto;padding:6px 12px 18px}
.nav::-webkit-scrollbar{width:6px}
.nav::-webkit-scrollbar-thumb{background:#2a3360}
.nav .group{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#5e6a96;
  padding:16px 12px 7px;font-weight:700}
.nav a{display:flex;align-items:center;gap:11px;padding:9.5px 12px;border-radius:10px;color:#aeb8d8;
  font-size:13.5px;font-weight:500;margin-bottom:2px;position:relative;transition:background .14s,color .14s}
.nav a svg{width:18px;height:18px;flex:none;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.nav a.active{background:linear-gradient(90deg,rgba(255,122,61,.16),rgba(255,122,61,.02));color:#fff}
.nav a.active::before{content:"";position:absolute;left:-12px;top:7px;bottom:7px;width:3px;border-radius:3px;background:var(--bridge)}
.nav a .tag{margin-left:auto;background:var(--bifrost-1);color:#fff;font-size:10px;font-weight:700;
  padding:1px 7px;border-radius:20px}
.sidebar .who{margin:10px 12px 14px;padding:12px;border-radius:14px;background:rgba(255,255,255,.04);
  display:flex;align-items:center;gap:11px}
.sidebar .who .ava{width:38px;height:38px;border-radius:11px;background:var(--bridge);display:grid;place-items:center;
  font-family:var(--ff-display);font-weight:700;color:#fff;font-size:15px;flex:none}
.sidebar .who .nm{font-size:13px;font-weight:600;color:#fff;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar .who .rk{font-size:11px;color:#8492be}

/* topbar */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:var(--topbar-h);background:rgba(255,255,255,.85);backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 28px;position:sticky;top:0;z-index:30}
.topbar .pagetitle{font-family:var(--ff-display);font-size:18px;font-weight:700}
.topbar .crumb{color:var(--faint);font-size:12.5px;margin-top:1px}
.topbar .spacer{flex:1}
.bal-pill{display:flex;align-items:center;gap:9px;background:var(--surface-2);border:1px solid var(--line);
  padding:7px 14px;border-radius:30px;font-weight:700;font-size:14px}
.bal-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--success)}
.bal-pill small{color:var(--muted);font-weight:600;font-size:11px;letter-spacing:.04em}
.icon-btn{width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:var(--surface);
  display:grid;place-items:center;cursor:pointer;color:var(--ink-soft);transition:.14s}
.icon-btn:hover{border-color:#cdd5e6;background:var(--surface-2)}
.lang{display:flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:11px;padding:8px 11px;
  cursor:pointer;font-weight:600;font-size:12.5px;color:var(--ink-soft);background:var(--surface)}

.content{padding:26px 28px 60px;max-width:1380px;width:100%}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head .ttl h1{font-size:23px}
.page-head .ttl p{color:var(--muted);margin:5px 0 0;font-size:13.5px}

/* ===================== CARDS ===================== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.card.pad{padding:20px}
.card-h{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line-2)}
.card-h h3{font-size:15px}
.card-h .sub{color:var(--muted);font-size:12.5px}
.card-h .spacer{flex:1}
.grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1180px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* account balance cards */
.acct{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:18px 20px 17px;color:#fff;
  min-height:128px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow)}
.acct .label{font-size:12.5px;font-weight:600;opacity:.92;display:flex;align-items:center;gap:8px}
.acct .amt{font-family:var(--ff-display);font-size:27px;font-weight:700;letter-spacing:-.01em;line-height:1}
.acct .amt small{font-size:14px;opacity:.8;font-weight:600;margin-left:3px}
.acct .meta{font-size:11.5px;opacity:.85;display:flex;justify-content:space-between;align-items:center}
.acct .ic{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.18);display:grid;place-items:center}
.acct .top{display:flex;justify-content:space-between;align-items:flex-start}
.acct--main{background:linear-gradient(135deg,#FF7A3D,#FF5DA2)}
.acct--main::after{content:"";position:absolute;right:-30px;bottom:-40px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.10)}
.acct--bonus{background:linear-gradient(135deg,#FFB23D,#FF7A3D)}
.acct--accmain{background:linear-gradient(135deg,#5B6CF0,#8A6CF0)}
.acct--accbonus{background:linear-gradient(135deg,#6E5BF0,#B06CF0)}
.acct--shares{background:linear-gradient(135deg,#0F1A3D,#243069)}
.acct--shares .bridge-top{position:absolute;left:0;right:0;top:0;height:3px;background:var(--bridge)}
.acct--reserve{background:linear-gradient(135deg,#33405e,#1d2842)}

/* stat tiles */
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow-sm)}
.stat .k{color:var(--muted);font-size:12px;font-weight:600;display:flex;align-items:center;gap:8px}
.stat .v{font-family:var(--ff-display);font-size:24px;font-weight:700;margin-top:8px}
.stat .d{font-size:12px;margin-top:5px;font-weight:600}
.stat .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center}
.tone-bifrost{background:var(--bifrost-wash);color:var(--bifrost-ink)}
.tone-aurora{background:var(--aurora-wash);color:var(--aurora-1)}
.tone-success{background:var(--success-wash);color:var(--success)}
.tone-info{background:var(--info-wash);color:var(--info)}
.tone-warning{background:var(--warning-wash);color:#b9770a}
.up{color:var(--success)} .down{color:var(--danger)}

/* ===================== TABLE ===================== */
.tbl-wrap{width:100%;overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;letter-spacing:.03em;
  text-transform:uppercase;padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap;background:var(--surface-2)}
table.tbl td{padding:13px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle}
table.tbl tbody tr:last-child td{border-bottom:none}
table.tbl tbody tr:hover{background:var(--surface-2)}
table.tbl td.num,table.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}
.cell-strong{font-weight:600;color:var(--ink)}
.cell-sub{color:var(--muted);font-size:12px}
.u-cell{display:flex;align-items:center;gap:10px}
.u-cell .av{width:30px;height:30px;border-radius:9px;background:var(--aurora-wash);color:var(--aurora-1);
  display:grid;place-items:center;font-weight:700;font-size:12px;flex:none}

/* ===================== BADGES / PILLS ===================== */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:30px;line-height:1.4}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.ok{background:var(--success-wash);color:#0e9c6e}
.badge.warn{background:var(--warning-wash);color:#b9770a}
.badge.dang{background:var(--danger-wash);color:#d23030}
.badge.info{background:var(--info-wash);color:#2b6fd6}
.badge.neutral{background:#eef1f7;color:#67748f}
.badge.muted{background:#eef1f7;color:#67748f}
.badge.flat::before{display:none}
.rank-chip{display:inline-flex;align-items:center;gap:6px;background:var(--sapphire-1);color:#fff;
  font-size:11.5px;font-weight:700;padding:3px 10px 3px 7px;border-radius:30px}
.rank-chip .r{width:18px;height:18px;border-radius:50%;background:var(--bridge);display:grid;place-items:center;font-size:10px}
.leader-chip{background:var(--bifrost-wash);color:var(--bifrost-ink);font-weight:700;font-size:11px;padding:3px 9px;border-radius:30px}

/* ===================== BUTTONS ===================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;
  border-radius:11px;padding:10px 17px;font-size:13.5px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-primary{background:linear-gradient(135deg,var(--bifrost-1),var(--bifrost-2));color:#fff;box-shadow:0 6px 16px rgba(255,122,61,.32)}
.btn-primary:hover:not(:disabled){filter:brightness(1.04);box-shadow:0 8px 22px rgba(255,122,61,.4)}
.btn-dark{background:var(--sapphire-1);color:#fff}
.btn-dark:hover:not(:disabled){background:#1b2350}
.btn-ghost{background:var(--surface);border-color:var(--line);color:var(--ink-soft)}
.btn-ghost:hover:not(:disabled){border-color:#cdd5e6;background:var(--surface-2)}
.btn-soft{background:var(--bifrost-wash);color:var(--bifrost-ink)}
.btn-soft:hover:not(:disabled){background:#ffe7d8}
.btn-success{background:var(--success);color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger-soft{background:var(--danger-wash);color:#d23030}
.btn-sm{padding:7px 12px;font-size:12.5px;border-radius:9px}
.btn-block{width:100%}
.btn-row{display:flex;gap:9px;flex-wrap:wrap}

/* ===================== FORMS ===================== */
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:7px}
.field .hint{font-size:11.5px;color:var(--faint);margin-top:6px}
.inp,.sel,textarea.inp{width:100%;border:1px solid var(--line);background:var(--surface);border-radius:11px;
  padding:11px 13px;font-size:14px;color:var(--ink);font-family:inherit;transition:.14s;outline:none}
.inp:focus,.sel:focus,textarea.inp:focus{border-color:var(--bifrost-1);box-shadow:0 0 0 3px rgba(255,122,61,.14)}
.inp::placeholder{color:var(--faint)}
.inp-group{position:relative}
.inp-group .suffix{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:600;font-size:13px}
.inp-group .inp{padding-right:54px}
.seg{display:flex;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:4px;gap:4px}
.seg button{flex:1;border:none;background:transparent;padding:8px;border-radius:8px;font-weight:600;font-size:13px;
  color:var(--muted);cursor:pointer;transition:.14s}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
.check{display:flex;align-items:center;gap:9px;cursor:pointer;font-size:13px;font-weight:500;color:var(--ink-soft)}
.check input{width:17px;height:17px;accent-color:var(--bifrost-1)}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:20px;overflow-x:auto}
.tabs button{border:none;background:transparent;padding:11px 15px;font-weight:600;font-size:13.5px;color:var(--muted);
  cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:.14s}
.tabs button:hover{color:var(--ink)}
.tabs button.on{color:var(--bifrost-ink);border-bottom-color:var(--bifrost-1)}

/* ===================== MODAL ===================== */
.scrim{position:fixed;inset:0;background:rgba(11,16,32,.55);backdrop-filter:blur(3px);z-index:100;
  display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .16s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;max-width:480px;
  max-height:92vh;overflow:auto;animation:pop .18s cubic-bezier(.2,.9,.3,1.2)}
.modal.wide{max-width:760px}
@keyframes pop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
.modal-h{padding:20px 24px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;gap:12px}
.modal-h h3{font-size:17px}
.modal-h .x{margin-left:auto;cursor:pointer;color:var(--faint);width:32px;height:32px;border-radius:9px;display:grid;place-items:center}
.modal-h .x:hover{background:var(--surface-2);color:var(--ink)}
.modal-b{padding:22px 24px}
.modal-f{padding:16px 24px 22px;display:flex;gap:10px}
.modal-f .btn{flex:1}
/* dark modal (p2p confirm) */
.modal.dark{background:linear-gradient(180deg,#141C40,#0E1530);color:#dfe4f3;border:1px solid #2a3360}
.modal.dark .modal-h{border-color:#262f57}.modal.dark .modal-h h3{color:#fff}
.modal.dark .modal-h .x{color:#8492be}.modal.dark .modal-h .x:hover{background:rgba(255,255,255,.06);color:#fff}
.modal.dark .inp{background:#0E1530;border-color:#2a3360;color:#fff}
.modal.dark label{color:#9aa6cc}
.confirm-row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid #262f57;font-size:13.5px}
.confirm-row b{font-weight:700}
.confirm-row.total{border:none;font-size:16px;padding-top:15px}

/* deposit address box */
.addr-box{background:var(--surface-2);border:1px dashed #c9d2e6;border-radius:12px;padding:14px;display:flex;
  align-items:center;gap:12px;word-break:break-all;font-family:ui-monospace,monospace;font-size:12.5px}
.qr{width:120px;height:120px;border-radius:12px;background:#fff;border:1px solid var(--line);padding:8px;flex:none}
.countdown{font-family:var(--ff-display);font-weight:700;font-size:18px;color:var(--bifrost-ink)}

/* toast */
.toast-wrap{position:fixed;right:22px;bottom:22px;z-index:200;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--sapphire-1);color:#fff;padding:13px 17px;border-radius:13px;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:11px;font-size:13.5px;font-weight:500;min-width:260px;max-width:380px;
  animation:slidein .22s cubic-bezier(.2,.9,.3,1.2)}
@keyframes slidein{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.toast .i{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;flex:none}
.toast.ok .i{background:var(--success)} .toast.err .i{background:var(--danger)} .toast.info .i{background:var(--info)}

/* misc */
.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty .e-ic{width:56px;height:56px;border-radius:16px;background:var(--surface-2);display:grid;place-items:center;margin:0 auto 14px;color:var(--faint)}
.empty h4{font-size:16px;margin-bottom:6px}
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--bifrost-1);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}
@keyframes spin{to{transform:rotate(360deg)}}
.skeleton{background:linear-gradient(90deg,#eef1f8 25%,#e3e8f3 37%,#eef1f8 63%);background-size:400% 100%;
  animation:sk 1.3s ease infinite;border-radius:8px}
@keyframes sk{0%{background-position:100% 0}100%{background-position:-100% 0}}
.divider{height:1px;background:var(--line-2);margin:18px 0}
.kv{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:13.5px}
.kv:last-child{border:none}.kv .k{color:var(--muted)}.kv .v{font-weight:600}
.muted{color:var(--muted)} .mono{font-family:ui-monospace,monospace}
.flex{display:flex} .between{justify-content:space-between} .center{align-items:center} .gap{gap:12px} .wrap{flex-wrap:wrap}
.mt{margin-top:16px}.mt-s{margin-top:9px}.mb{margin-bottom:16px}
.progress{height:7px;border-radius:20px;background:var(--line);overflow:hidden}
.progress > i{display:block;height:100%;border-radius:20px;background:var(--bridge)}
.pill-tab{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:30px;padding:3px}
.pill-tab button{border:none;background:transparent;padding:7px 15px;border-radius:30px;font-weight:600;font-size:12.5px;color:var(--muted);cursor:pointer}
.pill-tab button.on{background:var(--sapphire-1);color:#fff}

/* structure tree */
.tree{font-size:13.5px}
.tree-node{margin-left:0}
.tree-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:11px;border:1px solid var(--line);
  background:var(--surface);margin-bottom:7px;box-shadow:var(--shadow-sm)}
.tree-row .tw{width:26px;height:26px;border-radius:8px;background:var(--aurora-wash);color:var(--aurora-1);
  display:grid;place-items:center;font-weight:700;font-size:12px;cursor:pointer;flex:none}
.tree-children{margin-left:26px;padding-left:16px;border-left:2px dashed var(--line);margin-top:0}
.tree-meta{margin-left:auto;display:flex;gap:18px;align-items:center}
.tree-meta .m b{font-family:var(--ff-display);font-weight:700} .tree-meta .m span{color:var(--muted);font-size:11px;display:block}

/* admin: key-value rows, obligations, ops */
.kv-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line-2)}
.kv-row:last-child{border-bottom:0}
.kv-row b{font-family:var(--ff-display)}
.ob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ob-cell{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:14px;text-align:center}
.ob-n{font-family:var(--ff-display);font-weight:800;font-size:24px;color:var(--ink)}
.ob-n.warn{color:var(--bifrost-ink)}
.ob-l{font-size:11.5px;margin-top:2px}
.op-btn-col{display:flex;flex-direction:column;gap:10px}
.op-btn-col .btn{width:100%;justify-content:center}
/* row actions + mini buttons */
.row-actions{display:inline-flex;gap:6px;justify-content:flex-end}
.mini{font-family:var(--ff-body);font-size:12px;font-weight:600;padding:5px 11px;border-radius:8px;
  border:1px solid var(--line);background:var(--surface);color:var(--ink-2);cursor:pointer;transition:.15s}
.mini:hover{border-color:var(--aurora-1);color:var(--aurora-1);background:var(--aurora-wash)}
.mini.ok:hover{border-color:var(--success);color:var(--success);background:var(--success-wash)}
.mini.danger:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-wash)}
/* checkbox rows */
.chk-row{display:flex;align-items:center;gap:9px;padding:7px 0;cursor:pointer;font-size:13px;color:var(--ink-2)}
.chk{appearance:none;width:18px;height:18px;border:1.5px solid var(--line);border-radius:5px;background:var(--surface);
  cursor:pointer;display:grid;place-items:center;flex:0 0 auto;transition:.15s}
.chk:checked{background:var(--bifrost-1);border-color:var(--bifrost-1)}
.chk:checked::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px)}
/* v1.6: charts, funnel, landing */
.chart{width:100%;height:120px;display:block}
.funnel{display:flex;flex-direction:column;gap:10px}
.funnel-row{display:grid;grid-template-columns:120px 1fr 110px;align-items:center;gap:12px}
.funnel-label{font-size:12.5px;color:var(--muted)}
.funnel-track{height:14px;background:var(--surface-2);border-radius:7px;overflow:hidden}
.funnel-track i{display:block;height:100%;border-radius:7px;transition:width .4s}
.funnel-val{text-align:right;font-weight:700;font-size:13px}
/* landing */
.landing{min-height:100vh;background:linear-gradient(180deg,#0c1230 0%,#141b3f 60%,#0c1230 100%);color:#eef1fb}
.land-nav{display:flex;align-items:center;gap:14px;padding:22px clamp(20px,6vw,72px)}
.land-nav .spacer{flex:1}
.land-hero{padding:clamp(30px,7vh,80px) clamp(20px,6vw,72px);display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.land-hero h1{font-family:var(--ff-display);font-size:clamp(30px,4.4vw,52px);line-height:1.12;margin:0 0 18px}
.land-hero h1 em{color:var(--bridge,#ff7a3d);font-style:normal}
.land-hero p{color:#b9c2e4;font-size:15.5px;line-height:1.7;max-width:520px}
.land-cta{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap}
.land-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.land-stat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:20px}
.land-stat b{font-family:var(--ff-display);font-size:26px;display:block}
.land-stat span{color:#9aa6cf;font-size:12px}
.land-steps{padding:30px clamp(20px,6vw,72px) 70px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.land-step{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:22px}
.land-step .n{width:34px;height:34px;border-radius:10px;background:var(--bridge,#ff7a3d);color:#fff;display:grid;place-items:center;font-weight:800;margin-bottom:12px}
.land-step h3{margin:0 0 8px;font-size:16px}
.land-step p{color:#a8b2d8;font-size:13px;line-height:1.65;margin:0}
@media(max-width:860px){.land-hero{grid-template-columns:1fr}.land-steps{grid-template-columns:1fr}}
/* promo banners */
.banner-prev{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#0c1230}
.banner-prev svg{display:block;width:100%;height:auto}
/* faq */
.faq-item{border:1px solid var(--line);border-radius:var(--r);margin-bottom:10px;overflow:hidden;background:var(--surface)}
.faq-q{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;font-weight:600;font-size:14px}
.faq-q svg{margin-left:auto;transition:.2s;width:16px;height:16px;color:var(--muted)}
.faq-item.open .faq-q svg{transform:rotate(90deg)}
.faq-a{display:none;padding:0 16px 16px;color:var(--ink-2);font-size:13.5px;line-height:1.7}
.faq-item.open .faq-a{display:block}
/* v1.5: onboarding video, 2FA QR, calculator */
.video-wrap{position:relative;padding-top:42%;background:#0b1020}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(max-width:920px){.video-wrap{padding-top:56.25%}}
.qr-wrap{display:grid;place-items:center;margin:6px 0 12px}
.qr-wrap img{border-radius:12px;border:1px solid var(--line);background:#fff;padding:8px}
.calc-out{margin-top:4px}
/* profile hero + avatar */
.profile-hero{background:linear-gradient(135deg,var(--surface) 60%,var(--aurora-wash))}
.avatar-xl{width:84px;height:84px;border-radius:22px;background:var(--sapphire-2,#1b2350);color:#fff;
  display:grid;place-items:center;font-family:var(--ff-display);font-weight:800;font-size:26px;overflow:hidden;
  border:2px solid var(--line)}
.avatar-xl img{width:100%;height:100%;object-fit:cover}
.avatar-edit{position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);white-space:nowrap}
/* pool cards clickable */
.pool-card{transition:border-color .15s, transform .15s, box-shadow .15s}
.pool-card:hover{border-color:var(--aurora-1);transform:translateY(-2px);box-shadow:0 8px 24px rgba(10,16,40,.10)}
/* v1.3: notifications bell + panel */
.icon-btn.bell{position:relative}
.bell-badge{position:absolute;top:-4px;right:-5px;background:var(--bridge,#ff7a3d);color:#fff;font-size:10px;
  font-weight:800;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px;
  border:2px solid var(--surface);line-height:1}
.ntf-list{display:flex;flex-direction:column;gap:6px;max-height:55vh;overflow-y:auto}
.ntf-item{display:flex;gap:12px;padding:11px 12px;border:1px solid var(--line);border-radius:var(--r);
  background:var(--surface);cursor:pointer;transition:.15s}
.ntf-item:hover{border-color:var(--aurora-1);background:var(--aurora-wash)}
.ntf-item.unread{background:var(--surface-2);border-left:3px solid var(--bridge,#ff7a3d)}
.ntf-ic{width:34px;height:34px;border-radius:9px;background:var(--surface-2);display:grid;place-items:center;flex:none;color:var(--muted)}
.ntf-ic svg{width:17px;height:17px}
.ntf-body{min-width:0;flex:1}
.ntf-time{font-size:11px;margin-top:3px}
/* v1.2: paginator */
.pgn{display:flex;align-items:center;gap:10px;padding:12px 18px;border-top:1px solid var(--line-2);justify-content:flex-end}
.pgn-info{font-size:12px}
.pg-size{width:auto;padding:5px 26px 5px 9px;font-size:12px}
.pgn-page{font-size:12.5px;font-weight:600;min-width:52px;text-align:center}
.pgn .mini:disabled{opacity:.4;cursor:default}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:12px}
.gal-item{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#0b1020}
.gal-item img{width:100%;height:110px;object-fit:cover;display:block;cursor:pointer;transition:.18s}
.gal-item img:hover{transform:scale(1.04)}
.gal-item .rm{position:absolute;top:6px;right:6px}
.lightbox img{max-width:100%;max-height:70vh;border-radius:var(--r);display:block;margin:0 auto}
/* v1.1: kyc docs + side profiles */
.doc-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.doc-row{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:var(--r);font-size:13px}
.doc-row svg{width:17px;height:17px;color:var(--muted);flex:none}
.kyc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.kyc-doc{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface-2)}
.kyc-doc img{width:100%;height:180px;object-fit:cover;display:block;background:#0b1020}
.kyc-pdf{height:180px;display:grid;place-items:center;color:var(--muted)}
.kyc-pdf svg{width:34px;height:34px}
.kyc-meta{display:flex;align-items:center;gap:8px;padding:8px 10px}
.mobile-only{display:none}
@media(max-width:920px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;z-index:90;width:var(--sidebar-w);transform:translateX(-100%);transition:.22s}
  .sidebar.open{transform:none}
  .mobile-only{display:grid}
  .auth-wrap{grid-template-columns:1fr}.auth-art{display:none}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}


/* ============================================================
   DESIGN SKIN v2 — по макетам Figma «Asgard Develop».
   Светлая тема: белые поверхности, серый колодец #F6F6F8,
   оранжевый градиент-акцент (#F2A06A→#E2703A), золотой логотип.
   Слой каскадных переопределений поверх базовых компонентов —
   имена классов и разметка не меняются.
   ============================================================ */
:root {
  --bg: #F6F6F8;                 /* колодец контента */
  --surface: #FFFFFF;            /* карточки и сайдбар */
  --surface-2: #F3F4F7;          /* заливка инпутов, треки */
  --line: #ECECF1;
  --ink: #1C1C28; --ink-2: #4A4A57;
  --muted: #8B8B98; --hint: #A7A7B4;
  --bridge: #E2703A;             /* основной оранжевый */
  --bridge-2: #F2A06A;           /* светлый край градиента */
  --bridge-soft: #FDEEE4;        /* оранжевая подложка */
  --gold-1: #E2C893; --gold-2: #B08D55;
  --ok: #2E9E5B; --ok-soft: #E5F6EC;
  --warn: #D97A06; --warn-soft: #FCF1E0;
  --err: #DE4848; --err-soft: #FBEAEA;
  --info: #3B6FE0; --info-soft: #EAF0FC;
  --r: 16px; --r-lg: 24px;
  --shadow: 0 8px 28px rgba(28,28,40,.07);
  --shadow-sm: 0 2px 10px rgba(28,28,40,.05);
  --grad: linear-gradient(118deg, var(--bridge-2) 0%, var(--bridge) 100%);
}
html, body { background: var(--surface); color: var(--ink); }
.app { background: var(--surface); }
.main { background: var(--bg); border-radius: 28px 0 0 28px; }
a { color: var(--bridge); }

/* ---- сайдбар: белый, активный пункт — оранжевая пилюля ---- */
.sidebar { background: var(--surface); border-right: 1px solid var(--line); }
.sidebar .logo img, .land-nav img { filter: none; }
.nav-title { color: var(--hint); letter-spacing: .12em; }
.navlink { color: var(--ink-2); border-radius: 12px; }
.navlink svg { color: var(--muted); }
.navlink:hover { background: var(--surface-2); color: var(--ink); }
.navlink.on { background: var(--grad); color: #fff; box-shadow: 0 6px 16px rgba(226,112,58,.35); }
.navlink.on svg { color: #fff; }

/* ---- верхняя панель ---- */
.topbar { background: var(--surface); border-bottom: 1px solid var(--line); }
.lang-pill, .mini { background: var(--surface-2); color: var(--ink-2); border: 1px solid var(--line); border-radius: 999px; }
.lang-pill:hover, .mini:hover { background: #ECEDF2; }
.bell { color: var(--ink-2); } .bell .dot { background: var(--bridge); }
.avatar { background: var(--grad); color: #fff; }

/* ---- карточки ---- */
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow-sm); }
.card-h { border-bottom: 1px solid var(--line); }
.card-h h3, h1, h2, h3, h4 { color: var(--ink); }
.divider { background: var(--line); }
.muted { color: var(--muted); } .hint { color: var(--hint); }

/* ---- счета: основной — градиент, остальные — белые с оранжевой рамкой ---- */
.acct { background: var(--surface); border: 1.5px solid var(--bridge-2); border-radius: var(--r); color: var(--ink); }
.acct .acct-name { color: var(--ink-2); }
.acct .acct-balance { color: var(--bridge); }
.acct.acc-main { background: var(--grad); border-color: transparent; box-shadow: 0 10px 24px rgba(226,112,58,.32); }
.acct.acc-main .acct-name, .acct.acc-main .acct-balance, .acct.acc-main .acct-sub { color: #fff; }
.acct .acct-sub { color: var(--hint); }
.acct .acct-actions .mini { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.35); color: inherit; }
.acct:not(.acc-main) .acct-actions .mini { background: var(--surface-2); border-color: var(--line); color: var(--ink-2); }

/* ---- кнопки ---- */
.btn { border-radius: 12px; font-weight: 600; }
.btn-primary { background: var(--grad); color: #fff; border: none; box-shadow: 0 6px 16px rgba(226,112,58,.30); }
.btn-primary:hover { filter: brightness(1.05); }
.btn-primary:disabled { background: #EDEDF1; color: var(--hint); box-shadow: none; }
.btn-ghost { background: var(--surface); color: var(--bridge); border: 1.5px solid var(--bridge-2); }
.btn-ghost:hover { background: var(--bridge-soft); }
.btn-danger { background: var(--err); color: #fff; border: none; }
.btn-danger:hover { filter: brightness(1.06); }

/* ---- формы ---- */
.inp, select.inp, textarea.inp { background: var(--surface-2); border: 1.5px solid transparent; border-radius: 12px; color: var(--ink); }
.inp::placeholder { color: var(--hint); }
.inp:focus { background: #fff; border-color: var(--bridge-2); box-shadow: 0 0 0 4px rgba(242,160,106,.18); }
.field label { color: var(--ink-2); }
.chk-row a { color: var(--bridge); }

/* ---- таблицы ---- */
table.table th { color: var(--muted); border-bottom: 1px solid var(--line); }
table.table td { border-bottom: 1px solid var(--line); color: var(--ink); }
table.table tr:hover td { background: #FAFAFC; }
.cell-strong { color: var(--ink); } .cell-sub { color: var(--hint); }
.num.up { color: var(--ok); } .num.down { color: var(--err); }

/* ---- бейджи и статусы ---- */
.badge { border-radius: 999px; font-weight: 600; }
.badge.info { background: var(--info-soft); color: var(--info); }
.badge.ok { background: var(--ok-soft); color: var(--ok); }
.badge.warn { background: var(--warn-soft); color: var(--warn); }
.badge.err { background: var(--err-soft); color: var(--err); }
.badge.neutral { background: var(--surface-2); color: var(--ink-2); }
.leader-chip { background: linear-gradient(118deg, var(--gold-1), var(--gold-2)); color: #fff; }
.rank-chip { background: var(--grad); color: #fff; }

/* ---- пилюли-табы и пагинация ---- */
.pill-tab { background: var(--surface-2); border-radius: 999px; }
.pill-tab button { color: var(--ink-2); border-radius: 999px; }
.pill-tab button.on { background: var(--grad); color: #fff; box-shadow: 0 4px 10px rgba(226,112,58,.3); }
.pgn button { background: var(--surface); border: 1px solid var(--line); color: var(--ink-2); border-radius: 10px; }
.pgn button.on, .pgn button:hover { border-color: var(--bridge-2); color: var(--bridge); }

/* ---- модалки / тосты ---- */
.modal { background: #fff; border-radius: var(--r-lg); box-shadow: 0 24px 80px rgba(28,28,40,.18); border: none; }
.modal-h { border-bottom: 1px solid var(--line); }
.modal-x { background: var(--surface-2); color: var(--ink-2); border-radius: 999px; }
.modal-backdrop { background: rgba(20,20,30,.45); backdrop-filter: blur(3px); }
.toast { background: #fff; color: var(--ink); border: 1px solid var(--line); box-shadow: var(--shadow); border-radius: 14px; }
.toast.err { border-color: var(--err); }

/* ---- графики / воронка / дерево ---- */
.chart path, .chart circle { stroke: var(--bridge); fill: var(--bridge); }
.chart path[fill^="url"] { stroke: none; }
.funnel-track { background: var(--surface-2); }
.tree-node { background: var(--surface); border: 1px solid var(--line); }
.empty { color: var(--muted); } .empty svg { color: var(--bridge-2); }
.spinner { border-color: var(--line); border-top-color: var(--bridge); }

/* ============================================================
   АВТОРИЗАЦИЯ — фотофон, гласс-карта, белые табы (макет Autorization)
   ============================================================ */
.auth { background: #20242E url('/assets/auth-bg.jpg') center/cover no-repeat; }
.auth::before { content: ''; position: fixed; inset: 0; background: rgba(18,20,28,.28); }
.auth .auth-hero { position: relative; z-index: 1; }
.auth .auth-hero h1, .auth .auth-hero p { color: #fff; text-shadow: 0 2px 18px rgba(0,0,0,.35); }
.auth .grad { background: linear-gradient(118deg, var(--gold-1), var(--gold-2)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.auth-card { position: relative; z-index: 1; background: rgba(34,38,48,.55); backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.14); border-radius: var(--r-lg); box-shadow: 0 30px 80px rgba(0,0,0,.35); overflow: hidden; }
.auth-tabs { display: grid; grid-template-columns: 1fr 1fr; margin: -26px -26px 22px; }
.auth-tabs a { padding: 18px 10px; text-align: center; font-size: 17px; font-weight: 600; color: #fff; text-decoration: none; background: rgba(255,255,255,.06); }
.auth-tabs a.on { background: #fff; color: var(--ink); border-radius: 0 0 var(--r-lg) 0; }
.auth-tabs a.on:first-child { border-radius: 0 0 0 var(--r-lg); }
.auth-card .field label { color: rgba(255,255,255,.85); }
.auth-card .inp { background: #fff; border-radius: 14px; }
.auth-card .hint { color: rgba(255,255,255,.65); }
.auth-card .auth-switch { color: rgba(255,255,255,.8); }
.auth-card .auth-switch a, .auth-card a { color: #fff; text-decoration: underline; }
.auth-card .chk-row { color: rgba(255,255,255,.85); }
.auth-logo { position: absolute; top: 26px; left: 34px; z-index: 2; color: #fff; }
.auth-logo img { height: 44px; }

/* ============================================================
   ЛЕНДИНГ — светлый, по макету «Ми провідники в світ Asgard»
   ============================================================ */
.landing { background: #fff; color: var(--ink); }
.land-nav { background: #fff; }
.land-nav .btn-ghost { color: var(--ink-2) !important; border-color: var(--line) !important; background: var(--surface-2); }
.land-nav .btn-primary { color: #fff !important; }
.land-hero h1 { color: var(--ink); }
.land-hero h1 em { color: var(--bridge); }
.land-hero p { color: var(--ink-2); }
.land-kicker { color: var(--bridge); font-size: 12px; letter-spacing: .18em; font-weight: 700; text-transform: uppercase; margin-bottom: 14px; }
.land-photo { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow); margin: 26px clamp(20px,6vw,72px) 10px; }
.land-photo img { display: block; width: 100%; height: auto; }
.land-stats { gap: 14px; }
.land-stat { background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.land-stat b { color: var(--bridge); }
.land-stat span { color: var(--muted); }
.land-steps { padding-top: 10px; }
.land-step { background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.land-step .n { background: var(--grad); }
.land-step h3 { color: var(--ink); }
.land-step p { color: var(--ink-2); }

/* видео-карта и QR на светлом */
.video-card .card-h { border-bottom: none; }
.video-wrap { background: #10131C; border-radius: 0 0 var(--r) var(--r); }
.qr-wrap img { border-color: var(--line); }
.banner-prev { border-color: var(--line); }
.faq-item { box-shadow: var(--shadow-sm); }
.faq-q { color: var(--ink); }
.faq-a { color: var(--ink-2); }
.addr-box, .doc-row { background: var(--surface-2); border-radius: 12px; }
.calc-out .kv-row b { color: var(--ink); }
.ref-chip { background: var(--bridge-soft); color: var(--bridge); border-radius: 999px; }

/* auth layout v2: фото на весь экран, hero слева, карта справа */
.auth { min-height: 100vh; position: relative; }
.auth .auth-wrap { position: relative; z-index: 1; background: transparent; min-height: 100vh;
  display: grid; grid-template-columns: 1.05fr 460px; gap: 48px; align-items: center;
  padding: 90px clamp(20px,6vw,72px) 50px; }
.auth .auth-art { background: none; border: none; padding: 0; }
.auth .auth-hero .eyebrow { color: var(--gold-1); letter-spacing: .2em; }
.auth-card { width: 100%; max-width: 470px; justify-self: end; padding: 26px; }
@media (max-width: 960px) {
  .auth .auth-wrap { grid-template-columns: 1fr; padding-top: 110px; }
  .auth .auth-art { display: none; }
  .auth-card { justify-self: center; }
}

/* ---- итерация 2: детали по макетам ---- */
.auth.tab-signup { background-image: url('/assets/auth-bg-night.jpg'); }
/* стат-карточки админки: градиентный сквиркл-значок, оранжевая цифра */
.stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow-sm); padding: 16px 18px; }
.stat .k { color: var(--ink-2); font-size: 13px; font-weight: 600; }
.stat .ic { width: 44px; height: 44px; border-radius: 14px; display: grid; place-items: center; background: var(--grad); color: #fff; box-shadow: 0 6px 14px rgba(226,112,58,.30); }
.stat .ic svg { width: 20px; height: 20px; }
.stat .v { color: var(--bridge); font-size: 26px; font-weight: 800; margin-top: 6px; }
.stat .d { font-size: 12px; }
/* пагинация: активная страница — белый кружок с тенью */
.pgn button.on { background: #fff; border-color: transparent; color: var(--ink); border-radius: 999px; box-shadow: 0 4px 12px rgba(28,28,40,.14); font-weight: 700; }
/* фотокарточка лота */
.pool-photo { position: relative; height: 168px; background: #0F1320; }
.pool-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pool-photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,12,20,0) 45%, rgba(10,12,20,.62)); }
.pool-photo-name { position: absolute; left: 0; right: 0; bottom: 12px; text-align: center; color: #fff; font-weight: 700; font-style: italic; z-index: 1; text-shadow: 0 2px 10px rgba(0,0,0,.4); }
.pool-photo-badge { position: absolute; top: 10px; right: 10px; z-index: 1; }
/* тонкий видео-баннер */
.video-banner { display: flex; align-items: center; gap: 14px; padding: 14px 18px; }
.video-banner-text { font-size: 13.5px; color: var(--ink-2); }
.video-banner .mini { width: 30px; height: 30px; border-radius: 999px; display: grid; place-items: center; font-size: 15px; }
/* крупный логотип сайдбара */
.sidebar .logo img { height: 42px; }

/* ---- итерация 3 ---- */
/* степпер мастера Create User */
.steps { display: flex; align-items: center; justify-content: center; gap: 0; margin: 4px 0 18px; }
.step-dot { width: 14px; height: 14px; border-radius: 50%; border: 2px solid #D9D9E2; background: #fff; }
.step-dot.on { border-color: var(--bridge); box-shadow: 0 0 0 4px rgba(226,112,58,.18); background: var(--bridge); }
.step-dot.done { border-color: var(--bridge); background: var(--bridge); }
.step-line { width: 64px; height: 2px; background: #E3E3EA; }
.step-line.done { background: var(--bridge); }
.step-title { text-align: center; margin: 0 0 14px; font-size: 15px; }
/* таб-фильтры верификации (подчёркнутый актив, как в макете) */
.vtabs { display: flex; gap: 4px; flex-wrap: wrap; }
.vtabs button { background: none; border: none; padding: 8px 12px; font-size: 13px; font-weight: 600; color: var(--muted); cursor: pointer; border-bottom: 2px solid transparent; }
.vtabs button:hover { color: var(--ink); }
.vtabs button.on { color: var(--bridge); border-bottom-color: var(--bridge); }
/* футер кабинета */
.app-footer { display: grid; grid-template-columns: auto 1fr 1fr 1fr; gap: 28px; align-items: start;
  background: var(--surface); border-top: 1px solid var(--line); margin-top: auto; padding: 22px clamp(16px,3vw,34px); }
.foot-col { display: flex; flex-direction: column; gap: 7px; font-size: 12.5px; }
.foot-col b { font-size: 12.5px; color: var(--ink); margin-bottom: 2px; }
.foot-col a, .foot-col span { color: var(--muted); text-decoration: none; }
.foot-col a:hover { color: var(--bridge); }
.main { display: flex; flex-direction: column; }
.content { flex: 1; }
@media (max-width: 860px) { .app-footer { grid-template-columns: 1fr 1fr; } }

/* ---- итерация 4 ---- */
/* тёмный футер лендинга */
.land-footer { display: flex; align-items: center; gap: 34px; background: #15161B; color: #fff;
  padding: 26px clamp(20px,6vw,72px); margin-top: 46px; }
.land-footer img { height: 46px; color: #fff; }
.land-foot-nav { display: flex; gap: 26px; flex-wrap: wrap; }
.land-foot-nav a { color: #9A9AA6; text-decoration: none; font-size: 13.5px; font-weight: 600; }
.land-foot-nav a.on, .land-foot-nav a:hover { color: #fff; }
.land-foot-call { text-align: right; font-size: 13.5px; }
.land-foot-call b { display: block; }
.land-foot-call a { color: #9A9AA6; font-size: 12px; text-decoration: underline; }
@media (max-width: 760px) { .land-footer { flex-wrap: wrap; gap: 16px; } .land-foot-call { text-align: left; } }
/* узлы дерева структуры: оранжевый акцент как в макете */
.tree-row { border: 1px solid transparent; border-radius: 12px; transition: border-color .15s; }
.tree-row:hover { border-color: var(--bridge-2); background: #fff; }
.grid.cols-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 1100px) { .grid.cols-4 { grid-template-columns: repeat(2, 1fr); } }

/* ---- юридические страницы (тёмный макет Accepting Privacy/Terms) ---- */
.legal-page { min-height: 100vh; background: #2B2B2F; color: #E8E8EC; padding: 48px clamp(20px,7vw,90px); }
.legal-inner { max-width: 1180px; margin: 0 auto; }
.legal-logo { height: 64px; margin-bottom: 30px; color: #fff; }
.legal-page h1 { color: #fff; font-size: 34px; margin: 0 0 4px; }
.legal-sub { color: #B9B9C2; font-size: 15px; margin-bottom: 26px; }
.legal-page h3 { color: #fff; font-size: 16px; margin: 26px 0 8px; }
.legal-page p { color: #C9C9D2; font-size: 13.5px; line-height: 1.65; margin: 0 0 10px; }
.legal-page .btn-ghost { color: #fff; border-color: rgba(255,255,255,.35); background: transparent; }
.legal-scroll { max-height: 56vh; overflow: auto; padding-right: 8px; }
.legal-scroll h4 { margin: 16px 0 6px; }
.legal-p { font-size: 12.8px; line-height: 1.6; color: var(--ink-2); margin: 0 0 8px; }

/* ---- кошелёк и плашки объёмов ---- */
.wallet-warn { border: 1.5px solid var(--line); border-radius: 16px; padding: 14px 16px; }
.wallet-warn b { display: block; margin: 4px 0 4px; }
.wallet-warn p { margin: 0 0 8px; font-size: 12.8px; color: var(--ink-2); line-height: 1.55; }
.vol-chip { display: flex; align-items: center; gap: 12px; background: var(--surface-2); border-radius: 14px; padding: 12px 16px; }
.vol-chip .ic { width: 42px; height: 42px; border-radius: 50%; background: var(--grad); color: #fff; display: grid; place-items: center; }
.vol-chip .ic svg { width: 19px; height: 19px; }
.vol-chip .k { font-size: 12px; color: var(--muted); font-weight: 700; }
.vol-chip .v { color: var(--bridge); font-weight: 800; font-size: 17px; }

/* ---- макеты Admin/Another User/Contacts ---- */
.modal.dark { background: #232327; color: #fff; }
.modal.dark .modal-h { border-bottom: none; justify-content: center; }
.modal.dark .modal-h h3 { color: #fff; font-size: 24px; }
.modal.dark .modal-b, .modal.dark p { color: #D6D6DD; }
.modal.dark .x { background: transparent; border: 1px solid rgba(255,255,255,.4); color: #fff; }
.modal.dark .btn-ghost { background: transparent; color: #fff; border-color: var(--bridge-2); }
.copy-chip { display: flex; align-items: center; gap: 8px; background: var(--surface-2); border-radius: 12px; padding: 9px 12px; font-size: 12.5px; }
.copy-chip b { font-size: 12px; }
.pc-ava { position: relative; width: 96px; height: 96px; margin: 0 auto; border-radius: 50%;
  border: 2.5px solid var(--bridge); display: grid; place-items: center; font-size: 28px; font-weight: 800;
  color: var(--bridge); background: var(--bridge-soft); }
.pc-floor { position: absolute; bottom: -9px; left: 50%; transform: translateX(-50%); background: var(--grad);
  color: #fff; font-size: 10.5px; font-weight: 700; padding: 3px 10px; border-radius: 999px; white-space: nowrap; }

/* ---- топбар по макетам Header ---- */
.wallet-pill { background: var(--grad); color: #fff; font-weight: 700; font-size: 12.5px;
  padding: 9px 16px; border-radius: 12px; letter-spacing: .02em; }
.topbar-user { font-size: 13px; font-weight: 600; color: var(--ink); }
@media (max-width: 900px) { .hide-m { display: none !important; } }
/* соцсети футера: брендовые квадратики */
.soc-link { display: flex; align-items: center; gap: 8px; }
.soc-ico { width: 18px; height: 18px; border-radius: 5px; display: grid; place-items: center;
  color: #fff; font-size: 9px; font-weight: 800; }
.soc-ico.ig { background: radial-gradient(circle at 30% 110%, #FDF497 0%, #FD5949 45%, #D6249F 60%, #285AEB 90%); }
.soc-ico.yt { background: #FF0000; font-size: 8px; }
.app-footer { grid-template-columns: auto 1fr 1fr 1fr auto; }

/* ===================== v2.6 — CMS block, avatars, collapsed sidebar ===================== */
/* photo avatars: <img> fills the same boxes as initials */
.sidebar .who .ava{overflow:hidden}
.sidebar .who .ava img,.u-cell .av img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.u-cell .av{overflow:hidden}
.pc-ava img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}

/* collapsed icon-only sidebar (Cabinet-2 variation) */
.side-toggle{margin-left:auto;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;
  cursor:pointer;color:#8492be;transition:.15s}
.side-toggle:hover{background:rgba(255,255,255,.08);color:#fff}
.side-toggle svg{width:15px;height:15px;transform:rotate(180deg);transition:transform .2s}
.app.side-min{grid-template-columns:78px 1fr}
.app.side-min .side-toggle svg{transform:rotate(0deg)}
.app.side-min .brand{padding:20px 6px 14px;justify-content:center;gap:6px}
.app.side-min .brand-txt{display:none}
.app.side-min .side-toggle{margin-left:0}
.app.side-min .nav{padding:6px 10px 18px}
.app.side-min .nav .group{font-size:0;padding:10px 0 4px;border-top:1px solid rgba(255,255,255,.07);margin:6px 8px 0}
.app.side-min .nav a{justify-content:center;padding:11px 0}
.app.side-min .nav a span,.app.side-min .nav a .tag{display:none}
.app.side-min .nav a.active::before{left:-10px}
.app.side-min .who{margin:10px 8px 14px;padding:8px;justify-content:center}
.app.side-min .who .who-txt{display:none}
@media (max-width: 900px){.app.side-min{grid-template-columns:1fr}.side-toggle{display:none}}

/* CMS admin pages */
.inp.code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.55;white-space:pre}
textarea.inp{resize:vertical;min-height:64px}
.serp-prev{border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:var(--surface-2,#f7f8fb)}
.serp-prev .serp-url{font-size:12px;color:#1f7a3d;margin-bottom:3px;word-break:break-all}
.serp-prev .serp-title{font-size:17px;color:#1a0dab;font-weight:500;line-height:1.3;margin-bottom:3px}
.serp-prev .serp-desc{font-size:12.5px;color:var(--muted);line-height:1.5}

/* public page wrapper (guest FAQ etc.) */
.pub-page{min-height:100vh;background:var(--bg,#f2f3f8)}
.pub-page .land-nav{border-bottom:1px solid var(--line)}
.pub-body{max-width:980px;margin:0 auto;padding:26px clamp(16px,4vw,40px) 60px}

/* ===================== v2.7 — таблицы по макетам: «⋯» меню, чипы лота, покупка ===================== */
.menu-wrap{position:relative;display:inline-block}
.menu-dots{font-size:16px;letter-spacing:1px;width:30px;height:26px;border-radius:13px}
.menu-pop{position:absolute;right:0;top:calc(100% + 6px);z-index:60;min-width:210px;background:#fff;
  border:1px solid var(--line);border-radius:14px;box-shadow:0 14px 38px rgba(16,24,64,.16);padding:6px;
  display:flex;flex-direction:column}
.menu-pop.left{right:auto;left:0}
.menu-item{display:flex;align-items:center;gap:9px;padding:9px 12px;border:0;background:none;border-radius:9px;
  font:inherit;font-size:13.5px;color:var(--ink);cursor:pointer;text-align:left;width:100%}
.menu-item:hover{background:var(--surface-2,#f4f5fa)}
.menu-item.danger{color:#c23b3b}
.menu-item svg{width:15px;height:15px;flex:none}

/* карточка лота по макету: чипы с иконками, hero-фото, оверлей «Шаблон Угоди» */
.lot-hero{position:relative;border-radius:16px;overflow:hidden;margin-bottom:16px}
.lot-hero img{display:block;width:100%;height:clamp(220px,34vw,360px);object-fit:cover}
.lot-hero .lot-hero-actions{position:absolute;top:14px;right:14px;display:flex;gap:8px}
.lot-chips{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:0 0 16px}
@media (max-width:900px){.lot-chips{grid-template-columns:1fr 1fr}}
.lot-chip{display:flex;align-items:center;gap:11px;background:var(--surface-2,#f6f7fb);
  border:1px solid var(--line-2,#eceef6);border-radius:13px;padding:11px 13px}
.lot-chip .ic{width:34px;height:34px;border-radius:50%;flex:none;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,#ffb27a,#ff7a3d)}
.lot-chip .ic svg{width:16px;height:16px}
.lot-chip .lbl{font-size:11.5px;color:var(--muted);line-height:1.25}
.lot-chip .val{font-size:13.5px;font-weight:700;color:var(--bridge,#ff7a3d)}
.lot-cta{display:flex;justify-content:center;margin:0 0 18px}

/* нижний блок «Купівля частки у програмі» */
.buy-acc{display:flex;align-items:center;gap:10px;background:var(--surface-2,#f6f7fb);
  border:1.5px solid var(--line-2,#eceef6);border-radius:12px;padding:11px 14px;cursor:pointer;transition:.15s}
.buy-acc.on{border-color:var(--bridge,#ff7a3d);background:#fff7f1}
.buy-acc input{accent-color:var(--bridge,#ff7a3d)}
.buy-acc .nm{flex:1;font-weight:600;font-size:13.5px}
.buy-acc .bal{font-weight:700}
.buy-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:760px){.buy-grid{grid-template-columns:1fr}}

/* кабинет: «Відеоінструкція» ссылка в шапке страницы */
.page-link{font-size:13px;text-decoration:underline;color:var(--ink-2);cursor:pointer}

/* v2.7.1 — сортировка колонок, нумерованная пагинация, подписи галереи */
.tbl th.th-sort{cursor:pointer;user-select:none;white-space:nowrap}
.tbl th.th-sort:hover{color:var(--ink)}
.tbl th .sort-arr{margin-left:5px;font-size:10px;opacity:.55;letter-spacing:-2px}
.tbl th.on-asc .sort-arr,.tbl th.on-desc .sort-arr{opacity:1;color:var(--bridge,#ff7a3d)}
.pgn-n{min-width:28px;height:28px;border-radius:50%}
.pgn-n.on{background:var(--bridge,#ff7a3d);color:#fff;border-color:var(--bridge,#ff7a3d)}
.pgn-dots{padding:0 2px}
.acct-outline{border:1.5px solid var(--bridge,#ff7a3d) !important}
.acct-outline .amt{color:var(--bridge,#ff7a3d)}
.gal-item{position:relative}
.gal-cap{position:absolute;left:0;right:0;bottom:0;padding:18px 10px 8px;color:#fff;font-size:12px;font-style:italic;
  background:linear-gradient(transparent,rgba(10,12,24,.78));border-radius:0 0 10px 10px;pointer-events:none}
.vtabs button svg{width:14px;height:14px;vertical-align:-2px;margin-right:5px}

/* v2.8 — партнёрские отчёты: рейнджпикер с двумя календарями */
.rng-wrap{display:grid;grid-template-columns:170px 1fr;gap:18px}
@media (max-width:760px){.rng-wrap{grid-template-columns:1fr}}
.rng-presets{display:flex;flex-direction:column;gap:4px}
.rng-preset{background:none;border:0;text-align:left;padding:9px 10px;border-radius:9px;font:inherit;
  font-size:13.5px;cursor:pointer;color:var(--ink)}
.rng-preset:hover{background:var(--surface-2,#f4f5fa)}
.rng-grids{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:640px){.rng-grids{grid-template-columns:1fr}}
.rng-month{border:1px solid var(--line-2,#eceef6);border-radius:12px;padding:10px}
.rng-head{text-align:center;font-weight:700;margin-bottom:8px}
.rng-dow,.rng-cells{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.rng-dow span{font-size:10px;color:var(--muted);text-align:center;padding:2px 0}
.rng-day{border:0;background:none;font:inherit;font-size:12px;padding:6px 0;border-radius:50%;cursor:pointer}
.rng-day:hover{background:var(--surface-2,#f4f5fa)}
.rng-day.in{background:#ffe9db}
.rng-day.on{background:var(--bridge,#ff7a3d);color:#fff;font-weight:700}
.chart-grouped{min-width:600px;height:200px;display:block}

/* v2.9 — отчёты по бонусам и этажам, стейкинг */
.donut-pct{font-size:24px;font-weight:800;fill:var(--ink)}
.donut-sub{font-size:9.5px;fill:var(--muted)}
.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.donut-wrap .cap{font-size:11.5px;color:var(--muted)}
.chart-lines{min-width:600px;height:216px;display:block;color:var(--ink)}
.floors-flow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.chip-soft{display:flex;align-items:center;gap:10px;background:var(--surface-2,#f6f7fb);
  border-radius:13px;padding:9px 14px}
.chip-soft .ic{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,#ffb27a,#ff7a3d)}
.chip-soft.ghost .ic{background:linear-gradient(135deg,#c8d2e8,#8ea4cf)}
.chip-soft b{font-size:13.5px}
.chip-soft .sub{font-size:11px;color:var(--muted)}
.chips-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;margin-bottom:16px}
.chips-scroll .lot-chip{min-width:215px;flex:none;background:#fff;border:1px solid var(--line-2,#eceef6)}

/* ============================================================
   v2.10 — НОВЫЙ лендинг (.ld): простая блочная вёрстка.
   Никаких absolute-коллажей: flex/grid + aspect-ratio.
   ============================================================ */
.ld{max-width:1280px;margin:0 auto;padding:0 clamp(16px,4vw,48px) 0;color:#1c2030;background:#fff}
.ld .lp-nav{display:flex;align-items:center;gap:14px;padding:20px 0;flex-wrap:wrap}
.ld .lp-pills{display:flex;gap:8px}
.ld .lp-pill{padding:8px 16px;border-radius:999px;font-size:13.5px;color:#3a4054;text-decoration:none}
.ld .lp-pill.on,.ld .lp-pill:hover{background:#f2f3f8}
.ld-hero{padding:clamp(18px,4vh,44px) 0 0;text-align:center}
.ld-hero h1{font-family:var(--ff-display);font-size:clamp(34px,6.2vw,76px);line-height:1.05;letter-spacing:.5px;margin:0;text-transform:uppercase}
.ld-hero .ld-sub em{color:var(--bridge,#ff7a3d);font-style:normal}
.ld-cta{display:flex;gap:12px;justify-content:center;margin:22px 0 26px;flex-wrap:wrap}
.btn-lg{padding:13px 28px;font-size:15px}
.ld-img{border-radius:18px;overflow:hidden;background:#eef0f6}
.ld-img img{width:100%;height:100%;object-fit:cover;display:block}
.ld-kicker{font-size:12.5px;letter-spacing:1.5px;text-transform:uppercase;color:#7a8093;margin-bottom:10px}
.ld-sec{padding:clamp(34px,6vh,68px) 0}
.ld-sec h2{font-family:var(--ff-display);font-size:clamp(24px,3.4vw,40px);line-height:1.18;margin:0 0 20px}
.ld-sec h2 em{color:var(--bridge,#ff7a3d);font-style:normal}
.ld-split{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(20px,4vw,48px);align-items:center}
.ld-split.ld-rev{grid-template-columns:1.2fr 1fr}
.ld-center{text-align:center}
.ld-center h2{margin-left:auto;margin-right:auto;max-width:720px}
.ld-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ld-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ld-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:26px;text-align:left}
.ld-card h4{margin:14px 0 6px;font-size:16px}
.ld-card p{margin:0 0 12px;font-size:13px;color:#5d6478;line-height:1.55}
.ld-view{font-size:12px;letter-spacing:1.5px;font-weight:700;color:#1c2030;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.ld-view:hover{color:var(--bridge,#ff7a3d)}
.ld-review{background:#f6f7fb;border-radius:18px;padding:22px;text-align:left}
.ld-review p{margin:10px 0 0;font-size:13.5px;line-height:1.65;color:#3a4054}
.ld-quote{font-family:var(--ff-display);font-size:46px;line-height:.6;color:var(--bridge,#ff7a3d)}
.ld-stars{color:#f2b01e;display:inline-flex;gap:2px}
.ld-stars svg{width:15px;height:15px}
.ld-ini{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#ffb27a,#ff7a3d);color:#fff;display:grid;place-items:center;font-weight:700}
.ld-ok{width:22px;height:22px;border-radius:50%;background:#1f9d55;color:#fff;display:grid;place-items:center}
.ld-ok svg{width:12px;height:12px}
.ld-foot{display:flex;align-items:center;gap:clamp(16px,4vw,40px);flex-wrap:wrap;background:#15181f;color:#fff;
  border-radius:22px 22px 0 0;padding:26px clamp(18px,4vw,40px);margin:30px calc(-1 * clamp(16px,4vw,48px)) 0}
.ld-foot-links{display:flex;gap:clamp(10px,2.5vw,26px);flex-wrap:wrap}
.ld-foot-links a{color:#cfd3de;text-decoration:none;font-size:13.5px}
.ld-foot-links a:hover{color:#fff}
.ld .land-foot-call{display:flex;align-items:center;gap:12px}
.ld .land-foot-call b{font-size:15px}
.ld .land-foot-call a{color:var(--bridge,#ff7a3d);font-size:12.5px;text-decoration:underline}
@media (max-width:860px){
  .ld-split,.ld-split.ld-rev{grid-template-columns:1fr}
  .ld-grid3{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:640px){
  .ld-grid2{grid-template-columns:1fr}
  .ld-grid3{grid-template-columns:1fr 1fr}
  .ld-hero h1{font-size:clamp(30px,9vw,44px)}
}

/* ============================================================
   v2.10.1 — фикс «цифры упираются в край карточки».
   Раньше существовал только составной селектор .card.pad, и
   вложенный <div class="pad"> внутри карточки оставался БЕЗ
   отступов (16 мест по проекту: контрол-панель, отчёты,
   стейкинг, карточка лота…). Плюс крайние ячейки таблиц
   выравниваем с card-h (20px от края).
   ============================================================ */
.pad{padding:20px}
.card-h + .pad{padding-top:16px}
table.tbl th:first-child,table.tbl td:first-child{padding-left:20px}
table.tbl th:last-child,table.tbl td:last-child{padding-right:20px}
.kv-row b,.kv .v{padding-right:2px} /* жирные цифры не липнут к границе при overflow ellipsis */
