/* ============================================================
   Cabinet shell — static auth screens (R1).
   SSOT for cabinet.kakranshe.com auth UI, parallel to
   app-shell.{html,css,js} (VPN clients).

   Vanilla CSS faithful port of cabinet-a-blocks.jsx primitives
   (AFrame / ATermInput / ABtn / ALinkBtn / AFormError / ACaret).
   Tokens: ONLY the 9 cabinet --cd-* colour tokens + --cd-mono from
   design-system/web/colors_and_type.css (.concept-techcrt scope).
   Font: JetBrains Mono 14px single size, self-hosted (OPSEC: no
   Google/Cloudflare/jsdelivr CDN per
   feedback_cabinet_jbm_mono_must_self_host_not_google_cdn).
   ============================================================ */

/* ------------------------------------------------------------
   Self-hosted JetBrains Mono 400 + 500 (subset woff2, copied
   from design-system/web/fonts/). Unicode-range split mirrors
   colors_and_type.css verbatim so the browser picks the right
   subset (cyrillic / cyrillic-ext / latin / latin-ext / greek /
   vietnamese). Manrope + Press Start 2P are NOT used in cabinet
   (cabinet.md §2 / §16) — not loaded here.
   ------------------------------------------------------------ */

/* === JetBrains Mono 400 === */
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:400; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-400-cyrillic-ext.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:400; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-400-cyrillic.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:400; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-400-greek.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:400; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02AF, U+0304, U+0308, U+0329, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:400; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-400-vietnamese.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:400; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }

/* === JetBrains Mono 500 === */
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:500; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-500-cyrillic-ext.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:500; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-500-cyrillic.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:500; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-500-greek.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:500; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02AF, U+0304, U+0308, U+0329, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:500; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-500-vietnamese.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB; }
@font-face { font-family:'JetBrains Mono'; font-style:normal; font-weight:500; font-display:swap;
  src: url('/static/cabinet/fonts/jetbrains-mono-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }

/* ------------------------------------------------------------
   Tokens — the 9 cabinet --cd-* + --cd-mono. Verbatim from
   colors_and_type.css .concept-techcrt scope. No new colors.
   (--cd-card / --cd-phos-dim are NOT used in cabinet — omitted.)
   ------------------------------------------------------------ */
:root {
  --cd-bg:     #0a0c0a;   /* canvas */
  --cd-bg-2:   #131613;   /* surface (modals/sheets) */
  --cd-rule:   #2a2f2a;   /* hairline 1px */
  --cd-ink:    #dee3d6;   /* bright text */
  --cd-ink-2:  #b4bcb0;   /* mid text, links default */
  --cd-ink-3:  #8a9285;   /* dim text, labels, hints */
  --cd-phos:   #5cff7a;   /* state-good + primary CTA + alive */
  --cd-warn:   #ffb84a;   /* warning */
  --cd-danger: #ff6b5e;   /* danger / error */

  --cd-mono: 'JetBrains Mono', 'Menlo', 'Consolas', monospace;

  /* spacing scale A_SP (cabinet.md §3) */
  --cd-s-xs: 4px;
  --cd-s-sm: 8px;
  --cd-s-md: 12px;
  --cd-s-lg: 16px;
  --cd-s-xl: 20px;
  --cd-s-2xl: 24px;
  --cd-s-3xl: 32px;
  --cd-s-4xl: 40px;
}

/* ------------------------------------------------------------
   Scrollbar (phosphor thumb) — mirrors colors_and_type.css.
   ------------------------------------------------------------ */
* {
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--cd-phos) 35%, transparent) transparent;
}
*::-webkit-scrollbar { width: 8px; height: 8px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--cd-phos) 25%, transparent);
  border-radius: 4px;
  border: 2px solid transparent;
  background-clip: content-box;
  min-height: 32px;
}
*::-webkit-scrollbar-thumb:hover {
  background: color-mix(in srgb, var(--cd-phos) 50%, transparent);
  background-clip: content-box;
}
*::-webkit-scrollbar-corner { background: transparent; }

/* ------------------------------------------------------------
   Reset + page background. Frame is centred on the canvas; the
   page background is the same --cd-bg so on desktop the frame
   border reads as the only edge.
   ------------------------------------------------------------ */
* { box-sizing: border-box; }
html, body {
  margin: 0;
  padding: 0;
  min-height: 100%;
}
body {
  background: var(--cd-bg);
  color: var(--cd-ink-2);
  font-family: var(--cd-mono);
  font-size: 14px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: var(--cd-s-2xl) 0;
}

/* ------------------------------------------------------------
   AFrame — 390px shell, 1px rule, radius 16, overflow hidden.
   Auth screens use plan="new" hideTabs hideStatus → header only,
   no bottom tabs, no status label (cabinet.md §4 / §5 / §19).
   ------------------------------------------------------------ */
.cab-frame {
  width: 390px;
  max-width: 100%;
  position: relative;
  background: var(--cd-bg);
  color: var(--cd-ink-2);
  border: 1px solid var(--cd-rule);
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  font-family: var(--cd-mono);
}

/* header 52, border-bottom rule. Left: brand mark + wordmark.
   No status label (hideStatus), no hamburger, no version. */
.cab-header {
  height: 52px;
  padding: 0 var(--cd-s-lg);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--cd-s-sm);
  background: var(--cd-bg);
  border-bottom: 1px solid var(--cd-rule);
}
.cab-mark {
  width: 20px;
  height: 20px;
  image-rendering: pixelated;
  display: block;
  flex-shrink: 0;
}
.cab-wordmark {
  font-family: var(--cd-mono);
  font-size: 14px;
  font-weight: 500;
  color: var(--cd-ink-2);
  letter-spacing: -0.01em;
}

/* pane — scrollable content area. Frame padding xl/lg/2xl. */
.cab-pane {
  flex: 1;
  overflow: auto;
  min-height: 0;
  padding: var(--cd-s-xl) var(--cd-s-lg) var(--cd-s-2xl);
  display: flex;
  flex-direction: column;
  scrollbar-gutter: stable;
}

/* screen column wrapper (gap xl between prompt / fields / CTA / nav) */
.cab-screen {
  display: flex;
  flex-direction: column;
  gap: var(--cd-s-xl);
}
.cab-screen--tight { gap: var(--cd-s-lg); }

/* ------------------------------------------------------------
   Prompt line — "> заголовок". The ">" carries the accent:
   ink-3 for input prompts, phos for success/sent prompts
   (cabinet.md §19, mirrors cabinet-screens.jsx).
   ------------------------------------------------------------ */
.cab-prompt {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-2);
  line-height: 1.55;
}
.cab-prompt__chevron { color: var(--cd-ink-3); }
.cab-prompt__chevron--good { color: var(--cd-phos); }

/* dim helper / body paragraph */
.cab-hint {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-3);
  line-height: 1.6;
  letter-spacing: 0.02em;
}
.cab-body {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-2);
  line-height: 1.7;
}
.cab-body--indent { padding-left: 18px; }
.cab-phos-word { color: var(--cd-phos); }
.cab-dim-word { color: var(--cd-ink-3); }

/* field group (gap lg) */
.cab-fields {
  display: flex;
  flex-direction: column;
  gap: var(--cd-s-lg);
}

/* primary CTA wrapper — small top margin (mirrors marginTop sm) */
.cab-cta { margin-top: var(--cd-s-sm); }

/* nav row (links) */
.cab-nav {
  font-family: var(--cd-mono);
  font-size: 14px;
}
.cab-nav--split {
  display: flex;
  justify-content: space-between;
}
.cab-nav--top { margin-top: var(--cd-s-md); }

/* ------------------------------------------------------------
   ATermInput — terminal field with a MOVING block caret.
   Two layers in a relative wrapper: a visible text layer
   (before + caretChar + after) and a transparent <input> on top
   (caretColor transparent). Block sits on the insertion point.
   cabinet.md §14b — JBM Mono advance-width keeps layers aligned.
   ------------------------------------------------------------ */
.cab-input {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cab-input__label {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-3);
  letter-spacing: 0.04em;
}
.cab-input__box {
  position: relative;
  border-bottom: 1px solid var(--cd-rule);
  padding-bottom: 8px;
  min-width: 0;
  cursor: text;
  font-family: var(--cd-mono);
  font-size: 14px;
  line-height: 1.4;
}
.cab-input__box--error { border-bottom-color: var(--cd-danger); }

/* visible layer */
.cab-input__display {
  white-space: pre;
  overflow: hidden;
  color: var(--cd-ink-2);
}
.cab-input__display--placeholder { color: var(--cd-ink-3); }

/* the moving block caret span (reverse-video when focused) */
.cab-caret {
  display: inline-block;
  background: transparent;
  color: inherit;
}
.cab-input__box.is-focused .cab-caret {
  animation: a-block-blink 1.06s steps(1, end) infinite;
}

/* transparent editable input on top */
.cab-input__field {
  position: absolute;
  inset: 0;
  width: 100%;
  background: transparent;
  border: none;
  outline: none;
  padding: 0;
  margin: 0;
  font-family: var(--cd-mono);
  font-size: 14px;
  line-height: 1.4;
  color: transparent;
  caret-color: transparent;
}

/* per-field hint / error line under the box */
.cab-input__note {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-3);
  line-height: 1.5;
}
.cab-input__note--error { color: var(--cd-danger); }

/* reverse-video block-cursor blink (cabinet.md §14b) */
@keyframes a-block-blink {
  0%, 49%   { background: var(--cd-phos); color: var(--cd-bg); }
  50%, 100% { background: transparent;    color: var(--cd-ink-2); }
}

/* ACaret — decorative blinking block for static prompt strings
   (not tied to input). Kept for parity with cabinet-a-blocks. */
.cab-acaret {
  display: inline-block;
  width: 0.55em;
  height: 1em;
  background: var(--cd-phos);
  vertical-align: -2px;
  margin-left: 2px;
  animation: a-blink 1.06s steps(1) infinite;
}
@keyframes a-blink {
  0%, 49%   { opacity: 1; }
  50%, 100% { opacity: 0; }
}

/* ------------------------------------------------------------
   ABtn — outlined text button. height md=44 / lg=48. square
   corners, transparent bg, 1px state-color border, weight 500,
   letter-spacing 0.04em. Single primary per screen (cabinet.md
   §11 / §21). Fill only on hover (production), per §11.
   ------------------------------------------------------------ */
.cab-btn {
  height: 44px;
  padding: 0 var(--cd-s-lg);
  background: transparent;
  border: 1px solid var(--cd-rule);
  color: var(--cd-ink-2);
  border-radius: 0;
  font-family: var(--cd-mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cd-s-sm);
  white-space: nowrap;
  transition: background 0.12s ease, color 0.12s ease;
}
.cab-btn--lg { height: 48px; }
.cab-btn--full { width: 100%; }
.cab-btn--primary { border-color: var(--cd-phos); color: var(--cd-phos); }
.cab-btn--ghost { border-color: var(--cd-rule); color: var(--cd-ink-2); }
.cab-btn--primary:hover { background: color-mix(in srgb, var(--cd-phos) 12%, transparent); }
.cab-btn--ghost:hover { background: color-mix(in srgb, var(--cd-ink-2) 8%, transparent); }
.cab-btn:disabled {
  cursor: not-allowed;
  opacity: 0.35;
  background: transparent;
}

/* ------------------------------------------------------------
   ALinkBtn — text link (not outlined). Used for forgot/register
   nav + back links. Underline in rule color, offset 3.
   ------------------------------------------------------------ */
.cab-link {
  all: unset;
  cursor: pointer;
  color: var(--cd-ink-2);
  font-family: var(--cd-mono);
  font-size: 14px;
  text-decoration: underline;
  text-decoration-color: var(--cd-rule);
  text-underline-offset: 3px;
}
.cab-link:hover { text-decoration-color: var(--cd-ink-3); }
.cab-link--phos { color: var(--cd-phos); }
.cab-link--danger { color: var(--cd-danger); }

/* ------------------------------------------------------------
   AFormError — form-level danger line "× текст" under fields.
   marginTop -sm to sit close under the field group.
   ------------------------------------------------------------ */
.cab-form-error {
  display: flex;
  align-items: flex-start;
  gap: var(--cd-s-sm);
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-danger);
  line-height: 1.55;
  letter-spacing: 0.02em;
  margin-top: calc(-1 * var(--cd-s-sm));
}
.cab-form-error__x { flex-shrink: 0; }

/* ============================================================
   DASHBOARD (R2) — faithful port of cabinet-screens.jsx 4-tab
   design (A_Frame + A_TABS + tab content + drill-in + modals).
   Only the 9 --cd-* tokens + spacing scale. No new colors.
   §16 retired the hero card, the security tab and the subscription-
   cancel affordance — none are reintroduced here.
   ============================================================ */

/* ------------------------------------------------------------
   AFrame (dashboard variant) — same 390px shell as auth, but the
   content pane is flanked by a bottom-nav (height 64) and may host
   a thin warn banner under the header. On the served page the frame
   fills the viewport height; on a wide desktop it caps at a phone-
   like height so the bottom-nav reads as docked (mirrors the JSX
   fixed-height artboard without hard-coding 820px).
   ------------------------------------------------------------ */
.cab-frame--app {
  height: 100dvh;
  max-height: 760px;
}
@supports not (height: 100dvh) {
  .cab-frame--app { height: 100vh; }
}

/* thin warn banner slot (AExpiringBanner) under the header */
.cab-banner { flex-shrink: 0; }

/* scrollable per-tab content area (same padding as .cab-pane) */
.cab-app-pane {
  flex: 1;
  overflow: auto;
  min-height: 0;
  padding: var(--cd-s-xl) var(--cd-s-lg) var(--cd-s-2xl);
  display: flex;
  flex-direction: column;
  scrollbar-gutter: stable;
}

/* bottom nav — 4 icon tabs, height 64, top rule (cabinet.md §6) */
.cab-tabs {
  height: 64px;
  flex-shrink: 0;
  border-top: 1px solid var(--cd-rule);
  background: var(--cd-bg);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.cab-tab {
  all: unset;
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-family: var(--cd-mono);
  font-size: 14px;
  font-weight: 400;
  color: var(--cd-ink-3);
}
.cab-tab__edge {
  position: absolute;
  top: -1px;
  left: 30%;
  right: 30%;
  height: 2px;
  background: var(--cd-phos);
  display: none;
}
.cab-tab.is-active { color: var(--cd-phos); font-weight: 500; }
.cab-tab.is-active .cab-tab__edge { display: block; }
.cab-tab__icon { display: block; }

/* overlay slot (modals / bottom-sheets / lightbox / confirm-delete) */
.cab-overlay-slot:empty { display: none; }

/* ------------------------------------------------------------
   AExpiringBanner — thin warn bar (state=active, ≤3 дня).
   ------------------------------------------------------------ */
.cab-xbanner {
  cursor: pointer;
  padding: var(--cd-s-sm) var(--cd-s-lg);
  border-bottom: 1px solid var(--cd-rule);
  background: rgba(230, 184, 92, 0.08);
  display: flex;
  align-items: center;
  gap: var(--cd-s-sm);
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-warn);
  letter-spacing: 0.02em;
}
.cab-xbanner__dash { color: var(--cd-ink-3); }
.cab-xbanner__arrow { margin-left: auto; color: var(--cd-warn); }

/* ------------------------------------------------------------
   APlanStatus — single status sentence with a state dot.
   ------------------------------------------------------------ */
.cab-planstatus {
  display: flex;
  align-items: baseline;
  gap: var(--cd-s-sm);
  font-family: var(--cd-mono);
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: 0.02em;
  margin-bottom: var(--cd-s-lg);
}
.cab-planstatus__dot { flex-shrink: 0; transform: translateY(-1px); }
.cab-planstatus__text { color: var(--cd-ink-2); }
.cab-tone-phos { color: var(--cd-phos); }
.cab-tone-warn { color: var(--cd-warn); }
.cab-tone-danger { color: var(--cd-danger); }
.cab-tone-dim { color: var(--cd-ink-3); }

/* page-status / suspended banner line (mono 14/500 + rule under) */
.cab-statusline {
  font-family: var(--cd-mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding-bottom: var(--cd-s-sm);
  border-bottom: 1px solid var(--cd-rule);
  margin-bottom: var(--cd-s-xl);
}

/* ------------------------------------------------------------
   AGroupHead — section heading with a bottom rule (§9).
   ------------------------------------------------------------ */
.cab-grouphead {
  margin-top: var(--cd-s-xl);
  margin-bottom: var(--cd-s-sm);
  font-family: var(--cd-mono);
  font-size: 14px;
  font-weight: 500;
  color: var(--cd-ink-2);
  letter-spacing: 0.02em;
  padding-bottom: var(--cd-s-sm);
  border-bottom: 1px solid var(--cd-rule);
}
.cab-grouphead__count { color: var(--cd-ink-3); }

/* AGroupCollapse — toggleable section head + body */
.cab-collapse { margin-top: var(--cd-s-xl); }
.cab-collapse__head {
  all: unset;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: var(--cd-s-sm);
  width: 100%;
  padding-bottom: var(--cd-s-sm);
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
  font-weight: 500;
  color: var(--cd-ink-2);
  letter-spacing: 0.02em;
}
.cab-collapse__title { flex: 1; }
.cab-collapse__caret {
  flex-shrink: 0;
  color: var(--cd-ink-3);
  transition: transform 0.2s;
}
.cab-collapse__head.is-open .cab-collapse__caret { transform: rotate(180deg); }
.cab-collapse__body { margin-top: var(--cd-s-sm); }

/* ------------------------------------------------------------
   AKV — key/value row (§10). tabular-nums on the value.
   ------------------------------------------------------------ */
.cab-kv {
  display: flex;
  justify-content: space-between;
  gap: var(--cd-s-lg);
  font-family: var(--cd-mono);
  font-size: 14px;
  line-height: 1.6;
}
.cab-kv--rule {
  padding: var(--cd-s-md) 0;
  border-bottom: 1px solid var(--cd-rule);
}
.cab-kv__k { color: var(--cd-ink-3); }
.cab-kv__v {
  color: var(--cd-ink-2);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* prominent total row ("к оплате") */
.cab-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cd-s-sm) 0;
  font-family: var(--cd-mono);
  font-size: 14px;
}
.cab-total__k { color: var(--cd-ink-2); font-weight: 500; }
.cab-total__v {
  color: var(--cd-ink-2);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

/* ------------------------------------------------------------
   AStateIntro / generic dim helper paragraph.
   ------------------------------------------------------------ */
.cab-fact {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-2);
  line-height: 1.6;
}
.cab-note {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-3);
  line-height: 1.55;
  letter-spacing: 0.02em;
}
.cab-note--lh16 { line-height: 1.6; }
.cab-stack { display: flex; flex-direction: column; }
.cab-stack--gap-md { gap: var(--cd-s-md); }
.cab-stack--gap-lg { gap: var(--cd-s-lg); }
.cab-stack--gap-xl { gap: var(--cd-s-xl); }
.cab-row { display: flex; gap: var(--cd-s-sm); }
.cab-mt-sm { margin-top: var(--cd-s-sm); }
.cab-mt-md { margin-top: var(--cd-s-md); }
.cab-mt-xl { margin-top: var(--cd-s-xl); }
.cab-pt-lg-rule { margin-top: var(--cd-s-xl); padding-top: var(--cd-s-lg); border-top: 1px solid var(--cd-rule); }

/* ------------------------------------------------------------
   ACounterRow — − N + stepper (devices / months).
   ------------------------------------------------------------ */
.cab-counter {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cd-s-md) 0;
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
}
.cab-counter__label { color: var(--cd-ink-3); letter-spacing: 0.04em; }
.cab-counter__hint { color: var(--cd-ink-3); letter-spacing: 0.02em; margin-top: 2px; }
.cab-counter__ctrl { display: flex; align-items: center; gap: var(--cd-s-sm); }
.cab-counter__btn {
  all: unset;
  cursor: pointer;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  color: var(--cd-ink-2);
}
.cab-counter__btn:disabled { color: var(--cd-ink-3); cursor: not-allowed; }
.cab-counter__num {
  all: unset;
  width: 32px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  color: var(--cd-ink-2);
  font-weight: 500;
  border-bottom: 1px solid var(--cd-rule);
  padding: 2px 0;
}

/* ------------------------------------------------------------
   Device list rows (AD_row — drill-in) + free-slot + platform pick.
   ------------------------------------------------------------ */
.cab-drow {
  display: flex;
  align-items: flex-start;
  gap: var(--cd-s-md);
  padding: var(--cd-s-md) 0;
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
  cursor: pointer;
}
.cab-drow__dot { flex-shrink: 0; width: 10px; text-align: left; color: var(--cd-ink-3); }
.cab-drow__dot.is-on { color: var(--cd-phos); }
.cab-drow__main { flex: 1; min-width: 0; }
.cab-drow__name {
  color: var(--cd-ink-2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cab-drow__meta { font-size: 14px; color: var(--cd-ink-3); letter-spacing: 0.04em; margin-top: 2px; }
.cab-drow__arrow { color: var(--cd-ink-2); font-size: 16px; margin-top: 1px; flex-shrink: 0; }

.cab-freeslot {
  display: flex;
  align-items: center;
  gap: var(--cd-s-md);
  padding: var(--cd-s-md) 0;
  font-family: var(--cd-mono);
  font-size: 14px;
  border-bottom: 1px dashed var(--cd-rule);
  color: var(--cd-ink-3);
}
.cab-freeslot__o { flex-shrink: 0; width: 10px; text-align: left; }
.cab-freeslot__sub { font-size: 14px; color: var(--cd-ink-3); letter-spacing: 0.04em; margin-top: 2px; opacity: 0.7; }

.cab-prow {
  display: flex;
  align-items: center;
  gap: var(--cd-s-md);
  padding: var(--cd-s-md) 0;
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
  cursor: pointer;
}
.cab-prow__label { flex: 1; color: var(--cd-ink-2); }
.cab-prow__arrow { color: var(--cd-phos); font-size: 16px; flex-shrink: 0; }

/* device-card breadcrumb + KV rows + drill-in helper text */
.cab-crumb {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-3);
  margin-bottom: var(--cd-s-lg);
  border-bottom: 1px solid var(--cd-rule);
  padding-bottom: var(--cd-s-sm);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.cab-crumb__back { cursor: pointer; }
.cab-crumb__name { color: var(--cd-ink-2); margin-left: 8px; }
.cab-crumb__step { color: var(--cd-ink-3); letter-spacing: 0.04em; }
.cab-dhelp {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-3);
  line-height: 1.55;
  letter-spacing: 0.02em;
  padding: var(--cd-s-sm) 0 var(--cd-s-xs);
}
.cab-kvrow {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--cd-s-md) 0;
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
  gap: var(--cd-s-md);
}
.cab-kvrow__main { min-width: 0; flex: 1; }
.cab-kvrow__k { color: var(--cd-ink-3); letter-spacing: 0.04em; }
.cab-kvrow__v { color: var(--cd-ink-2); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cab-kvrow__v--wrap { word-break: break-all; line-height: 1.5; white-space: normal; overflow: visible; }
.cab-kvrow__act { flex-shrink: 0; }
.cab-kvrow__edit {
  display: flex;
  align-items: baseline;
  border-bottom: 1px solid var(--cd-phos);
  padding-bottom: 4px;
  margin-top: 2px;
  margin-right: 8px;
}
.cab-kvrow__edit-input {
  all: unset;
  flex: 1;
  color: var(--cd-ink-2);
  caret-color: var(--cd-phos);
  word-break: break-all;
}

/* AD_LinkField — phosphor link line + copy CTA (device VPN link) */
.cab-linkfield { display: flex; flex-direction: column; gap: var(--cd-s-md); }
.cab-linkfield__label { font-family: var(--cd-mono); font-size: 14px; color: var(--cd-ink-3); letter-spacing: 0.04em; }
.cab-linkfield__link {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-phos);
  word-break: break-all;
  line-height: 1.5;
  letter-spacing: 0.01em;
}

/* friends rows */
.cab-friend {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--cd-s-md) 0;
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
}
.cab-friend__email { color: var(--cd-ink-2); }
.cab-friend__paid { font-size: 14px; margin-top: 2px; letter-spacing: 0.04em; }
.cab-friend__amt { font-variant-numeric: tabular-nums; }
.cab-earned {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-bottom: var(--cd-s-sm);
  margin-bottom: var(--cd-s-xl);
  font-family: var(--cd-mono);
  font-size: 14px;
  border-bottom: 1px solid var(--cd-rule);
}
.cab-earned__k { color: var(--cd-ink-2); font-weight: 500; letter-spacing: 0.02em; }
.cab-earned__v { font-weight: 500; font-variant-numeric: tabular-nums; }
.cab-invite-block {
  font-family: var(--cd-mono);
  font-size: 14px;
  color: var(--cd-ink-3);
  line-height: 1.55;
  padding: var(--cd-s-sm) 0;
}
.cab-invite-block__link { color: var(--cd-ink-2); }

/* account inline-edit rows */
.cab-acctrow {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--cd-s-md) 0;
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
  gap: var(--cd-s-md);
}
.cab-acctrow__main { flex: 1; min-width: 0; }
.cab-acctrow__k { color: var(--cd-ink-3); font-size: 14px; letter-spacing: 0.04em; }
.cab-acctrow__v { color: var(--cd-ink-2); margin-top: 2px; line-height: 1.4; }
.cab-acctrow__act { flex-shrink: 0; }
/* brief success feedback after a 204 (password changed) */
.cab-acctrow__ok { color: var(--cd-phos); font-size: 14px; letter-spacing: 0.04em; }

/* inline-edit error state — danger underline (mirrors .cab-input__box--error)
   + danger note line, used by the account email/password rows. */
.cab-kvrow__edit--error { border-bottom-color: var(--cd-danger); }
.cab-note--error { color: var(--cd-danger); }

/* ------------------------------------------------------------
   Modals — AConfirmDelete (centred), A_ModalPayment +
   A_ModalReduceConfirm (docked-bottom sheet). Both inside the
   AFrame bounds via position:absolute on the frame.
   ------------------------------------------------------------ */
.cab-modal {
  position: absolute;
  inset: 0;
  z-index: 10;
  background: rgba(7, 9, 10, 0.78);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--cd-s-lg);
}
.cab-modal__card {
  width: 100%;
  max-width: 340px;
  background: var(--cd-bg);
  border: 1px solid var(--cd-rule);
  padding: var(--cd-s-xl) var(--cd-s-lg) var(--cd-s-lg);
  display: flex;
  flex-direction: column;
  gap: var(--cd-s-lg);
  font-family: var(--cd-mono);
}
.cab-modal__title { font-size: 14px; color: var(--cd-ink-2); line-height: 1.6; }
.cab-modal__title .cab-chev-danger { color: var(--cd-danger); }
.cab-modal__name { font-size: 14px; color: var(--cd-ink-2); line-height: 1.5; padding-left: 18px; font-weight: 500; }
.cab-modal__body { font-size: 14px; color: var(--cd-ink-2); line-height: 1.6; padding-left: 18px; letter-spacing: 0.02em; }
.cab-modal__btns { display: flex; gap: var(--cd-s-sm); margin-top: var(--cd-s-sm); }

/* docked-bottom sheet (payment / reduce-confirm) */
.cab-sheet {
  position: absolute;
  inset: 0;
  z-index: 40;
  background: rgba(7, 9, 10, 0.72);
  backdrop-filter: blur(2px);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.cab-sheet__panel {
  background: var(--cd-bg);
  border-top: 1px solid var(--cd-phos);
  font-family: var(--cd-mono);
  display: flex;
  flex-direction: column;
  max-height: 92%;
}
.cab-sheet__head {
  padding: var(--cd-s-md) var(--cd-s-lg);
  border-bottom: 1px solid var(--cd-rule);
  display: flex;
  align-items: center;
  gap: var(--cd-s-sm);
  font-size: 14px;
  font-weight: 500;
  color: var(--cd-ink-2);
}
.cab-sheet__head .cab-chev-good { color: var(--cd-phos); }
.cab-sheet__title { flex: 1; }
.cab-sheet__x {
  all: unset;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  color: var(--cd-ink-3);
  padding: 4px;
}
.cab-sheet__body {
  flex: 1;
  overflow: auto;
  min-height: 0;
  padding: var(--cd-s-lg) var(--cd-s-lg) 0;
  display: flex;
  flex-direction: column;
  gap: var(--cd-s-lg);
}
.cab-sheet__foot {
  padding: var(--cd-s-lg);
  display: flex;
  gap: var(--cd-s-sm);
  border-top: 1px solid var(--cd-rule);
}
.cab-sheet__group-label { font-size: 14px; color: var(--cd-ink-3); letter-spacing: 0.04em; padding-bottom: var(--cd-s-xs); }
.cab-sheet__demote-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--cd-s-sm) 0;
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
  gap: var(--cd-s-md);
}
.cab-sheet__demote-row .cab-dim { color: var(--cd-ink-3); }
.cab-sheet__demote-seen { color: var(--cd-ink-3); flex-shrink: 0; }

/* ------------------------------------------------------------
   AD_step — numbered instruction step (wizard).
   ------------------------------------------------------------ */
.cab-step {
  display: flex;
  gap: var(--cd-s-md);
  padding: var(--cd-s-md) 0;
  border-bottom: 1px solid var(--cd-rule);
  font-family: var(--cd-mono);
  font-size: 14px;
}
.cab-step__n { color: var(--cd-ink-3); flex-shrink: 0; width: 14px; font-variant-numeric: tabular-nums; }
.cab-step__body { flex: 1; min-width: 0; color: var(--cd-ink-2); line-height: 1.5; }

/* ------------------------------------------------------------
   Config gallery — AD_InstructionCard (collapsible card) +
   AD_gallery (2+3 grid) + AD_Lightbox (full-screen viewer).
   Shown on the «вставьте ссылку» wizard step (iphone only).
   ------------------------------------------------------------ */
.cab-instr {
  margin-top: var(--cd-s-lg);
  border: 1px solid var(--cd-rule);
}
.cab-instr__head {
  all: unset;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: var(--cd-s-md);
  width: 100%;
  box-sizing: border-box;
  padding: var(--cd-s-md);
}
.cab-instr__peek {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  overflow: hidden;
  border: 1px solid var(--cd-rule);
  background: rgba(92, 255, 122, 0.04);
}
.cab-instr__peekimg {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
.cab-instr__titles { flex: 1; min-width: 0; font-family: var(--cd-mono); }
.cab-instr__title { font-size: 14px; font-weight: 500; color: var(--cd-ink-2); letter-spacing: 0.02em; }
.cab-instr__sub { font-size: 14px; color: var(--cd-ink-3); margin-top: 2px; letter-spacing: 0.02em; }
.cab-instr__caret { flex-shrink: 0; color: var(--cd-ink-3); transition: transform 0.2s; }
.cab-instr__head.is-open .cab-instr__caret { transform: rotate(180deg); }
.cab-instr__body { padding: 0 var(--cd-s-md) var(--cd-s-md); }

/* AD_gallery — messenger-style 2+3 album grid (6-col, span 3/3/2/2/2). */
.cab-gallery {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 4px;
}
.cab-gallery__tile {
  all: unset;
  cursor: pointer;
  display: block;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border: 1px solid var(--cd-rule);
  background: #0d0f10;
  position: relative;
}
.cab-gallery__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* AD_Lightbox — full-screen viewer; sits above the 64px tab-bar so the
   prev/next controls stay reachable (matches the design's bottom:64). */
.cab-lb {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 64px;
  z-index: 50;
  background: rgba(7, 9, 10, 0.96);
  display: flex;
  flex-direction: column;
  font-family: var(--cd-mono);
}
.cab-lb__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cd-s-md) var(--cd-s-lg);
  flex-shrink: 0;
  font-size: 14px;
  color: var(--cd-ink-2);
}
.cab-lb__counter { letter-spacing: 0.06em; }
.cab-lb__x {
  all: unset;
  cursor: pointer;
  color: var(--cd-ink-2);
  font-size: 20px;
  line-height: 1;
  padding: 4px;
}
.cab-lb__stage {
  flex: 1;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--cd-s-lg);
  cursor: pointer;
}
.cab-lb__img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border: 1px solid var(--cd-rule);
}
.cab-lb__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cd-s-lg);
  flex-shrink: 0;
  gap: var(--cd-s-md);
}
.cab-lb__nav {
  all: unset;
  cursor: pointer;
  color: var(--cd-ink-2);
  font-size: 18px;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border: 1px solid var(--cd-rule);
}
.cab-lb__dots { display: flex; gap: 8px; align-items: center; }
.cab-lb__dot {
  all: unset;
  cursor: pointer;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--cd-rule);
}
.cab-lb__dot.is-on { width: 9px; height: 9px; background: var(--cd-phos); }

/* ------------------------------------------------------------
   AHelp — "?" pill + click tooltip (group heads).
   ------------------------------------------------------------ */
.cab-help { position: relative; display: inline-flex; align-items: center; }
.cab-help__btn {
  all: unset;
  cursor: pointer;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid var(--cd-ink-3);
  color: var(--cd-ink-2);
  font-family: var(--cd-mono);
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cab-help__btn.is-open { border-color: var(--cd-phos); color: var(--cd-phos); }
.cab-help__pop {
  position: absolute;
  top: 24px;
  right: -8px;
  background: var(--cd-bg);
  border: 1px solid var(--cd-rule);
  padding: var(--cd-s-md);
  width: 240px;
  font-size: 14px;
  color: var(--cd-ink-2);
  line-height: 1.6;
  letter-spacing: 0.02em;
  z-index: 5;
  font-family: var(--cd-mono);
}

/* phosphor word / dim word in dashboard copy */
.cab-phos { color: var(--cd-phos); }
.cab-dim { color: var(--cd-ink-3); }
.cab-good-chev { color: var(--cd-phos); flex-shrink: 0; }

/* pending-payment spinner glyph (reconciliation poll) */
.cab-spin {
  display: inline-block;
  margin-left: 8px;
  animation: cab-spin-rot 1.1s linear infinite;
}
@keyframes cab-spin-rot {
  to { transform: rotate(360deg); }
}

/* utility: hide */
[hidden] { display: none !important; }
