
	/* Hide scrollbars cross browser and enable momentum scroll for touch devices */
	[data-select-viewport] {
		scrollbar-width: none !important;
		-ms-overflow-style: none !important;
		-webkit-overflow-scrolling: touch !important;
	}

	[data-combobox-viewport] {
		scrollbar-width: none !important;
		-ms-overflow-style: none !important;
		-webkit-overflow-scrolling: touch !important;
	}

	[data-combobox-viewport]::-webkit-scrollbar {
		display: none !important;
	}
	[data-select-viewport]::-webkit-scrollbar {
		display: none !important;
	}

  .brand-mark.svelte-p1q4pl {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    flex-shrink: 0;
    overflow: visible;
    font-size: 1.625rem;
  }

  .brand-mark.svelte-p1q4pl img:where(.svelte-p1q4pl) {
    width: 100%;
    height: 100%;
    object-fit: contain;
    opacity: 0;
    transition: opacity 0.2s ease;
  }

  .brand-mark.svelte-p1q4pl img.loaded:where(.svelte-p1q4pl) {
    opacity: 1;
  }

  .brand-mark.brand-mark-lg.svelte-p1q4pl {
    width: 4.125rem;
    height: 4.125rem;
    font-size: 2.875rem;
  }

  .brand-mark.brand-mark-xl.svelte-p1q4pl {
    width: 6rem;
    height: 6rem;
    font-size: 4.375rem;
  }

  .brand-mark.svelte-p1q4pl img.brand-mark-animated-emoji:where(.svelte-p1q4pl) {
    object-fit: contain;
    transform: scale(1.08);
  }

  .brand-mark.brand-mark-animate.svelte-p1q4pl {
    animation: svelte-p1q4pl-brand-mark-pulse 2s ease-in-out infinite;
  }

  .brand-mark-spinner.svelte-p1q4pl {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .brand-mark-spinner.svelte-p1q4pl::after {
    content: "";
    width: 1rem;
    height: 1rem;
    border: 2px solid currentColor;
    border-bottom-color: transparent;
    border-radius: 50%;
    animation: svelte-p1q4pl-brand-mark-spin 0.8s linear infinite;
    opacity: 0.5;
  }

  @keyframes svelte-p1q4pl-brand-mark-spin {
    0% {
      transform: rotate(0deg);
    }
    100% {
      transform: rotate(360deg);
    }
  }

  @keyframes svelte-p1q4pl-brand-mark-pulse {
    0%,
    100% {
      transform: scale(1);
    }
    50% {
      transform: scale(1.05);
    }
  }

  .brand-mark-emoji.svelte-p1q4pl {
    color: inherit;
    font-size: 1em;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    transform: translateY(0.02em);
    transform-origin: center;
  }

  .brand-mark-xl.svelte-p1q4pl .brand-mark-emoji:where(.svelte-p1q4pl) {
    font-size: 1em;
  }

  .brand-mark-lg.svelte-p1q4pl .brand-mark-emoji:where(.svelte-p1q4pl) {
    font-size: 1em;
  }

  .emoji-font-noto-color.svelte-p1q4pl {
    font-family: "Noto Color Emoji", sans-serif;
  }

  .emoji-font-noto-emoji.svelte-p1q4pl {
    color: var(--accent);
    font-family: "Noto Emoji", sans-serif;
    font-weight: 700;
  }

  .emoji-font-twemoji.svelte-p1q4pl {
    font-family: "Twemoji Mozilla", sans-serif;
  }

  .emoji-font-openmoji.svelte-p1q4pl {
    font-family: "OpenMoji Color", sans-serif;
  }

  .emoji-font-apple.svelte-p1q4pl {
    font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
  }

  .emoji-font-segoe.svelte-p1q4pl {
    font-family: "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif;
  }

  .emoji-font-noto-local.svelte-p1q4pl {
    font-family: "Noto Color Emoji", "Noto Emoji", sans-serif;
  }
.uplot, .uplot *, .uplot *::before, .uplot *::after {box-sizing: border-box;}.uplot {font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";line-height: 1.5;width: min-content;}.u-title {text-align: center;font-size: 18px;font-weight: bold;}.u-wrap {position: relative;user-select: none;}.u-over, .u-under {position: absolute;}.u-under {overflow: hidden;}.uplot canvas {display: block;position: relative;width: 100%;height: 100%;}.u-axis {position: absolute;}.u-legend {font-size: 14px;margin: auto;text-align: center;}.u-inline {display: block;}.u-inline * {display: inline-block;}.u-inline tr {margin-right: 16px;}.u-legend th {font-weight: 600;}.u-legend th > * {vertical-align: middle;display: inline-block;}.u-legend .u-marker {width: 1em;height: 1em;margin-right: 4px;background-clip: padding-box !important;}.u-inline.u-live th::after {content: ":";vertical-align: middle;}.u-inline:not(.u-live) .u-value {display: none;}.u-series > * {padding: 4px;}.u-series th {cursor: pointer;}.u-legend .u-off > * {opacity: 0.3;}.u-select {background: rgba(0,0,0,0.07);position: absolute;pointer-events: none;}.u-cursor-x, .u-cursor-y {position: absolute;left: 0;top: 0;pointer-events: none;will-change: transform;}.u-hz .u-cursor-x, .u-vt .u-cursor-y {height: 100%;border-right: 1px dashed #607D8B;}.u-hz .u-cursor-y, .u-vt .u-cursor-x {width: 100%;border-bottom: 1px dashed #607D8B;}.u-cursor-pt {position: absolute;top: 0;left: 0;border-radius: 50%;border: 0 solid;pointer-events: none;will-change: transform;/*this has to be !important since we set inline "background" shorthand */background-clip: padding-box !important;}.u-axis.u-off, .u-select.u-off, .u-cursor-x.u-off, .u-cursor-y.u-off, .u-cursor-pt.u-off {display: none;}
  .admin-payments-user-cell.svelte-2goz9s {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
  }

  .admin-payments-user-name.svelte-2goz9s {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-cell-user-with-action.svelte-2goz9s .admin-payments-user-btn.admin-btn {
    width: 30px;
    height: 30px;
    min-width: 30px;
    min-height: 30px;
    flex-shrink: 0;
    padding: 0;
    border-radius: 7px;
  }

  .admin-cell-user-with-action.svelte-2goz9s .admin-payments-user-btn svg {
    width: 14px;
    height: 14px;
  }

  .admin-cell-traffic-gb.svelte-2goz9s {
    font-size: 12px;
    white-space: nowrap;
    color: var(--admin-muted);
  }

  .admin-user-action-sheet.svelte-1f6d31z {
    border: 1px solid var(--admin-border-muted, rgba(255, 255, 255, 0.08));
    border-radius: 12px;
    margin-bottom: 14px;
    overflow: hidden;
    background: var(--admin-surface-1, rgba(255, 255, 255, 0.02));
  }
  .admin-user-action-sheet.svelte-1f6d31z .admin-dashboard-section-head {
    padding: 12px 14px 10px;
    margin: 0;
    border-bottom: 1px solid var(--admin-border-muted, rgba(255, 255, 255, 0.06));
  }
  .admin-user-action-sheet-body.svelte-1f6d31z {
    padding: 12px 14px 12px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .admin-user-override-stack.svelte-1f6d31z {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  .admin-user-grant-stack.svelte-1f6d31z {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  .admin-user-action-sheet-footer.svelte-1f6d31z {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px;
    padding: 4px 14px 12px;
  }
  .admin-override-card-footer.svelte-1f6d31z {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .admin-override-card-toolbar.svelte-1f6d31z {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 10px 14px;
    width: 100%;
  }
  .admin-override-card-toolbar.svelte-1f6d31z .admin-btn {
    flex: 0 0 auto;
    min-height: 36px;
    padding-left: 16px;
    padding-right: 16px;
  }
  .admin-override-unlimited-label.svelte-1f6d31z {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--admin-text, inherit);
    cursor: pointer;
    user-select: none;
    min-height: 36px;
  }
  .admin-override-unlimited-label.svelte-1f6d31z input[type="checkbox"]:where(.svelte-1f6d31z) {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
  }
  @media (max-width: 520px) {
    .admin-override-card-toolbar.svelte-1f6d31z {
      flex-direction: column;
      align-items: stretch;
    }
    .admin-override-card-toolbar.svelte-1f6d31z .admin-btn {
      width: 100%;
    }
  }
  .admin-override-status-lines.svelte-1f6d31z {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 0;
    font-size: 12px;
    line-height: 1.35;
  }
  .admin-user-dialog .admin-actions-tab {
    padding-bottom: 14px;
  }
  .admin-user-action-sheet--regular-override.svelte-1f6d31z {
    margin-top: 10px;
  }
  .admin-user-action-sheet--traffic-grant.svelte-1f6d31z {
    margin-top: 10px;
  }
  .admin-user-action-sheet.svelte-1f6d31z .admin-grant-kind-select {
    width: 100%;
    max-width: 100%;
  }
  .admin-user-dialog .admin-user-logs-tab {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .admin-user-logs-head.svelte-1f6d31z {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
  }
  .admin-user-logs-meta.svelte-1f6d31z {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
  }
  .admin-user-logs-wrap.svelte-1f6d31z {
    min-height: 120px;
  }
  .admin-user-log-event.svelte-1f6d31z {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
  }
  .admin-user-log-content {
    white-space: pre-wrap;
    word-break: break-word;
    max-width: 520px;
  }
  @media (max-width: 640px) {
    .admin-user-log-content {
      max-width: 100%;
    }
  }

  .admin-users-cell-user-inner.svelte-umzpm9 {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
  }

  .admin-users-cell-user-text.svelte-umzpm9 {
    display: grid;
    gap: 2px;
    min-width: 0;
    text-align: left;
  }

  .admin-users-cell-name.svelte-umzpm9 {
    font-weight: 650;
    font-size: 13px;
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-users-cell-secondary.svelte-umzpm9 {
    font-size: 11px;
    color: var(--admin-dim);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-users-cell-id.svelte-umzpm9 {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--admin-muted);
  }

  .admin-users-cell-premium.svelte-umzpm9 {
    white-space: nowrap;
  }

  .admin-users-cell-premium.svelte-umzpm9 .admin-user-premium-badge {
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 11px;
    font-variant-numeric: tabular-nums;
  }

  .admin-user-premium-placeholder.svelte-umzpm9 {
    color: var(--admin-dim);
    font-size: 12px;
    font-variant-numeric: tabular-nums;
  }

  .admin-users-cell-date.svelte-umzpm9 {
    white-space: nowrap;
    font-size: 12px;
    color: var(--admin-muted);
  }

  .admin-users-table-wrap.svelte-umzpm9 .admin-users-table tbody tr.is-clickable:focus-visible {
    outline: 2px solid var(--admin-ring);
    outline-offset: -2px;
  }
/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-border-style: solid;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-ease: initial;
    }
  }
}

@layer theme {
  :root, :host {
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
    --font-mono: "JetBrains Mono", "Fira Code", monospace;
    --radius-lg: .5rem;
    --ease-in-out: cubic-bezier(.4, 0, .2, 1);
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  }
}

@layer components;

@layer utilities {
  .static {
    position: static;
  }

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

  .flex-shrink {
    flex-shrink: 1;
  }

  .transform {
    transform: var(--tw-rotate-x, ) var(--tw-rotate-y, ) var(--tw-rotate-z, ) var(--tw-skew-x, ) var(--tw-skew-y, );
  }

  .flex-wrap {
    flex-wrap: wrap;
  }

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

  .filter {
    filter: var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, );
  }

  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }
}

@font-face {
  font-family: Twemoji Country Flags;
  src: url("https://cdn.jsdelivr.net/npm/country-flag-emoji-polyfill@0.1/dist/TwemojiCountryFlags.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+1F1E6-1F1FF, U+1F3F4, U+E0062-E0063, U+E0065, U+E0067, U+E006C, U+E006E, U+E0073-E0074, U+E0077, U+E007F;
}

:root {
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  --font-mono: "JetBrains Mono", "Fira Code", monospace;
  color-scheme: dark;
  --accent: #00fe7a;
  --bg: #03070b;
  --panel: #111820;
  --panel-2: #0b1118;
  --panel-3: #17212b;
  --border: #ffffff1f;
  --border-strong: #fff3;
  --text: #f2f7f4;
  --muted: #a9b4b0;
  --dim: #68736f;
  --danger: #ff6b6b;
  --blue: #2d9cff;
  --radius: 8px;
  --admin-bg: var(--bg);
  --admin-surface: var(--panel);
  --admin-surface-2: var(--panel-2);
  --admin-elev: var(--panel-3);
  --admin-border: var(--border);
  --admin-border-strong: var(--border-strong);
  --admin-text: var(--text);
  --admin-muted: var(--muted);
  --admin-dim: var(--dim);
  --admin-ring: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --admin-ring: color-mix(in srgb, var(--accent) 50%, transparent);
  }
}

:root {
  --screen-gutter: 18px;
  --safe-inline: max(env(safe-area-inset-left), env(safe-area-inset-right));
  --nav-inline-gutter: max(var(--screen-gutter), var(--safe-inline));
  --bottom-nav-height: 64px;
  --bottom-nav-offset: 10px;
  --bottom-nav-left: calc(max(0px, (100% - 440px) / 2) + var(--nav-inline-gutter));
  --bottom-nav-width: min(calc(100% - (var(--nav-inline-gutter) * 2)),
    calc(440px - (var(--nav-inline-gutter) * 2)));
  font-family: var(--font-sans);
}

* {
  box-sizing: border-box;
}

html, body, #app {
  min-height: 100%;
  margin: 0;
  overflow-x: clip;
}

body {
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0;
  background: #02070b;
}

button, input {
  font: inherit;
  letter-spacing: 0;
}

.app-shell {
  min-height: 100dvh;
  background: #02070b !important;
}

:root {
  --desktop-rail-width: 252px;
  --desktop-page-gutter: clamp(28px, 4vw, 72px);
}

button:disabled {
  cursor: progress;
  opacity: .58;
}

.btn {
  border-radius: var(--radius);
  background: var(--panel-2);
  min-height: 46px;
  color: var(--text);
  font: inherit;
  text-align: center;
  cursor: pointer;
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 0 16px;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.1;
  text-decoration: none;
  transition: transform .16s, border-color .16s, background .16s, box-shadow .16s, color .16s;
  display: inline-flex;
  box-shadow: 0 10px 26px #0000002e;
}

.btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 14px 32px #00000038;
}

.btn:active:not(:disabled) {
  transform: translateY(0);
}

.btn:focus-visible {
  box-shadow: 0 0 0 3px var(--accent), 0 14px 32px #00000038;
  outline: none;
}

@supports (color: color-mix(in lab, red, red)) {
  .btn:focus-visible {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 28%, transparent), 0 14px 32px #00000038;
  }
}

.btn.wide, .wide {
  width: 100%;
}

.btn-primary {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .btn-primary {
    border-color: color-mix(in srgb, var(--accent) 72%, white);
  }
}

.btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent));
}

@supports (color: color-mix(in lab, red, red)) {
  .btn-primary {
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 76%, white));
  }
}

.btn-primary {
  color: #03100a;
}

.btn-secondary {
  border-color: var(--border);
  background: var(--panel-3);
  color: var(--text);
}

.btn-outline {
  border-color: var(--border-strong);
  color: var(--text);
  background: none;
}

.btn-ghost {
  color: var(--text);
  box-shadow: none;
  background: none;
  border-color: #0000;
}

.btn-telegram {
  color: #fff;
  background: #229ed9;
  border-color: #53b3e1;
}

.btn-icon, .btn-square {
  width: 42px;
  min-width: 42px;
  height: 42px;
  min-height: 42px;
  padding: 0;
}

.btn-sm {
  min-height: 36px;
  padding: 0 12px;
  font-size: 13px;
}

.btn-lg {
  min-height: 52px;
  padding: 0 18px;
  font-size: 16px;
}

.progress {
  background: #ffffff14;
  border-radius: 999px;
  height: 8px;
  margin-top: 12px;
  position: relative;
  overflow: hidden;
}

.progress span {
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent));
  width: 0;
  position: absolute;
  inset: 0 auto 0 0;
}

@supports (color: color-mix(in lab, red, red)) {
  .progress span {
    background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 72%, white));
  }
}

.progress span {
  box-shadow: 0 0 18px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .progress span {
    box-shadow: 0 0 18px color-mix(in srgb, var(--accent) 40%, transparent);
  }
}

.input {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--panel-2);
  width: 100%;
  min-height: 46px;
  color: var(--text);
  font: inherit;
  padding: 8px 16px;
  font-size: 14px;
  line-height: 1.5;
  transition: border-color .16s, box-shadow .16s;
}

.input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
  outline: none;
}

@supports (color: color-mix(in lab, red, red)) {
  .input:focus {
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 38%, transparent);
  }
}

.input::placeholder {
  color: var(--dim);
}

.input:disabled {
  opacity: .52;
  cursor: not-allowed;
}

.input.input-error {
  border-color: var(--danger);
  box-shadow: 0 0 0 1px var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .input.input-error {
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--danger) 70%, transparent);
  }
}

.preview-phone .btn {
  min-height: 38px;
  padding: 8px 10px;
  font-size: 12px;
}

.preview-phone .btn-square {
  width: 36px;
  min-width: 36px;
  height: 36px;
  padding: 0;
}

.dialog-skeleton {
  gap: 12px;
  display: grid;
}

.dialog {
  z-index: 220;
  padding: max(14px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(14px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));
  isolation: isolate;
  place-items: center;
  display: grid;
  position: fixed;
  inset: 0;
  overflow: hidden;
}

.dialog-backdrop {
  z-index: 0;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  cursor: pointer;
  background: #0000008f;
  border: 0;
  position: absolute;
  inset: 0;
}

.dialog-card {
  z-index: 1;
  overscroll-behavior: contain;
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 24px;
  gap: 16px;
  width: min(100%, 520px);
  max-height: min(86dvh, 760px);
  padding: 18px;
  display: grid;
  position: relative;
  overflow: auto;
}

@supports (color: color-mix(in lab, red, red)) {
  .dialog-card {
    background: color-mix(in srgb, var(--panel) 94%, #07111a);
  }
}

.dialog-card {
  color: var(--text);
  box-shadow: 0 26px 70px #00000075;
}

.dialog-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
  display: grid;
}

.dialog-head h2 {
  color: var(--text);
  margin: 0;
  font-size: 19px;
  line-height: 1.18;
}

.dialog-head p {
  color: var(--muted);
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.45;
}

.dialog-card .bottom-action {
  margin-top: 2px;
}

.payment-dialog-card {
  max-height: 100%;
  overflow-y: auto;
}

.payment-dialog-body {
  gap: 10px;
  display: grid;
}

.payment-divider {
  background: var(--border);
  width: 100%;
  height: 1px;
}

.payment-submit-button {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .payment-submit-button {
    border-color: color-mix(in srgb, var(--accent) 72%, transparent);
  }
}

.payment-submit-button {
  background: linear-gradient(180deg, var(--accent), var(--accent));
}

@supports (color: color-mix(in lab, red, red)) {
  .payment-submit-button {
    background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 94%, white), var(--accent));
  }
}

.payment-submit-button {
  color: #031009;
  box-shadow: 0 16px 38px var(--accent), 0 0 0 1px var(--accent), 0 0 26px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .payment-submit-button {
    box-shadow: 0 16px 38px color-mix(in srgb, var(--accent) 28%, transparent), 0 0 0 1px color-mix(in srgb, var(--accent) 45%, transparent), 0 0 26px color-mix(in srgb, var(--accent) 42%, transparent);
  }
}

.link-email-dialog-card {
  grid-template-rows: auto minmax(0, 1fr);
  height: min(100%, 560px);
  max-height: 100%;
  display: grid;
  overflow: hidden;
}

.link-email-dialog-card .dialog-head {
  z-index: 2;
  position: relative;
}

.link-email-dialog-card .payment-dialog-body {
  min-height: 0;
}

@media (min-width: 720px) {
  .dialog-card {
    border-radius: var(--radius-lg);
    padding: 20px;
  }
}

.admin-cn-dashboard-stack {
  flex-direction: column;
  gap: 18px;
  min-width: 0;
  display: flex;
}

.admin-cn-dashboard-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  display: grid;
}

@media (min-width: 720px) {
  .admin-cn-dashboard-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.admin-cn-card[data-slot="card"] {
  border: 1px solid var(--admin-border);
  background: linear-gradient(135deg, #ffffff0e, #ffffff05), var(--admin-surface);
  border-radius: 12px;
  flex-direction: column;
  min-width: 0;
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 18px 48px #00000038, inset 0 1px #ffffff0d;
}

.admin-cn-card-header {
  grid-template-rows: auto auto;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: flex-start;
  gap: 4px 12px;
  padding: 14px 16px 0;
  display: grid;
}

.admin-cn-card-header > [data-slot="card-description"] {
  grid-area: 1 / 1;
}

.admin-cn-card-header > [data-slot="card-title"] {
  grid-area: 2 / 1;
}

.admin-cn-card-header > [data-slot="card-action"] {
  grid-area: 1 / 2 / span 2;
  place-self: flex-start end;
}

.admin-cn-card-header--lead > [data-slot="card-title"] {
  grid-row: 1;
}

.admin-cn-card-header--lead > [data-slot="card-description"] {
  grid-row: 2;
}

.admin-cn-card-description {
  color: var(--admin-muted);
  margin: 0;
  font-size: 12px;
  font-weight: 500;
}

.admin-cn-card-title {
  letter-spacing: -.02em;
  color: var(--admin-text);
  font-variant-numeric: tabular-nums;
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.15;
}

.admin-cn-card-title--section {
  letter-spacing: -.01em;
  font-size: 1.05rem;
  font-weight: 600;
}

.admin-cn-card-skeleton {
  min-height: 132px;
}

.admin-cn-card-skeleton--tall {
  min-height: 0;
}

@media (min-width: 900px) {
  .admin-cn-card-title {
    font-size: 1.65rem;
  }
}

.admin-cn-card-footer {
  border-top: 1px solid var(--admin-border);
  margin-top: auto;
  padding: 12px 16px 14px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-card-footer {
    border-top: 1px solid color-mix(in srgb, var(--admin-border) 70%, transparent);
  }
}

.admin-cn-card-footer--stack {
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  font-size: 13px;
  display: flex;
}

.admin-cn-card-footer-primary {
  color: var(--admin-text);
  align-items: center;
  gap: 6px;
  min-width: 0;
  font-weight: 600;
  display: flex;
}

.admin-cn-card-footer-muted {
  color: var(--admin-muted);
  font-size: 12px;
  line-height: 1.35;
}

.admin-cn-card-content {
  gap: 12px;
  min-width: 0;
  padding: 12px 16px 14px;
  display: grid;
}

.admin-cn-card-content--flush {
  padding-top: 4px;
}

.admin-cn-badge {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 999px;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-badge {
    background: color-mix(in srgb, var(--admin-surface-2) 88%, var(--admin-bg));
  }
}

.admin-cn-badge {
  color: var(--admin-text);
}

.admin-cn-badge :global(svg) {
  flex-shrink: 0;
  width: 14px;
  height: 14px;
}

.admin-cn-badge-outline {
  border-color: var(--admin-border);
  color: var(--admin-muted);
  background: none;
}

.admin-cn-badge-destructive {
  background: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-badge-destructive {
    background: color-mix(in srgb, var(--danger) 16%, var(--admin-surface));
  }
}

.admin-cn-badge-destructive {
  border-color: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-badge-destructive {
    border-color: color-mix(in srgb, var(--danger) 35%, var(--admin-border));
  }
}

.admin-cn-badge-destructive {
  color: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-badge-destructive {
    color: color-mix(in srgb, var(--danger) 92%, var(--admin-text));
  }
}

.admin-cn-badge-success {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-badge-success {
    background: color-mix(in srgb, var(--accent) 14%, var(--admin-surface));
  }
}

.admin-cn-badge-success {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-badge-success {
    border-color: color-mix(in srgb, var(--accent) 32%, var(--admin-border));
  }
}

.admin-cn-badge-success {
  color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-badge-success {
    color: color-mix(in srgb, var(--accent) 88%, var(--admin-text));
  }
}

.admin-cn-badge-muted {
  background: var(--admin-surface-2);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-cn-badge-muted {
    background: color-mix(in srgb, var(--admin-surface-2) 70%, var(--admin-bg));
  }
}

.admin-cn-badge-muted {
  color: var(--admin-muted);
}

.ui-spinner, .telegram-button-spinner {
  border: 2px solid;
  border-right-color: #0000;
  border-radius: 999px;
  flex: none;
  width: 16px;
  height: 16px;
  animation: .72s linear infinite ui-spin;
  display: inline-block;
}

.ui-spinner-sm {
  border-width: 2px;
  width: 13px;
  height: 13px;
}

.ui-spinner-lg {
  border-width: 3px;
  width: 24px;
  height: 24px;
}

@keyframes ui-spin {
  to {
    transform: rotate(360deg);
  }
}

.ui-skeleton, .admin-skeleton, .skeleton-line, .skeleton-dot, .skeleton-pay-button {
  background: linear-gradient(90deg, #ffffff14, #ffffff24, #ffffff14) 0 0 / 220% 100%;
  animation: 1.2s ease-in-out infinite ui-skeleton-pulse;
  display: inline-block;
}

.ui-skeleton {
  border-radius: 10px;
  width: 100%;
  min-height: 40px;
}

.ui-skeleton-line, .admin-skeleton-line, .skeleton-line {
  border-radius: 999px;
  width: 100%;
  height: 10px;
  min-height: 0;
}

.ui-skeleton-title, .skeleton-line-title {
  width: 72%;
  height: 14px;
  min-height: 0;
}

.ui-skeleton-short, .admin-skeleton-line-short, .skeleton-line-short {
  width: 56%;
}

.ui-skeleton-tiny, .admin-skeleton-line-tiny, .skeleton-line-tiny {
  width: 34%;
}

.ui-skeleton-badge, .admin-skeleton-badge {
  border-radius: 999px;
  width: 64px;
  height: 18px;
  min-height: 0;
}

.ui-skeleton-dot, .skeleton-dot {
  border-radius: 999px;
  width: 18px;
  height: 18px;
  min-height: 0;
}

@keyframes ui-skeleton-pulse {
  0% {
    background-position: 120% 0;
  }

  100% {
    background-position: -120% 0;
  }
}

button {
  cursor: pointer;
}

a {
  color: inherit;
}

.phone-screen {
  width: min(100%, 440px);
  min-height: 100dvh;
  padding: max(16px, env(safe-area-inset-top)) max(var(--screen-gutter), var(--safe-inline)) max(18px, env(safe-area-inset-bottom)) max(var(--screen-gutter), var(--safe-inline));
  margin: 0 auto;
  position: relative;
  overflow-x: hidden;
}

.content {
  gap: 10px;
  animation: .22s ease-out both section-enter;
  display: grid;
}

.content.with-nav {
  padding-bottom: 86px;
}

.loader {
  min-height: 100dvh;
  color: var(--muted);
  align-content: center;
  place-items: center;
  gap: 14px;
  font-weight: 800;
  display: grid;
}

.app-header, .preview-header, .screen-head {
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  display: grid;
}

.screen-head {
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  margin-bottom: 6px;
}

.center-title {
  align-items: start;
}

.center-copy {
  text-align: center;
  min-width: 0;
}

.screen-head h1, .center-copy h1 {
  color: var(--text);
  margin: 0;
  font-size: 18px;
  font-weight: 850;
  line-height: 1.16;
}

.screen-head p, .center-copy p {
  color: var(--muted);
  margin: 3px 0 0;
  font-size: 12px;
  line-height: 1.3;
}

.screen-head strong {
  color: var(--accent);
}

.brand-row {
  align-items: center;
  gap: 10px;
  min-width: 0;
  display: flex;
}

.brand-row strong {
  min-width: 0;
  color: var(--text);
  font-size: 15px;
  font-weight: 850;
  font-family: var(--font-mono);
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.accent-title .brand-row strong {
  color: var(--accent);
}

.brand-mark {
  width: 38px;
  height: 38px;
  color: var(--accent);
  flex: none;
  place-items: center;
  font-size: 26px;
  line-height: 1;
  display: grid;
  position: relative;
  overflow: visible;
}

.brand-mark img {
  object-fit: contain;
  opacity: 0;
  width: 100%;
  height: 100%;
  transition: opacity .18s;
}

.brand-mark img.loaded {
  opacity: 1;
}

.brand-mark-spinner {
  border: 2px solid var(--accent);
  width: 42%;
  height: 42%;
  position: absolute;
}

@supports (color: color-mix(in lab, red, red)) {
  .brand-mark-spinner {
    border: 2px solid color-mix(in srgb, var(--accent) 24%, transparent);
  }
}

.brand-mark-spinner {
  border-top-color: var(--accent);
  border-radius: 999px;
  animation: .72s linear infinite brand-mark-spin;
}

@keyframes brand-mark-spin {
  to {
    transform: rotate(360deg);
  }
}

.brand-mark-lg {
  width: 66px;
  height: 66px;
  font-size: 46px;
}

.brand-mark-xl {
  width: 96px;
  height: 96px;
  font-size: 70px;
}

.card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(135deg, #ffffff0e, #ffffff05), var(--panel);
  padding: 14px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 18px 48px #00000038, inset 0 1px #ffffff0d;
}

.card-active {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .card-active {
    border-color: color-mix(in srgb, var(--accent) 76%, var(--border));
  }
}

.card-active {
  box-shadow: 0 18px 48px #00000038, 0 0 0 1px var(--accent), inset 0 1px 0 #ffffff0d;
}

@supports (color: color-mix(in lab, red, red)) {
  .card-active {
    box-shadow: 0 18px 48px #00000038, 0 0 0 1px color-mix(in srgb, var(--accent) 38%, transparent), inset 0 1px 0 #ffffff0d;
  }
}

.card-compact {
  padding: 11px;
}

.status-card {
  padding: 16px;
}

.status-card-inactive {
  border-color: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .status-card-inactive {
    border-color: color-mix(in srgb, var(--danger) 58%, var(--border));
  }
}

.status-card-inactive {
  background: linear-gradient(135deg, var(--danger), #ffffff03), var(--panel);
}

@supports (color: color-mix(in lab, red, red)) {
  .status-card-inactive {
    background: linear-gradient(135deg, color-mix(in srgb, var(--danger) 14%, #ffffff08), #ffffff03), var(--panel);
  }
}

.status-card-inactive .sub-status {
  color: var(--danger);
}

.sub-status-inactive {
  justify-content: flex-start;
  min-height: 0;
}

.sub-status {
  color: var(--accent);
  align-items: center;
  gap: 12px;
  display: flex;
}

.sub-status h2 {
  margin: 0;
  font-size: 15px;
  line-height: 1.16;
}

.sub-status p {
  color: var(--text);
  opacity: .82;
  margin: 5px 0 0;
  font-size: 12px;
}

.sub-status .current-tariff-line {
  opacity: 1;
  font-weight: 850;
}

.traffic-top, .total-card {
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  display: flex;
}

.traffic-top span, .card-label, .total-card span, .settings-row small, .method-card small {
  color: var(--muted);
  font-size: 12px;
}

.traffic-top strong {
  font-size: 12px;
  font-weight: 850;
}

.card-heading {
  color: var(--text);
  margin: 0 0 10px;
  font-size: 15px;
  font-weight: 850;
  line-height: 1.2;
}

.card-heading-accent {
  color: var(--accent);
}

.promo-heading {
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.traffic-meta {
  color: var(--muted);
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
  font-size: 11px;
  display: flex;
}

.traffic-percent {
  text-align: right;
  color: var(--muted);
  margin-top: 0;
  font-size: 11px;
}

.traffic-card-clickable {
  cursor: pointer;
}

.card-click-target {
  z-index: 6;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  background: none;
  border: 0;
  width: 100%;
  position: absolute;
  inset: 0;
}

.card-click-target:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -3px;
}

.premium-traffic-card {
  display: block;
}

.premium-traffic-card-limited {
  border-color: #ffc10757;
}

.premium-progress span {
  background: linear-gradient(90deg, #38bdf8, var(--accent));
}

.premium-traffic-meta {
  align-items: flex-start;
}

.premium-server-dropdown {
  z-index: 7;
  min-width: 0;
  position: relative;
}

.premium-server-dropdown summary {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  align-items: center;
  gap: 6px;
  min-width: 0;
  min-height: 32px;
  margin: -6px -8px;
  padding: 6px 8px;
  list-style: none;
  display: inline-flex;
}

.premium-server-dropdown summary:focus {
  outline: none;
}

.premium-server-dropdown summary::-webkit-details-marker {
  display: none;
}

.premium-server-dropdown summary span {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.premium-server-dropdown svg {
  opacity: .72;
  flex: none;
}

.premium-server-list-dropdown {
  margin-top: 8px;
}

.premium-detail-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  display: grid;
}

.premium-detail-grid span {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.premium-detail-grid small, .premium-server-list small, .topup-summary-card small {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.3;
}

.premium-detail-grid strong {
  font-size: 12px;
  line-height: 1.2;
}

.premium-server-list {
  gap: 6px;
  display: grid;
}

.premium-server-list > div {
  flex-wrap: wrap;
  gap: 6px;
  display: flex;
}

.premium-server-list span {
  max-width: 100%;
  color: var(--text);
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  border: 1px solid #ffffff1a;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 11px;
}

.topup-summary-card {
  gap: 10px;
  padding: 12px;
  display: grid;
}

.topup-summary-card > div:not(.premium-server-list) {
  gap: 3px;
  display: grid;
}

.topup-summary-card strong {
  font-size: 12px;
  line-height: 1.2;
}

.premium-server-list-modal {
  margin-top: 0;
}

.trial-card {
  padding: 13px 14px;
}

.trial-card-head {
  align-items: center;
  gap: 11px;
  display: flex;
}

.trial-card-head > svg {
  color: var(--accent);
  flex: none;
}

.trial-card-head span {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.trial-card-head strong {
  font-size: 13px;
  line-height: 1.18;
}

.trial-card-head small {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.28;
}

.devices-summary-card {
  gap: 10px;
  display: grid;
}

.devices-summary-head, .device-card-head {
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 11px;
  display: grid;
}

.devices-summary-head > svg {
  color: var(--accent);
}

.devices-summary-head span, .device-card-head span {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.devices-summary-head strong, .device-card-head strong {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  overflow: hidden;
}

.devices-summary-head small, .device-card-head small, .device-meta span, .device-meta small, .devices-empty-card small {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.3;
}

.devices-progress {
  margin-top: 0;
}

.devices-list {
  gap: 8px;
  display: grid;
}

.device-card {
  gap: 12px;
  display: grid;
}

.device-card-head {
  grid-template-columns: 38px minmax(0, 1fr);
}

.device-icon {
  border: 1px solid var(--accent);
  place-items: center;
  width: 38px;
  height: 38px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .device-icon {
    border: 1px solid color-mix(in srgb, var(--accent) 38%, var(--border));
  }
}

.device-icon {
  border-radius: var(--radius);
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .device-icon {
    background: color-mix(in srgb, var(--accent) 9%, #ffffff08);
  }
}

.device-icon {
  color: var(--accent);
}

.device-meta {
  gap: 7px;
  display: grid;
}

.device-meta div {
  gap: 2px;
  display: grid;
}

.device-meta strong, .device-meta code {
  color: var(--text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 800;
  overflow: hidden;
}

.device-meta code {
  font-family: var(--font-mono);
}

.device-user-agent small {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.device-disconnect-button, .device-danger-button {
  border-color: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .device-disconnect-button, .device-danger-button {
    border-color: color-mix(in srgb, var(--danger) 62%, var(--border));
  }
}

.device-disconnect-button, .device-danger-button {
  color: #ffb8b8;
}

.devices-empty-card {
  text-align: center;
  justify-items: center;
  gap: 7px;
  display: grid;
}

.devices-empty-card svg {
  color: var(--accent);
}

.action-stack {
  gap: 8px;
  display: grid;
}

.bottom-action {
  margin-top: 4px;
}

.period-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  display: grid;
}

.period-grid-two-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.period-card, .method-card, .settings-row {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  background: linear-gradient(135deg, #ffffff0d, #ffffff05);
  box-shadow: inset 0 1px #ffffff0b;
}

.period-card {
  place-items: center;
  gap: 4px;
  min-height: 82px;
  padding: 10px 8px;
  display: grid;
  position: relative;
}

.period-card strong {
  text-align: center;
  overflow-wrap: anywhere;
  font-size: 12px;
  line-height: 1.12;
}

.period-card span {
  font-size: 16px;
  font-weight: 850;
}

.period-card em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 750;
}

.period-card small {
  color: var(--muted);
  font-size: 10px;
}

.period-card svg {
  color: var(--accent);
  position: absolute;
  top: 8px;
  right: 8px;
}

.period-card.active, .method-card.active {
  border-color: var(--accent);
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .period-card.active, .method-card.active {
    background: color-mix(in srgb, var(--accent) 9%, #ffffff09);
  }
}

.period-card.active, .method-card.active {
  box-shadow: 0 0 0 1px var(--accent), inset 0 1px 0 #ffffff0f;
}

@supports (color: color-mix(in lab, red, red)) {
  .period-card.active, .method-card.active {
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 50%, transparent), inset 0 1px 0 #ffffff0f;
  }
}

.total-card {
  padding: 12px 14px;
}

.total-card strong {
  font-size: 22px;
  font-weight: 900;
}

.method-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  display: grid;
}

.option-list {
  gap: 8px;
  display: grid;
}

.option-row, .tariff-selected-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  width: 100%;
  min-height: 66px;
  color: var(--text);
  text-align: left;
  background: linear-gradient(135deg, #ffffff0d, #ffffff05);
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px;
  display: flex;
  box-shadow: inset 0 1px #ffffff0b;
}

.option-row-main, .tariff-selected-card span {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.option-row-main strong, .tariff-selected-card strong {
  overflow-wrap: anywhere;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.2;
}

.option-row-main small, .tariff-selected-card small {
  color: var(--muted);
  overflow-wrap: anywhere;
  font-size: 11px;
  line-height: 1.35;
}

.option-row-meta {
  text-align: right;
  flex: none;
  justify-items: end;
  gap: 3px;
  max-width: 42%;
  display: grid;
}

.option-row-meta em, .tariff-selected-card em {
  color: var(--accent);
  overflow-wrap: anywhere;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  line-height: 1.2;
}

.option-row-meta small {
  color: var(--muted);
  font-size: 10px;
  line-height: 1.2;
}

.option-row.active {
  border-color: var(--accent);
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .option-row.active {
    background: color-mix(in srgb, var(--accent) 9%, #ffffff09);
  }
}

.option-row.active {
  box-shadow: 0 0 0 1px var(--accent), inset 0 1px 0 #ffffff0f;
}

@supports (color: color-mix(in lab, red, red)) {
  .option-row.active {
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 50%, transparent), inset 0 1px 0 #ffffff0f;
  }
}

.tariff-row {
  min-height: 74px;
}

.plan-row, .change-action-row {
  min-height: 62px;
}

.change-action-row {
  align-items: flex-start;
}

.change-action-row > svg {
  color: var(--accent);
  flex: none;
  margin-top: 1px;
}

.topup-carryover-note {
  border-radius: var(--radius);
  background: #ffffff09;
  border: 1px solid #ffffff14;
  gap: 6px;
  padding: 10px 12px;
  display: grid;
}

.topup-carryover-note p {
  color: var(--muted);
  margin: 0;
  font-size: 11px;
  line-height: 1.35;
}

.skeleton-row, .skeleton-method, .skeleton-pay-button {
  pointer-events: none;
}

.skeleton-line, .skeleton-dot, .skeleton-pay-button {
  background: linear-gradient(90deg, #ffffff12 0%, #ffffff24 42%, #ffffff12 84%) 0 0 / 220% 100%;
  border-radius: 999px;
  animation: 1.15s ease-in-out infinite skeleton-shimmer;
  display: block;
  overflow: hidden;
}

.skeleton-line-title {
  width: 118px;
  height: 13px;
}

.skeleton-line-short {
  opacity: .75;
  width: 76px;
  height: 10px;
}

.skeleton-line-price {
  width: 58px;
  height: 12px;
  min-height: 0;
}

.skeleton-line-tiny {
  opacity: .7;
  width: 34px;
  height: 9px;
  min-height: 0;
}

.skeleton-line-method {
  width: 72px;
  height: 12px;
  min-height: 0;
}

.skeleton-dot {
  flex: none;
  width: 18px;
  height: 18px;
  min-height: 0;
}

.skeleton-method {
  gap: 8px;
}

.skeleton-pay-button {
  border-radius: var(--radius);
  width: 100%;
  height: 46px;
}

@keyframes skeleton-shimmer {
  0% {
    background-position: 120% 0;
  }

  100% {
    background-position: -120% 0;
  }
}

.back-inline {
  width: fit-content;
  color: var(--muted);
  background: none;
  border: 0;
  align-items: center;
  gap: 6px;
  padding: 0;
  font-size: 12px;
  font-weight: 850;
  display: inline-flex;
}

.tariff-step-caption, .section-kicker {
  color: var(--muted);
  margin: 0;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.3;
}

.section-kicker {
  color: var(--dim);
  text-transform: uppercase;
}

.tariff-selected-card {
  background: var(--accent);
  min-height: 58px;
}

@supports (color: color-mix(in lab, red, red)) {
  .tariff-selected-card {
    background: color-mix(in srgb, var(--accent) 7%, #ffffff09);
  }
}

.tariff-action-list {
  gap: 8px;
  display: grid;
}

.tariff-action-card, .tariff-warning-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  text-align: left;
  background: linear-gradient(135deg, #ffffff0d, #ffffff05);
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 12px;
  display: flex;
}

.tariff-action-card span {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.tariff-action-card strong, .tariff-warning-card span {
  font-size: 13px;
  font-weight: 850;
}

.tariff-action-card small {
  color: var(--muted);
  font-size: 11px;
}

.tariff-action-card em {
  color: var(--accent);
  white-space: nowrap;
  font-size: 10px;
  font-style: normal;
  font-weight: 850;
}

.tariff-action-card.active {
  border-color: var(--accent);
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .tariff-action-card.active {
    background: color-mix(in srgb, var(--accent) 9%, #ffffff09);
  }
}

.tariff-warning-card {
  color: var(--warning, #ffd166);
  justify-content: flex-start;
}

.confirm-summary-card {
  gap: 8px;
  display: grid;
}

.confirm-summary-card p {
  color: var(--text);
  margin: 0;
  font-size: 13px;
  font-weight: 750;
  line-height: 1.35;
}

.method-card {
  text-align: center;
  background: #ffffff09;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 56px;
  padding: 10px;
  display: flex;
}

.method-card svg {
  flex: none;
}

.method-card-main {
  justify-content: center;
  align-items: center;
  gap: 8px;
  min-width: 0;
  display: inline-flex;
}

.method-card strong {
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: center;
  font-size: 12px;
  overflow: hidden;
}

.settings-list {
  gap: 8px;
  display: grid;
}

.settings-list.settings-list--language-open .settings-row:not(.settings-row-language) {
  pointer-events: none;
}

.language-select-guard {
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  z-index: 100;
  box-shadow: none;
  pointer-events: auto;
  touch-action: manipulation;
  background: none;
  border: 0;
  outline: none;
  padding: 0;
  position: fixed;
  inset: 0;
}

.copy-row, .email-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  display: grid;
}

.field-error-wrap {
  min-width: 0;
  position: relative;
}

.field-error-icon {
  color: var(--danger);
  pointer-events: none;
}

.field-error-trigger {
  cursor: help;
  background: none;
  border: 0;
  place-items: center;
  width: 20px;
  height: 20px;
  padding: 0;
  display: grid;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
}

.field-error-tooltip {
  z-index: 120;
  border: 1px solid var(--danger);
  max-width: 280px;
}

@supports (color: color-mix(in lab, red, red)) {
  .field-error-tooltip {
    border: 1px solid color-mix(in srgb, var(--danger) 60%, var(--border));
  }
}

.field-error-tooltip {
  color: #ffd8d8;
  transform-origin: top;
  background: #2a1010;
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 12px;
  line-height: 1.3;
}

.field-error-tooltip[data-state="delayed-open"], .field-error-tooltip[data-state="instant-open"] {
  animation: .16s ease-out both tooltip-in;
}

.field-error-tooltip[data-state="closed"] {
  animation: .12s ease-in both tooltip-out;
}

@keyframes tooltip-in {
  from {
    opacity: 0;
    transform: translateY(4px) scale(.98);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes tooltip-out {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  to {
    opacity: 0;
    transform: translateY(2px) scale(.98);
  }
}

.copy-row code {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  min-width: 0;
  color: var(--text);
  text-overflow: ellipsis;
  white-space: nowrap;
  background: #0003;
  padding: 12px;
  font-size: 12px;
  overflow: hidden;
}

.referral-copy-row {
  align-items: stretch;
}

.referral-copy-button {
  height: 100%;
}

.bonus-card {
  gap: 10px;
  display: grid;
}

.bonus-card-head {
  align-items: center;
  gap: 14px;
  display: flex;
}

.bonus-card-head > svg {
  color: var(--accent);
  flex: none;
}

.bonus-card strong {
  color: var(--accent);
  font-size: 17px;
  display: block;
}

.bonus-card p {
  color: var(--muted);
  margin: 4px 0 0;
  font-size: 12px;
}

.referral-bonus-list {
  gap: 8px;
  display: grid;
}

.referral-bonus-intro {
  color: var(--muted);
  margin: 2px 2px 0;
  font-size: 12px;
}

.referral-bonus-row {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: #ffffff05;
  gap: 3px;
  padding: 10px 11px;
  display: grid;
}

.referral-bonus-row strong {
  font-size: 13px;
}

.referral-bonus-row small {
  color: var(--muted);
  font-size: 12px;
}

.settings-profile {
  align-items: center;
  gap: 12px;
  display: flex;
}

.settings-avatar {
  border: 1px solid var(--border);
  background: #ffffff08;
  border-radius: 999px;
  flex: none;
  place-items: center;
  width: 58px;
  height: 58px;
  display: grid;
  overflow: hidden;
}

.settings-avatar img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.settings-avatar svg {
  color: var(--accent);
}

.settings-profile-meta {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.settings-profile-meta strong {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  overflow: hidden;
}

.settings-profile-meta small {
  color: var(--muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  overflow: hidden;
}

.settings-links-block {
  gap: 8px;
  display: grid;
}

.settings-divider {
  background: var(--border);
  height: 1px;
}

.settings-row {
  text-align: left;
  background: #ffffff08;
  grid-template-columns: 28px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 10px;
  min-height: 50px;
  padding: 9px 10px;
  display: grid;
}

.settings-row > svg:first-child {
  color: var(--text);
  opacity: .9;
}

.settings-row > svg:last-child {
  color: var(--muted);
}

.settings-row span {
  gap: 2px;
  min-width: 0;
  display: grid;
}

.settings-row strong, .settings-row small {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.settings-row strong {
  font-size: 12px;
}

.settings-row-linked {
  border-color: var(--accent);
  grid-template-columns: 28px minmax(0, 1fr);
}

@supports (color: color-mix(in lab, red, red)) {
  .settings-row-linked {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
  }
}

.settings-row-linked {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .settings-row-linked {
    background: color-mix(in srgb, var(--accent) 11%, #ffffff08);
  }
}

.settings-row-linked > svg:first-child, .settings-row-linked strong {
  color: var(--accent);
}

.emoji-flag {
  font-variant-emoji: emoji;
  font-family: Twemoji Country Flags, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji, sans-serif;
  line-height: 1;
}

.settings-row-language {
  grid-template-columns: 28px minmax(0, 1fr);
  padding: 7px 10px;
}

.language-select-trigger {
  width: 100%;
  min-height: 34px;
  color: var(--text);
  text-align: left;
  background: none;
  border: 0;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 0;
  display: grid;
}

.language-select-trigger:focus-visible {
  box-shadow: 0 0 0 2px var(--accent);
  outline: 0;
}

@supports (color: color-mix(in lab, red, red)) {
  .language-select-trigger:focus-visible {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 45%, transparent);
  }
}

.language-select-trigger:focus-visible {
  border-radius: 6px;
}

.language-select-trigger > svg {
  color: var(--muted);
}

.language-select-copy {
  gap: 2px;
  min-width: 0;
  display: grid;
}

.language-select-copy strong {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  overflow: hidden;
}

.language-select-current {
  align-items: center;
  gap: 7px;
  min-width: 0;
  display: inline-flex;
}

.language-select-current .emoji-flag {
  font-size: 14px;
}

.language-select-content {
  z-index: 140;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  background: var(--panel-3);
  box-sizing: border-box;
  transform-origin: 100% 0;
  width: min(210px, 100vw - 28px);
  min-width: 170px;
  max-width: min(210px, 100vw - 28px);
  animation: .16s ease-out both dropdown-enter;
  overflow: hidden;
  box-shadow: 0 20px 34px #0000006b;
}

.language-select-viewport {
  max-height: min(220px, 45dvh);
  padding: 6px;
}

.language-select-item {
  min-height: 36px;
  color: var(--text);
  cursor: pointer;
  border-radius: 6px;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 7px 9px;
  font-size: 13px;
  display: flex;
}

.language-select-item[data-highlighted] {
  background: #ffffff0f;
}

.language-select-item[data-selected] {
  color: var(--text) !important;
}

.language-select-item[data-selected] .language-select-item-check {
  color: var(--text);
}

.language-select-item-main {
  text-overflow: ellipsis;
  align-items: center;
  gap: 11px;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap !important;
  flex-wrap: nowrap !important;
  display: inline-flex !important;
}

.language-select-item-main > span {
  display: inline-block !important;
}

.language-select-item-main > span:last-child {
  text-overflow: ellipsis;
  margin-left: 6px;
  overflow: hidden;
  white-space: nowrap !important;
}

.language-select-item-main .emoji-flag {
  font-size: 14px;
}

.language-select-item-check {
  opacity: 0;
  color: var(--accent);
}

.language-select-item[data-selected] .language-select-item-check {
  opacity: 1;
}

.settings-telegram-link-btn {
  justify-content: center;
}

.attention-wrap {
  position: relative;
}

.attention-dot {
  pointer-events: none;
  background: #ff4b4b;
  border-radius: 999px;
  width: 13px;
  height: 13px;
  animation: 1.6s ease-out infinite attention-pulse;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(50%, -50%);
  box-shadow: 0 0 #ff4b4bbf;
}

.nav-attention-dot {
  top: 6px;
  right: 10px;
  transform: none;
}

.bottom-nav button.attention-wrap {
  padding-right: 6px;
}

@keyframes attention-pulse {
  0% {
    box-shadow: 0 0 #ff4b4bbf;
  }

  70% {
    box-shadow: 0 0 0 8px #ff4b4b00;
  }

  100% {
    box-shadow: 0 0 #ff4b4b00;
  }
}

.bottom-nav {
  left: var(--bottom-nav-left);
  width: var(--bottom-nav-width);
  max-width: none;
  right: auto;
  bottom: max(var(--bottom-nav-offset), env(safe-area-inset-bottom));
  z-index: 80;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  background: #070c11e0;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  min-height: 64px;
  display: grid;
  transform: none;
  box-shadow: 0 16px 38px #0000005c;
  position: fixed !important;
}

.bottom-nav-devices {
  grid-template-columns: repeat(4, 1fr);
}

.bottom-nav.static {
  position: fixed;
}

.bottom-nav button {
  color: var(--muted);
  background: none;
  border: 0;
  align-content: center;
  place-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 800;
  display: grid;
}

.bottom-nav button.active {
  color: var(--accent);
}

.rail-admin-entry {
  display: none !important;
}

.home-layout {
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 18px;
  min-height: calc(100dvh - 34px);
  padding-bottom: 86px;
  animation: .24s ease-out both section-enter;
  display: grid;
}

.home-brand {
  align-self: center;
  padding-top: 0;
}

.home-bottom {
  align-self: end;
  gap: 10px;
  display: grid;
}

.auth-screen {
  align-content: center;
  display: grid;
}

.auth-card-wrap {
  gap: 24px;
  display: grid;
}

.login-brand {
  text-align: center;
  justify-items: center;
  gap: 10px;
  display: grid;
}

.login-brand.small {
  gap: 5px;
}

.login-brand-auth .brand-mark.brand-mark-xl {
  width: 116px;
  height: 116px;
  font-size: 84px;
}

.login-brand h1 {
  overflow-wrap: anywhere;
  color: var(--accent);
  font-size: 32px;
  font-weight: 900;
  font-family: var(--font-mono);
  margin: 0;
  line-height: 1.04;
}

.login-brand p {
  color: var(--muted);
  margin: 0;
  font-size: 13px;
}

.auth-card {
  gap: 14px;
  display: grid;
}

.auth-pane {
  gap: 10px;
  display: grid;
}

.auth-email-stack {
  gap: 12px;
  display: grid;
}

.auth-pane .field-label, .auth-card .field-label {
  color: var(--text);
  font-size: 13px;
  font-weight: 850;
}

.auth-bottom {
  text-align: center;
  color: var(--muted);
  font-size: 13px;
}

.telegram-login-button {
  justify-content: center;
  padding-left: 14px;
  padding-right: 14px;
}

.telegram-login-button.unavailable:disabled {
  cursor: not-allowed;
}

.telegram-login-button.checking:disabled {
  opacity: .82;
}

.telegram-login-text {
  justify-content: center;
  align-items: center;
  gap: 8px;
  width: 100%;
  display: inline-flex;
}

.telegram-button-spinner {
  border: 2px solid #ffffff59;
  border-top-color: #fff;
  border-radius: 999px;
  width: 17px;
  height: 17px;
  animation: .72s linear infinite telegram-button-spin;
}

@keyframes telegram-button-spin {
  to {
    transform: rotate(360deg);
  }
}

.auth-legal {
  justify-items: center;
  gap: 6px;
  display: grid;
}

.auth-legal-intro, .auth-legal-links {
  color: var(--muted);
  text-align: center;
  font-size: 12px;
}

.auth-legal-links {
  flex-wrap: wrap;
  justify-content: center;
  gap: 4px;
  display: flex;
}

.auth-legal a {
  color: inherit;
  text-underline-offset: 2px;
  text-decoration: underline;
}

.auth-legal a:hover, .auth-bottom strong {
  color: var(--accent);
}

.or-line {
  color: var(--muted);
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  display: grid;
}

.or-line span {
  background: var(--border);
  height: 1px;
}

.otp-wrap {
  align-content: center;
  gap: 20px;
  min-height: calc(100dvh - 120px);
  display: grid;
}

.otp-input-wrap {
  display: block;
  position: relative;
}

.otp-input-wrap input {
  z-index: 2;
  color: #0000;
  caret-color: #0000;
  background: none;
  border: 0;
  outline: none;
  width: 100%;
  position: absolute;
  inset: 0;
}

.otp-slots {
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
  display: grid;
}

.otp-slots span {
  aspect-ratio: 1;
  border: 1px solid var(--accent);
  place-items: center;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .otp-slots span {
    border: 1px solid color-mix(in srgb, var(--accent) 74%, var(--border));
  }
}

.otp-slots span {
  border-radius: var(--radius);
  background: #ffffff09;
  font-size: 25px;
  font-weight: 900;
}

.otp-slots span.filled {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .otp-slots span.filled {
    background: color-mix(in srgb, var(--accent) 9%, #ffffff0a);
  }
}

.link-button {
  color: var(--muted);
  background: none;
  border: 0;
  justify-content: center;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  display: inline-flex;
}

.status-line {
  color: var(--accent);
  font-size: 12px;
  line-height: 1.4;
}

.auth-login-status {
  text-align: center;
  justify-self: center;
  width: 100%;
}

.status-line.error, .error {
  color: var(--danger);
}

.empty-card {
  color: var(--muted);
  grid-column: 1 / -1;
  font-size: 13px;
}

.toast {
  z-index: 120;
  border: 1px solid var(--accent);
  max-width: min(420px, 100vw - 32px);
  position: fixed;
  bottom: 16px;
  right: 16px;
}

@supports (color: color-mix(in lab, red, red)) {
  .toast {
    border: 1px solid color-mix(in srgb, var(--accent) 46%, var(--border));
  }
}

.toast {
  border-radius: var(--radius);
  color: var(--text);
  background: #0f151beb;
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 800;
  animation: .22s ease-out both toast-enter;
  box-shadow: 0 16px 42px #0000006b;
}

@keyframes section-enter {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes dropdown-enter {
  from {
    opacity: 0;
    transform: translateY(-6px) scale(.97);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes toast-enter {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.preview-board {
  background: linear-gradient(#06100c 0%, #02060b 32%, #010407 100%);
  grid-template-columns: repeat(3, auto);
  align-items: start;
  gap: 22px 38px;
  width: max-content;
  min-height: 100vh;
  padding: 18px 74px 28px;
  display: grid;
}

.preview-phone-wrap {
  gap: 9px;
  display: grid;
}

.preview-phone-wrap h2 {
  text-align: center;
  margin: 0;
  font-size: 18px;
  line-height: 1.1;
}

.preview-phone-wrap h2 span {
  color: var(--accent);
}

.preview-phone {
  background: linear-gradient(135deg, #ffffff13, #ffffff04), #071017;
  border: 1px solid #ffffff38;
  border-radius: 18px;
  align-content: start;
  gap: 8px;
  width: 430px;
  min-height: 318px;
  padding: 15px 16px 16px;
  display: grid;
  position: relative;
  overflow: hidden;
  box-shadow: 0 28px 80px #0000008a, inset 0 1px #ffffff14;
}

.preview-phone-wrap.wide .preview-phone {
  width: 510px;
}

.preview-phone .bottom-nav {
  width: auto;
  min-height: 50px;
  box-shadow: none;
  bottom: 8px;
  left: 16px;
  right: 16px;
}

.preview-phone .bottom-nav span {
  font-size: 9px;
}

.preview-phone .card {
  padding: 12px;
}

.preview-phone .status-card {
  padding: 14px;
}

.preview-phone .period-card {
  min-height: 72px;
}

.preview-phone .method-card {
  min-height: 42px;
}

.preview-phone .settings-row {
  min-height: 39px;
}

.preview-phone .settings-avatar {
  width: 46px;
  height: 46px;
}

.preview-phone .settings-profile-meta strong {
  font-size: 12px;
}

.preview-phone .settings-profile-meta small {
  font-size: 10px;
}

.preview-phone .brand-mark {
  width: 34px;
  height: 34px;
  font-size: 23px;
}

.preview-phone .brand-mark-lg {
  width: 56px;
  height: 56px;
  font-size: 39px;
}

.preview-phone .brand-mark-xl {
  width: 78px;
  height: 78px;
  font-size: 56px;
}

.preview-phone .home-layout {
  gap: 12px;
  min-height: 300px;
  padding-bottom: 58px;
}

.preview-phone .home-brand {
  padding-top: 0;
}

.preview-phone .login-brand h1 {
  font-size: 24px;
}

.preview-modal {
  border: 1px solid var(--border-strong);
  text-align: center;
  background: #141d23f0;
  border-radius: 14px;
  justify-items: center;
  gap: 8px;
  width: 178px;
  padding: 16px;
  display: grid;
  position: absolute;
  bottom: 18px;
  right: 18px;
  box-shadow: 0 18px 52px #00000075;
}

.preview-modal svg {
  color: var(--accent);
}

.preview-modal strong {
  font-size: 13px;
}

.preview-modal p {
  color: var(--muted);
  margin: 0;
  font-size: 10px;
  line-height: 1.35;
}

@media (max-width: 460px) {
  :root {
    --screen-gutter: 10px;
  }

  .period-grid, .method-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .copy-row, .email-row {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .content, .home-layout, .language-select-content, .dialog-backdrop, .dialog-card, .toast {
    animation: none !important;
  }
}

@supports not (color: color-mix(in srgb, #000 50%, #fff)) {
  .btn-primary {
    background: var(--accent);
  }
}

@media (min-width: 1024px) {
  body {
    background: #02070b;
  }

  .app-shell {
    min-height: 100dvh;
    padding: 0;
    display: block;
    background: none !important;
  }

  .phone-screen {
    width: auto;
    max-width: none;
    min-height: 100dvh;
    box-shadow: none;
    padding: max(28px, env(safe-area-inset-top)) var(--desktop-page-gutter) 40px calc(var(--desktop-rail-width) + var(--desktop-page-gutter));
    background: none;
    border: 0;
    border-radius: 0;
    margin: 0;
    overflow-x: visible;
  }

  .phone-screen > .app-header, .phone-screen > main, .phone-screen > .home-layout, .phone-screen > nav.bottom-nav ~ * {
    max-width: 1080px;
    margin-left: auto;
    margin-right: auto;
  }

  .phone-screen.auth-screen {
    width: min(100%, 460px);
    min-height: 100dvh;
    padding: max(16px, env(safe-area-inset-top)) clamp(24px, 4vw, 16px) 16px;
    margin: 0 auto;
  }

  .phone-screen.auth-screen ~ .bottom-nav, .auth-screen .bottom-nav {
    display: none !important;
  }

  .phone-screen.home-screen {
    min-height: 100dvh;
    padding: max(32px, env(safe-area-inset-top)) var(--desktop-page-gutter) 42px calc(var(--desktop-rail-width) + var(--desktop-page-gutter));
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
    display: grid;
  }

  .home-layout {
    grid-template-rows: minmax(280px, 1fr) auto;
    grid-template-columns: minmax(0, 1fr);
    justify-self: center;
    align-items: stretch;
    gap: clamp(24px, 4vh, 52px);
    width: min(100%, 680px);
    max-width: none;
    min-height: calc(100dvh - 74px);
    margin: 0;
    padding-bottom: 0;
  }

  .home-layout > .home-brand {
    text-align: center;
    grid-column: auto;
    align-self: center;
    justify-items: center;
    gap: 22px;
  }

  .home-brand h1 {
    letter-spacing: 0;
    max-width: 560px;
    font-size: clamp(36px, 4vw, 58px);
    line-height: 1.02;
  }

  .home-brand .brand-mark, .home-brand .brand-mark-lg, .home-brand .brand-mark-xl {
    width: clamp(180px, 18vw, 260px);
    height: clamp(180px, 18vw, 260px);
    font-size: clamp(124px, 13vw, 184px);
  }

  .home-bottom {
    place-self: end center;
    gap: 12px;
    width: min(100%, 560px);
  }

  .app-header.accent-title {
    display: none;
  }

  .content.with-nav {
    padding-bottom: 32px;
  }

  .bottom-nav {
    z-index: 40;
    width: var(--desktop-rail-width) !important;
    border: 0 !important;
    border-right: 1px solid var(--border) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    backdrop-filter: blur(14px) !important;
    background: #070c118c !important;
    border-radius: 0 !important;
    grid-template-rows: none !important;
    grid-template-columns: 1fr !important;
    grid-auto-rows: auto !important;
    align-content: start !important;
    gap: 2px !important;
    height: 100dvh !important;
    padding: 28px 14px !important;
    display: grid !important;
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    transform: none !important;
    box-shadow: inset -1px 0 #ffffff05 !important;
  }

  .bottom-nav-devices {
    grid-template-columns: 1fr !important;
  }

  .bottom-nav button {
    color: var(--muted);
    border: 1px solid #0000;
    transition: background .12s, color .12s, border-color .12s;
    text-align: left !important;
    border-radius: 10px !important;
    grid-template-rows: auto !important;
    grid-template-columns: 22px 1fr !important;
    place-items: center start !important;
    gap: 12px !important;
    padding: 12px 14px !important;
    font-size: 13px !important;
    display: grid !important;
  }

  .bottom-nav button > svg {
    width: 20px;
    height: 20px;
  }

  .bottom-nav button > span {
    font-weight: 600;
    text-align: left !important;
    font-size: 13px !important;
  }

  .bottom-nav button:hover {
    color: var(--text);
    background: #ffffff0a;
  }

  .bottom-nav button.active {
    background: var(--accent);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bottom-nav button.active {
      background: color-mix(in srgb, var(--accent) 16%, transparent);
    }
  }

  .bottom-nav button.active {
    border-color: var(--accent);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bottom-nav button.active {
      border-color: color-mix(in srgb, var(--accent) 30%, transparent);
    }
  }

  .bottom-nav button.active {
    color: var(--text);
  }

  .bottom-nav .nav-attention-dot {
    top: 14px;
    right: 14px;
  }

  .bottom-nav .rail-admin-entry {
    display: grid !important;
  }

  .settings-admin-block {
    display: none !important;
  }

  .phone-screen > main.content.with-nav {
    padding-top: 0;
  }

  .settings-profile {
    padding: 12px;
  }

  .settings-links-block {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .settings-links-block .settings-divider {
    display: none;
  }

  .settings-links-block .settings-row, .settings-links-block .settings-telegram-link-btn {
    min-height: 48px;
  }

  .settings-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .settings-list .settings-row {
    min-height: 48px;
  }

  .settings-row-language, .settings-row-support, .settings-row-logout {
    grid-column: 1 / -1;
  }

  .dialog-card {
    width: min(100%, 560px);
  }

  .payment-dialog-card, .link-email-dialog-card {
    width: min(100%, 640px);
  }
}

@media (min-width: 1280px) {
  :root {
    --desktop-rail-width: 264px;
  }
}

.rail-brand {
  display: none;
}

@media (min-width: 1024px) {
  .bottom-nav .rail-brand {
    border-bottom: 1px solid var(--border);
    color: var(--text);
    align-items: center;
    gap: 12px;
    margin-bottom: 8px;
    padding: 4px 12px 18px;
    display: flex;
  }

  .bottom-nav .rail-brand strong {
    color: var(--accent);
    letter-spacing: -.01em;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
    font-size: 14px;
    font-weight: 800;
    overflow: hidden;
  }
}

.admin-screen-wrap {
  --admin-sidebar-w: var(--desktop-rail-width);
  --admin-header-h: 60px;
  --admin-card-bg: linear-gradient(135deg, #ffffff0e, #ffffff05),
    var(--admin-surface);
  --admin-card-shadow: 0 18px 48px #00000038,
    inset 0 1px 0 #ffffff0d;
  width: 100vw;
  height: 100dvh;
  color: var(--admin-text);
  overscroll-behavior: contain;
  z-index: 60;
  background: #02070b;
  flex-direction: row;
  display: flex;
  position: fixed;
  inset: 0;
  overflow: hidden;
  transform: translateZ(0);
}

.admin-sidebar {
  flex: 0 0 var(--admin-sidebar-w);
  border-right: 1px solid var(--admin-border);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  background: #070c118c;
  flex-direction: column;
  gap: 2px;
  height: 100%;
  min-height: 0;
  padding: 28px 14px;
  display: flex;
  overflow-y: auto;
  box-shadow: inset -1px 0 #ffffff05;
}

.admin-sidebar > :not(.admin-sidebar-footer) {
  flex-shrink: 0;
}

.admin-sidebar-brand {
  border-bottom: 1px solid var(--admin-border);
  color: var(--admin-text);
  grid-template-columns: 38px minmax(0, 1fr) 34px;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
  padding: 4px 12px 18px;
  display: grid;
}

.admin-sidebar-brand .admin-brand-mark {
  width: 38px;
  height: 38px;
  color: var(--accent);
  place-items: center;
  display: grid;
}

.admin-sidebar-brand strong {
  min-width: 0;
  color: var(--accent);
  letter-spacing: -.01em;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  font-weight: 800;
  display: block;
  overflow: hidden;
}

.admin-sidebar-brand small {
  color: var(--admin-muted);
  font-size: 11px;
  display: block;
}

.admin-sidebar-section-label {
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--admin-dim);
  padding: 14px 12px 6px;
  font-size: 10px;
  font-weight: 700;
}

.admin-nav {
  gap: 2px;
  display: grid;
}

.admin-nav-item {
  color: var(--admin-muted);
  text-align: left;
  cursor: pointer;
  background: none;
  border: 1px solid #0000;
  border-radius: 10px;
  grid-template-columns: 22px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 600;
  transition: background .12s, color .12s, border-color .12s;
  display: grid;
  position: relative;
}

.admin-nav-item > svg {
  width: 20px;
  height: 20px;
}

.admin-nav-item:hover {
  color: var(--admin-text);
  background: #ffffff0a;
}

.admin-nav-item.active {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-nav-item.active {
    background: color-mix(in srgb, var(--accent) 16%, transparent);
  }
}

.admin-nav-item.active {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-nav-item.active {
    border-color: color-mix(in srgb, var(--accent) 30%, transparent);
  }
}

.admin-nav-item.active {
  color: var(--admin-text);
  font-weight: 600;
}

.admin-nav-item.active:before {
  display: none;
}

.admin-sidebar-footer {
  border-top: 1px solid var(--admin-border);
  color: var(--admin-dim);
  gap: 10px;
  margin-top: auto;
  padding: 14px 0 0;
  font-size: 11px;
  display: grid;
}

.admin-language-switch {
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  display: grid;
}

.admin-language-switch > svg {
  color: var(--admin-muted);
}

.admin-language-trigger {
  border: 1px solid var(--admin-border);
  width: 100%;
  min-width: 0;
  color: var(--admin-text);
  text-align: left;
  cursor: pointer;
  background: #ffffff09;
  border-radius: 10px;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  display: flex;
}

.admin-language-trigger:focus-visible {
  outline: 2px solid var(--admin-ring);
  outline-offset: 2px;
}

.admin-language-trigger > span {
  gap: 2px;
  min-width: 0;
  display: grid;
}

.admin-language-trigger strong {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 650;
  overflow: hidden;
}

.admin-language-trigger small {
  min-width: 0;
  color: var(--admin-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  display: inline-flex;
  overflow: hidden;
}

.admin-version-link {
  max-width: 100%;
  color: var(--admin-muted);
  font-family: var(--font-mono);
  text-overflow: ellipsis;
  white-space: nowrap;
  order: 2;
  gap: 2px;
  font-size: 11px;
  text-decoration: none;
  transition: color .12s;
  display: grid;
  overflow: hidden;
}

.admin-version-link span {
  text-overflow: ellipsis;
  overflow: hidden;
}

.admin-version-link:hover {
  color: var(--accent);
}

.admin-content {
  flex-direction: column;
  flex: auto;
  min-width: 0;
  height: 100%;
  min-height: 0;
  display: flex;
  overflow: hidden;
}

.admin-header {
  min-height: var(--admin-header-h);
  z-index: 5;
  border-bottom: 1px solid var(--admin-border);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  background: #02070bd1;
  flex: none;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 0 28px;
  display: grid;
}

.admin-header-title {
  gap: 2px;
  min-width: 0;
  display: grid;
}

.admin-header-title h2 {
  letter-spacing: -.01em;
  margin: 0;
  font-size: 16px;
  font-weight: 700;
}

.admin-header-title small {
  color: var(--admin-muted);
  font-size: 12px;
}

.admin-header-actions {
  align-items: center;
  gap: 8px;
  display: flex;
}

.admin-mobile-toggle {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  width: 36px;
  height: 36px;
  color: var(--admin-text);
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  display: none;
}

.admin-main {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  flex-direction: column;
  flex: auto;
  gap: 16px;
  min-height: 0;
  padding: 24px 28px 36px;
  display: flex;
  overflow: hidden auto;
}

.admin-main > * {
  flex-shrink: 0;
}

.admin-section-stage {
  flex-direction: column;
  flex-shrink: 0;
  gap: 16px;
  width: 100%;
  min-width: 0;
  display: flex;
}

.admin-card {
  border: 1px solid var(--admin-border);
  background: var(--admin-card-bg);
  box-shadow: var(--admin-card-shadow);
  border-radius: 12px;
  grid-template-columns: minmax(0, 1fr);
  min-width: 0;
  display: grid;
  overflow: hidden;
}

.admin-card-head {
  border-bottom: 1px solid var(--admin-border);
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  min-width: 0;
  padding: 14px 18px;
  display: grid;
}

.admin-card-head h3 {
  letter-spacing: 0;
  text-transform: none;
  color: var(--admin-text);
  word-break: break-word;
  margin: 0;
  font-size: 13px;
  font-weight: 600;
}

.admin-card-head small {
  color: var(--admin-muted);
  word-break: break-word;
  font-size: 12px;
}

.admin-card-body {
  gap: 12px;
  min-width: 0;
  padding: 16px 18px;
  display: grid;
}

.admin-empty {
  border: 1px dashed var(--admin-border);
  background: var(--admin-card-bg);
  color: var(--admin-muted);
  border-radius: 12px;
  place-items: center;
  padding: 48px 16px;
  font-size: 13px;
  display: grid;
}

.admin-muted {
  color: var(--admin-muted);
  font-size: 12px;
}

.admin-stat-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  display: grid;
}

@media (min-width: 560px) {
  .admin-stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .admin-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1440px) {
  .admin-stat-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.admin-stat-card {
  border: 1px solid var(--admin-border);
  background: var(--admin-card-bg);
  box-shadow: var(--admin-card-shadow);
  border-radius: 12px;
  gap: 6px;
  min-height: 96px;
  padding: 16px 18px;
  display: grid;
}

.admin-stat-card .admin-stat-label {
  color: var(--admin-muted);
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 500;
  display: flex;
}

.admin-stat-card .admin-stat-value {
  letter-spacing: -.02em;
  color: var(--admin-text);
  font-size: 26px;
  font-weight: 700;
}

.admin-stat-card .admin-stat-trend {
  color: var(--admin-muted);
  font-size: 12px;
}

.admin-dashboard-section {
  margin-top: 20px;
}

.admin-dashboard-section:first-child {
  margin-top: 0;
}

.admin-dashboard-section-head {
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin: 0 0 10px;
  display: flex;
}

.admin-dashboard-section-head h3 {
  color: var(--admin-text);
  letter-spacing: -.01em;
  margin: 0;
  font-size: 14px;
  font-weight: 600;
}

.admin-dashboard-section-head small {
  color: var(--admin-muted);
  font-size: 12px;
}

.admin-revenue-panel {
  border: 1px solid var(--admin-border);
  background: var(--admin-card-bg);
  box-shadow: var(--admin-card-shadow);
  border-radius: 12px;
  gap: 14px;
  min-width: 0;
  padding: 16px 18px;
  display: grid;
}

.admin-revenue-panel__body {
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
  gap: 18px;
  display: grid;
}

@media (min-width: 900px) {
  .admin-revenue-panel__body {
    grid-template-columns: minmax(240px, 340px) minmax(0, 1fr);
    gap: 22px;
  }
}

.admin-revenue-kpis {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  min-width: 0;
  display: grid;
}

@media (min-width: 520px) {
  .admin-revenue-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.admin-revenue-kpi {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 10px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-kpi {
    background: color-mix(in srgb, var(--admin-surface-2) 72%, var(--admin-bg));
  }
}

.admin-revenue-kpi {
  gap: 4px;
  min-width: 0;
  padding: 10px 12px;
  display: grid;
}

.admin-revenue-kpi--wide {
  grid-column: span 2;
}

.admin-revenue-kpi-label {
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--admin-muted);
  font-size: 11px;
  font-weight: 600;
}

.admin-revenue-kpi-value {
  letter-spacing: -.02em;
  color: var(--admin-text);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.15;
}

.admin-revenue-kpi-sub {
  color: var(--admin-muted);
  font-size: 12px;
  line-height: 1.35;
}

.admin-revenue-kpi-growth {
  font-size: 12px;
  font-weight: 600;
}

.admin-revenue-kpi-growth.is-up {
  color: #3ecf8e;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-kpi-growth.is-up {
    color: color-mix(in srgb, #3ecf8e 92%, var(--admin-text));
  }
}

.admin-revenue-kpi-growth.is-down {
  color: #ff6b6b;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-kpi-growth.is-down {
    color: color-mix(in srgb, #ff6b6b 88%, var(--admin-text));
  }
}

.admin-revenue-chart {
  gap: 8px;
  min-width: 0;
  display: grid;
}

.admin-revenue-chart-head {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px 14px;
  min-width: 0;
  display: flex;
}

.admin-revenue-chart-toolbar {
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  min-width: 0;
  display: flex;
}

.admin-revenue-chart-toolbar .admin-revenue-period {
  flex: auto;
  justify-content: flex-end;
}

.admin-revenue-granularity {
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  display: flex;
}

.admin-revenue-period-btn--compact {
  padding: 4px 9px;
  font-size: 10px;
}

.admin-revenue-period-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.admin-revenue-range-popover {
  z-index: 80;
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  width: min(100vw - 24px, 320px);
  color: var(--admin-text);
  border-radius: 12px;
  padding: 12px 14px 14px;
  box-shadow: 0 12px 40px #00000073;
}

.admin-revenue-range-popover__title {
  color: var(--admin-text);
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 600;
}

.admin-revenue-range-popover__actions {
  justify-content: flex-end;
  margin-top: 12px;
  display: flex;
}

.admin-revenue-rcal {
  margin-top: 2px;
}

.admin-revenue-rcal__header {
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  display: flex;
}

.admin-revenue-rcal__heading {
  text-align: center;
  color: var(--admin-text);
  flex: 1;
  font-size: 12px;
  font-weight: 600;
}

.admin-revenue-rcal__nav {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-rcal__nav {
    background: color-mix(in srgb, var(--admin-surface-2) 70%, var(--admin-bg));
  }
}

.admin-revenue-rcal__nav {
  color: var(--admin-text);
  cursor: pointer;
}

.admin-revenue-rcal__nav:hover {
  background: var(--admin-surface);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-rcal__nav:hover {
    background: color-mix(in srgb, var(--admin-surface) 80%, var(--admin-bg));
  }
}

.admin-revenue-rcal__grids {
  flex-direction: column;
  gap: 10px;
  display: flex;
}

.admin-revenue-rcal__grid {
  border-collapse: collapse;
  width: 100%;
}

.admin-revenue-rcal__weekrow {
  width: 100%;
  display: flex;
}

.admin-revenue-rcal__headcell {
  text-align: center;
  color: var(--admin-muted);
  flex: 1;
  min-width: 0;
  padding: 2px 0 6px;
  font-size: 10px;
  font-weight: 500;
}

.admin-revenue-rcal__cell {
  text-align: center;
  flex: 1;
  min-width: 0;
  padding: 0;
}

.admin-revenue-rcal__day {
  width: 100%;
  max-width: 36px;
  height: 32px;
  color: var(--admin-text);
  cursor: pointer;
  background: none;
  border: 1px solid #0000;
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  font-size: 11px;
  font-weight: 500;
  display: inline-flex;
}

.admin-revenue-rcal__day:hover {
  background: var(--admin-surface-2);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-rcal__day:hover {
    background: color-mix(in srgb, var(--admin-surface-2) 80%, var(--admin-bg));
  }
}

.admin-revenue-rcal__day[data-highlighted] {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-rcal__day[data-highlighted] {
    background: color-mix(in srgb, var(--accent) 10%, var(--admin-surface));
  }
}

.admin-revenue-rcal__day[data-selection-start], .admin-revenue-rcal__day[data-selection-end] {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-rcal__day[data-selection-start], .admin-revenue-rcal__day[data-selection-end] {
    background: color-mix(in srgb, var(--accent) 35%, var(--admin-surface));
  }
}

.admin-revenue-rcal__day[data-selection-start], .admin-revenue-rcal__day[data-selection-end] {
  color: var(--admin-text);
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-rcal__day[data-selection-start], .admin-revenue-rcal__day[data-selection-end] {
    border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  }
}

.admin-revenue-rcal__day[data-selected]:not([data-selection-start]):not([data-selection-end]) {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-rcal__day[data-selected]:not([data-selection-start]):not([data-selection-end]) {
    background: color-mix(in srgb, var(--accent) 14%, var(--admin-surface));
  }
}

.admin-revenue-rcal__day[data-disabled] {
  opacity: .35;
  pointer-events: none;
}

.admin-revenue-rcal__day[data-outside-month] {
  opacity: .25;
}

.admin-revenue-chart-title {
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--admin-muted);
  font-size: 11px;
  font-weight: 600;
}

.admin-revenue-period {
  border: 1px solid var(--admin-border);
  border-radius: 10px;
  flex-wrap: wrap;
  gap: 4px;
  padding: 3px;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-period {
    border: 1px solid color-mix(in srgb, var(--admin-border) 80%, transparent);
  }
}

.admin-revenue-period {
  background: var(--admin-surface-2);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-period {
    background: color-mix(in srgb, var(--admin-surface-2) 55%, var(--admin-bg));
  }
}

.admin-revenue-period-btn {
  appearance: none;
  letter-spacing: .02em;
  color: var(--admin-muted);
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 7px;
  margin: 0;
  padding: 6px 10px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 650;
  line-height: 1.1;
}

.admin-revenue-period-btn:hover {
  color: var(--admin-text);
  background: var(--admin-surface);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-period-btn:hover {
    background: color-mix(in srgb, var(--admin-surface) 55%, transparent);
  }
}

.admin-revenue-period-btn.is-active {
  color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-period-btn.is-active {
    color: color-mix(in srgb, var(--accent) 22%, var(--admin-text));
  }
}

.admin-revenue-period-btn.is-active {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-period-btn.is-active {
    background: color-mix(in srgb, var(--accent) 12%, var(--admin-surface));
  }
}

.admin-revenue-period-btn.is-active {
  box-shadow: inset 0 0 0 1px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-period-btn.is-active {
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 28%, transparent);
  }
}

.admin-revenue-chart-hint {
  margin: 0;
  font-size: 11px;
  line-height: 1.35;
}

.admin-revenue-chart-meta {
  flex-wrap: wrap;
  align-items: baseline;
  gap: 4px 8px;
  font-size: 11px;
  line-height: 1.35;
  display: flex;
}

.admin-revenue-chart-meta-sep {
  opacity: .55;
}

.admin-revenue-svg-frame {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 10px;
  width: 100%;
  min-width: 0;
  position: relative;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-revenue-svg-frame {
    background: color-mix(in srgb, var(--admin-bg) 88%, var(--admin-surface-2));
  }
}

.admin-revenue-svg-frame {
  overflow: hidden;
}

.admin-revenue-svg-frame--chart {
  width: 100%;
}

.admin-revenue-uplot-host {
  width: 100%;
  min-width: 0;
  display: block;
}

.admin-revenue-uplot-host .uplot {
  width: 100%;
  min-width: 0;
  max-width: 100%;
}

.admin-revenue-uplot-host .u-wrap {
  border-radius: 8px;
  width: 100%;
  overflow: hidden;
}

.admin-uplot.uplot {
  color: var(--admin-muted);
  font-family: var(--font-sans, system-ui, sans-serif);
}

.admin-uplot .u-title {
  color: var(--admin-text);
}

.admin-revenue-uplot-host .u-legend {
  box-sizing: border-box;
  padding: 10px 12px 8px;
}

.admin-uplot .u-legend {
  color: var(--admin-muted);
  font-size: 11px;
}

.admin-uplot .u-legend th, .admin-uplot .u-legend td {
  color: var(--admin-text);
}

.admin-uplot .u-inline {
  border-color: var(--admin-border);
}

.admin-revenue-chart-skeleton {
  width: 100%;
  height: min(204px, 36vw);
  min-height: 120px;
  display: block;
}

.admin-revenue-xlabels {
  color: var(--admin-muted);
  justify-content: space-between;
  gap: 6px;
  padding: 0 2px;
  font-size: 10px;
  display: flex;
}

.admin-revenue-xlabels span {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.admin-panel-dash-card {
  padding-top: 14px;
  padding-bottom: 14px;
}

.admin-panel-dash {
  gap: 18px;
  min-width: 0;
  display: grid;
}

.admin-panel-dash-tiles {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 12px;
  grid-template-columns: repeat(auto-fit, minmax(148px, 1fr));
  gap: 10px;
  padding: 12px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-tiles {
    background: color-mix(in srgb, var(--admin-bg) 65%, var(--admin-surface-2));
  }
}

.admin-panel-dash-tile {
  border: 1px solid var(--admin-border);
  border-radius: 10px;
  gap: 6px;
  padding: 12px 12px 11px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-tile {
    border: 1px solid color-mix(in srgb, var(--admin-border) 85%, transparent);
  }
}

.admin-panel-dash-tile {
  background: var(--admin-surface);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-tile {
    background: color-mix(in srgb, var(--admin-surface) 92%, var(--admin-bg));
  }
}

.admin-panel-dash-tile {
  min-width: 0;
}

.admin-panel-dash-tile--wide {
  grid-column: 1 / -1;
}

.admin-panel-dash-tile-label {
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--admin-muted);
  align-items: center;
  gap: 6px;
  min-width: 0;
  font-size: 11px;
  font-weight: 600;
  display: flex;
}

.admin-panel-dash-ico {
  color: var(--accent);
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-ico {
    color: color-mix(in srgb, var(--accent) 82%, var(--admin-muted));
  }
}

.admin-panel-dash-ico {
  flex-shrink: 0;
}

.admin-panel-dash-ico :global(svg) {
  display: block;
}

.admin-panel-dash-tile-value {
  letter-spacing: -.03em;
  color: var(--accent);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.1;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-tile-value {
    color: color-mix(in srgb, var(--accent) 22%, var(--admin-text));
  }
}

.admin-panel-dash-tile-value {
  font-variant-numeric: tabular-nums;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.admin-panel-dash-tile-value--sm {
  white-space: normal;
  font-size: 16px;
  font-weight: 650;
  line-height: 1.25;
}

.admin-panel-dash-nodes {
  gap: 10px;
  min-width: 0;
  display: grid;
}

.admin-panel-dash-nodes-head {
  gap: 4px;
  padding: 0 2px;
  display: grid;
}

.admin-panel-dash-nodes-title {
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--admin-text);
  margin: 0;
  font-size: 12px;
  font-weight: 700;
}

.admin-panel-dash-nodes-hint {
  color: var(--admin-muted);
  margin: 0;
  font-size: 11px;
  line-height: 1.35;
}

.admin-panel-dash-nodes-grid {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 12px;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
  max-height: 240px;
  padding: 10px;
  display: grid;
  overflow-y: auto;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-nodes-grid {
    background: color-mix(in srgb, var(--admin-bg) 65%, var(--admin-surface-2));
  }
}

.admin-panel-dash-node {
  border: 1px solid var(--admin-border);
  border-radius: 10px;
  gap: 4px;
  padding: 10px 11px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-node {
    border: 1px solid color-mix(in srgb, var(--admin-border) 85%, transparent);
  }
}

.admin-panel-dash-node {
  background: var(--admin-surface);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-node {
    background: color-mix(in srgb, var(--admin-surface) 92%, var(--admin-bg));
  }
}

.admin-panel-dash-node {
  min-width: 0;
}

.admin-panel-dash-node-name {
  color: var(--admin-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 600;
  overflow: hidden;
}

.admin-panel-dash-node-value {
  color: var(--accent);
  font-size: 15px;
  font-weight: 700;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-panel-dash-node-value {
    color: color-mix(in srgb, var(--accent) 28%, var(--admin-text));
  }
}

.admin-panel-dash-node-value {
  font-variant-numeric: tabular-nums;
}

.admin-panel-dash-node-meta {
  color: var(--admin-muted);
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  font-weight: 600;
}

.admin-panel-dash-nodes-more {
  color: var(--admin-muted);
  margin: 0;
  padding: 0 4px;
  font-size: 11px;
}

.admin-panel-dash-nodes-empty {
  color: var(--admin-muted);
  margin: 0;
  padding: 8px 4px 0;
  font-size: 12px;
}

.admin-sync-strip {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 12px;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 18px;
  padding: 12px 14px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-sync-strip {
    background: color-mix(in srgb, var(--admin-surface-2) 70%, var(--admin-bg));
  }
}

.admin-sync-strip {
  color: var(--admin-muted);
  font-size: 12px;
}

.admin-sync-strip strong {
  color: var(--admin-text);
  font-weight: 600;
}

.admin-stat-skeleton-card {
  border: 1px solid var(--admin-border);
  background: var(--admin-card-bg);
  box-shadow: var(--admin-card-shadow);
  border-radius: 12px;
  gap: 10px;
  min-height: 96px;
  padding: 16px 18px;
  display: grid;
}

.admin-stat-skeleton-wide {
  grid-column: span 1;
}

@media (min-width: 560px) {
  .admin-stat-skeleton-wide {
    grid-column: span 2;
  }
}

.admin-toolbar {
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  display: flex;
}

.admin-toolbar-users {
  border: 1px solid var(--admin-border);
  background: var(--admin-card-bg);
  box-shadow: var(--admin-card-shadow);
  border-radius: 12px;
  grid-template-columns: minmax(260px, 1fr);
  gap: 10px;
  padding: 12px;
  display: grid;
}

.admin-toolbar-card {
  border: 1px solid var(--admin-border);
  background: var(--admin-card-bg);
  box-shadow: var(--admin-card-shadow);
  border-radius: 12px;
  grid-template-columns: minmax(260px, 1fr) auto;
  align-items: end;
  gap: 8px;
  padding: 12px;
  display: grid;
}

.admin-toolbar-search {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-width: 0;
  display: grid;
}

.admin-toolbar-search-actions {
  grid-template-columns: minmax(0, 1fr) auto auto;
}

.admin-toolbar-controls {
  grid-template-columns: repeat(4, minmax(130px, 1fr)) minmax(96px, auto);
  align-items: end;
  gap: 8px;
  display: grid;
}

.admin-toolbar-field {
  align-items: start;
  gap: 6px;
  min-width: 0;
  display: grid;
}

.admin-toolbar-field-label {
  color: var(--admin-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  white-space: nowrap;
  font-size: 11px;
  font-weight: 600;
}

.admin-toolbar-select {
  min-width: 0;
  height: 36px;
}

.admin-toolbar-summary {
  white-space: nowrap;
  align-content: center;
  justify-items: end;
  gap: 2px;
  min-width: 96px;
  min-height: 36px;
  padding: 0 2px;
  display: grid;
}

.admin-toolbar-summary strong {
  color: var(--admin-text);
  font-size: 14px;
  font-weight: 650;
  line-height: 1;
}

@media (max-width: 900px) {
  .admin-toolbar-controls {
    grid-template-columns: repeat(2, minmax(130px, 1fr));
  }

  .admin-toolbar-summary {
    justify-items: start;
  }
}

@media (max-width: 560px) {
  .admin-toolbar-search, .admin-toolbar-search-actions, .admin-toolbar-card, .admin-toolbar-controls {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-toolbar-summary {
    justify-items: start;
  }
}

.admin-table-wrap {
  border: 1px solid var(--admin-border);
  background: var(--admin-card-bg);
  box-shadow: var(--admin-card-shadow);
  border-radius: 12px;
  overflow: hidden;
}

.admin-table-wrap > .admin-card-head {
  border-bottom: 1px solid var(--admin-border);
}

.admin-table {
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
  font-size: 13px;
}

.admin-table thead th {
  text-align: left;
  color: var(--admin-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
  background: var(--admin-surface-2);
  padding: 12px 16px;
  font-size: 11px;
  font-weight: 500;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-table thead th {
    background: color-mix(in srgb, var(--admin-surface-2) 72%, var(--admin-bg));
  }
}

.admin-table thead th {
  border-bottom: 1px solid var(--admin-border);
  white-space: nowrap;
}

.admin-table tbody td {
  border-bottom: 1px solid var(--admin-border);
  vertical-align: middle;
  color: var(--admin-text);
  padding: 12px 16px;
}

.admin-table tbody tr:last-child td {
  border-bottom: 0;
}

.admin-table tbody tr {
  transition: background 80ms;
}

.admin-table tbody tr:hover {
  background: #ffffff09;
}

.admin-table td.admin-cell-mono {
  font-family: var(--font-mono);
  font-size: 12px;
}

.admin-table td.admin-cell-actions {
  text-align: right;
  white-space: nowrap;
}

.admin-table td.admin-cell-wrap {
  white-space: normal;
  word-break: break-word;
  max-width: 320px;
  color: var(--admin-muted);
  font-size: 12px;
}

.admin-table td.admin-cell-id {
  color: var(--admin-muted);
  font-family: var(--font-mono);
  width: 80px;
  font-size: 12px;
}

.admin-table tbody tr.is-clickable {
  cursor: pointer;
}

.admin-user-list {
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
}

.admin-user-list > li {
  border-bottom: 1px solid var(--admin-border);
}

.admin-user-list > li:last-child {
  border-bottom: 0;
}

.admin-user-row {
  width: 100%;
  color: var(--admin-text);
  text-align: left;
  cursor: pointer;
  background: none;
  border: 0;
  grid-template-columns: 36px minmax(0, 1fr) minmax(72px, max-content) auto;
  align-items: center;
  gap: 12px;
  padding: 8px 14px;
  transition: background .12s;
  display: grid;
}

.admin-user-row:hover {
  background: var(--admin-elev);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-user-row:hover {
    background: color-mix(in srgb, var(--admin-elev) 60%, transparent);
  }
}

.admin-user-row:focus-visible {
  outline: 2px solid var(--admin-ring);
  outline-offset: -2px;
}

.admin-user-premium-col {
  justify-content: flex-end;
  align-items: center;
  min-width: 0;
  display: flex;
}

.admin-user-premium-badge {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  max-width: 148px;
  font-size: 11px;
  overflow: hidden;
}

.admin-user-premium-placeholder {
  color: var(--admin-dim);
  font-variant-numeric: tabular-nums;
  font-size: 12px;
}

.admin-user-side {
  white-space: nowrap;
  flex: none;
  align-items: center;
  gap: 10px;
  display: flex;
}

.admin-user-tertiary {
  color: var(--admin-dim);
  white-space: nowrap;
  font-size: 11px;
}

.admin-avatar.admin-avatar-sm {
  width: 36px;
  height: 36px;
  font-size: 11px;
}

@media (max-width: 480px) {
  .admin-user-tertiary {
    display: none;
  }

  .admin-user-row {
    gap: 10px;
  }
}

.admin-avatar {
  border: 1px solid var(--admin-border);
  background: var(--accent);
  border-radius: 8px;
  flex: none;
  place-items: center;
  width: 42px;
  height: 42px;
  display: inline-grid;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-avatar {
    background: color-mix(in srgb, var(--accent) 16%, var(--admin-surface-2));
  }
}

.admin-avatar {
  color: var(--accent);
  letter-spacing: 0;
  font-size: 12px;
  font-weight: 700;
}

.admin-avatar img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.admin-avatar-lg {
  width: 58px;
  height: 58px;
  font-size: 16px;
}

.admin-user-main, .admin-user-meta, .admin-user-profile-head > div {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.admin-user-main strong, .admin-user-profile-head strong {
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 650;
  overflow: hidden;
}

.admin-user-main small, .admin-user-profile-head small, .admin-user-meta span {
  color: var(--admin-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  overflow: hidden;
}

.admin-user-meta strong {
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 500;
  overflow: hidden;
}

.admin-user-status {
  justify-self: end;
}

.admin-user-profile-head {
  border-bottom: 1px solid var(--admin-border);
  align-items: center;
  gap: 12px;
  min-width: 0;
  padding-bottom: 12px;
  display: flex;
}

.admin-mini-list {
  gap: 0;
  display: grid;
}

.admin-mini-list-row {
  border-bottom: 1px solid var(--admin-border);
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 9px 0;
  display: grid;
}

.admin-mini-list-row:last-child {
  border-bottom: 0;
}

.admin-mini-list-row div {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.admin-mini-list-row strong {
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 600;
  overflow: hidden;
}

.admin-mini-list-row small {
  color: var(--admin-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  overflow: hidden;
}

.admin-pagination {
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 4px 0;
  display: flex;
}

.admin-pagination .admin-pagination-meta {
  color: var(--admin-muted);
  font-size: 12px;
}

.admin-pagination-buttons {
  gap: 6px;
  display: flex;
}

.admin-select {
  appearance: auto;
  width: 100%;
}

.admin-textarea, .admin-screen-wrap textarea, .admin-dialog textarea {
  border: 1px solid var(--admin-border-strong);
  background: var(--admin-bg);
  width: 100%;
  min-height: 110px;
  color: var(--admin-text);
  font: inherit;
  resize: vertical;
  border-radius: 10px;
  outline: none;
  padding: 12px;
  font-size: 13px;
  transition: border-color .12s, box-shadow .12s;
}

.admin-textarea:focus, .admin-dialog textarea:focus {
  border-color: var(--admin-ring);
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-textarea:focus, .admin-dialog textarea:focus {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
  }
}

.admin-form {
  gap: 12px;
  display: grid;
}

.admin-form-row {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
  display: grid;
}

.admin-form-row.admin-form-row-3 {
  grid-template-columns: minmax(180px, 1.1fr) minmax(160px, .8fr) minmax(140px, .6fr);
}

.admin-form label {
  color: var(--admin-muted);
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  display: grid;
}

.admin-form label > span {
  color: var(--admin-text);
  font-weight: 500;
}

.admin-form label > small {
  color: var(--admin-dim);
  font-weight: 400;
}

.admin-switch.admin-switch-field {
  align-self: end;
  min-height: 36px;
  display: flex;
}

.admin-skeleton {
  background: linear-gradient(90deg, var(--admin-surface-2) 0%, var(--admin-elev) 50%, var(--admin-surface-2) 100%);
  display: inline-block;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-skeleton {
    background: linear-gradient(90deg, var(--admin-surface-2) 0%, color-mix(in srgb, var(--admin-elev) 65%, transparent) 50%, var(--admin-surface-2) 100%);
  }
}

.admin-skeleton {
  background-size: 200% 100%;
  border-radius: 6px;
  animation: 1.2s ease-in-out infinite admin-skeleton-shimmer;
}

.admin-skeleton-line {
  border-radius: 4px;
  width: 100%;
  height: 10px;
  display: block;
}

.admin-skeleton-line-strong {
  width: 60%;
  height: 12px;
}

.admin-skeleton-line-soft {
  opacity: .7;
  width: 40%;
  height: 9px;
}

.admin-skeleton-line-short {
  width: 50%;
}

.admin-skeleton-line-tiny {
  width: 32%;
}

.admin-skeleton-avatar {
  border-radius: 50%;
  width: 36px;
  height: 36px;
}

.admin-skeleton-badge {
  border-radius: 999px;
  width: 64px;
  height: 18px;
}

.admin-user-row-skeleton {
  cursor: default;
  pointer-events: none;
}

.admin-user-row-skeleton .admin-user-main {
  gap: 6px;
  display: grid;
}

.admin-user-row-skeleton .admin-user-side {
  gap: 8px;
}

.admin-table-skeleton td {
  padding: 12px 16px;
}

@keyframes admin-skeleton-shimmer {
  0% {
    background-position: 100% 0;
  }

  100% {
    background-position: -100% 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .admin-skeleton {
    animation: none;
  }
}

.admin-detail-grid {
  grid-template-columns: 1fr;
  gap: 14px;
  display: grid;
}

@media (min-width: 900px) {
  .admin-detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.admin-meta-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
}

.admin-meta-list li {
  border-bottom: 1px solid var(--admin-border);
  grid-template-columns: 130px minmax(0, 1fr);
  align-items: baseline;
  gap: 12px;
  padding: 8px 0;
  font-size: 13px;
  display: grid;
}

.admin-meta-list li:last-child {
  border-bottom: 0;
}

.admin-meta-list li > span {
  color: var(--admin-muted);
  font-size: 12px;
}

.admin-meta-list li > strong {
  color: var(--admin-text);
  word-break: break-word;
  font-weight: 500;
}

.admin-accordion {
  gap: 10px;
  display: grid;
}

.admin-accordion-item.admin-card {
  min-width: 0;
  display: block;
}

.admin-accordion-header {
  margin: 0;
  display: block;
}

.admin-accordion-trigger {
  appearance: none;
  text-align: left;
  color: var(--admin-text);
  cursor: pointer;
  font: inherit;
  background: none;
  border: 0;
  outline: none;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 18px;
  transition: background .12s;
  display: grid;
}

.admin-accordion-trigger:hover {
  background: var(--admin-surface-2);
}

.admin-accordion-trigger:focus-visible {
  background: var(--admin-surface-2);
  box-shadow: inset 0 0 0 2px var(--admin-ring);
}

.admin-accordion-trigger[data-state="open"] {
  border-bottom: 1px solid var(--admin-border);
}

.admin-accordion-title {
  color: var(--admin-text);
  text-transform: capitalize;
  word-break: break-word;
  min-width: 0;
  font-size: 13px;
  font-weight: 600;
}

.admin-accordion-meta {
  color: var(--admin-muted);
  white-space: nowrap;
  text-overflow: ellipsis;
  max-width: 100%;
  font-size: 12px;
  overflow: hidden;
}

.admin-accordion-chev {
  color: var(--admin-muted);
  flex: none;
  transition: transform .2s;
}

.admin-accordion-trigger[data-state="open"] .admin-accordion-chev {
  transform: rotate(90deg);
}

.admin-accordion-content {
  overflow: hidden;
}

.admin-accordion-content[data-state="closed"] {
  display: none;
}

@media (max-width: 720px) {
  .admin-accordion-trigger {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas: "title chev"
                         "meta meta";
    gap: 8px;
    padding: 12px 14px;
  }

  .admin-accordion-title {
    grid-area: title;
  }

  .admin-accordion-chev {
    grid-area: chev;
  }

  .admin-accordion-meta {
    white-space: normal;
    grid-area: meta;
    font-size: 11px;
  }
}

.admin-setting {
  border-bottom: 1px solid var(--admin-border);
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  align-items: center;
  gap: 24px;
  padding: 16px 18px;
  display: grid;
}

.admin-setting:last-child {
  border-bottom: 0;
}

.admin-setting.is-overridden {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-setting.is-overridden {
    background: color-mix(in srgb, var(--accent) 5%, transparent);
  }
}

.admin-setting-meta {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.admin-setting-meta strong {
  color: var(--admin-text);
  word-break: break-word;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  display: inline-flex;
}

.admin-setting-meta code {
  font-family: var(--font-mono);
  color: var(--admin-dim);
  word-break: break-all;
  overflow-wrap: anywhere;
  font-size: 11px;
}

.admin-setting-meta small {
  color: var(--admin-muted);
  overflow-wrap: anywhere;
  font-size: 12px;
  line-height: 1.5;
}

.admin-setting-control {
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-width: 0;
  display: flex;
}

.admin-setting-control .admin-color {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  cursor: pointer;
  border-radius: 8px;
  flex: 0 0 36px;
  width: 36px;
  height: 36px;
  padding: 0;
}

.admin-setting-switch {
  min-height: 36px;
  color: var(--admin-text);
  align-items: center;
  gap: 10px;
  font-size: 12px;
  font-weight: 500;
  display: inline-flex;
}

.admin-tabs {
  border-bottom: 1px solid var(--admin-border);
  gap: 2px;
  display: inline-flex;
}

.admin-tabs button {
  color: var(--admin-muted);
  cursor: pointer;
  background: none;
  border: 0;
  border-bottom: 2px solid #0000;
  margin-bottom: -1px;
  padding: 9px 12px;
  font-size: 13px;
  font-weight: 500;
}

.admin-tabs button.active {
  color: var(--admin-text);
  border-bottom-color: var(--accent);
}

.admin-dialog {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  width: min(100%, 520px);
  max-height: 100%;
  overflow-y: auto;
}

.admin-dialog.admin-dialog-compact {
  width: min(100%, 400px);
}

.admin-dialog-compact .admin-dialog-form-section {
  gap: 12px;
  display: grid;
}

.admin-dialog-compact .admin-dialog-form-section + .admin-dialog-form-section {
  border-top: 1px solid var(--admin-border);
  margin-top: 2px;
  padding-top: 14px;
}

.admin-user-dialog {
  width: min(100%, 1040px);
  max-height: min(100%, 760px);
}

.admin-user-dialog-body {
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  min-width: 0;
  display: grid;
}

.admin-user-aside {
  flex-direction: column;
  gap: 12px;
  min-width: 0;
  display: flex;
}

.admin-user-main {
  flex-direction: column;
  min-width: 0;
  display: flex;
}

.admin-user-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  display: grid;
}

.admin-user-stat {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 10px;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  padding: 10px 12px;
  display: flex;
}

.admin-user-stat span {
  color: var(--admin-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 11px;
  font-weight: 600;
}

.admin-user-stat strong {
  color: var(--admin-text);
  word-break: break-word;
  font-size: 15px;
  font-weight: 700;
}

.admin-link-list {
  flex-direction: column;
  gap: 6px;
  display: flex;
}

.admin-link-row {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 8px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 8px 10px;
  display: grid;
}

.admin-link-row-meta {
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  display: flex;
}

.admin-link-row-label {
  color: var(--admin-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 11px;
  font-weight: 600;
}

.admin-link-row-url {
  color: var(--admin-text);
  font-family: var(--font-mono);
  white-space: nowrap;
  text-overflow: ellipsis;
  min-width: 0;
  font-size: 11px;
  text-decoration: none;
  overflow: hidden;
}

.admin-link-row-url:hover {
  color: var(--accent);
  text-decoration: underline;
}

.admin-meta-truncate {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.admin-traffic-summary {
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  display: grid;
}

.admin-traffic-card {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 10px;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
  padding: 12px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-traffic-card {
    background: color-mix(in srgb, var(--admin-surface-2) 54%, var(--admin-bg));
  }
}

.admin-traffic-card-premium {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-traffic-card-premium {
    border-color: color-mix(in srgb, var(--accent) 30%, var(--admin-border));
  }
}

.admin-traffic-card-warning {
  border-color: #ffb454;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-traffic-card-warning {
    border-color: color-mix(in srgb, #ffb454 46%, var(--admin-border));
  }
}

.admin-traffic-head, .admin-traffic-meta {
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  min-width: 0;
  display: flex;
}

.admin-traffic-head span {
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 600;
}

.admin-traffic-head strong {
  color: var(--admin-text);
  text-align: right;
  font-size: 13px;
  font-weight: 700;
}

.admin-traffic-bar {
  background: var(--admin-bg);
  height: 8px;
  box-shadow: inset 0 0 0 1px var(--admin-border);
  border-radius: 999px;
  overflow: hidden;
}

.admin-traffic-bar span {
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent));
  max-width: 100%;
  height: 100%;
  display: block;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-traffic-bar span {
    background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 55%, #fff));
  }
}

.admin-traffic-bar-premium span {
  background: linear-gradient(90deg, #66e3ff, var(--accent));
}

.admin-traffic-card-warning .admin-traffic-bar span {
  background: linear-gradient(90deg, #ffb454, #ff6b6b);
}

.admin-traffic-meta {
  color: var(--admin-muted);
  font-size: 11px;
  font-weight: 600;
}

@media (min-width: 860px) {
  .admin-user-dialog-body {
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    align-items: start;
    gap: 20px;
  }

  .admin-user-aside {
    position: sticky;
    top: 0;
  }
}

.admin-tariff-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  display: grid;
}

@media (min-width: 720px) {
  .admin-tariff-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1280px) {
  .admin-tariff-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.admin-tariff-card {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 8px;
  gap: 12px;
  min-width: 0;
  padding: 14px;
  display: grid;
}

.admin-tariff-card.is-disabled {
  opacity: .72;
}

.admin-tariff-top, .admin-tariff-title, .admin-tariff-actions, .admin-editor-section-head {
  align-items: center;
  gap: 8px;
  display: flex;
}

.admin-tariff-top {
  justify-content: space-between;
}

.admin-tariff-title {
  flex-wrap: wrap;
  min-width: 0;
}

.admin-tariff-title strong {
  color: var(--admin-text);
  font-size: 15px;
}

.admin-tariff-card code {
  color: var(--admin-dim);
  font-family: var(--font-mono);
  margin-top: 4px;
  font-size: 11px;
  display: block;
}

.admin-tariff-card p {
  color: var(--admin-muted);
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
}

.admin-tariff-facts {
  color: var(--admin-muted);
  gap: 6px;
  font-size: 12px;
  display: grid;
}

.admin-tariff-facts span {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.admin-tariff-actions {
  flex-wrap: wrap;
}

.admin-tariff-dialog {
  width: min(980px, 100vw - 32px);
}

.admin-editor-section {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 8px;
  gap: 10px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-editor-section {
    background: color-mix(in srgb, var(--admin-surface-2) 62%, transparent);
  }
}

.admin-editor-section {
  padding: 12px;
}

.admin-editor-section-head {
  justify-content: space-between;
  min-height: 28px;
}

.admin-editor-section-head strong {
  color: var(--admin-text);
  font-size: 13px;
}

.admin-editor-section-head > div {
  flex-wrap: wrap;
  gap: 6px;
  display: flex;
}

.admin-editor-section-head > .admin-editor-section-title {
  flex-direction: column;
  flex: 200px;
  gap: 2px;
  min-width: 0;
  display: flex;
}

.admin-editor-section-head > .admin-editor-section-title small {
  color: var(--admin-muted);
  text-transform: none;
  letter-spacing: 0;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.4;
}

.admin-row-editor-line.admin-row-editor-header {
  color: var(--admin-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 0 4px;
  font-size: 11px;
  font-weight: 600;
}

.admin-row-editor-line.admin-row-editor-header span {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.admin-row-editor {
  gap: 8px;
  min-width: 0;
  display: grid;
}

.admin-row-editor-line {
  grid-template-columns: minmax(90px, 1fr) minmax(110px, 1fr) 32px;
  align-items: center;
  gap: 8px;
  display: grid;
}

.admin-row-editor-line.admin-row-editor-4 {
  grid-template-columns: minmax(80px, .8fr) minmax(100px, 1fr) minmax(100px, 1fr) 32px;
}

.admin-package-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  display: grid;
}

.admin-dialog-actions {
  justify-content: flex-end;
  gap: 8px;
  padding-top: 2px;
  display: flex;
}

@media (max-width: 1023px) {
  .admin-screen-wrap {
    --admin-header-h: 56px;
  }

  .admin-sidebar {
    z-index: 80;
    flex: none;
    width: 280px;
    transition: transform .22s;
    position: fixed;
    inset: 0 auto 0 0;
    transform: translateX(-100%);
    box-shadow: 0 32px 80px #0009;
  }

  .admin-screen-wrap.is-sidebar-open .admin-sidebar {
    transform: translateX(0);
  }

  .admin-sidebar-backdrop {
    z-index: 70;
    cursor: pointer;
    background: #00000080;
    border: 0;
    position: fixed;
    inset: 0;
  }

  .admin-mobile-toggle {
    display: inline-flex;
  }

  .admin-header {
    min-height: var(--admin-header-h);
    grid-template-columns: minmax(0, 1fr);
    grid-auto-rows: auto;
    grid-auto-flow: row;
    align-content: center;
    gap: 6px;
    padding: 8px 16px;
  }

  .admin-header-actions {
    scrollbar-width: none;
    padding-bottom: 2px;
    overflow-x: auto;
  }

  .admin-header-actions::-webkit-scrollbar {
    display: none;
  }

  .admin-main {
    padding: 16px;
  }
}

@media (max-width: 720px) {
  .admin-setting {
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
    padding: 14px;
  }

  .admin-card-head {
    padding: 12px 14px;
  }

  .admin-card-body {
    padding: 14px;
  }

  .admin-tariff-card {
    padding: 12px;
  }

  .admin-tariff-actions .admin-btn {
    flex: calc(50% - 4px);
  }

  .admin-tariff-actions .admin-btn[aria-label] {
    flex: none;
  }

  .admin-user-meta strong {
    font-size: 11px;
  }

  .admin-form-row.admin-form-row-3, .admin-package-columns, .admin-row-editor-line, .admin-row-editor-line.admin-row-editor-4 {
    grid-template-columns: 1fr;
  }

  .admin-dialog-actions {
    flex-direction: column-reverse;
    justify-content: stretch;
  }

  .admin-dialog-actions .admin-btn {
    width: 100%;
  }

  .admin-table thead {
    display: none;
  }

  .admin-table tbody td {
    border: 0;
    padding: 6px 16px;
    display: block;
  }

  .admin-table tbody tr {
    border-bottom: 1px solid var(--admin-border);
    padding: 10px 0;
    display: block;
  }

  .admin-table tbody tr:last-child {
    border-bottom: 0;
  }

  .admin-table tbody td:before {
    content: attr(data-label);
    min-width: 110px;
    color: var(--admin-muted);
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-right: 8px;
    font-size: 11px;
    display: inline-block;
  }

  .admin-table td.admin-cell-actions {
    text-align: left;
  }
}

.settings-admin-block {
  gap: 10px;
  margin: 6px 0 0;
  display: grid;
}

.settings-row.settings-row-admin {
  border-radius: var(--radius);
  cursor: pointer;
  background: #f59e0b1f;
  border: 1px solid #f59e0b6b;
  width: 100%;
  padding: 10px 12px;
  transition: background .12s, border-color .12s;
}

.settings-row.settings-row-admin:hover {
  background: #f59e0b2e;
  border-color: #f59e0b94;
}

.settings-row.settings-row-admin > svg:first-child {
  color: #fbbf24;
  opacity: 1;
}

.settings-row.settings-row-admin strong {
  color: var(--text);
}

.admin-tabs-root {
  flex-direction: column;
  gap: 14px;
  min-width: 0;
  display: flex;
}

.admin-tabs-list {
  background: var(--admin-surface-2);
  border: 1px solid var(--admin-border);
  scrollbar-width: none;
  border-radius: 10px;
  flex: none;
  align-items: center;
  gap: 4px;
  padding: 4px;
  display: inline-flex;
  overflow-x: auto;
}

.admin-tabs-list::-webkit-scrollbar {
  display: none;
}

.admin-tabs-trigger {
  appearance: none;
  color: var(--admin-muted);
  font: inherit;
  cursor: pointer;
  white-space: nowrap;
  background: none;
  border: 0;
  border-radius: 7px;
  outline: none;
  padding: 7px 14px;
  font-size: 13px;
  font-weight: 500;
  transition: background .12s, color .12s, box-shadow .12s;
}

.admin-tabs-trigger:hover {
  color: var(--admin-text);
}

.admin-tabs-trigger[data-state="active"] {
  background: var(--admin-surface);
  color: var(--admin-text);
  box-shadow: 0 1px 2px #0006;
}

.admin-tabs-trigger:focus-visible {
  box-shadow: 0 0 0 2px var(--admin-ring);
}

.admin-tabs-content {
  outline: none;
  flex-direction: column;
  gap: 14px;
  display: flex;
}

.admin-tabs-content[data-state="inactive"] {
  display: none;
}

.admin-user-tabs-root {
  gap: 0;
}

.admin-user-tabs-root .admin-tabs-list {
  background: var(--admin-surface-2);
  border-radius: 10px 10px 0 0;
  gap: 2px;
  padding: 4px 4px 0;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-user-tabs-root .admin-tabs-list {
    background: color-mix(in srgb, var(--admin-surface-2) 74%, var(--admin-bg));
  }
}

.admin-user-tabs-root .admin-tabs-list {
  border-bottom: 0;
  width: fit-content;
  max-width: 100%;
}

.admin-user-tabs-root .admin-tabs-trigger {
  border-radius: 7px 7px 0 0;
  padding: 8px 14px 9px;
}

.admin-user-tabs-root .admin-tabs-trigger[data-state="active"] {
  z-index: 1;
  box-shadow: 0 -1px 0 var(--admin-border), 1px 0 0 var(--admin-border), -1px 0 0 var(--admin-border), 0 1px 0 var(--admin-surface);
  position: relative;
}

.admin-user-tabs-root .admin-tabs-content {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 0 10px 10px;
  margin-top: -1px;
  padding: 16px;
}

.admin-switch-root {
  appearance: none;
  border: 1px solid var(--admin-border);
  background: var(--admin-elev);
  cursor: pointer;
  border-radius: 999px;
  outline: none;
  flex: none;
  align-items: center;
  width: 40px;
  height: 22px;
  padding: 0;
  transition: background .18s, border-color .18s;
  display: inline-flex;
  position: relative;
}

.admin-switch-root[data-state="checked"] {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-switch-root[data-state="checked"] {
    background: color-mix(in srgb, var(--accent) 80%, var(--admin-elev));
  }
}

.admin-switch-root[data-state="checked"] {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-switch-root[data-state="checked"] {
    border-color: color-mix(in srgb, var(--accent) 50%, transparent);
  }
}

.admin-switch-root:focus-visible {
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-switch-root:focus-visible {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 30%, transparent);
  }
}

.admin-switch-root:disabled {
  opacity: .5;
  cursor: not-allowed;
}

.admin-switch-thumb {
  background: #fff;
  border-radius: 999px;
  width: 16px;
  height: 16px;
  margin-left: 2px;
  transition: transform .18s;
  display: block;
  box-shadow: 0 1px 3px #0006;
}

.admin-switch-root[data-state="checked"] .admin-switch-thumb {
  transform: translateX(18px);
}

.admin-select-trigger {
  border: 1px solid var(--admin-border-strong);
  background: var(--admin-bg);
  border-radius: 10px;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  width: 100%;
  height: 36px;
  padding: 0 12px;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-select-trigger {
    background: color-mix(in srgb, var(--admin-bg) 82%, var(--admin-surface-2));
  }
}

.admin-select-trigger {
  color: var(--admin-text);
  font: inherit;
  cursor: pointer;
  text-align: left;
  outline: none;
  font-size: 13px;
  transition: border-color .12s, box-shadow .12s;
}

.admin-select-trigger:hover {
  border-color: var(--admin-border-strong);
}

.admin-select-trigger:focus-visible, .admin-select-trigger[data-state="open"] {
  border-color: var(--admin-ring);
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-select-trigger:focus-visible, .admin-select-trigger[data-state="open"] {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
  }
}

.admin-select-icon {
  color: var(--admin-muted);
  flex: none;
  transition: transform .18s;
}

.admin-select-trigger[data-state="open"] .admin-select-icon {
  transform: rotate(180deg);
}

.admin-select-content {
  z-index: 90;
  min-width: var(--bits-select-anchor-width);
  max-height: var(--bits-select-content-available-height, 320px);
  border: 1px solid var(--admin-border);
  background: linear-gradient(135deg, #ffffff0e, #ffffff05), var(--admin-surface);
  border-radius: 10px;
  outline: none;
  flex-direction: column;
  gap: 1px;
  padding: 4px;
  display: flex;
  overflow-y: auto;
  box-shadow: 0 16px 36px #00000073;
}

.admin-select-item {
  color: var(--admin-text);
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
  border-radius: 7px;
  outline: none;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  font-size: 13px;
  display: flex;
}

.admin-select-item[data-highlighted], .admin-select-item:hover {
  background: var(--admin-surface-2);
}

.admin-select-item-check {
  color: var(--accent);
  opacity: 0;
}

.admin-select-item[data-state="checked"] .admin-select-item-check {
  opacity: 1;
}

.admin-chip-list {
  flex-wrap: wrap;
  gap: 6px;
  min-height: 0;
  display: flex;
}

.admin-chip {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  max-width: 100%;
  min-height: 28px;
  color: var(--admin-text);
  font: inherit;
  cursor: pointer;
  border-radius: 8px;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  font-size: 12px;
  display: inline-flex;
}

.admin-chip:hover {
  border-color: var(--admin-border-strong);
}

.admin-field-label {
  color: var(--admin-muted);
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  font-size: 12px;
  font-weight: 500;
  display: flex;
}

.admin-field-label > span {
  color: var(--admin-text);
  font-size: 13px;
  font-weight: 500;
}

.admin-field-label > small {
  color: var(--admin-dim);
  font-size: 12px;
  font-weight: 400;
  line-height: 1.45;
}

.admin-field-label > small code, .admin-editor-section-title small code {
  background: var(--admin-elev);
  border-radius: 4px;
  padding: 0 4px;
  display: inline-block;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-field-label > small code, .admin-editor-section-title small code {
    background: color-mix(in srgb, var(--admin-elev) 70%, transparent);
  }
}

.admin-field-label > small code, .admin-editor-section-title small code {
  color: var(--admin-text);
  font-family: var(--font-mono);
  font-size: 11px;
}

.admin-field-label > small b, .admin-editor-section-title small b {
  color: var(--admin-text);
  font-weight: 600;
}

.admin-action-row {
  align-items: center;
  gap: 12px;
  min-width: 0;
  padding: 10px 0;
  display: flex;
}

.admin-action-row-bordered {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 10px;
  padding: 12px 14px;
}

.admin-action-label {
  min-width: 0;
  color: var(--admin-text);
  cursor: pointer;
  flex-direction: column;
  gap: 2px;
  font-size: 13px;
  display: flex;
}

.admin-action-label > strong {
  font-weight: 600;
}

.admin-action-label > small {
  color: var(--admin-muted);
  font-size: 12px;
  line-height: 1.4;
}

.admin-action-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: end;
  gap: 10px;
  display: grid;
}

.admin-user-quick-actions {
  grid-template-columns: minmax(180px, .75fr) minmax(260px, 1.25fr);
  align-items: end;
  gap: 12px;
  display: grid;
}

.admin-reset-trial-btn {
  width: 100%;
  height: 36px;
}

.admin-extend-field {
  gap: 6px;
  min-width: 0;
}

.admin-action-inline-field {
  gap: 6px;
}

.admin-extend-control {
  border: 1px solid var(--admin-border-strong);
  background: var(--admin-bg);
  border-radius: 8px;
  grid-template-columns: minmax(72px, 1fr) auto;
  align-items: stretch;
  min-width: 0;
  height: 36px;
  display: grid;
  overflow: hidden;
}

.admin-extend-control:focus-within {
  border-color: var(--admin-ring);
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-extend-control:focus-within {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
  }
}

.admin-input-row {
  grid-template-columns: minmax(72px, 1fr) auto;
  align-items: stretch;
  gap: 8px;
  min-width: 0;
  display: grid;
}

.admin-message-actions {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 8px;
  display: grid;
}

.admin-confirm-message-preview {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  max-height: min(280px, 45vh);
  color: var(--admin-text);
  white-space: pre-wrap;
  word-break: break-word;
  border-radius: 10px;
  padding: 12px 14px;
  font-size: 13px;
  line-height: 1.45;
  overflow: auto;
}

@media (max-width: 640px) {
  .admin-action-grid, .admin-user-quick-actions, .admin-message-actions, .admin-input-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-extend-control {
    grid-template-columns: minmax(0, 1fr);
    height: auto;
  }

  .admin-extend-control .input, .admin-extend-control .admin-btn {
    height: 36px;
  }

  .admin-extend-control .admin-btn {
    border-width: 1px 0 0;
  }
}

.admin-form-row.admin-form-row-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 720px) {
  .admin-form-row.admin-form-row-2 {
    grid-template-columns: minmax(0, 1fr);
  }
}

.admin-user-summary {
  background: var(--admin-surface-2);
  border: 1px solid var(--admin-border);
  border-radius: 12px;
  grid-template-columns: 56px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  min-width: 0;
  padding: 14px 14px 16px;
  display: grid;
}

.admin-user-summary-meta {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.admin-user-summary-meta strong {
  color: var(--admin-text);
  word-break: break-word;
  font-size: 15px;
  font-weight: 700;
}

.admin-user-summary-meta small {
  color: var(--admin-muted);
  word-break: break-word;
  font-size: 12px;
}

.admin-user-summary-tags {
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
  display: flex;
}

.admin-avatar.admin-avatar-lg {
  background: var(--accent);
  border-radius: 16px;
  place-items: center;
  width: 56px;
  height: 56px;
  display: grid;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-avatar.admin-avatar-lg {
    background: color-mix(in srgb, var(--accent) 18%, var(--admin-surface));
  }
}

.admin-avatar.admin-avatar-lg {
  color: var(--accent);
  flex: none;
  font-size: 18px;
  font-weight: 700;
}

.admin-avatar.admin-avatar-lg img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
}

.admin-subsection-title {
  color: var(--admin-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 12px;
  font-weight: 600;
}

.admin-separator {
  background: var(--admin-border);
  border: 0;
  height: 1px;
  margin: 4px 0;
}

.admin-editor-section-actions {
  flex-wrap: wrap;
  gap: 6px;
  display: flex;
}

.admin-row-editor-caption {
  color: var(--admin-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 11px;
  font-weight: 600;
}

.admin-danger-zone {
  background: #ff6b6b;
  border: 1px solid #ff6b6b52;
  border-radius: 12px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-danger-zone {
    background: color-mix(in srgb, #ff6b6b 6%, var(--admin-surface));
  }
}

.admin-danger-zone {
  flex-direction: column;
  gap: 12px;
  margin-top: 4px;
  padding: 14px 16px;
  display: flex;
}

.admin-danger-zone-head {
  flex-direction: column;
  gap: 2px;
  display: flex;
}

.admin-danger-zone-head strong {
  color: #ffb4b4;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 13px;
  font-weight: 700;
}

.admin-danger-zone-head small {
  color: #ffb4b4;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-danger-zone-head small {
    color: color-mix(in srgb, #ffb4b4 70%, var(--admin-muted));
  }
}

.admin-danger-zone-head small {
  font-size: 12px;
  line-height: 1.45;
}

.admin-subsection-accordion {
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
  display: flex;
}

.admin-settings-subsection {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 10px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-settings-subsection {
    background: color-mix(in srgb, var(--admin-surface-2) 40%, transparent);
  }
}

.admin-settings-subsection {
  overflow: hidden;
}

.admin-settings-subsection-trigger {
  appearance: none;
  text-align: left;
  width: 100%;
  color: var(--admin-text);
  font: inherit;
  cursor: pointer;
  background: none;
  border: 0;
  outline: none;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  transition: background .12s;
  display: grid;
}

.admin-settings-subsection-trigger:hover {
  background: var(--admin-surface);
}

.admin-settings-subsection-trigger[data-state="open"] {
  background: var(--admin-surface);
  border-bottom: 1px solid var(--admin-border);
}

.admin-settings-subsection-trigger:focus-visible {
  background: var(--admin-surface);
  box-shadow: inset 0 0 0 2px var(--admin-ring);
}

.admin-settings-subsection-trigger strong {
  color: var(--admin-text);
  text-transform: uppercase;
  letter-spacing: .06em;
  min-width: 0;
  font-size: 12px;
  font-weight: 700;
}

.admin-settings-subsection-meta {
  color: var(--admin-muted);
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 11px;
  overflow: hidden;
}

.admin-settings-subsection-trigger .admin-accordion-chev {
  color: var(--admin-muted);
  flex: none;
  transition: transform .18s;
}

.admin-settings-subsection-trigger[data-state="open"] .admin-accordion-chev {
  transform: rotate(90deg);
}

.admin-settings-subsection-body .admin-setting:last-child {
  border-bottom: 0;
}

@media (max-width: 720px) {
  .admin-settings-subsection-trigger {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas: "title chev"
                         "meta meta";
    row-gap: 4px;
    padding: 9px 12px;
  }

  .admin-settings-subsection-trigger strong {
    grid-area: title;
  }

  .admin-settings-subsection-trigger .admin-accordion-chev {
    grid-area: chev;
  }

  .admin-settings-subsection-meta {
    white-space: normal;
    grid-area: meta;
  }
}

.admin-toolbar-search .input, .admin-toolbar-search .admin-btn {
  height: 36px;
}

.admin-toolbar > .input, .admin-toolbar input[type="text"], .admin-toolbar input[type="number"], .admin-toolbar input[type="search"] {
  flex: 200px;
  min-width: 180px;
}

.admin-toolbar > .admin-btn {
  height: 36px;
}

.admin-table td.admin-cell-actions .admin-btn {
  margin-left: 4px;
}

.admin-screen-wrap input, .admin-screen-wrap textarea, .admin-screen-wrap select, .admin-screen-wrap .input, .admin-dialog input, .admin-dialog textarea, .admin-dialog select, .admin-dialog .input {
  min-width: 0;
  max-width: 100%;
}

.admin-screen-wrap .input, .admin-screen-wrap input[type="text"], .admin-screen-wrap input[type="number"], .admin-screen-wrap input[type="email"], .admin-screen-wrap input[type="search"], .admin-screen-wrap input[type="password"], .admin-screen-wrap input[type="url"], .admin-screen-wrap select, .admin-dialog .input, .admin-dialog input[type="text"], .admin-dialog input[type="number"], .admin-dialog input[type="email"], .admin-dialog input[type="search"], .admin-dialog input[type="password"], .admin-dialog input[type="url"], .admin-dialog select {
  border: 1px solid var(--admin-border-strong);
  background: var(--admin-bg);
  border-radius: 8px;
  height: 36px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-screen-wrap .input, .admin-screen-wrap input[type="text"], .admin-screen-wrap input[type="number"], .admin-screen-wrap input[type="email"], .admin-screen-wrap input[type="search"], .admin-screen-wrap input[type="password"], .admin-screen-wrap input[type="url"], .admin-screen-wrap select, .admin-dialog .input, .admin-dialog input[type="text"], .admin-dialog input[type="number"], .admin-dialog input[type="email"], .admin-dialog input[type="search"], .admin-dialog input[type="password"], .admin-dialog input[type="url"], .admin-dialog select {
    background: color-mix(in srgb, var(--admin-bg) 82%, var(--admin-surface-2));
  }
}

.admin-screen-wrap .input, .admin-screen-wrap input[type="text"], .admin-screen-wrap input[type="number"], .admin-screen-wrap input[type="email"], .admin-screen-wrap input[type="search"], .admin-screen-wrap input[type="password"], .admin-screen-wrap input[type="url"], .admin-screen-wrap select, .admin-dialog .input, .admin-dialog input[type="text"], .admin-dialog input[type="number"], .admin-dialog input[type="email"], .admin-dialog input[type="search"], .admin-dialog input[type="password"], .admin-dialog input[type="url"], .admin-dialog select {
  color: var(--admin-text);
  outline: none;
  padding: 0 12px;
  font-size: 13px;
  transition: border-color .12s, box-shadow .12s;
}

.admin-screen-wrap .input::placeholder, .admin-screen-wrap input::placeholder, .admin-screen-wrap textarea::placeholder, .admin-dialog .input::placeholder, .admin-dialog input::placeholder, .admin-dialog textarea::placeholder {
  color: var(--admin-dim);
}

.admin-screen-wrap .input:focus, .admin-screen-wrap input:focus, .admin-screen-wrap select:focus, .admin-dialog .input:focus, .admin-dialog input:focus, .admin-dialog select:focus {
  border-color: var(--admin-ring);
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-screen-wrap .input:focus, .admin-screen-wrap input:focus, .admin-screen-wrap select:focus, .admin-dialog .input:focus, .admin-dialog input:focus, .admin-dialog select:focus {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
  }
}

.admin-btn {
  border: 1px solid var(--admin-border);
  background: linear-gradient(135deg, #ffffff0d, #ffffff04), var(--admin-surface-2);
  height: 34px;
  color: var(--admin-text);
  cursor: pointer;
  white-space: nowrap;
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  gap: 6px;
  padding: 0 14px;
  font-size: 13px;
  font-weight: 500;
  transition: background .12s, border-color .12s, color .12s;
  display: inline-flex;
}

.admin-btn:hover:not(:disabled) {
  background: linear-gradient(135deg, #fff1, #ffffff05), var(--admin-elev);
  border-color: var(--admin-border-strong);
}

.admin-btn:disabled {
  opacity: .5;
  cursor: not-allowed;
}

.admin-btn.admin-btn-primary {
  background: var(--accent);
  color: #02110a;
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-btn.admin-btn-primary {
    border-color: color-mix(in srgb, var(--accent) 70%, #000);
  }
}

.admin-btn.admin-btn-primary {
  font-weight: 600;
}

.admin-btn.admin-btn-primary:hover:not(:disabled) {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-btn.admin-btn-primary:hover:not(:disabled) {
    background: color-mix(in srgb, var(--accent) 90%, #fff);
  }
}

.admin-btn.admin-btn-ghost {
  color: var(--admin-muted);
  background: none;
  border-color: #0000;
}

.admin-btn.admin-btn-ghost:hover:not(:disabled) {
  color: var(--admin-text);
  background: #ffffff0a;
}

.admin-btn.admin-btn-danger {
  color: #fff;
  background: #cc4646;
  border-color: #993434;
  font-weight: 600;
}

.admin-btn.admin-btn-danger:hover:not(:disabled) {
  background: #ff5757;
  border-color: #ff5757;
}

.admin-btn.admin-btn-danger-soft {
  color: #ffb4b4;
  background: var(--admin-surface-2);
  border-color: #ff6b6b4d;
}

.admin-btn.admin-btn-danger-soft:hover:not(:disabled) {
  background: #ff6b6b;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-btn.admin-btn-danger-soft:hover:not(:disabled) {
    background: color-mix(in srgb, #ff6b6b 14%, var(--admin-surface));
  }
}

.admin-btn.admin-btn-danger-soft:hover:not(:disabled) {
  border-color: #ff6b6b80;
}

.admin-btn.admin-btn-icon {
  width: 34px;
  padding: 0;
}

.admin-btn.admin-btn-sm {
  border-radius: 6px;
  height: 28px;
  padding: 0 10px;
  font-size: 12px;
}

.admin-badge {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  color: var(--admin-muted);
  white-space: nowrap;
  border-radius: 999px;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 600;
  display: inline-flex;
}

.admin-badge.admin-badge-success {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-badge.admin-badge-success {
    border-color: color-mix(in srgb, var(--accent) 36%, transparent);
  }
}

.admin-badge.admin-badge-success {
  color: var(--accent);
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-badge.admin-badge-success {
    background: color-mix(in srgb, var(--accent) 12%, var(--admin-surface));
  }
}

.admin-badge.admin-badge-danger {
  color: #ffb4b4;
  background: #ff6b6b;
  border-color: #ff6b6b52;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-badge.admin-badge-danger {
    background: color-mix(in srgb, #ff6b6b 12%, var(--admin-surface));
  }
}

.admin-badge.admin-badge-warning {
  color: #ffd166;
  background: #ffd166;
  border-color: #ffd16652;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-badge.admin-badge-warning {
    background: color-mix(in srgb, #ffd166 12%, var(--admin-surface));
  }
}

.admin-badge.admin-badge-muted {
  color: var(--admin-muted);
}

.admin-setting-control .input, .admin-setting-control .admin-setting-select, .admin-setting-control input[type="text"], .admin-setting-control input[type="number"] {
  flex: 160px;
  width: 100%;
  min-width: 0;
}

.admin-btn.admin-btn-icon {
  flex: none;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  padding: 0;
  display: inline-flex;
}

.admin-row-editor-line .admin-btn {
  width: 32px;
  padding: 0;
}

.admin-action-grid > .admin-btn {
  align-self: end;
  width: 100%;
  height: 36px;
}

.admin-extend-control .input {
  height: 100%;
  min-height: 0;
  box-shadow: none;
  background: none;
  border: 0;
  border-radius: 0;
  padding: 0 12px;
  line-height: 34px;
}

.admin-extend-control .input:focus {
  box-shadow: none;
}

.admin-extend-control .admin-btn {
  border-width: 0 0 0 1px;
  border-color: var(--admin-border-strong);
  background: var(--admin-surface-2);
  white-space: nowrap;
  border-radius: 0;
  justify-content: center;
  align-items: center;
  height: 100%;
  min-height: 0;
  padding: 0 12px;
  line-height: 1;
  display: inline-flex;
}

.admin-extend-control .admin-btn svg {
  flex: none;
}

.admin-extend-control .admin-btn.admin-btn-primary {
  background: var(--accent);
  color: #02110a;
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-extend-control .admin-btn.admin-btn-primary {
    border-color: color-mix(in srgb, var(--accent) 70%, #000);
  }
}

.admin-extend-control .admin-btn.admin-btn-primary {
  font-weight: 600;
}

.admin-extend-control .admin-btn.admin-btn-primary:hover:not(:disabled) {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-extend-control .admin-btn.admin-btn-primary:hover:not(:disabled) {
    background: color-mix(in srgb, var(--accent) 90%, #fff);
  }
}

.admin-input-row .input, .admin-input-row .admin-btn {
  height: 36px;
}

.admin-actions-tab > .admin-btn {
  width: 100%;
  height: 36px;
}

.admin-message-actions .admin-btn {
  height: 36px;
}

.dialog:has(.admin-dialog) {
  padding: max(12px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));
  z-index: 90;
}

@property --tw-rotate-x {
  syntax: "*";
  inherits: false
}

@property --tw-rotate-y {
  syntax: "*";
  inherits: false
}

@property --tw-rotate-z {
  syntax: "*";
  inherits: false
}

@property --tw-skew-x {
  syntax: "*";
  inherits: false
}

@property --tw-skew-y {
  syntax: "*";
  inherits: false
}

@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-blur {
  syntax: "*";
  inherits: false
}

@property --tw-brightness {
  syntax: "*";
  inherits: false
}

@property --tw-contrast {
  syntax: "*";
  inherits: false
}

@property --tw-grayscale {
  syntax: "*";
  inherits: false
}

@property --tw-hue-rotate {
  syntax: "*";
  inherits: false
}

@property --tw-invert {
  syntax: "*";
  inherits: false
}

@property --tw-opacity {
  syntax: "*";
  inherits: false
}

@property --tw-saturate {
  syntax: "*";
  inherits: false
}

@property --tw-sepia {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false
}

@property --tw-ease {
  syntax: "*";
  inherits: false
}
/*$vite$:1*/