/* nxtme — дизайн-система (M6/Д1). Одна база, светлая и тёмная тема на CSS-переменных.
   Токены/компоненты перенесены из Design/nxtme-ui-kit.html и натянуты на реальные
   классы приложения, поэтому все страницы получают единый вид разом. */
:root{
  --paper:#F4F5F1;--surface:#FFFFFF;--ink:#17191C;--ink-soft:#5B616A;--ink-faint:#8A909A;
  --line:#E5E6E0;--line-strong:#D2D4CC;
  --now:#0C6B57;--now-tint:#E7F0EC;--now-ink:#0A5646;
  --next:#C0821F;--next-tint:#F6ECD7;--next-ink:#8C5D11;
  --mut:#7A828C;--mut-tint:#EDEEEA;--err:#B4342B;--err-tint:#FBECEA;
  --radius:15px;--radius-sm:11px;
  --shadow-soft:0 1px 2px rgba(23,25,28,.04), 0 10px 26px -20px rgba(23,25,28,.18);
  --font-display:'Clash Display',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-body:'Satoshi',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
:root[data-theme="dark"]{
  --paper:#0E0F12;--surface:#171A1E;--ink:#F0F1EC;--ink-soft:#A7ADB4;--ink-faint:#727880;
  --line:#262A2F;--line-strong:#31363C;
  --now:#3FBFA0;--now-tint:#12241F;--now-ink:#7BD8C1;
  --next:#E0A94A;--next-tint:#28210F;--next-ink:#EBC078;
  --mut:#8A929B;--mut-tint:#20242A;--err:#E4796E;--err-tint:#241413;
  --shadow-soft:0 1px 2px rgba(0,0,0,.35), 0 14px 34px -22px rgba(0,0,0,.55);
}
/* Тема по умолчанию — СВЕТЛАЯ везде (не следуем системной prefers-color-scheme).
   Тёмная включается только явным выбором пользователя (data-theme="dark"). */

*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--paper);color:var(--ink);font-family:var(--font-body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;transition:background .4s,color .4s}
h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;line-height:1.15}
h2{font-size:22px;margin-bottom:4px}
h3{font-size:16px;color:var(--ink);margin:20px 0 8px}
h4{font-family:var(--font-display);font-weight:500;font-size:14px;margin:16px 0 6px}
a{color:var(--now-ink);text-decoration:none}
a:hover{text-decoration:underline}
.mono{font-family:var(--font-mono);font-feature-settings:"tnum" 1}
:focus-visible{outline:2px solid var(--now);outline-offset:2px;border-radius:5px}
code{font-family:var(--font-mono);font-size:.9em;background:var(--mut-tint);padding:1px 5px;border-radius:5px}

/* ---- app shell (sidebar) ---- */
.app{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.side{border-right:1px solid var(--line);background:var(--surface);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side-logo{font-family:var(--font-display);font-weight:600;font-size:22px;letter-spacing:-.03em;padding:22px 24px 18px;display:flex;align-items:center;gap:9px;color:var(--ink)}
.side-logo:hover{text-decoration:none}
.side-logo .lm{width:23px;height:23px;flex:none}
.side-nav{display:flex;flex-direction:column;gap:2px;padding:8px 14px;overflow-y:auto}
.side-nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:var(--ink-soft);font-size:14.5px;font-weight:500;transition:background .18s,color .18s}
.side-nav a:hover{background:var(--now-tint);color:var(--ink);text-decoration:none}
.side-nav a.active{background:var(--now-tint);color:var(--now-ink)}
.side-nav a svg{flex:none;opacity:.85}
.side-nav .grp{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-faint);padding:14px 12px 5px}
.side-foot{margin-top:auto;padding:14px 16px;border-top:1px solid var(--line);display:flex;align-items:center;gap:11px}
.avatar{width:34px;height:34px;border-radius:9px;background:var(--now);color:#fff;display:grid;place-items:center;font-weight:600;font-size:14px;flex:none}
.side-foot .who{flex:1;min-width:0}
.side-foot .who b{font-size:13.5px;font-weight:500;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-foot .who span{font-size:12px;color:var(--ink-faint)}
.theme-toggle{width:32px;height:32px;border-radius:8px;border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);cursor:pointer;display:grid;place-items:center;flex:none}
.theme-toggle:hover{color:var(--ink);border-color:var(--ink)}
.main{min-width:0;padding:26px 34px 60px;max-width:1120px}
.main>h2:first-child{font-size:26px;margin-bottom:18px}

/* мобильный топбар + оффканвас-подложка (видны только на узких экранах) */
.topbar{display:none}
.nav-backdrop{display:none}
.burger{padding:0}
.tb-brand{color:var(--ink)}
.tb-brand:hover{text-decoration:none}
.tb-brand .lm{width:20px;height:20px;flex:none}

/* ---- public landing (M6/Д5) ---- */
body.landing{background:var(--paper)}
.pub-top{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;border-bottom:1px solid var(--line);position:sticky;top:0;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(8px);z-index:10}
.logo-brand{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:21px;letter-spacing:-.03em}
.logo-brand .lm{width:23px;height:23px}
.pub-actions{display:flex;gap:8px}
.pub-main{max-width:940px;margin:0 auto;padding:0 24px 64px}
.eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:14px}
.hero{padding:64px 0 30px;text-align:center}
.hero h1{font-size:clamp(30px,5vw,46px);max-width:16em;margin:0 auto}
.hero .lead{color:var(--ink-soft);font-size:17px;max-width:40em;margin:18px auto 0}
.accent-now{color:var(--now-ink)}.accent-next{color:var(--next-ink)}
.hero-cta{display:flex;gap:11px;justify-content:center;margin-top:26px;flex-wrap:wrap}
.hero-hz{margin-top:40px}.hero-hz svg{width:100%;max-width:640px;height:22px}
.steps3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:22px}
.step .s-n{color:var(--ink-faint);font-size:13px}
.step h3{margin:8px 0 6px}
.step p{font-size:13.5px;color:var(--ink-soft)}
.pub-band{background:linear-gradient(180deg,var(--now-tint) 0%,transparent 70%),var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:34px;text-align:center;margin-top:34px}
.pub-band h2{font-size:26px}.pub-band .lead{color:var(--ink-soft);max-width:40em;margin:12px auto 22px}
.pub-foot{text-align:center;color:var(--ink-faint);font-size:12.5px;margin-top:40px}

/* ---- auth (centered) layout ---- */
body.auth{display:grid;place-items:center;min-height:100vh;padding:24px}
.auth-brand{display:flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:24px;letter-spacing:-.03em;margin-bottom:18px}
.auth-brand .lm{width:26px;height:26px}

/* ---- cards ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:24px;margin-bottom:18px}
.card.narrow{max-width:380px;width:100%;margin:0 auto}

/* ---- forms ---- */
label{display:block;margin:12px 0;font-size:13px;color:var(--ink-soft);font-weight:500}
label.inline{display:inline-flex;align-items:center;gap:8px;margin:8px 14px 8px 0;font-size:14px;color:var(--ink)}
label.inline input{width:auto;margin:0}
input,select,textarea{width:100%;padding:10px 13px;margin-top:5px;border:1px solid var(--line-strong);border-radius:10px;background:var(--surface);color:var(--ink);font-family:var(--font-body);font-size:14.5px;transition:border-color .18s,box-shadow .18s}
textarea{line-height:1.5}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--now);box-shadow:0 0 0 4px var(--now-tint)}
input[type=checkbox],input[type=radio]{width:auto;margin-top:0;accent-color:var(--now)}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>label{flex:1;min-width:150px}

/* ---- buttons ---- */
button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--now);color:#fff;border:1px solid transparent;padding:10px 17px;border-radius:10px;cursor:pointer;font-family:var(--font-body);font-weight:500;font-size:14px;text-decoration:none;transition:transform .16s,background .18s,border-color .18s,color .18s}
button:hover,.btn:hover{background:var(--now-ink);text-decoration:none}
button:active,.btn:active{transform:translateY(1px)}
.btn-amber{background:var(--next)}.btn-amber:hover{background:var(--next-ink)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}.btn-ghost:hover{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-sm{padding:7px 12px;font-size:13px}
.arw{transition:transform .2s}button:hover .arw,.btn:hover .arw{transform:translateX(3px)}

/* ---- flash ---- */
.flash{padding:11px 15px;border-radius:11px;margin-bottom:12px;font-size:14px;border:1px solid transparent}
.flash.ok{background:var(--now-tint);color:var(--now-ink);border-color:var(--now)}
.flash.error{background:var(--err-tint);color:var(--err);border-color:var(--err)}

/* ---- tables ---- */
table.jobs{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft)}
table.jobs th{background:transparent;text-align:left;padding:12px 14px;font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint);border-bottom:1px solid var(--line)}
table.jobs td{padding:13px 14px;border-top:1px solid var(--line);vertical-align:top;font-size:14px}
table.jobs tr:first-child td{border-top:none}
td.score{font-family:var(--font-mono);font-weight:500;font-size:20px;color:var(--now-ink)}
td.actions{white-space:nowrap}
td.actions form{display:inline}
td.actions button{padding:5px 9px;font-size:12.5px}

/* ---- misc ---- */
.muted{color:var(--ink-faint);font-size:12.5px}
.gaps{color:var(--next-ink);font-size:12.5px}
.badge{display:inline-block;margin-left:6px;padding:2px 9px;border-radius:7px;background:var(--now-tint);color:var(--now-ink);font-size:11px;font-weight:600;font-family:var(--font-mono);vertical-align:middle}
.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-soft)}
.toolbar select,.toolbar input{width:auto;margin-top:0}
.toolbar .right{margin-left:auto}
.funnel-buttons{display:flex;gap:7px;flex-wrap:wrap;margin:10px 0}
.star-btn{background:none;color:var(--line-strong);font-size:18px;line-height:1;padding:2px 5px;border:none}
.star-btn:hover{background:none;color:var(--next)}
.star-btn.on{color:var(--next)}
.pager{display:flex;gap:6px;align-items:center;justify-content:center;margin-top:16px;flex-wrap:wrap}
.pager a,.pager span{padding:6px 11px;border-radius:8px;font-size:13px;font-family:var(--font-mono)}
.pager a{background:var(--surface);border:1px solid var(--line-strong);color:var(--ink-soft)}
.pager a:hover{border-color:var(--now);color:var(--now-ink);text-decoration:none}
.pager .cur{background:var(--now-tint);color:var(--now-ink);border:1px solid var(--now)}
.pager .muted{background:none;border:none}

/* ---- chips ---- */
.chip{display:inline-flex;align-items:center;font-size:12px;padding:4px 10px;border-radius:7px;background:var(--now-tint);color:var(--now-ink);white-space:nowrap}
.chip.gap{background:transparent;border:1px dashed var(--next);color:var(--next-ink)}
.chip.mut{background:var(--mut-tint);color:var(--ink-soft)}

/* ============ M6/Д2 — дашборд «два горизонта» ============ */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.metric{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-soft)}
.metric .m-k{font-size:12.5px;color:var(--ink-faint);display:flex;align-items:center;gap:7px}
.metric .m-k .pip{width:8px;height:8px;border-radius:50%;background:var(--line-strong)}
.metric.now .m-k .pip{background:var(--now)}.metric.next .m-k .pip{background:var(--next)}
.metric .m-v{font-family:var(--font-mono);font-size:30px;font-weight:500;margin-top:8px;letter-spacing:-.02em;line-height:1}
.metric.now .m-v{color:var(--now-ink)}.metric.next .m-v{color:var(--next-ink)}
.metric .m-s{font-size:12px;color:var(--ink-soft);margin-top:7px}
.metric .m-big{font-family:var(--font-display);font-weight:600;font-size:17px;margin-top:8px;letter-spacing:-.01em}

.seg-tabs{display:none;gap:8px;margin-bottom:16px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:5px}
.seg-tabs button{flex:1;padding:11px;border:none;background:transparent;border-radius:9px;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--ink-soft);cursor:pointer}
.seg-tabs button.on{background:var(--now-tint);color:var(--now-ink)}
.seg-tabs button.next-t.on{background:var(--next-tint);color:var(--next-ink)}

.segments{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.col-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.col-head .h{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:17px}
.col-head .h .cnt{font-family:var(--font-mono);font-size:13px;padding:3px 9px;border-radius:20px}
.col.now .h .cnt{background:var(--now-tint);color:var(--now-ink)}
.col.next .h .cnt{background:var(--next-tint);color:var(--next-ink)}
.col-head .sort{font-size:12.5px;color:var(--ink-faint);font-family:var(--font-mono)}
.empty{border:1px dashed var(--line-strong);border-radius:12px;padding:26px 18px;text-align:center;color:var(--ink-faint);font-size:13.5px}
.col-more{text-align:center;margin-top:12px;padding:10px;border:1px dashed var(--line-strong);border-radius:11px;font-size:12.5px;color:var(--ink-soft);font-family:var(--font-mono)}

.jobcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:17px 18px;position:relative;overflow:hidden;box-shadow:var(--shadow-soft)}
.jobcard+.jobcard{margin-top:14px}
.jobcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}
.jobcard.now::before{background:var(--now)}
.jobcard.next::before{background:var(--next)}
.jobcard.next{background:linear-gradient(180deg,var(--next-tint) 0%,transparent 44%)}
.jc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.jc-title{font-family:var(--font-display);font-weight:600;font-size:16.5px;letter-spacing:-.01em}
.jc-title a{color:var(--ink)}.jc-title a:hover{color:var(--now-ink)}
.jc-org{font-size:12px;color:var(--ink-faint);margin-top:3px;font-family:var(--font-mono)}
.match,.gapbadge{text-align:right;flex:none}
.match .n{font-family:var(--font-mono);font-size:22px;font-weight:500;color:var(--now-ink);line-height:1}
.gapbadge .n{font-family:var(--font-mono);font-size:22px;font-weight:500;color:var(--next-ink);line-height:1}
.match .l,.gapbadge .l{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}
.reason{font-size:13px;color:var(--ink-soft);margin-top:11px}
.status-next{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--next-ink);font-family:var(--font-mono);margin-top:5px}
.status-next .ring{width:8px;height:8px;border-radius:50%;border:2.5px solid var(--next)}
.jobcard .chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px}
.jc-meta{display:flex;flex-wrap:wrap;gap:14px;margin-top:12px;font-size:12.5px;color:var(--ink-soft);font-family:var(--font-mono)}
.effect{font-size:12.5px;color:var(--ink-soft);margin-top:11px;background:var(--next-tint);border-radius:9px;padding:8px 11px}
.effect b{color:var(--next-ink);font-family:var(--font-mono);font-weight:500}
.jc-actions{display:flex;gap:8px;margin-top:14px;padding-top:13px;border-top:1px solid var(--line);align-items:center;flex-wrap:wrap}
.jc-actions form{display:inline}

/* ============ M6/Д3 — карта навыков ============ */
.greet{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);letter-spacing:.04em;text-transform:uppercase}
.summary{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:20px 22px;margin-bottom:22px}
.sum-stats{display:flex;gap:28px;flex-wrap:wrap;margin-bottom:16px}
.sum-stat .v{font-family:var(--font-mono);font-size:24px;font-weight:500;letter-spacing:-.02em}
.sum-stat .k{font-size:12.5px;color:var(--ink-soft);margin-top:2px}
.sum-stat.have .v{color:var(--now-ink)}
.sum-stat.next .v{color:var(--next-ink)}
.stackbar{display:flex;height:10px;border-radius:6px;overflow:hidden;gap:2px}
.stackbar i{height:100%;border-radius:3px}
.stackbar .b-have{background:var(--now)}.stackbar .b-conf{background:var(--mut)}.stackbar .b-gap{background:var(--next)}
.stackleg{display:flex;gap:18px;margin-top:12px;flex-wrap:wrap}
.stackleg span{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-soft)}
.stackleg .d{width:9px;height:9px;border-radius:50%}
.zone{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);margin-bottom:18px;overflow:hidden}
.zone.have{--z:var(--now);--zt:var(--now-tint);--zi:var(--now-ink)}
.zone.confirm{--z:var(--mut);--zt:var(--mut-tint);--zi:var(--ink-soft)}
.zone.gap{--z:var(--next);--zt:var(--next-tint);--zi:var(--next-ink)}
.zone-head{display:flex;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--line);background:linear-gradient(90deg,var(--zt) 0%,transparent 60%)}
.zone-head h3{margin:0;font-size:17px}
.zone-dot{width:11px;height:11px;border-radius:50%;background:var(--z);flex:none}
.zone.confirm .zone-dot,.zone.gap .zone-dot{background:transparent;border:2px solid var(--z)}
.zone-head .cnt{font-family:var(--font-mono);font-size:13px;padding:3px 10px;border-radius:20px;background:var(--surface);color:var(--zi);border:1px solid var(--line)}
.zone-head .mean{font-size:12.5px;color:var(--ink-soft);margin-left:auto;text-align:right;max-width:46%}
.zone-body{padding:4px 20px 12px}
.skill{display:grid;grid-template-columns:1fr 150px;gap:18px;align-items:center;padding:13px 0;border-top:1px solid var(--line)}
.skill:first-child{border-top:none}
.sk-main .nm{font-weight:500;font-size:15px}
.impact{text-align:right}
.impact .iv{font-family:var(--font-mono);font-size:17px;font-weight:500;letter-spacing:-.01em}
.zone.have .impact .iv{color:var(--now-ink)}.zone.gap .impact .iv{color:var(--next-ink)}
.impact .il{font-size:11px;color:var(--ink-faint);margin-top:2px}
.zone-cta{margin:8px 20px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 17px;border-radius:12px;background:var(--next-tint)}
.zone-cta p{font-size:13px;color:var(--next-ink);max-width:40em}

/* ============ M6/Д4 — план роста ============ */
.plan-band{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:20px 24px;margin-bottom:28px;display:flex;flex-wrap:wrap;gap:26px;align-items:center}
.pb-stat{display:flex;flex-direction:column;gap:3px}
.pb-stat .k{font-size:12px;color:var(--ink-faint);font-family:var(--font-mono);letter-spacing:.03em;text-transform:uppercase}
.pb-stat .v{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-.01em}
.pb-stat .v.mono{font-family:var(--font-mono);font-weight:500}
.pb-stat.target .v{color:var(--next-ink)}.pb-stat.effect .v{color:var(--now-ink)}
.pb-div{width:1px;align-self:stretch;background:var(--line)}
.timeline{position:relative;padding-left:6px}
.tstep{position:relative;display:grid;grid-template-columns:52px 1fr;gap:18px;padding-bottom:24px}
.tstep:last-child{padding-bottom:0}
.tnode{display:flex;flex-direction:column;align-items:center}
.tnum{width:38px;height:38px;border-radius:50%;background:var(--now);color:#fff;display:grid;place-items:center;font-family:var(--font-mono);font-size:15px;font-weight:500;flex:none;z-index:2}
.tline{width:2px;flex:1;margin-top:6px;background:linear-gradient(var(--now),var(--next));opacity:.5}
.tstep:last-child .tline{display:none}
.stepcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:18px 20px}
.sc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.sc-title{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-.01em}
.sc-what{font-size:13px;color:var(--ink-soft);margin-top:5px}
.prio{font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:20px;white-space:nowrap;flex:none}
.prio.high{background:var(--next-tint);color:var(--next-ink)}
.prio.mid{background:var(--mut-tint);color:var(--ink-soft)}
.effbar{height:6px;border-radius:4px;background:var(--next-tint);overflow:hidden;margin-top:14px}
.effbar i{display:block;height:100%;background:var(--next);border-radius:4px}
.sc-row{display:flex;flex-wrap:wrap;gap:22px;align-items:center;margin-top:15px;padding-top:14px;border-top:1px solid var(--line)}
.sc-metric{display:flex;flex-direction:column;gap:2px}
.sc-metric .mv{font-family:var(--font-mono);font-size:16px;font-weight:500;color:var(--next-ink)}
.sc-metric.time .mv{color:var(--ink)}
.sc-metric .mk{font-size:11.5px;color:var(--ink-faint)}
.sc-confirm{margin-left:auto;font-size:12px;color:var(--ink-soft);font-family:var(--font-mono);max-width:50%;text-align:right}
.dest{margin-top:30px;background:linear-gradient(180deg,var(--next-tint) 0%,transparent 70%),var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:24px 26px;position:relative;overflow:hidden}
.dest::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--next)}
.dest h3{font-size:19px}
.dest .lead{color:var(--ink-soft);font-size:13.5px;margin-top:8px}
.roles{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
.rolechip{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:var(--surface)}
.rolechip .rn{font-family:var(--font-display);font-weight:500;font-size:15px}
.rolechip .rm{font-size:12px;color:var(--ink-faint);margin-top:2px}
.rolechip .rv{font-family:var(--font-mono);font-size:16px;font-weight:500;color:var(--next-ink)}
.dest-cta{display:flex;gap:11px;margin-top:20px;flex-wrap:wrap}

@media(max-width:1080px){.metrics{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){
  .app{grid-template-columns:1fr}
  /* топбар с гамбургером */
  .topbar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:30;
    padding:11px 16px;border-bottom:1px solid var(--line);
    background:color-mix(in srgb,var(--surface) 92%,transparent);backdrop-filter:blur(8px)}
  .burger{width:38px;height:38px;border-radius:10px;border:1px solid var(--line-strong);
    background:transparent;color:var(--ink);display:grid;place-items:center;cursor:pointer;flex:none}
  .burger:hover{border-color:var(--ink);background:transparent}
  .tb-brand{display:flex;align-items:center;gap:8px;font-family:var(--font-display);
    font-weight:600;font-size:19px;letter-spacing:-.03em}
  /* сайдбар превращается в выезжающее меню */
  .side{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:272px;max-width:82vw;z-index:50;
    transform:translateX(-100%);transition:transform .26s ease;box-shadow:0 20px 60px -20px rgba(0,0,0,.4)}
  body.nav-open .side{transform:translateX(0)}
  .nav-backdrop{display:block;position:fixed;inset:0;z-index:40;background:rgba(8,10,12,.44);
    opacity:0;pointer-events:none;transition:opacity .26s}
  body.nav-open .nav-backdrop{opacity:1;pointer-events:auto}
  .main{padding:20px 18px 56px}
  .pub-top{padding:14px 18px}
  .seg-tabs{display:flex}
  .segments{grid-template-columns:1fr}
  .segments[data-active="now"] .col.next{display:none}
  .segments[data-active="next"] .col.now{display:none}
  .zone-head .mean{display:none}
  .roles{grid-template-columns:1fr}
  .steps3{grid-template-columns:1fr}
  .pub-main{padding:0 18px 48px}
  .pb-div{display:none}
  .sc-confirm{max-width:100%;text-align:left;margin-left:0;width:100%}
}
@media(max-width:640px){
  .row>label{flex:1 1 100%}
  .toolbar{padding:12px 13px}
  .card{padding:18px 16px}
  .stat-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
}
@media(max-width:520px){.metrics{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}

/* ── Админ-раздел (обзор/пользователи/платежи) ───────────────────────────── */
.admin-tabs{display:flex;gap:4px;flex-wrap:wrap;margin:8px 0 20px;border-bottom:1px solid var(--line)}
.admin-tabs a{padding:8px 14px;border-radius:9px 9px 0 0;color:var(--ink-soft);font-weight:500;font-size:14px}
.admin-tabs a:hover{color:var(--ink)}
.admin-tabs a.active{color:var(--now-ink);background:var(--now-tint);border-bottom:2px solid var(--now)}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin:8px 0 4px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px}
.stat-v{font-family:var(--font-display);font-weight:600;font-size:24px;letter-spacing:-.02em;color:var(--ink);font-feature-settings:"tnum" 1}
.stat-l{font-size:13px;color:var(--ink-soft);margin-top:2px}
.table-scroll{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:14px;min-width:640px}
.admin-table th,.admin-table td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.admin-table th{color:var(--ink-soft);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
.admin-table tbody tr:nth-child(even) td{background:color-mix(in srgb,var(--mut-tint) 45%,transparent)}
.admin-table tbody tr:hover td{background:var(--mut-tint)}
.tag{display:inline-block;padding:1px 8px;border-radius:20px;font-size:12px;background:var(--mut-tint);color:var(--ink-soft)}
.tag-ok{background:var(--now-tint);color:var(--now-ink)}
.tag-err{background:var(--err-tint);color:var(--err)}
.tag-mut{background:var(--mut-tint);color:var(--ink-soft)}
.inline-form{display:inline-flex;gap:3px;margin:2px 4px 2px 0}
.inline-form select{padding:4px 7px;font-size:13px}
.inline-form button{padding:4px 10px;font-size:12.5px;font-weight:500;background:transparent;color:var(--ink-soft);border-color:var(--line-strong)}
.inline-form button:hover{background:var(--mut-tint);color:var(--ink);border-color:var(--ink)}
.inline-form button.danger{color:var(--err);border-color:var(--err-tint)}
.inline-form button.danger:hover{background:var(--err-tint);color:var(--err);border-color:var(--err)}
