
	/* 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;
	}

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

	:where([data-scroll-area-viewport]) {
		display: flex;
		flex-direction: column;
		align-items: stretch;
	}
	:where([data-scroll-area-content]) {
		flex-grow: 1;
	}
.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;}
  .ui-checkbox {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    padding: 0;
    border: 1px solid var(--admin-border-strong, var(--border));
    border-radius: 4px;
    background: color-mix(
      in srgb,
      var(--admin-bg, var(--panel)) 84%,
      var(--admin-surface-2, transparent)
    );
    color: #fff;
    cursor: pointer;
    outline: none;
    transition:
      background 0.14s ease,
      border-color 0.14s ease,
      box-shadow 0.14s ease;
  }

  .ui-checkbox:hover {
    border-color: var(--admin-ring, var(--accent));
  }

  .ui-checkbox[data-state="checked"],
  .ui-checkbox[data-state="indeterminate"] {
    border-color: color-mix(in srgb, var(--accent) 82%, transparent);
    background: var(--accent);
  }

  .ui-checkbox:focus-visible {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 24%, transparent);
  }

  .ui-checkbox:disabled {
    opacity: 0.5;
    cursor: not-allowed;
  }

  .scroll-area {
    position: relative;
    overflow: hidden;
  }

  .scroll-area--dialog {
    overflow: visible;
  }

  .scroll-area__viewport {
    width: 100%;
    height: 100%;
    max-height: inherit;
    border-radius: inherit;
  }

  .scroll-area__scrollbar {
    z-index: 2;
    display: flex;
    touch-action: none;
    user-select: none;
    padding: 2px;
    transition: background 0.14s ease;
  }

  .scroll-area__scrollbar[data-orientation="vertical"] {
    width: 10px;
  }

  .scroll-area--dialog .scroll-area__scrollbar[data-orientation="vertical"] {
    transform: translateX(12px);
  }

  .scroll-area__scrollbar[data-orientation="horizontal"] {
    flex-direction: column;
    height: 10px;
  }

  .scroll-area__thumb {
    position: relative;
    flex: 1;
    border-radius: 999px;
    background: color-mix(
      in srgb,
      var(--admin-muted, var(--muted)) 34%,
      var(--admin-border, var(--border))
    );
  }

  .scroll-area__thumb:hover {
    background: color-mix(
      in srgb,
      var(--admin-muted, var(--muted)) 48%,
      var(--admin-border, var(--border))
    );
  }

  .scroll-area__corner {
    background: transparent;
  }

  .ui-radio-group {
    display: grid;
    gap: 8px;
  }

  .ui-radio-item {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    padding: 0;
    border: 1px solid var(--admin-border-strong, var(--border));
    border-radius: 999px;
    background: color-mix(
      in srgb,
      var(--admin-bg, var(--panel)) 84%,
      var(--admin-surface-2, transparent)
    );
    cursor: pointer;
    outline: none;
    transition:
      border-color 0.14s ease,
      box-shadow 0.14s ease;
  }

  .ui-radio-item:hover {
    border-color: var(--admin-ring, var(--accent));
  }

  .ui-radio-item:focus-visible {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 24%, transparent);
  }

  .ui-radio-item:disabled {
    opacity: 0.5;
    cursor: not-allowed;
  }

  .ui-radio-indicator.svelte-1lyfe04 {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--accent);
    opacity: 0;
    transform: scale(0.6);
    transition:
      opacity 0.14s ease,
      transform 0.14s ease;
  }

  .ui-radio-item[data-state="checked"] {
    border-color: var(--accent);
  }

  .ui-radio-item[data-state="checked"] .ui-radio-indicator.svelte-1lyfe04 {
    opacity: 1;
    transform: scale(1);
  }

  .ui-range-input {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    height: 18px;
    touch-action: none;
    user-select: none;
  }

  .ui-range-input::before {
    content: "";
    position: absolute;
    right: 0;
    left: 0;
    height: 5px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--admin-border-strong, var(--border)) 70%, transparent);
  }

  .ui-range-input__range {
    position: absolute;
    height: 5px;
    border-radius: 999px;
    background: var(--accent);
  }

  .ui-range-input__thumb {
    display: block;
    width: 16px;
    height: 16px;
    border: 2px solid var(--accent);
    border-radius: 999px;
    background: var(--admin-surface, var(--panel));
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.24);
    outline: none;
    transition:
      box-shadow 0.14s ease,
      transform 0.14s ease;
  }

  .ui-range-input__thumb:hover {
    transform: scale(1.05);
  }

  .ui-range-input__thumb:focus-visible {
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 24%, transparent);
  }

  .ui-range-input[data-disabled] {
    opacity: 0.5;
    cursor: not-allowed;
  }

  .brand-mark.svelte-p1n2t9 {
    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-p1n2t9 img:where(.svelte-p1n2t9) {
    width: 100%;
    height: 100%;
    object-fit: contain;
    opacity: 0;
    transition: opacity 0.2s ease;
  }

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

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

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

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

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

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

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

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

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

  .brand-mark-emoji.svelte-p1n2t9 {
    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-p1n2t9 .brand-mark-emoji:where(.svelte-p1n2t9) {
    font-size: 1em;
  }

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

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

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

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

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

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

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

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

  .backups-layout.svelte-1ohqtwa {
    display: grid;
    gap: 12px;
  }

  .backups-toolbar-main.svelte-1ohqtwa {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
  }

  .backups-file-input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }

  .backups-dir.svelte-1ohqtwa,
  .backups-selected-name.svelte-1ohqtwa,
  .backups-name.svelte-1ohqtwa {
    font-family: var(--font-mono);
    word-break: break-word;
  }

  .backups-dir.svelte-1ohqtwa {
    max-width: min(420px, 70vw);
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .backups-restore-body.svelte-1ohqtwa {
    display: grid;
    grid-template-columns: repeat(2, minmax(160px, 1fr)) auto;
    gap: 10px;
    align-items: center;
  }

  .backups-check.svelte-1ohqtwa {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    padding: 8px 10px;
    border: 1px solid var(--admin-border);
    border-radius: 8px;
    background: var(--admin-surface-2);
    color: var(--admin-text);
    font-size: 13px;
  }

  .backups-check.is-disabled.svelte-1ohqtwa {
    opacity: 0.55;
  }

  .backups-restore-note.svelte-1ohqtwa {
    border-top: 1px solid var(--admin-border);
    padding: 10px 14px;
    color: var(--admin-muted);
    font-size: 12px;
  }

  .backups-table tbody tr.is-selected {
    background: color-mix(in srgb, var(--accent) 12%, transparent);
  }

  .backups-badges.svelte-1ohqtwa {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }

  .backups-archive-radio-group.ui-radio-group {
    display: block;
  }

  .backups-radio.ui-radio-item {
    margin-inline: auto;
  }

  .backups-warning-trigger {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 24px;
    padding: 2px 7px;
    border: 1px solid var(--warning-border);
    border-radius: 999px;
    background: var(--warning-soft);
    color: var(--warning-text);
    font: inherit;
    font-size: 11px;
    font-weight: 600;
    cursor: help;
    outline: none;
  }

  .backups-warning-trigger:focus-visible {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--warning) 22%, transparent);
  }

  .backups-warning-tooltip {
    z-index: 120;
    display: grid;
    gap: 6px;
    max-width: min(440px, calc(100vw - 32px));
    padding: 10px 12px;
    border: 1px solid var(--admin-border);
    border-radius: 10px;
    background: var(--admin-surface);
    color: var(--admin-text);
    box-shadow: var(--shadow-popover);
    font-size: 12px;
    line-height: 1.4;
  }

  .backups-warning-tooltip p.svelte-1ohqtwa {
    margin: 0;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
  }

  @media (max-width: 760px) {
    .backups-restore-body.svelte-1ohqtwa {
      grid-template-columns: minmax(0, 1fr);
    }

    .backups-restore-body .admin-btn {
      width: 100%;
    }
  }

  .admin-logs-user-cell.svelte-1ltn002 {
    min-width: 150px;
  }

  .admin-logs-user.svelte-1ltn002 {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
  }

  .admin-logs-user-meta.svelte-1ltn002 {
    display: grid;
    gap: 2px;
    min-width: 0;
  }

  .admin-logs-user-name.svelte-1ltn002 {
    min-width: 0;
    overflow: hidden;
    color: var(--admin-text);
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-logs-user-id.svelte-1ltn002 {
    color: var(--admin-dim);
    font-family: var(--font-mono);
    font-size: 11px;
    line-height: 1.2;
    white-space: nowrap;
  }

  .admin-logs-user-cell.svelte-1ltn002 .admin-logs-user-btn.admin-btn {
    width: 30px;
    height: 30px;
    min-width: 30px;
    min-height: 30px;
    flex-shrink: 0;
    padding: 0;
    border-radius: 7px;
  }

  .admin-logs-user-cell.svelte-1ltn002 .admin-logs-user-btn svg {
    width: 14px;
    height: 14px;
  }

  .admin-payments-user-cell.svelte-mf3mji {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
  }

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

  .admin-cell-user-with-action.svelte-mf3mji .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-mf3mji .admin-payments-user-btn svg {
    width: 14px;
    height: 14px;
  }

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

  .admin-cell-id.svelte-mf3mji .admin-payment-id-btn.admin-btn {
    height: 28px;
    min-height: 28px;
    padding: 0 8px;
    gap: 6px;
    border-radius: 7px;
    color: var(--admin-text);
    font-family: var(--font-mono);
    font-size: 12px;
  }

  .appearance-stack.svelte-13yy6yt {
    display: grid;
    gap: 14px;
  }

  .appearance-logo-grid.svelte-13yy6yt {
    display: grid;
    grid-template-columns: minmax(190px, 220px) minmax(0, 520px);
    gap: 18px;
    align-items: stretch;
  }

  .appearance-favicon-grid.svelte-13yy6yt {
    grid-template-columns: minmax(132px, 140px) minmax(0, 520px);
    border-top: 1px solid var(--admin-border);
  }

  .appearance-logo-preview.svelte-13yy6yt {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    grid-row: 1;
    width: auto;
    height: 100%;
    aspect-ratio: 1 / 1;
    justify-self: start;
    padding: 10px;
    overflow: hidden;
    border: 1px solid var(--admin-border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--admin-surface-2) 54%, var(--admin-surface));
  }

  .appearance-favicon-preview.svelte-13yy6yt {
    width: 140px;
    height: 140px;
    max-width: 100%;
  }

  .appearance-logo-image.svelte-13yy6yt {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .appearance-logo-empty.svelte-13yy6yt {
    width: 44%;
    aspect-ratio: 1 / 1;
    border: 1px dashed var(--admin-border-strong);
    border-radius: 8px;
    opacity: 0.65;
  }

  .appearance-logo-preview.svelte-13yy6yt .brand-mark {
    width: 100%;
    height: 100%;
    font-size: clamp(3rem, 8vw, 5rem);
  }

  .appearance-controls.svelte-13yy6yt {
    display: grid;
    gap: 12px;
    align-content: start;
    max-width: 520px;
  }

  .appearance-control-card.svelte-13yy6yt {
    display: grid;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--admin-border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--admin-surface-2) 40%, transparent);
  }

  .appearance-file-input {
    display: none;
  }

  .appearance-url-row.svelte-13yy6yt,
  .appearance-emoji-grid.svelte-13yy6yt {
    display: grid;
    gap: 8px;
    max-width: 520px;
  }

  .appearance-url-row.svelte-13yy6yt {
    grid-template-columns: minmax(0, 1fr) max-content;
    width: 100%;
  }

  .appearance-emoji-grid.svelte-13yy6yt {
    grid-template-columns: minmax(0, 360px) max-content;
  }

  .appearance-control.input,
  .appearance-control.admin-btn,
  .appearance-control.admin-select-trigger {
    height: 36px;
    min-height: 36px;
  }

  .appearance-control.admin-btn {
    padding-inline: 12px;
    border-radius: 8px;
    font-size: 13px;
  }

  .appearance-switch.svelte-13yy6yt {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    max-width: 520px;
    color: var(--admin-text);
    font-size: 13px;
  }

  .admin-theme-grid.svelte-13yy6yt {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 12px;
  }

  .admin-theme-card.svelte-13yy6yt {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    min-height: 154px;
    padding: 14px;
    border: 1px solid var(--admin-border);
    border-radius: 8px;
    background: var(--admin-surface);
    color: var(--admin-text);
    text-align: left;
    cursor: pointer;
  }

  .admin-theme-card.svelte-13yy6yt:hover {
    border-color: var(--admin-border-strong);
    background: color-mix(in srgb, var(--admin-surface-2) 72%, var(--admin-surface));
  }

  .admin-theme-card.is-current.svelte-13yy6yt {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 44%, transparent);
  }

  .admin-theme-card.is-disabled.svelte-13yy6yt {
    opacity: 0.58;
  }

  .admin-theme-card-main.svelte-13yy6yt {
    display: grid;
    align-content: start;
    gap: 5px;
    min-width: 0;
  }

  .admin-theme-card-title.svelte-13yy6yt {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
  }

  .admin-theme-card-title.svelte-13yy6yt strong:where(.svelte-13yy6yt) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-theme-card-main.svelte-13yy6yt small:where(.svelte-13yy6yt),
  .admin-theme-card-meta.svelte-13yy6yt {
    color: var(--admin-muted);
    font-size: 12px;
  }

  .admin-theme-card-meta.svelte-13yy6yt {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 7px;
    min-width: 0;
  }

  .admin-theme-card-meta.svelte-13yy6yt span:where(.svelte-13yy6yt) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-theme-card-option.svelte-13yy6yt {
    grid-column: 1 / -1;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    max-width: 100%;
    color: var(--admin-muted);
    font-size: 12px;
    cursor: default;
  }

  .appearance-color-row.svelte-13yy6yt {
    display: grid;
    grid-template-columns: auto 38px minmax(0, 1fr);
    width: 100%;
  }

  .appearance-color-text {
    min-width: 0;
  }

  .appearance-logo-scale-row.svelte-13yy6yt {
    display: grid;
    grid-template-columns: auto minmax(96px, 1fr) auto;
    width: 100%;
  }

  .appearance-logo-scale-range {
    width: 100%;
    accent-color: var(--accent);
  }

  .appearance-logo-scale-value.svelte-13yy6yt {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--admin-text);
  }

  .appearance-logo-scale-value .input {
    width: 70px;
    min-height: 32px;
    padding: 4px 8px;
    font-size: 12px;
  }

  .admin-color.is-empty {
    opacity: 0.42;
    filter: grayscale(1);
  }

  .appearance-theme-actions.svelte-13yy6yt {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-start;
  }

  .admin-theme-card-check.svelte-13yy6yt {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    color: var(--accent);
  }

  @media (max-width: 720px) {
    .appearance-logo-grid.svelte-13yy6yt {
      grid-template-columns: 1fr;
    }

    .appearance-logo-preview.svelte-13yy6yt {
      grid-row: auto;
      height: auto;
      width: min(164px, 100%);
    }

    .appearance-favicon-preview.svelte-13yy6yt {
      width: min(140px, 100%);
      height: auto;
    }

    .appearance-url-row.svelte-13yy6yt,
    .appearance-emoji-grid.svelte-13yy6yt {
      grid-template-columns: 1fr;
    }
  }

  .admin-user-action-sheet.svelte-75118r {
    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-75118r .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-75118r {
    padding: 12px 14px 12px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .admin-user-override-stack.svelte-75118r {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  .admin-user-grant-stack.svelte-75118r {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  .admin-user-action-sheet-footer.svelte-75118r {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px;
    padding: 4px 14px 12px;
  }
  .admin-override-card-footer.svelte-75118r {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .admin-override-card-toolbar.svelte-75118r {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 10px 14px;
    width: 100%;
  }
  .admin-override-card-toolbar.svelte-75118r .admin-btn {
    flex: 0 0 auto;
    min-height: 36px;
    padding-left: 16px;
    padding-right: 16px;
  }
  .admin-override-unlimited-label.svelte-75118r {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--admin-text, inherit);
    cursor: pointer;
    user-select: none;
    min-height: 36px;
  }
  @media (max-width: 520px) {
    .admin-override-card-toolbar.svelte-75118r {
      flex-direction: column;
      align-items: stretch;
    }
    .admin-override-card-toolbar.svelte-75118r .admin-btn {
      width: 100%;
    }
  }
  .admin-override-status-lines.svelte-75118r {
    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-75118r {
    margin-top: 10px;
  }
  .admin-user-action-sheet--traffic-grant.svelte-75118r {
    margin-top: 10px;
  }
  .admin-user-action-sheet.svelte-75118r .admin-grant-kind-select {
    width: 100%;
    max-width: 100%;
  }
  .admin-avatar-preview-trigger.svelte-75118r {
    padding: 0;
    appearance: none;
  }
  .admin-avatar-preview-trigger.svelte-75118r img:where(.svelte-75118r) {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .admin-avatar-preview-trigger.svelte-75118r:disabled {
    cursor: default;
  }
  .admin-avatar-preview-trigger.is-clickable.svelte-75118r {
    cursor: zoom-in;
  }
  .admin-avatar-preview-trigger.is-clickable.svelte-75118r:hover,
  .admin-avatar-preview-trigger.is-clickable.svelte-75118r:focus-visible {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
  }
  .admin-user-summary-actions.svelte-75118r {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
  }
  .admin-user-ref-row.svelte-75118r {
    grid-template-columns: 130px minmax(0, 1fr) auto;
    align-items: center;
  }
  .admin-user-ref-row.svelte-75118r .admin-btn {
    flex: 0 0 auto;
  }
  .admin-user-ref-value.svelte-75118r {
    display: grid;
    gap: 2px;
    min-width: 0;
  }
  .admin-user-ref-value.svelte-75118r small:where(.svelte-75118r) {
    color: var(--admin-muted);
    font-size: 11px;
    font-weight: 500;
  }
  .admin-user-referrals-dialog {
    width: min(760px, calc(100vw - 28px));
    max-height: min(760px, calc(100dvh - 28px));
  }
  .admin-user-referrals-body.svelte-75118r {
    display: grid;
    gap: 12px;
    min-width: 0;
  }
  .admin-user-referrals-table-wrap {
    min-height: 120px;
  }
  .admin-referral-user-cell.svelte-75118r {
    display: grid;
    gap: 2px;
    min-width: 0;
  }
  .admin-referral-user-cell.svelte-75118r strong:where(.svelte-75118r) {
    color: var(--admin-text);
    font-weight: 650;
    word-break: break-word;
  }
  .admin-referral-user-cell.svelte-75118r small:where(.svelte-75118r) {
    color: var(--admin-muted);
    font-size: 12px;
    word-break: break-word;
  }
  .admin-referral-user-actions.svelte-75118r {
    text-align: right;
  }
  @media (max-width: 560px) {
    .admin-user-ref-row.svelte-75118r {
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 4px 8px;
    }
    .admin-user-ref-row.svelte-75118r > span:where(.svelte-75118r) {
      grid-column: 1 / -1;
    }
  }
  .admin-avatar-dialog {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    width: min(920px, calc(100vw - 28px));
    height: min(820px, calc(100dvh - 28px));
    max-height: calc(100dvh - 28px);
    gap: 10px;
    padding: 12px;
    overflow: hidden;
  }
  .admin-avatar-preview.svelte-75118r {
    display: grid;
    place-items: center;
    min-height: 0;
    width: 100%;
    height: 100%;
    padding: 4px;
    overflow: hidden;
  }
  .admin-avatar-preview.svelte-75118r img:where(.svelte-75118r) {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 14px;
    border: 1px solid var(--admin-border);
    background: var(--admin-surface-2);
  }
  @media (max-width: 640px) {
    .dialog:has(.admin-avatar-dialog) {
      padding: max(8px, env(safe-area-inset-top)) max(8px, env(safe-area-inset-right))
        max(8px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));
    }
    .admin-avatar-dialog {
      width: calc(100vw - 16px);
      height: min(88dvh, calc(100dvh - 16px));
      max-height: calc(100dvh - 16px);
      border-radius: 18px;
      padding: 10px;
    }
  }
  .admin-user-dialog .admin-user-logs-tab {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .admin-user-logs-head.svelte-75118r {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
  }
  .admin-user-logs-meta.svelte-75118r {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
  }
  .admin-user-logs-wrap {
    min-height: 120px;
  }
  .admin-user-log-event.svelte-75118r {
    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-toolbar-users .admin-toolbar-controls {
    grid-template-columns: repeat(3, minmax(150px, 1fr)) minmax(82px, auto);
    gap: 10px;
  }

  .admin-users-search-button {
    min-width: 82px;
  }

  .admin-users-filter-toggle {
    display: none;
    position: relative;
    align-items: center;
    gap: 7px;
    min-width: 0;
  }

  .admin-users-filter-count.svelte-1ydmf45 {
    display: inline-grid;
    min-width: 18px;
    height: 18px;
    place-items: center;
    padding: 0 5px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--admin-bg) 74%, transparent);
    color: inherit;
    font-size: 11px;
    font-weight: 750;
    line-height: 1;
  }

  .admin-users-filter-chips.svelte-1ydmf45 {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    min-width: 0;
  }

  .admin-users-filter-chip.svelte-1ydmf45 {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    max-width: 100%;
    min-height: 28px;
    padding: 3px 5px 3px 10px;
    border: 1px solid var(--admin-border);
    border-radius: 999px;
    background: color-mix(in srgb, var(--admin-muted) 8%, transparent);
    color: var(--admin-text);
    font-size: 12px;
  }

  .admin-users-filter-chip-text.svelte-1ydmf45 {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-width: 0;
    max-width: 260px;
  }

  .admin-users-filter-chip.svelte-1ydmf45 strong:where(.svelte-1ydmf45) {
    color: var(--admin-muted);
    font-size: 11px;
    font-weight: 650;
  }

  .admin-users-filter-chip-text.svelte-1ydmf45 > span:where(.svelte-1ydmf45) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-users-filter-chip.svelte-1ydmf45 button:where(.svelte-1ydmf45) {
    display: inline-grid;
    width: 20px;
    height: 20px;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--admin-muted);
    cursor: pointer;
  }

  .admin-users-filter-chip.svelte-1ydmf45 button:where(.svelte-1ydmf45):hover,
  .admin-users-filter-chip.svelte-1ydmf45 button:where(.svelte-1ydmf45):focus-visible {
    background: color-mix(in srgb, var(--admin-muted) 14%, transparent);
    color: var(--admin-text);
    outline: none;
  }

  .admin-users-filter-fields-sheet.svelte-1ydmf45,
  .admin-users-filter-sheet-body.svelte-1ydmf45 {
    display: grid;
    gap: 12px;
  }

  .admin-users-filter-sheet-actions.svelte-1ydmf45 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 8px;
    padding-top: 2px;
  }

  .admin-users-filter-dialog {
    width: min(100%, 420px);
  }

  .admin-users-table-wrap.svelte-1ydmf45 .admin-table-wrap {
    overflow-x: auto;
  }

  .admin-users-table-wrap.svelte-1ydmf45 .admin-users-table {
    min-width: 1080px;
  }

  .admin-sort-header.svelte-1ydmf45 {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    max-width: 100%;
    margin: -4px -6px;
    padding: 4px 6px;
    border: 0;
    border-radius: 6px;
    background: transparent;
    color: inherit;
    font: inherit;
    letter-spacing: inherit;
    text-transform: inherit;
    cursor: pointer;
  }

  .admin-sort-header.svelte-1ydmf45:hover,
  .admin-sort-header.svelte-1ydmf45:focus-visible {
    color: var(--admin-text);
    background: color-mix(in srgb, var(--admin-muted) 10%, transparent);
    outline: none;
  }

  .admin-sort-header.svelte-1ydmf45:focus-visible {
    box-shadow: 0 0 0 2px var(--admin-ring);
  }

  .admin-sort-state.svelte-1ydmf45 {
    display: inline-flex;
    align-items: center;
    color: var(--admin-dim);
  }

  .admin-sort-state[data-state="ascending"].svelte-1ydmf45,
  .admin-sort-state[data-state="descending"].svelte-1ydmf45 {
    color: color-mix(in srgb, var(--accent) 72%, var(--admin-muted));
  }

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

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

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

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

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

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

  .admin-users-cell-premium.svelte-1ydmf45 .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-1ydmf45 {
    color: var(--admin-dim);
    font-size: 12px;
    font-variant-numeric: tabular-nums;
  }

  .admin-users-cell-money.svelte-1ydmf45,
  .admin-users-cell-counter.svelte-1ydmf45 {
    white-space: nowrap;
  }

  .admin-users-cell-money.svelte-1ydmf45 .admin-user-money-badge {
    font-variant-numeric: tabular-nums;
  }

  .admin-user-counter.svelte-1ydmf45 {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--admin-text);
    font-size: 12px;
    font-weight: 650;
    font-variant-numeric: tabular-nums;
  }

  .admin-user-counter.svelte-1ydmf45 svg {
    color: var(--admin-muted);
    flex: 0 0 auto;
  }

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

  .admin-users-table-wrap.svelte-1ydmf45 .admin-users-table tbody tr.is-clickable:focus-visible {
    outline: 2px solid var(--admin-ring);
    outline-offset: -2px;
  }

  @media (max-width: 720px) {
    .admin-toolbar-users .admin-toolbar-search {
      grid-template-columns: minmax(0, 1fr) auto auto;
    }

    .admin-toolbar-users .admin-toolbar-controls {
      display: none;
    }

    .admin-users-search-button {
      min-width: 0;
      padding-inline: 10px;
    }

    .admin-users-filter-toggle {
      display: inline-flex;
      min-width: 38px;
      padding-inline: 10px;
    }

    .admin-users-filter-toggle-label.svelte-1ydmf45 {
      display: none;
    }

    .admin-users-filter-chips.svelte-1ydmf45 {
      gap: 5px;
    }

    .admin-users-filter-chip-text.svelte-1ydmf45 {
      max-width: min(250px, calc(100vw - 96px));
    }

    .dialog:has(.admin-users-filter-dialog) {
      align-items: end;
      padding: max(12px, env(safe-area-inset-top)) 0 0;
    }

    .admin-users-filter-dialog {
      width: 100%;
      max-height: min(82dvh, 620px);
      padding: 16px;
      border-right: 0;
      border-bottom: 0;
      border-left: 0;
      border-radius: 18px 18px 0 0;
    }

    .admin-users-table-wrap.svelte-1ydmf45 .admin-users-table thead {
      display: table-header-group;
    }

    .admin-users-table-wrap.svelte-1ydmf45 .admin-users-table tbody tr {
      display: table-row;
      padding: 0;
      border-bottom: 0;
    }

    .admin-users-table-wrap.svelte-1ydmf45 .admin-users-table tbody tr:last-child td {
      border-bottom: 0;
    }

    .admin-users-table-wrap.svelte-1ydmf45 .admin-users-table tbody td {
      display: table-cell;
      padding: 12px 16px;
      border-bottom: 1px solid var(--admin-border);
    }

    .admin-users-table-wrap.svelte-1ydmf45 .admin-users-table tbody td::before {
      content: none;
    }
  }
/*! 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-out: cubic-bezier(0, 0, .2, 1);
    --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 {
  .visible {
    visibility: visible;
  }

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .static {
    position: static;
  }

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

  .inline {
    display: inline;
  }

  .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;
  }

  .rounded {
    border-radius: .25rem;
  }

  .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);
  }

  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-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;
  --font-logo: var(--font-mono);
  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;
  --danger-text: #ffb4b4;
  --danger-soft: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --danger-soft: color-mix(in srgb, var(--danger) 12%, var(--panel));
  }
}

:root {
  --danger-border: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --danger-border: color-mix(in srgb, var(--danger) 34%, var(--border));
  }
}

:root {
  --success: #3ecf8e;
  --success-text: #7ff0b9;
  --success-soft: var(--success);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --success-soft: color-mix(in srgb, var(--success) 12%, var(--panel));
  }
}

:root {
  --success-border: var(--success);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --success-border: color-mix(in srgb, var(--success) 34%, var(--border));
  }
}

:root {
  --warning: #ffd166;
  --warning-text: #ffd166;
  --warning-soft: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --warning-soft: color-mix(in srgb, var(--warning) 12%, var(--panel));
  }
}

:root {
  --warning-border: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --warning-border: color-mix(in srgb, var(--warning) 34%, var(--border));
  }
}

:root {
  --info: #2d9cff;
  --info-text: #8ed0ff;
  --info-soft: var(--info);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --info-soft: color-mix(in srgb, var(--info) 12%, var(--panel));
  }
}

:root {
  --info-border: var(--info);
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --info-border: color-mix(in srgb, var(--info) 34%, var(--border));
  }
}

:root {
  --blue: #2d9cff;
  --radius: 8px;
  --accent-contrast: #03100a;
  --surface-sheen: #ffffff0e;
  --surface-sheen-soft: #ffffff05;
  --surface-hover: #ffffff0a;
  --surface-muted: #ffffff09;
  --surface-subtle: #ffffff08;
  --surface-subtle-border: #ffffff1a;
  --overlay-scrim: #0000008f;
  --nav-bg: #070c11e0;
  --rail-bg: #070c118c;
  --shadow-soft: 0 18px 48px #00000038;
  --shadow-strong: 0 26px 70px #00000075;
  --shadow-popover: 0 20px 34px #0000006b;
  --inset-highlight: #ffffff0d;
  --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);
}

.theme-light {
  color-scheme: light;
}

* {
  box-sizing: border-box;
}

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

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

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

.app-shell {
  min-height: 100dvh;
  background: var(--bg, #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;
  box-shadow: var(--shadow-soft);
  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;
}

.btn:hover:not(:disabled) {
  box-shadow: var(--shadow-soft);
  transform: translateY(-1px);
}

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

.btn:focus-visible {
  box-shadow: 0 0 0 3px var(--accent), var(--shadow-soft);
  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), var(--shadow-soft);
  }
}

.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: var(--accent-contrast);
}

.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: var(--muted);
  border-radius: 999px;
  height: 8px;
  margin-top: 12px;
  position: relative;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .progress {
    background: color-mix(in srgb, var(--muted) 18%, transparent);
  }
}

.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;
  background: var(--overlay-scrim);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  cursor: pointer;
  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;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 16px;
  width: min(100%, 520px);
  max-height: min(86dvh, 760px);
  padding: 18px;
  display: grid;
  position: relative;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .dialog-card {
    background: color-mix(in srgb, var(--panel) 96%, var(--bg));
  }
}

.dialog-card {
  color: var(--text);
  box-shadow: var(--shadow-strong);
}

.dialog-body-scroll {
  min-height: 0;
  max-height: none;
}

.dialog-body-scroll > .scroll-area__viewport {
  display: grid;
}

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

.dialog-title-block {
  min-width: 0;
}

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

.dialog-title-icon {
  width: 24px;
  height: 24px;
  color: var(--accent);
  place-items: center;
  display: grid;
}

.dialog-title-icon svg {
  width: 23px;
  height: 23px;
}

.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: hidden;
}

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

.activation-success-dialog {
  gap: 22px;
  width: min(100%, 440px);
  padding: 22px 20px 20px;
}

.activation-success-dialog .dialog-title-with-icon {
  gap: 14px;
}

.activation-success-dialog .dialog-head p {
  margin-top: 8px;
  line-height: 1.52;
}

.activation-success-dialog-body {
  justify-items: center;
  padding-top: 2px;
  display: grid;
}

.activation-success-dialog-body .btn {
  width: 100%;
}

.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: var(--accent-contrast);
  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);
  }
}

.email-code-fullscreen {
  z-index: 220;
  background: var(--bg);
  overscroll-behavior: contain;
  animation: .2s ease-out both email-code-fullscreen-enter;
  position: fixed;
  inset: 0;
  overflow-y: auto;
}

@keyframes email-code-fullscreen-enter {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@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, var(--surface-sheen), var(--surface-sheen-soft)), var(--admin-surface);
  min-width: 0;
  box-shadow: var(--shadow-soft), inset 0 1px 0 var(--inset-highlight);
  border-radius: 12px;
  flex-direction: column;
  display: flex;
  position: relative;
  overflow: hidden;
}

.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: 0;
  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: 0;
  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-soft);
  border-color: var(--danger-border);
  color: var(--danger-text);
}

.admin-cn-badge-success {
  background: var(--success-soft);
  border-color: var(--success-border);
  color: var(--success-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, var(--muted), var(--muted), var(--muted));
  display: inline-block;
}

@supports (color: color-mix(in lab, red, red)) {
  .ui-skeleton, .admin-skeleton, .skeleton-line, .skeleton-dot, .skeleton-pay-button {
    background: linear-gradient(90deg, color-mix(in srgb, var(--muted) 10%, transparent), color-mix(in srgb, var(--muted) 18%, transparent), color-mix(in srgb, var(--muted) 10%, transparent));
  }
}

.ui-skeleton, .admin-skeleton, .skeleton-line, .skeleton-dot, .skeleton-pay-button {
  background-size: 220% 100%;
  animation: 1.2s ease-in-out infinite ui-skeleton-pulse;
}

.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;
  }
}

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

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

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

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

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

.scroll-area {
  min-height: 0;
  overflow: hidden;
}

.scroll-area--mono {
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: var(--admin-muted, var(--muted)) transparent;
}

@supports (color: color-mix(in lab, red, red)) {
  .scroll-area--mono {
    scrollbar-color: color-mix(in srgb, var(--admin-muted, var(--muted)) 34%, var(--admin-border, var(--border))) transparent;
  }
}

.scroll-area--mono::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

.scroll-area--mono::-webkit-scrollbar-track {
  background: none;
}

.scroll-area--mono::-webkit-scrollbar-thumb {
  background: var(--admin-muted, var(--muted));
  border: 2px solid #0000;
  border-radius: 999px;
}

@supports (color: color-mix(in lab, red, red)) {
  .scroll-area--mono::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--admin-muted, var(--muted)) 34%, var(--admin-border, var(--border)));
  }
}

.scroll-area--mono::-webkit-scrollbar-thumb {
  background-clip: padding-box;
}

.scroll-area--mono::-webkit-scrollbar-thumb:hover {
  background: var(--admin-muted, var(--muted));
}

@supports (color: color-mix(in lab, red, red)) {
  .scroll-area--mono::-webkit-scrollbar-thumb:hover {
    background: color-mix(in srgb, var(--admin-muted, var(--muted)) 48%, var(--admin-border, var(--border)));
  }
}

.scroll-area--mono::-webkit-scrollbar-thumb:hover {
  background-clip: padding-box;
}

.attention-dot {
  pointer-events: none;
  background: #ff4b4b;
  border-radius: 999px;
  width: 13px;
  min-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;
}

.attention-dot-inline {
  flex: none;
  display: block;
  position: static;
  transform: none;
}

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

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

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

.nav-badge {
  box-sizing: border-box;
  --numeric-badge-optical-y: .5px;
  color: #fff;
  text-align: center;
  font-variant-numeric: lining-nums;
  font-feature-settings: "lnum";
  background: #ef4444;
  border-radius: 999px;
  place-items: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  display: inline-grid;
}

.numeric-badge-value {
  min-width: 0;
  font-family: var(--font-sans);
  font-size: inherit;
  font-weight: inherit;
  text-align: center;
  transform: translateY(var(--numeric-badge-optical-y, .5px));
  text-box-trim: trim-both;
  text-box-edge: cap alphabetic;
  font-variant-numeric: lining-nums;
  font-feature-settings: "lnum";
  line-height: 1;
  display: block;
}

@supports (text-box-trim: trim-both) {
  .numeric-badge-value {
    transform: none;
  }
}

.nav-badge-floating {
  position: absolute;
  top: 2px;
  right: 14px;
}

.section-heading-row {
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 16px;
  display: flex;
}

.support-screen {
  align-content: start;
  gap: 10px;
  display: grid;
}

.support-ticket-screen {
  align-content: start;
  gap: 12px;
  display: grid;
}

.support-overview-card, .support-list-card, .support-ticket-card, .support-conversation-card {
  gap: 12px;
  min-width: 0;
  display: grid;
  overflow: visible;
}

.support-list-card {
  align-content: start;
}

.support-ticket-card .empty-card {
  text-align: center;
  place-items: center;
  min-height: 160px;
  display: grid;
}

.support-conversation-card {
  gap: 12px;
}

.support-heading-row {
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  display: grid;
}

.support-heading-copy {
  min-width: 0;
}

.support-heading-copy h1 {
  color: var(--accent);
  margin: 0;
  font-size: 17px;
  font-weight: 850;
  line-height: 1.16;
}

.support-heading-copy p {
  color: var(--muted);
  margin: 4px 0 0;
  font-size: 12px;
  line-height: 1.35;
}

.support-heading-icon {
  width: 42px;
  height: 42px;
  color: var(--accent);
  flex: none;
  justify-content: center;
  align-items: center;
  display: flex;
}

.support-new-ticket-button {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(135deg, var(--surface-sheen), var(--surface-sheen-soft));
  width: 100%;
  min-height: 58px;
  color: var(--text);
  text-align: left;
  box-shadow: inset 0 1px 0 var(--inset-highlight);
  grid-template-columns: 38px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  transition: border-color .16s, background .16s, box-shadow .16s;
  display: grid;
}

.support-new-ticket-button:hover {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-new-ticket-button:hover {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
  }
}

.support-new-ticket-button:hover {
  background: var(--surface-muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-new-ticket-button:hover {
    background: color-mix(in srgb, var(--surface-muted) 84%, var(--accent) 8%);
  }
}

.support-new-ticket-button.active {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-new-ticket-button.active {
    border-color: color-mix(in srgb, var(--accent) 58%, var(--border));
  }
}

.support-new-ticket-button.active {
  background: var(--surface-muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-new-ticket-button.active {
    background: color-mix(in srgb, var(--surface-muted) 82%, var(--accent) 12%);
  }
}

.support-new-ticket-button > span:not(.support-new-ticket-icon) {
  min-width: 0;
}

.support-new-ticket-button strong, .support-new-ticket-button small {
  display: block;
}

.support-new-ticket-button strong {
  font-size: 13px;
  line-height: 1.2;
}

.support-new-ticket-button small {
  color: var(--muted);
  margin-top: 2px;
  font-size: 12px;
  line-height: 1.3;
}

.support-new-ticket-icon {
  background: var(--accent);
  border-radius: 8px;
  place-items: center;
  width: 38px;
  height: 38px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-new-ticket-icon {
    background: color-mix(in srgb, var(--accent) 14%, var(--surface-muted));
  }
}

.support-new-ticket-icon {
  color: var(--accent);
}

.support-create-panel, .ticket-composer, .support-admin-composer {
  gap: 10px;
  display: grid;
}

.support-create-panel {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-muted);
  overflow: visible;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-create-panel {
    background: color-mix(in srgb, var(--surface-muted) 86%, transparent);
  }
}

.support-create-panel {
  box-shadow: inset 0 1px 0 var(--inset-highlight);
}

.support-create-panel-inner {
  gap: 12px;
  padding: 12px;
  display: grid;
}

.support-create-grid, .ticket-composer-row, .support-admin-composer-row, .ticket-badges {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: center;
  gap: 8px;
  display: grid;
}

.ticket-composer-row, .support-admin-composer-row, .ticket-badges {
  display: flex;
}

.support-field {
  gap: 7px;
  min-width: 0;
  display: grid;
}

.support-field > span, .support-field > small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.2;
}

.support-field > small {
  justify-self: end;
  font-weight: 700;
}

.support-message-input {
  min-height: 128px;
}

.support-submit-button {
  margin-top: 2px;
}

.support-select-trigger {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-muted);
  width: 100%;
  min-height: 46px;
  color: var(--text);
  text-align: left;
  font: inherit;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 0 12px;
  font-size: 14px;
  font-weight: 800;
  display: grid;
  box-shadow: inset 0 1px #ffffff0d;
}

.support-select-trigger:focus-visible {
  border-color: var(--accent);
  outline: none;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-select-trigger:focus-visible {
    border-color: color-mix(in srgb, var(--accent) 72%, white);
  }
}

.support-select-trigger:focus-visible {
  box-shadow: 0 0 0 3px var(--accent);
}

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

.support-select-content {
  z-index: 150;
  width: var(--bits-select-anchor-width, min(250px, calc(100vw - 28px)));
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  background: var(--panel-3);
  min-width: min(180px, 100vw - 28px);
  max-width: calc(100vw - 28px);
  box-shadow: var(--shadow-popover);
  transform-origin: 0 0;
  animation: .16s ease-out both dropdown-enter;
  overflow: hidden;
}

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

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

.support-select-item[data-highlighted] {
  background: var(--surface-hover);
}

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

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

.support-status-tabs {
  min-width: 0;
}

.support-status-tabs-list {
  border: 1px solid var(--border);
  background: var(--surface-muted);
  border-radius: 10px;
  align-items: center;
  gap: 4px;
  width: 100%;
  max-width: 100%;
  display: flex;
  overflow-x: auto;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-status-tabs-list {
    background: color-mix(in srgb, var(--surface-muted) 86%, transparent);
  }
}

.support-status-tabs-list {
  scrollbar-width: none;
  padding: 4px;
  box-shadow: inset 0 1px #ffffff0d;
}

.support-status-tabs-list::-webkit-scrollbar {
  display: none;
}

.support-status-tabs-trigger {
  appearance: none;
  min-height: 34px;
  color: var(--muted);
  font: inherit;
  white-space: nowrap;
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 8px;
  outline: none;
  flex: none;
  justify-content: center;
  align-items: center;
  gap: 7px;
  padding: 8px 11px;
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  transition: background .16s, color .16s, box-shadow .16s, transform .16s;
  display: inline-flex;
}

.support-status-tabs-trigger b {
  background: var(--surface-muted);
  border-radius: 999px;
  place-items: center;
  min-width: 20px;
  height: 20px;
  display: inline-grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-status-tabs-trigger b {
    background: color-mix(in srgb, var(--surface-muted) 82%, transparent);
  }
}

.support-status-tabs-trigger b {
  color: var(--muted);
  padding-inline: 6px;
  font-size: 11px;
  font-weight: 800;
}

.support-status-tabs-trigger:hover {
  color: var(--text);
}

.support-status-tabs-trigger[data-state="active"] {
  background: var(--panel);
  color: var(--text);
  box-shadow: var(--shadow-soft);
}

.support-status-tabs-trigger[data-state="active"] b {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-status-tabs-trigger[data-state="active"] b {
    background: color-mix(in srgb, var(--accent) 18%, transparent);
  }
}

.support-status-tabs-trigger[data-state="active"] b {
  color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-status-tabs-trigger[data-state="active"] b {
    color: color-mix(in srgb, var(--accent) 78%, white);
  }
}

.support-status-tabs-trigger:focus-visible {
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-status-tabs-trigger:focus-visible {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 26%, transparent);
  }
}

.support-list-card .ticket-list {
  gap: 10px;
  display: grid;
}

.support-list-card .empty-card {
  text-align: center;
  place-items: center;
  min-height: 180px;
  display: grid;
}

.support-user-list-skeleton {
  gap: 10px;
  min-width: 0;
  display: grid;
}

.support-user-ticket-skeleton {
  border: 1px solid var(--border);
  background: var(--panel-2);
  border-radius: 12px;
  grid-template-columns: minmax(0, 1fr) minmax(112px, auto);
  align-items: center;
  gap: 14px;
  min-height: 78px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-user-ticket-skeleton {
    background: color-mix(in srgb, var(--panel-2) 92%, transparent);
  }
}

.support-user-ticket-skeleton {
  padding: 14px 14px 14px 18px;
}

.support-user-ticket-skeleton-main, .support-user-ticket-skeleton-side {
  gap: 9px;
  min-width: 0;
  display: grid;
}

.support-user-ticket-skeleton-side {
  justify-items: end;
}

.ticket-list, .ticket-message-list, .support-admin-messages, .support-inbox-list-inner {
  gap: 10px;
  display: grid;
}

.ticket-card {
  text-align: left;
  border: 1px solid var(--border);
  background: var(--panel-2);
  border-radius: 12px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  width: 100%;
  display: grid;
  position: relative;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-card {
    background: color-mix(in srgb, var(--panel-2) 92%, transparent);
  }
}

.ticket-card {
  color: inherit;
  cursor: pointer;
  padding: 14px 14px 14px 18px;
  transition: border-color .16s, background .16s, box-shadow .16s;
}

.ticket-card:before {
  content: "";
  background: var(--ticket-accent, var(--border-strong));
  border-radius: 3px;
  width: 3px;
  transition: background .16s;
  position: absolute;
  inset: 10px auto 10px 6px;
}

.ticket-card[data-status="open"], .ticket-card[data-status="awaiting_admin"] {
  --ticket-accent: var(--accent);
}

.ticket-card[data-status="awaiting_user"] {
  --ticket-accent: var(--info);
}

.ticket-card[data-status="resolved"], .ticket-card[data-status="closed"] {
  --ticket-accent: var(--muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-card[data-status="resolved"], .ticket-card[data-status="closed"] {
    --ticket-accent: color-mix(in srgb, var(--muted) 70%, transparent);
  }
}

.ticket-card[data-priority="urgent"] {
  --ticket-accent: var(--danger);
}

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

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

.ticket-card:hover {
  background: var(--panel-2);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-card:hover {
    background: color-mix(in srgb, var(--panel-2) 86%, var(--accent) 6%);
  }
}

.ticket-card:hover {
  box-shadow: var(--shadow-soft);
}

.ticket-card:focus-visible {
  border-color: var(--accent);
  outline: none;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-card:focus-visible {
    border-color: color-mix(in srgb, var(--accent) 60%, var(--border));
  }
}

.ticket-card:focus-visible {
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-card:focus-visible {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 26%, transparent);
  }
}

.ticket-card-main, .ticket-card-title, .ticket-card-side, .ticket-card-badges, .ticket-card-meta {
  min-width: 0;
}

.ticket-card-main {
  gap: 6px;
  display: grid;
}

.ticket-card-side {
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  display: flex;
}

.ticket-card-title {
  align-items: center;
  gap: 9px;
  display: flex;
}

.ticket-card-title svg {
  color: var(--accent);
  flex: none;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-card-title svg {
    color: color-mix(in srgb, var(--accent) 72%, var(--muted));
  }
}

.ticket-card-title strong {
  letter-spacing: -.01em;
  color: var(--text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.25;
  overflow: hidden;
}

.ticket-card-meta {
  color: var(--muted);
  flex-wrap: wrap;
  align-items: center;
  gap: 4px 8px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  display: flex;
}

.ticket-card-meta > span + span:before {
  content: "·";
  color: var(--muted);
  margin-right: 8px;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-card-meta > span + span:before {
    color: color-mix(in srgb, var(--muted) 60%, transparent);
  }
}

.ticket-card-badges, .ticket-badges {
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  display: flex;
}

.ticket-status-badge, .ticket-priority-badge, .ticket-message-role-badge {
  border: 1px solid var(--border);
  background: var(--surface-muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-status-badge, .ticket-priority-badge, .ticket-message-role-badge {
    background: color-mix(in srgb, var(--surface-muted) 80%, transparent);
  }
}

.ticket-status-badge, .ticket-priority-badge, .ticket-message-role-badge {
  color: var(--muted);
  letter-spacing: .01em;
  text-transform: none;
  font-weight: 700;
}

.ticket-status-badge--open, .ticket-status-badge--awaiting_admin {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-status-badge--open, .ticket-status-badge--awaiting_admin {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
  }
}

.ticket-status-badge--open, .ticket-status-badge--awaiting_admin {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-status-badge--open, .ticket-status-badge--awaiting_admin {
    background: color-mix(in srgb, var(--accent) 14%, transparent);
  }
}

.ticket-status-badge--open, .ticket-status-badge--awaiting_admin {
  color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-status-badge--open, .ticket-status-badge--awaiting_admin {
    color: color-mix(in srgb, var(--accent) 80%, white);
  }
}

.ticket-status-badge--awaiting_user {
  border-color: var(--info);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-status-badge--awaiting_user {
    border-color: color-mix(in srgb, var(--info) 38%, var(--border));
  }
}

.ticket-status-badge--awaiting_user {
  background: var(--info);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-status-badge--awaiting_user {
    background: color-mix(in srgb, var(--info) 14%, transparent);
  }
}

.ticket-status-badge--awaiting_user {
  color: var(--info-text);
}

.ticket-status-badge--closed, .ticket-status-badge--resolved {
  border-color: var(--muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-status-badge--closed, .ticket-status-badge--resolved {
    border-color: color-mix(in srgb, var(--muted) 24%, var(--border));
  }
}

.ticket-status-badge--closed, .ticket-status-badge--resolved {
  background: var(--muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-status-badge--closed, .ticket-status-badge--resolved {
    background: color-mix(in srgb, var(--muted) 10%, transparent);
  }
}

.ticket-status-badge--closed, .ticket-status-badge--resolved {
  color: var(--muted);
}

.ticket-priority-badge--normal, .ticket-priority-badge--low {
  border-color: var(--border);
  background: var(--surface-muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-priority-badge--normal, .ticket-priority-badge--low {
    background: color-mix(in srgb, var(--surface-muted) 80%, transparent);
  }
}

.ticket-priority-badge--normal, .ticket-priority-badge--low {
  color: var(--muted);
}

.ticket-priority-badge--high {
  border-color: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-priority-badge--high {
    border-color: color-mix(in srgb, var(--warning) 42%, var(--border));
  }
}

.ticket-priority-badge--high {
  background: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-priority-badge--high {
    background: color-mix(in srgb, var(--warning) 14%, transparent);
  }
}

.ticket-priority-badge--high {
  color: var(--warning-text);
}

.ticket-priority-badge--urgent {
  border-color: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-priority-badge--urgent {
    border-color: color-mix(in srgb, var(--danger) 48%, var(--border));
  }
}

.ticket-priority-badge--urgent {
  background: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-priority-badge--urgent {
    background: color-mix(in srgb, var(--danger) 14%, transparent);
  }
}

.ticket-priority-badge--urgent {
  color: var(--danger-text);
}

.ticket-card-unread {
  box-sizing: border-box;
  --numeric-badge-optical-y: .5px;
  background: var(--danger);
  color: #fff;
  text-align: center;
  font-variant-numeric: lining-nums;
  font-feature-settings: "lnum";
  min-width: 22px;
  height: 22px;
  box-shadow: 0 0 0 3px var(--danger);
  border-radius: 999px;
  place-items: center;
  padding: 0 7px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  display: inline-grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-card-unread {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--danger) 22%, transparent);
  }
}

.ticket-card-unread-dot {
  flex: none;
}

.support-ticket-detail-header {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 10px 12px;
  margin-bottom: 0;
  display: grid;
}

.support-back-button {
  align-self: start;
}

.ticket-detail-title {
  min-width: 0;
}

.ticket-detail-title small {
  color: var(--muted);
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 800;
  display: block;
}

.ticket-detail-title h1 {
  overflow-wrap: anywhere;
  margin: 0;
  font-size: 20px;
  line-height: 1.18;
}

.support-ticket-detail-header .ticket-badges {
  grid-column: 2;
  justify-content: flex-start;
}

.support-ticket-state-card {
  align-content: stretch;
}

.support-empty-state {
  border: 1px dashed var(--accent);
  grid-column: 1 / -1;
  place-items: center;
  gap: 9px;
  min-height: 170px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-empty-state {
    border: 1px dashed color-mix(in srgb, var(--accent) 34%, var(--border));
  }
}

.support-empty-state {
  border-radius: var(--radius);
  background: var(--panel);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-empty-state {
    background: color-mix(in srgb, var(--panel) 86%, transparent);
  }
}

.support-empty-state {
  color: var(--text);
  text-align: center;
  padding: 22px 18px;
}

.support-empty-state svg {
  color: var(--accent);
}

.support-empty-state strong {
  font-size: 18px;
  line-height: 1.2;
}

.support-empty-state small {
  max-width: 260px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

.ticket-message-meta time {
  color: var(--muted);
  margin: 0;
  display: block;
}

.support-message-scroll, .support-admin-message-scroll {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 14px;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-message-scroll, .support-admin-message-scroll {
    background: color-mix(in srgb, var(--panel) 70%, transparent);
  }
}

.support-message-scroll, .support-admin-message-scroll {
  padding: 14px;
}

.support-ticket-screen .support-message-scroll {
  overflow: visible;
}

.support-conversation-card--loading {
  grid-template-rows: minmax(0, 1fr);
}

.ticket-message-list, .support-admin-messages {
  flex-direction: column;
  justify-content: flex-start;
  gap: 16px;
  display: flex;
}

.ticket-message-list--loading {
  justify-content: flex-end;
  min-height: 100%;
}

.ticket-message-skeleton-row {
  grid-template-columns: 32px minmax(0, min(72%, 520px));
  align-items: end;
  gap: 10px;
  min-width: 0;
  display: grid;
}

.ticket-message-skeleton-row--outgoing {
  grid-template-columns: minmax(0, min(72%, 520px)) 32px;
  justify-content: end;
}

.ticket-message-skeleton-row--outgoing .ui-skeleton-dot {
  grid-area: 1 / 2;
}

.ticket-message-skeleton-row--outgoing .ticket-message-skeleton-content {
  grid-area: 1 / 1;
  justify-items: end;
}

.ticket-message-skeleton-content {
  gap: 7px;
  min-width: 0;
  display: grid;
}

.ticket-message-row {
  flex: none;
  grid-template-columns: 36px minmax(0, 1fr);
  align-items: flex-end;
  gap: 10px;
  min-width: 0;
  animation: .18s ease-out both ticket-message-enter;
  display: grid;
}

.ticket-message-row--outgoing {
  grid-template-columns: minmax(0, 1fr) 36px;
}

.ticket-message-row--outgoing .ticket-message-avatar {
  grid-area: 1 / 2;
}

.ticket-message-row--outgoing .ticket-message-content {
  grid-area: 1 / 1;
  justify-self: end;
  align-items: flex-end;
}

.ticket-message-row--incoming .ticket-message-content {
  grid-area: 1 / 2;
  justify-self: start;
  align-items: flex-start;
}

.ticket-message-avatar {
  border: 1px solid var(--border);
  background: var(--surface-muted);
  border-radius: 999px;
  place-items: center;
  width: 36px;
  height: 36px;
  display: grid;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-avatar {
    background: color-mix(in srgb, var(--surface-muted) 78%, transparent);
  }
}

.ticket-message-avatar {
  color: var(--muted);
}

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

.ticket-message-avatar strong {
  color: var(--text);
  letter-spacing: .02em;
  font-size: 11px;
  font-weight: 800;
}

.ticket-message-avatar .brand-mark {
  width: 100%;
  height: 100%;
  color: inherit;
  font-size: 22px;
}

.ticket-message-row--admin {
  --ticket-bubble-bg: var(--info);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--admin {
    --ticket-bubble-bg: color-mix(in srgb, var(--info) 14%, var(--panel-2));
  }
}

.ticket-message-row--admin {
  --ticket-bubble-border: var(--info);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--admin {
    --ticket-bubble-border: color-mix(in srgb, var(--info) 32%, var(--border));
  }
}

.ticket-message-row--admin {
  --ticket-bubble-text: #eaf3ff;
}

.ticket-message-row--user {
  --ticket-bubble-bg: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--user {
    --ticket-bubble-bg: color-mix(in srgb, var(--accent) 18%, var(--panel-2));
  }
}

.ticket-message-row--user {
  --ticket-bubble-border: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--user {
    --ticket-bubble-border: color-mix(in srgb, var(--accent) 38%, var(--border));
  }
}

.ticket-message-row--user {
  --ticket-bubble-text: #f4fff9;
}

.ticket-message-row--system {
  --ticket-bubble-bg: var(--surface-muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--system {
    --ticket-bubble-bg: color-mix(in srgb, var(--surface-muted) 72%, var(--panel-2));
  }
}

.ticket-message-row--system {
  --ticket-bubble-border: var(--border);
  --ticket-bubble-text: var(--text);
}

.ticket-message-row--admin .ticket-message-avatar {
  border-color: var(--info);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--admin .ticket-message-avatar {
    border-color: color-mix(in srgb, var(--info) 32%, var(--border));
  }
}

.ticket-message-row--admin .ticket-message-avatar {
  background: var(--info);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--admin .ticket-message-avatar {
    background: color-mix(in srgb, var(--info) 12%, transparent);
  }
}

.ticket-message-row--admin .ticket-message-avatar {
  color: var(--info-text);
}

.ticket-message-row--user .ticket-message-avatar {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--user .ticket-message-avatar {
    border-color: color-mix(in srgb, var(--accent) 34%, var(--border));
  }
}

.ticket-message-row--user .ticket-message-avatar {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--user .ticket-message-avatar {
    background: color-mix(in srgb, var(--accent) 12%, transparent);
  }
}

.ticket-message-row--user .ticket-message-avatar {
  color: var(--accent);
}

.ticket-message-row--internal .ticket-message-avatar {
  border-style: dashed;
  border-color: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--internal .ticket-message-avatar {
    border-color: color-mix(in srgb, var(--warning) 42%, var(--border));
  }
}

.ticket-message-row--internal .ticket-message-avatar {
  background: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--internal .ticket-message-avatar {
    background: color-mix(in srgb, var(--warning) 10%, transparent);
  }
}

.ticket-message-row--internal .ticket-message-avatar {
  color: var(--warning-text);
}

.ticket-message-content {
  flex-direction: column;
  gap: 4px;
  width: fit-content;
  min-width: 0;
  max-width: min(82%, 680px);
  display: flex;
}

.ticket-message-meta {
  min-width: 0;
  color: var(--muted);
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  padding: 0 4px;
  font-size: 11px;
  line-height: 1.1;
  display: flex;
}

.ticket-message-row--outgoing .ticket-message-meta {
  justify-content: flex-end;
}

.ticket-message-author {
  min-width: 0;
  color: var(--muted);
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-author {
    color: color-mix(in srgb, var(--muted) 84%, var(--text));
  }
}

.ticket-message-author {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 650;
}

.ticket-message-meta time {
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  line-height: 1;
}

.ticket-message-bubble {
  border: 1px solid var(--ticket-bubble-border, var(--border));
  background: var(--ticket-bubble-bg, var(--panel-2));
  border-radius: 14px 14px 14px 4px;
  width: fit-content;
  max-width: 100%;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-bubble {
    background: var(--ticket-bubble-bg, color-mix(in srgb, var(--panel-2) 92%, transparent));
  }
}

.ticket-message-bubble {
  white-space: pre-wrap;
  padding: 10px 13px;
}

.ticket-message-bubble p {
  overflow-wrap: anywhere;
  word-break: normal;
  color: var(--ticket-bubble-text, var(--text));
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
}

.ticket-message-row--outgoing .ticket-message-bubble {
  border-radius: 14px 14px 4px;
}

.ticket-message-row--internal .ticket-message-bubble {
  --ticket-bubble-bg: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--internal .ticket-message-bubble {
    --ticket-bubble-bg: color-mix(in srgb, var(--warning) 8%, var(--panel-2));
  }
}

.ticket-message-row--internal .ticket-message-bubble {
  --ticket-bubble-border: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-message-row--internal .ticket-message-bubble {
    --ticket-bubble-border: color-mix(in srgb, var(--warning) 28%, var(--border));
  }
}

.ticket-message-row--internal .ticket-message-bubble {
  border-style: dashed;
}

.ticket-composer {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 14px;
  gap: 10px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-composer {
    background: color-mix(in srgb, var(--panel) 88%, transparent);
  }
}

.ticket-composer {
  box-shadow: var(--shadow-soft);
  padding: 12px;
  transition: border-color .16s;
}

.ticket-composer:focus-within {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-composer:focus-within {
    border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
  }
}

.ticket-composer:focus-within {
  box-shadow: var(--shadow-soft), 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .ticket-composer:focus-within {
    box-shadow: var(--shadow-soft), 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
  }
}

.ticket-composer-textarea {
  resize: vertical;
  min-height: 96px;
}

.ticket-composer-row {
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  display: flex;
}

.ticket-composer-row small {
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  letter-spacing: .01em;
  font-size: 12px;
  font-weight: 700;
}

.ticket-composer-send {
  min-width: 132px;
}

.support-messages-empty {
  min-height: 120px;
  color: var(--muted);
  text-align: center;
  place-items: center;
  font-size: 13px;
  display: grid;
}

@keyframes ticket-message-enter {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

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

@media (min-width: 1024px) {
  .support-screen {
    grid-template-rows: auto minmax(0, 1fr);
    align-content: stretch;
    gap: 12px;
    min-height: calc(100dvh - 74px);
  }

  .support-ticket-screen {
    grid-template-rows: auto minmax(0, 1fr);
    align-content: stretch;
    gap: 14px;
    height: calc(100dvh - 68px);
    min-height: 0;
    max-height: calc(100dvh - 68px);
    padding-bottom: 0;
    overflow: hidden;
  }

  .support-overview-card, .support-list-card, .support-ticket-card, .support-conversation-card {
    gap: 14px;
  }

  .support-list-card {
    grid-template-rows: auto minmax(0, 1fr);
    align-content: stretch;
    min-height: 0;
  }

  .support-ticket-list-scroll {
    height: 100%;
    min-height: 0;
  }

  .support-list-card .ticket-list, .support-user-list-skeleton {
    align-content: start;
    padding-right: 4px;
  }

  .support-list-card .support-empty-state {
    place-self: center;
    width: min(100%, 430px);
    height: auto;
    min-height: 220px;
  }

  .support-heading-row {
    grid-template-columns: 46px minmax(0, 1fr);
  }

  .support-heading-icon {
    width: 46px;
    height: 46px;
  }

  .support-new-ticket-button {
    min-height: 62px;
    padding: 10px 12px;
  }

  .support-create-panel-inner {
    padding: 14px;
  }

  .support-status-tabs-trigger {
    text-align: center;
    flex: 1 1 0;
  }

  .ticket-card {
    min-height: 84px;
    padding: 16px 16px 16px 20px;
  }

  .ticket-card-title strong {
    font-size: 15.5px;
  }

  .support-ticket-detail-header {
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    margin-bottom: 0;
  }

  .support-ticket-detail-header .ticket-badges {
    grid-column: 3;
    justify-content: flex-end;
  }

  .support-ticket-screen > .support-ticket-state-card {
    min-height: calc(100dvh - 74px);
  }

  .support-conversation-card {
    grid-template-rows: minmax(0, 1fr) auto;
    align-content: stretch;
    height: 100%;
    min-height: 0;
    overflow: hidden;
  }

  .support-conversation-card--loading {
    grid-template-rows: minmax(0, 1fr);
  }

  .support-ticket-screen .support-message-scroll {
    scrollbar-width: thin;
    height: 100%;
    min-height: 0;
    padding: 20px;
    overflow: hidden;
  }

  .support-ticket-screen .ticket-message-list {
    justify-content: flex-end;
    min-height: 100%;
  }

  .support-ticket-screen .support-messages-empty {
    height: 100%;
    min-height: 0;
  }

  .support-ticket-screen .ticket-composer {
    padding: 14px;
  }

  .support-ticket-screen .ticket-composer-textarea {
    min-height: 92px;
  }

  .ticket-message-row {
    grid-template-columns: 40px minmax(0, 1fr);
  }

  .ticket-message-row--outgoing {
    grid-template-columns: minmax(0, 1fr) 40px;
  }

  .ticket-message-avatar {
    width: 40px;
    height: 40px;
  }
}

@media (max-width: 520px) {
  .support-screen {
    padding-bottom: calc(var(--bottom-nav-height) + var(--bottom-nav-offset) + 24px);
  }

  .support-ticket-screen {
    height: calc(100dvh - max(16px, env(safe-area-inset-top)) - 48px);
    min-height: 0;
    padding-bottom: calc(var(--bottom-nav-height) + max(var(--bottom-nav-offset), env(safe-area-inset-bottom)) + 12px);
    grid-template-rows: auto minmax(0, 1fr);
    align-content: stretch;
    gap: 10px;
    overflow: hidden;
  }

  .support-ticket-screen > .support-ticket-state-card {
    min-height: 100%;
  }

  .support-ticket-screen .support-conversation-card {
    grid-template-rows: minmax(0, 1fr) auto;
    align-content: stretch;
    min-height: 0;
    overflow: hidden;
  }

  .support-ticket-screen .support-conversation-card--loading {
    grid-template-rows: minmax(0, 1fr);
  }

  .support-new-ticket-button {
    grid-template-columns: 38px minmax(0, 1fr) auto;
    min-height: 58px;
    padding: 9px 10px;
  }

  .support-new-ticket-icon {
    width: 38px;
    height: 38px;
  }

  .support-create-grid {
    grid-template-columns: 1fr;
  }

  .support-message-input {
    height: 108px;
    min-height: 108px;
  }

  .support-status-tabs-list {
    width: 100%;
    display: flex;
    overflow-x: auto;
  }

  .support-status-tabs-trigger {
    white-space: nowrap;
    flex: none;
    padding-inline: 10px;
    line-height: 1;
  }

  .support-empty-state {
    min-height: 190px;
  }

  .support-user-ticket-skeleton {
    grid-template-columns: 1fr;
    align-items: start;
    gap: 12px;
    padding: 14px;
  }

  .support-user-ticket-skeleton-side {
    grid-auto-flow: column;
    justify-content: start;
    justify-items: start;
  }

  .ticket-card {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 10px;
    padding: 14px 14px 14px 18px;
  }

  .ticket-card-main {
    gap: 5px;
  }

  .ticket-card-title strong {
    white-space: normal;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    font-size: 14.5px;
    display: -webkit-box;
    overflow: hidden;
  }

  .ticket-card-side {
    align-items: flex-end;
    gap: 6px;
  }

  .ticket-card-badges {
    flex-direction: column;
    align-items: flex-end;
    gap: 5px;
  }

  .support-ticket-detail-header {
    grid-template-columns: auto minmax(0, 1fr);
    gap: 8px 10px;
  }

  .support-ticket-detail-header .ticket-badges {
    grid-column: 2;
    justify-content: flex-start;
  }

  .support-back-button {
    width: fit-content;
  }

  .support-ticket-detail-header .ticket-detail-title h1 {
    font-size: 17px;
    line-height: 1.18;
  }

  .support-message-scroll, .support-admin-message-scroll {
    padding: 12px 10px;
    overflow: visible;
    max-height: none !important;
  }

  .support-ticket-screen .support-message-scroll {
    height: 100%;
    min-height: 0;
    padding: 10px;
    overflow: hidden;
  }

  .support-ticket-screen .ticket-message-list {
    justify-content: flex-end;
    min-height: 100%;
  }

  .support-ticket-screen .support-messages-empty {
    height: 100%;
    min-height: 0;
  }

  .ticket-message-list, .support-admin-messages {
    gap: 14px;
  }

  .ticket-message-row {
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 8px;
  }

  .ticket-message-row--outgoing {
    grid-template-columns: minmax(0, 1fr) 32px;
  }

  .ticket-message-row--outgoing .ticket-message-avatar {
    grid-column: 2;
  }

  .ticket-message-row--outgoing .ticket-message-content {
    grid-column: 1;
    justify-self: end;
    align-items: flex-end;
  }

  .ticket-message-row--incoming .ticket-message-content {
    grid-column: 2;
    justify-self: start;
  }

  .ticket-message-content {
    max-width: min(86%, 100vw - 80px);
  }

  .ticket-message-avatar {
    width: 32px;
    height: 32px;
  }

  .ticket-message-avatar .brand-mark {
    font-size: 18px;
  }

  .ticket-message-bubble {
    border-radius: 14px 14px 14px 4px;
    width: fit-content;
    padding: 9px 11px;
  }

  .ticket-message-row--outgoing .ticket-message-bubble {
    border-radius: 14px 14px 4px;
  }

  .ticket-message-bubble p {
    font-size: 13.5px;
    line-height: 1.45;
  }

  .ticket-composer-textarea {
    min-height: 76px;
  }

  .support-ticket-screen .ticket-composer {
    gap: 6px;
    padding: 9px 10px;
  }

  .support-ticket-screen .ticket-composer-textarea {
    height: 56px;
    min-height: 56px;
  }

  .ticket-composer-row {
    flex-direction: row;
    align-items: center;
  }

  .ticket-composer-send {
    width: auto;
    min-width: 108px;
    padding-inline: 14px;
  }

  .support-new-ticket-button strong, .ticket-card-title strong, .ticket-detail-title h1 {
    letter-spacing: 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;
}

.public-install-shell {
  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;
  overflow-x: hidden;
}

.public-install-brand {
  box-sizing: border-box;
  width: 100%;
  min-height: 48px;
  color: var(--text);
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  text-decoration: none;
  display: flex;
}

.public-install-brand strong {
  color: var(--accent);
  font-size: 15px;
  line-height: 1.2;
}

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

.app-shell .loader .brand-mark.brand-mark-lg {
  width: calc(4.125rem * var(--home-logo-scale, 1));
  height: calc(4.125rem * var(--home-logo-scale, 1));
  font-size: calc(2.875rem * var(--home-logo-scale, 1));
}

.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-logo);
  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, var(--surface-sheen), var(--surface-sheen-soft)), var(--panel);
  box-shadow: var(--shadow-soft), inset 0 1px 0 var(--inset-highlight);
  padding: 14px;
  position: relative;
  overflow: hidden;
}

.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: var(--shadow-soft), 0 0 0 1px var(--accent), inset 0 1px 0 var(--inset-highlight);
}

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

.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), var(--surface-sheen-soft)), var(--panel);
}

@supports (color: color-mix(in lab, red, red)) {
  .status-card-inactive {
    background: linear-gradient(135deg, color-mix(in srgb, var(--danger) 14%, var(--surface-sheen-soft)), var(--surface-sheen-soft)), 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-main {
  flex: auto;
  min-width: 0;
}

.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;
}

.sub-status-details {
  min-width: 0;
}

.status-tariff-action {
  white-space: nowrap;
  flex: none;
  min-height: 34px;
  margin-left: auto;
  padding: 0 12px;
}

@media (max-width: 1023px) {
  .status-card {
    padding: 13px;
  }

  .sub-status {
    grid-template-columns: 34px minmax(0, 1fr);
    align-items: center;
    gap: 8px 10px;
    display: grid;
  }

  .sub-status-icon {
    width: 30px;
    height: 30px;
  }

  .sub-status h2 {
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 14px;
    line-height: 1.14;
    overflow: hidden;
  }

  .sub-status-details {
    align-items: baseline;
    gap: 4px;
    min-width: 0;
    display: flex;
    overflow: hidden;
  }

  .sub-status-details p {
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
    margin-top: 3px;
    line-height: 1.2;
    overflow: hidden;
  }

  .sub-status-details-with-tariff .current-tariff-line {
    flex: 0 auto;
  }

  .sub-status-details-with-tariff .subscription-end-line {
    flex: none;
  }

  .status-tariff-action {
    grid-column: 1 / -1;
    justify-content: center;
    width: 100%;
    margin-left: 0;
  }

  .subscription-renew-action {
    min-height: 54px;
    padding-block: 12px;
    font-size: 15px;
  }

  .subscription-renew-action svg {
    flex: none;
    width: 19px;
    height: 19px;
  }
}

.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;
}

.traffic-card-compact {
  display: grid;
}

.traffic-card-compact .progress {
  margin-top: 8px;
}

.traffic-summary-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
  line-height: 1.15;
  display: grid;
}

.traffic-summary-left, .traffic-summary-right {
  align-items: baseline;
  gap: 5px;
  min-width: 0;
}

.traffic-summary-left {
  color: var(--muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  display: block;
  overflow: hidden;
}

.traffic-summary-right {
  color: var(--text);
  text-align: right;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  justify-content: flex-end;
  font-size: 11px;
  font-weight: 850;
  display: inline-flex;
}

.traffic-summary-separator {
  color: var(--muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .traffic-summary-separator {
    color: color-mix(in srgb, var(--muted) 58%, transparent);
  }
}

.traffic-summary-right .traffic-summary-separator {
  flex: none;
}

.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;
}

.traffic-card-depleted {
  border-color: var(--danger-border);
  background: linear-gradient(135deg, var(--danger), var(--surface-sheen-soft)), var(--panel);
}

@supports (color: color-mix(in lab, red, red)) {
  .traffic-card-depleted {
    background: linear-gradient(135deg, color-mix(in srgb, var(--danger) 16%, var(--surface-sheen-soft)), var(--surface-sheen-soft)), var(--panel);
  }
}

.traffic-card-depleted .traffic-top span, .traffic-card-depleted .traffic-top strong, .traffic-card-depleted .traffic-summary-left, .traffic-card-depleted .traffic-summary-right, .traffic-card-depleted .traffic-summary-separator, .traffic-card-depleted .traffic-meta, .traffic-card-depleted .traffic-percent {
  color: var(--danger-text);
}

.traffic-card-depleted .progress {
  background: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .traffic-card-depleted .progress {
    background: color-mix(in srgb, var(--danger) 18%, transparent);
  }
}

.traffic-card-depleted .progress span {
  background: linear-gradient(90deg, var(--danger), var(--danger));
}

@supports (color: color-mix(in lab, red, red)) {
  .traffic-card-depleted .progress span {
    background: linear-gradient(90deg, var(--danger), color-mix(in srgb, var(--danger) 68%, white));
  }
}

.traffic-card-depleted .progress span {
  box-shadow: 0 0 18px var(--danger);
}

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

.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;
  margin-top: 5px;
}

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

.premium-server-dropdown-inline {
  min-width: 0;
  display: grid;
}

.premium-server-dropdown summary {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  border-radius: 999px;
  min-width: 0;
  min-height: 26px;
  margin: -4px -7px 0;
  padding: 4px 7px;
  list-style: none;
  transition: background .16s, color .16s;
}

.premium-server-dropdown-inline summary {
  max-width: 100%;
  min-height: 0;
  margin: 0;
  padding: 0;
  display: grid;
}

.premium-server-summary {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  gap: 8px;
}

.premium-summary-trigger {
  white-space: nowrap;
  align-items: center;
  gap: 6px;
  min-width: 0;
  display: inline-flex;
  overflow: hidden;
}

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

.premium-server-dropdown summary:focus-visible {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .premium-server-dropdown summary:focus-visible {
    background: color-mix(in srgb, var(--accent) 12%, transparent);
  }
}

.premium-server-dropdown summary:focus-visible {
  box-shadow: 0 0 0 2px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .premium-server-dropdown summary:focus-visible {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 22%, transparent);
  }
}

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

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

.premium-summary-copy {
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 0 auto;
  min-width: 0;
  display: block;
  overflow: hidden;
}

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

.premium-server-help-icon {
  color: var(--muted);
  background: var(--muted);
  border-radius: 999px;
  padding: 1px;
}

@supports (color: color-mix(in lab, red, red)) {
  .premium-server-help-icon {
    background: color-mix(in srgb, var(--muted) 10%, transparent);
  }
}

.premium-server-help-icon {
  transition: color .16s, background .16s, transform .18s;
}

.premium-server-dropdown summary:hover .premium-server-help-icon, .premium-server-dropdown[open] .premium-server-help-icon {
  color: var(--accent);
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .premium-server-dropdown summary:hover .premium-server-help-icon, .premium-server-dropdown[open] .premium-server-help-icon {
    background: color-mix(in srgb, var(--accent) 14%, transparent);
  }
}

.premium-server-list-dropdown {
  opacity: 0;
  transform-origin: top;
  grid-template-rows: 0fr;
  margin-top: 0;
  transition: grid-template-rows .22s, margin-top .22s, opacity .18s, transform .22s;
  display: grid;
  transform: translateY(-2px);
}

.premium-server-dropdown[open] .premium-server-list-dropdown {
  opacity: 1;
  grid-template-rows: 1fr;
  margin-top: 6px;
  transform: translateY(0);
}

.premium-server-list-dropdown > div {
  min-height: 0;
  overflow: hidden;
}

.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 {
  border: 1px solid var(--surface-subtle-border);
  max-width: 100%;
  color: var(--text);
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  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 {
  gap: 12px;
  padding: 14px;
  display: grid;
}

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

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

.trial-offer-card {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .trial-offer-card {
    background: color-mix(in srgb, var(--accent) 7%, var(--panel));
  }
}

.trial-card-head {
  align-items: flex-start;
  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;
}

.trial-card-description {
  color: var(--muted);
  margin: 0;
  font-size: 12px;
  line-height: 1.42;
}

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

.trial-card-facts span {
  border: 1px solid var(--surface-subtle-border);
  background: var(--surface-subtle);
  border-radius: 12px;
  gap: 3px;
  min-width: 0;
  padding: 9px 10px;
  display: grid;
}

.trial-card-facts small {
  color: var(--muted);
  font-size: 10px;
  line-height: 1.2;
}

.trial-card-facts strong {
  overflow-wrap: anywhere;
  color: var(--text);
  font-size: 12px;
  line-height: 1.2;
}

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

.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-topup-validity {
  color: var(--muted);
  margin: 0;
  font-size: 11px;
  line-height: 1.35;
}

.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%, var(--surface-muted));
  }
}

.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-border);
  color: var(--danger-text);
}

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

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

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

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

.devices-inactive-card svg {
  color: var(--danger);
}

.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);
  background: linear-gradient(135deg, var(--surface-sheen), var(--surface-sheen-soft));
  color: var(--text);
  box-shadow: inset 0 1px 0 var(--inset-highlight);
}

.period-card {
  background: var(--surface-muted);
  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%, var(--surface-muted));
  }
}

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

@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 var(--inset-highlight);
  }
}

.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;
}

.method-grid-single .method-card, .method-grid-many .method-card:first-child, .method-grid-many .method-card:last-child:nth-child(2n) {
  grid-column: 1 / -1;
}

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

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

.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%, var(--surface-muted));
  }
}

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

@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 var(--inset-highlight);
  }
}

.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: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-muted);
  gap: 6px;
  padding: 10px 12px;
  display: grid;
}

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

.subscription-purchase-description {
  border: 1px solid var(--accent);
  gap: 6px;
  padding: 11px 12px;
  display: grid;
}

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

.subscription-purchase-description {
  border-radius: var(--radius);
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .subscription-purchase-description {
    background: color-mix(in srgb, var(--accent) 8%, var(--surface-muted));
  }
}

.subscription-purchase-description {
  box-shadow: inset 0 1px 0 var(--inset-highlight);
}

.subscription-purchase-description p {
  color: var(--text);
  overflow-wrap: anywhere;
  margin: 0;
  font-size: 12px;
  line-height: 1.45;
}

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

.skeleton-line, .skeleton-dot, .skeleton-pay-button {
  background: linear-gradient(90deg, var(--muted) 0%, var(--muted) 42%, var(--muted) 84%);
  border-radius: 999px;
  display: block;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .skeleton-line, .skeleton-dot, .skeleton-pay-button {
    background: linear-gradient(90deg, color-mix(in srgb, var(--muted) 10%, transparent) 0%, color-mix(in srgb, var(--muted) 18%, transparent) 42%, color-mix(in srgb, var(--muted) 10%, transparent) 84%);
  }
}

.skeleton-line, .skeleton-dot, .skeleton-pay-button {
  background-size: 220% 100%;
  animation: 1.15s ease-in-out infinite skeleton-shimmer;
}

.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%, var(--surface-muted));
  }
}

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

.tariff-action-card, .tariff-warning-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(135deg, var(--surface-sheen), var(--surface-sheen-soft));
  color: var(--text);
  text-align: left;
  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%, var(--surface-muted));
  }
}

.tariff-warning-card {
  color: var(--warning-text);
  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 {
  background: var(--surface-muted);
  text-align: center;
  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-border);
  background: var(--danger-soft);
  max-width: 280px;
  color: var(--danger-text);
  transform-origin: top;
  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);
  background: var(--panel-2);
  min-width: 0;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .copy-row code {
    background: color-mix(in srgb, var(--panel-2) 86%, transparent);
  }
}

.copy-row code {
  color: var(--text);
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 12px;
  font-size: 12px;
}

.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: var(--surface-sheen-soft);
  gap: 3px;
  padding: 10px 11px;
  display: grid;
}

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

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

.referral-tariff-dropdown {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-sheen-soft);
  min-width: 0;
  display: grid;
}

.referral-tariff-summary {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 10px 11px;
  list-style: none;
  display: grid;
}

.referral-tariff-summary::-webkit-details-marker {
  display: none;
}

.referral-tariff-copy {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.referral-tariff-copy strong {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  overflow: hidden;
}

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

.referral-tariff-dropdown summary:hover .premium-server-help-icon, .referral-tariff-dropdown[open] .premium-server-help-icon {
  color: var(--accent);
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .referral-tariff-dropdown summary:hover .premium-server-help-icon, .referral-tariff-dropdown[open] .premium-server-help-icon {
    background: color-mix(in srgb, var(--accent) 14%, transparent);
  }
}

.referral-tariff-details {
  opacity: 0;
  transform-origin: top;
  grid-template-rows: 0fr;
  padding: 0 8px;
  transition: grid-template-rows .22s, padding .22s, opacity .18s, transform .22s;
  display: grid;
  transform: translateY(-2px);
}

.referral-tariff-details > div {
  min-height: 0;
  overflow: hidden;
}

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

.referral-tariff-dropdown[open] .referral-tariff-details {
  opacity: 1;
  grid-template-rows: 1fr;
  padding: 0 8px 8px;
  transform: translateY(0);
}

.referral-bonus-row-nested {
  background: var(--surface);
}

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

.settings-avatar {
  border: 1px solid var(--border);
  background: var(--surface-muted);
  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, .settings-admin-block {
  gap: 8px;
  display: grid;
}

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

.settings-row {
  text-align: left;
  background: var(--surface-muted);
  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.settings-row-admin {
  border-color: var(--warning-border);
  background: linear-gradient(135deg, var(--warning), var(--warning));
  min-height: 54px;
}

@supports (color: color-mix(in lab, red, red)) {
  .settings-row.settings-row-admin {
    background: linear-gradient(135deg, color-mix(in srgb, var(--warning) 13%, var(--panel)), color-mix(in srgb, var(--warning) 7%, var(--panel-2)));
  }
}

.settings-row.settings-row-admin {
  cursor: pointer;
  transition: transform .14s, border-color .14s, background .14s, box-shadow .14s;
}

.settings-row.settings-row-admin:hover:not(:disabled) {
  border-color: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .settings-row.settings-row-admin:hover:not(:disabled) {
    border-color: color-mix(in srgb, var(--warning) 52%, var(--border));
  }
}

.settings-row.settings-row-admin:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--warning), var(--warning));
}

@supports (color: color-mix(in lab, red, red)) {
  .settings-row.settings-row-admin:hover:not(:disabled) {
    background: linear-gradient(135deg, color-mix(in srgb, var(--warning) 16%, var(--panel)), color-mix(in srgb, var(--warning) 9%, var(--panel-2)));
  }
}

.settings-row.settings-row-admin:active:not(:disabled) {
  transform: translateY(1px);
}

.settings-row.settings-row-admin:focus-visible {
  border-color: var(--warning);
  outline: none;
}

@supports (color: color-mix(in lab, red, red)) {
  .settings-row.settings-row-admin:focus-visible {
    border-color: color-mix(in srgb, var(--warning) 58%, var(--border));
  }
}

.settings-row.settings-row-admin:focus-visible {
  box-shadow: 0 0 0 2px var(--warning), inset 0 1px 0 var(--inset-highlight);
}

@supports (color: color-mix(in lab, red, red)) {
  .settings-row.settings-row-admin:focus-visible {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--warning) 24%, transparent), inset 0 1px 0 var(--inset-highlight);
  }
}

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

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

@supports (color: color-mix(in lab, red, red)) {
  .settings-row.settings-row-admin > svg:last-child {
    color: color-mix(in srgb, var(--warning) 70%, var(--muted));
  }
}

.settings-row.settings-row-admin strong {
  color: var(--warning-text);
}

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

.settings-row-linked-with-action {
  grid-template-columns: 28px minmax(0, 1fr);
  row-gap: 8px;
}

.settings-inline-action {
  white-space: nowrap;
  grid-column: 1 / -1;
  justify-self: stretch;
  width: 100%;
  max-width: none;
  min-height: 34px;
  padding-left: 10px;
  padding-right: 10px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1.1;
}

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

.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);
  width: min(210px, 100vw - 28px);
  min-width: 170px;
  max-width: min(210px, 100vw - 28px);
  box-shadow: var(--shadow-popover);
  box-sizing: border-box;
  transform-origin: 100% 0;
  animation: .16s ease-out both dropdown-enter;
  overflow: hidden;
}

.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: var(--surface-hover);
}

.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;
}

.telegram-notifications-card {
  border-color: #ff4b4b;
  grid-template-columns: 38px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  width: 100%;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .telegram-notifications-card {
    border-color: color-mix(in srgb, #ff4b4b 46%, var(--border));
  }
}

.telegram-notifications-card {
  background: linear-gradient(135deg, #ff4b4b1c, #00fe7a0d), var(--card);
}

.home-layout > .telegram-notifications-card {
  align-self: end;
}

.telegram-notifications-dot {
  top: 9px;
  right: 9px;
  transform: none;
}

.telegram-notifications-icon {
  background: #ff4b4b;
  border-radius: 10px;
  place-items: center;
  width: 38px;
  height: 38px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .telegram-notifications-icon {
    background: color-mix(in srgb, #ff4b4b 16%, var(--surface));
  }
}

.telegram-notifications-icon {
  color: #ff6b6b;
}

.telegram-notifications-copy {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.telegram-notifications-copy strong {
  color: var(--text);
  font-size: 14px;
  line-height: 1.2;
}

.telegram-notifications-copy small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.telegram-notifications-actions {
  grid-column: 1 / -1;
  grid-template-columns: minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  display: grid;
}

.telegram-notifications-actions .btn {
  white-space: nowrap;
  width: 100%;
  min-width: 0;
}

.telegram-notifications-actions .btn svg {
  flex: none;
}

.telegram-notifications-primary {
  grid-area: 1 / 1;
}

.attention-wrap {
  position: relative;
}

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

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

.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;
  grid-template-columns: repeat(var(--bottom-nav-visible-items, 3), minmax(0, 1fr));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--nav-bg);
  min-height: 64px;
  box-shadow: var(--shadow-soft);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  grid-auto-flow: column;
  gap: 2px;
  display: grid;
  overflow: hidden;
  transform: none;
  position: fixed !important;
}

.bottom-nav-devices {
  grid-template-columns: repeat(var(--bottom-nav-visible-items, 4), minmax(0, 1fr));
}

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

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

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

.bottom-nav .bottom-nav-label {
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
  line-height: 1.1;
  display: block;
  overflow: hidden;
}

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

@media (max-width: 380px) {
  .bottom-nav.bottom-nav-many {
    min-height: 58px;
  }

  .bottom-nav.bottom-nav-many button {
    gap: 0;
    padding: 0 2px;
  }

  .bottom-nav.bottom-nav-many .bottom-nav-label {
    display: none;
  }

  .bottom-nav.bottom-nav-many .nav-attention-dot {
    top: 8px;
    right: calc(50% - 18px);
  }

  .bottom-nav.bottom-nav-many .nav-badge-floating {
    top: 6px;
    right: calc(50% - 24px);
  }
}

@media (max-width: 360px) {
  .bottom-nav {
    min-height: 56px;
  }

  .bottom-nav button {
    gap: 0;
    padding: 0 2px;
  }

  .bottom-nav .bottom-nav-label {
    display: none;
  }

  .bottom-nav .nav-attention-dot {
    top: 8px;
    right: calc(50% - 18px);
  }

  .bottom-nav .nav-badge-floating {
    top: 6px;
    right: calc(50% - 24px);
  }
}

.home-layout {
  grid-template-rows: minmax(min-content, 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: safe center;
  padding-top: 0;
}

.app-shell .home-brand .brand-mark.brand-mark-xl {
  width: calc(6rem * var(--home-logo-scale, 1));
  height: calc(6rem * var(--home-logo-scale, 1));
  font-size: calc(4.375rem * var(--home-logo-scale, 1));
}

.app-shell .login-brand-auth .brand-mark.brand-mark-xl {
  width: calc(116px * var(--home-logo-scale, 1));
  height: calc(116px * var(--home-logo-scale, 1));
  font-size: calc(84px * var(--home-logo-scale, 1));
}

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

.auth-screen {
  align-content: safe 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 h1 {
  overflow-wrap: anywhere;
  color: var(--accent);
  font-size: 32px;
  font-weight: 900;
  font-family: var(--font-logo);
  margin: 0;
  line-height: 1.04;
}

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

.auth-card {
  box-sizing: content-box;
  will-change: height;
  align-content: start;
  transition: height .22s;
  display: grid;
  overflow: hidden;
}

.auth-mode-panel {
  gap: 10px;
  min-width: 0;
  animation: .18s ease-out both auth-mode-enter;
  display: grid;
}

.auth-mode-panel-password {
  padding-top: 2px;
}

.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;
}

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

.password-switch-stack {
  justify-items: center;
  gap: 5px;
  margin-top: -3px;
  display: grid;
}

.password-switch-button, .auth-code-fallback {
  justify-self: center;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

@keyframes auth-mode-enter {
  from {
    opacity: 0;
    transform: translateY(5px) scale(.985);
  }

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

@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 {
  color: var(--accent);
}

.auth-language-trigger {
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  min-height: 26px;
  color: var(--muted);
  font: inherit;
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 7px;
  justify-content: center;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  line-height: 1;
  display: inline-flex;
}

.auth-language-trigger:hover, .auth-language-trigger[data-state="open"] {
  color: var(--accent);
}

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

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

.auth-language-trigger > span:last-of-type {
  text-underline-offset: 2px;
  text-decoration: underline;
}

.auth-language-trigger > svg, .auth-language-trigger > .emoji-flag {
  flex: none;
}

.auth-language-content {
  transform-origin: top;
  width: min(188px, 100vw - 40px);
  min-width: 154px;
}

.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: var(--surface-muted);
  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%, var(--surface-muted));
  }
}

.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(--success-text);
  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(--border-strong);
  border-radius: var(--radius);
  background: var(--panel);
  max-width: min(420px, 100vw - 32px);
  position: fixed;
  bottom: 16px;
  right: 16px;
}

@supports (color: color-mix(in lab, red, red)) {
  .toast {
    background: color-mix(in srgb, var(--panel) 92%, transparent);
  }
}

.toast {
  box-shadow: var(--shadow-popover);
  color: var(--text);
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 800;
  animation: .22s ease-out both toast-enter;
}

.motion-height-stage {
  align-content: start;
  min-width: 0;
  display: grid;
}

.motion-height-stage.motion-height-locked {
  transition: height var(--motion-stage-duration, .36s) cubic-bezier(.22, .72, .2, 1);
  will-change: height;
  overflow: hidden;
}

.motion-height-stage.motion-height-instant {
  transition: none;
}

.motion-enter-card {
  animation: motion-card-enter var(--motion-enter-duration, .34s) cubic-bezier(.22, .72, .2, 1) backwards;
  animation-delay: var(--motion-delay, 0s);
  transform-origin: var(--motion-origin, center top);
  will-change: opacity, transform;
}

.motion-fade-up {
  animation: motion-fade-up var(--motion-enter-duration, .16s) ease-out both;
}

.motion-scale-in {
  animation: motion-scale-in var(--motion-enter-duration, .24s) cubic-bezier(.22, .72, .2, 1) both;
}

.motion-shimmer {
  animation: motion-shimmer var(--motion-shimmer-duration, 1.15s) ease-in-out infinite;
}

@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 motion-card-enter {
  from {
    opacity: 0;
    transform: translate3d(0, 12px, 0) scale(.985);
  }

  70% {
    opacity: 1;
  }

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

@keyframes motion-fade-up {
  from {
    opacity: 0;
    transform: translateY(4px);
  }

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

@keyframes motion-scale-in {
  from {
    opacity: 0;
    transform: scale(.975);
  }

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

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

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

@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, .preview-phone .bottom-nav .bottom-nav-label {
  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;
  }

  .traffic-summary-row {
    gap: 6px;
  }

  .traffic-summary-left, .traffic-summary-right {
    font-size: 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, .auth-mode-panel, .motion-enter-card, .motion-fade-up, .motion-scale-in, .motion-shimmer, .toast {
    animation: none !important;
  }

  .auth-card, .motion-height-stage.motion-height-locked, .premium-server-dropdown summary, .premium-server-help-icon, .premium-server-list-dropdown {
    transition: none !important;
  }
}

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

@media (min-width: 1024px) {
  body {
    background: var(--bg);
  }

  .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;
  }

  .public-install-shell {
    width: auto;
    max-width: none;
    min-height: 100dvh;
    padding: max(28px, env(safe-area-inset-top)) var(--desktop-page-gutter) 40px;
    margin: 0;
    overflow-x: visible;
  }

  .public-install-shell > .public-install-brand, .public-install-shell > main {
    max-width: 1080px;
    margin-left: auto;
    margin-right: auto;
  }

  .public-install-shell > .public-install-brand {
    width: min(100%, 1080px);
  }

  .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;
  }

  .app-shell .home-brand .brand-mark, .app-shell .home-brand .brand-mark.brand-mark-lg, .app-shell .home-brand .brand-mark.brand-mark-xl {
    width: calc(clamp(180px, 18vw, 260px) * var(--home-logo-scale, 1));
    height: calc(clamp(180px, 18vw, 260px) * var(--home-logo-scale, 1));
    font-size: calc(clamp(124px, 13vw, 184px) * var(--home-logo-scale, 1));
  }

  .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;
    background: var(--rail-bg) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    backdrop-filter: blur(14px) !important;
    height: 100dvh !important;
    box-shadow: inset -1px 0 0 var(--border) !important;
    border-radius: 0 !important;
    grid-template-rows: none !important;
    grid-template-columns: 1fr !important;
    grid-auto-rows: auto !important;
    grid-auto-columns: 1fr !important;
    grid-auto-flow: row !important;
    align-content: start !important;
    gap: 2px !important;
    padding: 28px 14px !important;
    display: grid !important;
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    overflow: hidden auto !important;
    transform: none !important;
  }

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

  .bottom-nav button {
    color: var(--muted);
    border: 1px solid #0000;
    width: 100%;
    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 42px 12px 14px !important;
    font-size: 13px !important;
    display: grid !important;
  }

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

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

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

  .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, .bottom-nav .nav-badge-floating {
    top: 50%;
    right: 14px;
    transform: translateY(-50%);
  }

  .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-row-linked-with-action {
    grid-template-columns: 28px minmax(0, 1fr) max-content;
    row-gap: 0;
  }

  .settings-row-linked-with-action .settings-inline-action {
    grid-column: auto;
    justify-self: end;
    width: auto;
    max-width: 132px;
  }

  .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 {
    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);
    width: 100%;
    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);
    font-size: 14px;
    font-weight: 800;
    font-family: var(--font-logo);
    letter-spacing: 0;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
    overflow: hidden;
  }
}

.admin-screen-wrap {
  --admin-sidebar-w: var(--desktop-rail-width);
  --admin-header-h: 60px;
  --admin-card-bg: linear-gradient(135deg, var(--surface-sheen), var(--surface-sheen-soft)), var(--admin-surface);
  --admin-card-shadow: var(--shadow-soft), inset 0 1px 0 var(--inset-highlight);
  background: var(--admin-bg);
  width: 100vw;
  height: 100dvh;
  color: var(--admin-text);
  overscroll-behavior: contain;
  z-index: 60;
  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);
  background: var(--rail-bg);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  height: 100%;
  min-height: 0;
  box-shadow: inset -1px 0 0 var(--admin-border);
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: var(--admin-muted) transparent;
  flex-direction: column;
  gap: 1px;
  padding: 22px 14px;
  display: flex;
  overflow: hidden auto;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-sidebar {
    scrollbar-color: color-mix(in srgb, var(--admin-muted) 34%, var(--admin-border)) transparent;
  }
}

.admin-sidebar::-webkit-scrollbar {
  width: 8px;
}

.admin-sidebar::-webkit-scrollbar-track {
  background: none;
}

.admin-sidebar::-webkit-scrollbar-thumb {
  background: var(--admin-muted);
  border: 2px solid #0000;
  border-radius: 999px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-sidebar::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--admin-muted) 34%, var(--admin-border));
  }
}

.admin-sidebar::-webkit-scrollbar-thumb {
  background-clip: padding-box;
}

.admin-sidebar::-webkit-scrollbar-thumb:hover {
  background: var(--admin-muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-sidebar::-webkit-scrollbar-thumb:hover {
    background: color-mix(in srgb, var(--admin-muted) 48%, var(--admin-border));
  }
}

.admin-sidebar::-webkit-scrollbar-thumb:hover {
  background-clip: padding-box;
}

.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: 6px;
  padding: 2px 10px 14px;
  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);
  font-size: 14px;
  font-weight: 800;
  font-family: var(--font-logo);
  letter-spacing: 0;
  text-overflow: ellipsis;
  white-space: nowrap;
  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: 10px 10px 5px;
  font-size: 10px;
  font-weight: 700;
}

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

.admin-nav-item {
  min-height: 38px;
  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: 10px;
  width: 100%;
  padding: 9px 12px;
  font-size: 13px;
  font-weight: 600;
  transition: background .12s, color .12s, border-color .12s;
  display: grid;
  position: relative;
}

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

.admin-nav-item > span:last-child {
  justify-content: flex-end;
  align-items: center;
  min-width: 0;
  display: flex;
}

.admin-nav-item .admin-badge.admin-badge-danger {
  box-sizing: border-box;
  --numeric-badge-optical-y: .5px;
  background: var(--danger);
  color: #fff;
  text-align: center;
  font-variant-numeric: lining-nums;
  font-feature-settings: "lnum";
  border: 0;
  place-items: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  display: inline-grid;
}

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

.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: 10px 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);
  background: var(--surface-muted);
  width: 100%;
  min-width: 0;
  color: var(--admin-text);
  text-align: left;
  cursor: pointer;
  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);
  background: var(--admin-bg);
  flex: none;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 0 28px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-header {
    background: color-mix(in srgb, var(--admin-bg) 82%, transparent);
  }
}

.admin-header {
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}

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

.admin-header-title h2 {
  letter-spacing: 0;
  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-section-stage:has(.support-admin-layout) {
  flex: auto;
  min-height: 0;
}

.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: 0;
  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: 0;
  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: 0;
  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: var(--success-text);
}

.admin-revenue-kpi-growth.is-down {
  color: var(--danger-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);
  box-shadow: var(--shadow-popover);
  border-radius: 12px;
  padding: 12px 14px 14px;
}

.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: 0;
  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-scroll {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 12px;
  max-height: 240px;
}

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

.admin-panel-dash-nodes-grid {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
  padding: 10px;
  display: grid;
}

.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: var(--surface-hover);
}

.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-screen-wrap 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-screen-wrap 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);
  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="open"] {
  animation: .14s cubic-bezier(.16, 1, .3, 1) admin-accordion-open;
}

.admin-accordion-content[data-state="closed"] {
  animation: .11s cubic-bezier(.4, 0, .2, 1) admin-accordion-close;
}

@keyframes admin-accordion-open {
  from {
    opacity: .72;
    height: 0;
  }

  to {
    height: var(--bits-accordion-content-height);
    opacity: 1;
  }
}

@keyframes admin-accordion-close {
  from {
    height: var(--bits-accordion-content-height);
    opacity: 1;
  }

  to {
    opacity: .72;
    height: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .admin-accordion-content[data-state="open"], .admin-accordion-content[data-state="closed"] {
    animation: 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-webhook-hint {
  border-bottom: 1px solid var(--admin-border);
  background: var(--info);
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  align-items: center;
  gap: 16px;
  min-width: 0;
  padding: 14px 18px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-webhook-hint {
    background: color-mix(in srgb, var(--info) 7%, transparent);
  }
}

.admin-webhook-hint-meta {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.admin-webhook-hint-meta strong {
  color: var(--admin-text);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 12px;
  font-weight: 700;
}

.admin-webhook-hint-meta small {
  color: var(--admin-muted);
  overflow-wrap: anywhere;
  font-size: 12px;
  line-height: 1.45;
}

.admin-webhook-value {
  align-items: center;
  gap: 8px;
  min-width: 0;
  display: flex;
}

.admin-webhook-value code {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 8px;
  flex: auto;
  min-width: 0;
  padding: 8px 10px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-webhook-value code {
    background: color-mix(in srgb, var(--admin-bg) 82%, var(--admin-surface-2));
  }
}

.admin-webhook-value code {
  color: var(--admin-text);
  font-family: var(--font-mono);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  line-height: 1.35;
  overflow: hidden;
}

.admin-webhook-copy {
  flex: none;
}

.admin-settings-warning {
  border: 1px solid var(--warning-border);
  background: var(--warning);
  border-radius: 10px;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  min-width: 0;
  margin: 14px 18px 4px;
  padding: 12px 14px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-settings-warning {
    background: color-mix(in srgb, var(--warning) 10%, var(--admin-surface));
  }
}

.admin-settings-warning {
  color: var(--admin-text);
}

.admin-settings-warning > svg {
  color: var(--warning);
}

.admin-settings-warning-copy {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.admin-settings-warning-copy strong {
  font-size: 13px;
  line-height: 1.3;
}

.admin-settings-warning-copy p {
  color: var(--admin-muted);
  margin: 0;
  font-size: 12px;
  line-height: 1.45;
}

.admin-settings-warning-link {
  color: var(--accent);
  white-space: nowrap;
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
}

.admin-settings-warning-link:hover {
  text-decoration: underline;
}

.admin-settings-field-groups {
  gap: 10px;
  padding: 12px 18px 18px;
  display: grid;
}

.admin-settings-field-group {
  border: 1px solid var(--admin-border);
  min-width: 0;
  display: grid;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-settings-field-group {
    border: 1px solid color-mix(in srgb, var(--admin-border) 88%, transparent);
  }
}

.admin-settings-field-group {
  background: var(--admin-bg);
  border-radius: 10px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-settings-field-group {
    background: color-mix(in srgb, var(--admin-bg) 52%, transparent);
  }
}

.admin-settings-field-group.is-dirty {
  border-color: var(--warning-border);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-settings-field-group.is-dirty {
    border-color: color-mix(in srgb, var(--warning-border) 74%, var(--admin-border));
  }
}

.admin-settings-field-group-head {
  border-bottom: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  gap: 3px;
  padding: 10px 14px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-settings-field-group-head {
    background: color-mix(in srgb, var(--admin-surface-2) 56%, transparent);
  }
}

.admin-settings-field-group-head strong {
  color: var(--admin-text);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.25;
}

.admin-settings-field-group-head small {
  color: var(--admin-muted);
  font-size: 11px;
  line-height: 1.35;
}

.admin-settings-field-group-body .admin-setting {
  padding-inline: 14px;
}

.admin-settings-field-group-body .admin-setting:last-child, .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.is-dirty {
  background: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-setting.is-dirty {
    background: color-mix(in srgb, var(--warning) 7%, 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-icon-picker-trigger {
  justify-content: flex-start;
  min-width: 180px;
}

.admin-icon-picker-trigger span {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.admin-icon-picker-dialog {
  width: min(100%, 760px);
}

.admin-icon-picker-body {
  gap: 18px;
  display: grid;
}

.admin-icon-picker-current {
  border: 1px solid var(--admin-border);
  background: linear-gradient(135deg, var(--surface-sheen), transparent), var(--admin-surface-2);
  border-radius: 10px;
  grid-template-columns: 52px minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 14px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-icon-picker-current {
    background: linear-gradient(135deg, var(--surface-sheen), transparent), color-mix(in srgb, var(--admin-surface-2) 86%, transparent);
  }
}

.admin-icon-picker-current-preview {
  border: 1px solid var(--accent);
  place-items: center;
  width: 52px;
  height: 52px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-icon-picker-current-preview {
    border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--admin-border));
  }
}

.admin-icon-picker-current-preview {
  background: var(--accent);
  border-radius: 10px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-icon-picker-current-preview {
    background: color-mix(in srgb, var(--accent) 10%, var(--surface-muted));
  }
}

.admin-icon-picker-current-preview {
  color: var(--admin-text);
}

.admin-icon-picker-current-meta {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.admin-icon-picker-current-meta small {
  color: var(--admin-muted);
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 600;
}

.admin-icon-picker-current-meta strong {
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  font-weight: 650;
  overflow: hidden;
}

.admin-icon-picker-toolbar {
  gap: 10px;
  display: grid;
}

.admin-icon-picker-search {
  display: block;
  position: relative;
}

.admin-icon-picker-search > svg {
  color: var(--admin-muted);
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 12px;
  transform: translateY(-50%);
}

.admin-icon-picker-search .input {
  width: 100%;
  padding-left: 36px;
}

.admin-icon-picker-scroll {
  border-radius: 10px;
}

.admin-icon-picker-grid {
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
  padding: 2px 4px 4px 0;
  display: grid;
}

.admin-icon-picker-option {
  border: 1px solid var(--admin-border);
  background: var(--surface-muted);
  min-height: 48px;
  color: var(--admin-text);
  text-align: left;
  cursor: pointer;
  border-radius: 8px;
  grid-template-columns: 24px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 11px 12px;
  display: grid;
}

.admin-icon-picker-option > svg {
  color: var(--admin-muted);
  justify-self: center;
}

.admin-icon-picker-option span {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.admin-icon-picker-option:hover, .admin-icon-picker-option.active {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-icon-picker-option:hover, .admin-icon-picker-option.active {
    border-color: color-mix(in srgb, var(--accent) 45%, var(--admin-border));
  }
}

.admin-icon-picker-option:hover, .admin-icon-picker-option.active {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-icon-picker-option:hover, .admin-icon-picker-option.active {
    background: color-mix(in srgb, var(--accent) 12%, var(--surface-muted));
  }
}

.admin-icon-picker-option.active > svg {
  color: var(--accent);
}

@media (max-width: 640px) {
  .admin-icon-picker-current {
    grid-template-columns: 44px minmax(0, 1fr);
  }

  .admin-icon-picker-current > .admin-btn {
    grid-column: 1 / -1;
    justify-self: start;
  }

  .admin-icon-picker-current-preview {
    width: 44px;
    height: 44px;
  }

  .admin-icon-picker-grid {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  }
}

.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-translations-toolbar {
  grid-template-columns: minmax(220px, 1fr) auto;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
  display: grid;
}

.admin-translations-search {
  min-width: 0;
  display: block;
  position: relative;
}

.admin-translations-search > svg {
  color: var(--admin-muted);
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 12px;
  transform: translateY(-50%);
}

.admin-translations-search .input {
  width: 100%;
  padding-left: 36px;
}

.admin-translations-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  display: flex;
}

.admin-translations-path {
  overflow-wrap: anywhere;
  margin: 0 0 12px;
}

.admin-translations-skeleton {
  gap: 10px;
  display: grid;
}

.admin-translation-skeleton-card {
  gap: 10px;
  padding: 16px 18px;
  display: grid;
}

.admin-translations-language-panel {
  border: 1px solid var(--admin-border);
  background: var(--surface-muted);
  border-radius: 10px;
  grid-template-columns: minmax(180px, .8fr) minmax(0, 1.2fr) auto;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  padding: 12px;
  display: grid;
}

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

.admin-translations-language-head > svg {
  color: var(--admin-muted);
  grid-row: span 2;
}

.admin-translations-language-head strong {
  color: var(--admin-text);
  font-size: 12px;
  font-weight: 700;
}

.admin-translations-language-head small {
  color: var(--admin-muted);
  font-size: 11px;
}

.admin-translations-language-list {
  flex-wrap: wrap;
  gap: 7px;
  min-width: 0;
  display: flex;
}

.admin-translations-language-chip {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  max-width: 180px;
  min-height: 30px;
  color: var(--admin-text);
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  font-size: 11px;
  display: inline-flex;
}

.admin-translations-language-chip.is-custom {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-translations-language-chip.is-custom {
    border-color: color-mix(in srgb, var(--accent) 34%, var(--admin-border));
  }
}

.admin-translations-language-chip strong, .admin-translations-language-chip code {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.admin-translations-language-chip code {
  color: var(--admin-muted);
  font-size: 10px;
}

.admin-translations-language-add {
  grid-template-columns: minmax(100px, 150px) auto;
  align-items: center;
  gap: 8px;
  display: grid;
}

.admin-translations-audience-tabs {
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 12px;
  display: flex;
}

.admin-translations-audience-tabs button {
  border: 1px solid var(--admin-border);
  min-height: 32px;
  color: var(--admin-muted);
  cursor: pointer;
  background: none;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 650;
  transition: background .12s, border-color .12s, color .12s;
}

.admin-translations-audience-tabs button:hover, .admin-translations-audience-tabs button.is-active {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-translations-audience-tabs button:hover, .admin-translations-audience-tabs button.is-active {
    border-color: color-mix(in srgb, var(--accent) 34%, var(--admin-border));
  }
}

.admin-translations-audience-tabs button:hover, .admin-translations-audience-tabs button.is-active {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-translations-audience-tabs button:hover, .admin-translations-audience-tabs button.is-active {
    background: color-mix(in srgb, var(--accent) 11%, transparent);
  }
}

.admin-translations-audience-tabs button:hover, .admin-translations-audience-tabs button.is-active {
  color: var(--admin-text);
}

.admin-translations-audience-section {
  gap: 10px;
  margin-top: 12px;
  display: grid;
}

.admin-translations-audience-head {
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
  min-width: 0;
  padding: 0 2px;
  display: flex;
}

.admin-translations-audience-head span {
  gap: 2px;
  min-width: 0;
  display: grid;
}

.admin-translations-audience-head strong {
  color: var(--admin-text);
  font-size: 13px;
  font-weight: 750;
}

.admin-translations-audience-head small {
  color: var(--admin-muted);
  font-size: 11px;
}

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

.admin-translation-group-description {
  margin: 12px 18px 0;
  font-size: 12px;
  line-height: 1.45;
}

.admin-translation-group-skeleton {
  gap: 10px;
  padding: 14px 18px;
  display: grid;
}

.admin-translation-list {
  min-width: 0;
  display: grid;
}

.admin-translation-row {
  border-bottom: 1px solid var(--admin-border);
  grid-template-columns: minmax(220px, .75fr) minmax(0, 1.35fr);
  align-items: start;
  gap: 20px;
  padding: 16px 18px;
  display: grid;
}

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

.admin-translation-row-skeleton {
  grid-template-columns: minmax(220px, .75fr) minmax(0, 1.35fr);
  padding: 10px 0;
}

.admin-translation-row-skeleton > span {
  gap: 8px;
  display: grid;
}

.admin-translation-locales {
  gap: 8px;
  min-width: 0;
  display: grid;
}

.admin-translation-locale {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 10px;
  min-width: 0;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-translation-locale {
    background: color-mix(in srgb, var(--admin-bg) 70%, transparent);
  }
}

.admin-translation-locale {
  overflow: hidden;
}

.admin-translation-locale.is-overridden {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-translation-locale.is-overridden {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--admin-border));
  }
}

.admin-translation-locale.is-overridden {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-translation-locale.is-overridden {
    background: color-mix(in srgb, var(--accent) 6%, var(--admin-bg));
  }
}

.admin-translation-locale.is-dirty {
  border-color: var(--warning-border);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-translation-locale.is-dirty {
    border-color: color-mix(in srgb, var(--warning-border) 72%, var(--admin-border));
  }
}

.admin-translation-locale.is-dirty {
  background: var(--warning);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-translation-locale.is-dirty {
    background: color-mix(in srgb, var(--warning) 7%, var(--admin-bg));
  }
}

.admin-translation-locale-toggle {
  width: 100%;
  min-width: 0;
  color: inherit;
  text-align: left;
  cursor: pointer;
  background: none;
  border: 0;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 10px 11px;
  display: grid;
}

.admin-translation-locale-toggle:hover, .admin-translation-locale-toggle:focus-visible {
  background: var(--surface-hover);
  outline: none;
}

.admin-translation-locale-main {
  align-items: center;
  gap: 7px;
  min-width: 0;
  display: flex;
}

.admin-translation-locale-main strong {
  min-width: 0;
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 700;
  overflow: hidden;
}

.admin-translation-locale-main code {
  color: var(--admin-muted);
  font-size: 10px;
}

.admin-translation-locale-badges {
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 5px;
  display: flex;
}

.admin-translation-locale.is-expanded .admin-accordion-chev {
  transform: rotate(90deg);
}

.admin-translation-locale-toggle small {
  min-width: 0;
  color: var(--admin-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  grid-column: 1 / -1;
  font-size: 11px;
  line-height: 1.35;
  display: block;
  overflow: hidden;
}

.admin-translation-locale-body {
  gap: 8px;
  min-width: 0;
  padding: 0 11px 11px;
  display: grid;
}

.admin-translation-textarea {
  resize: vertical;
  width: 100%;
  min-height: 82px;
}

.admin-translation-base {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.admin-translation-base small {
  color: var(--admin-muted);
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: 10px;
  font-weight: 700;
}

.admin-translation-base span {
  max-height: 4.2em;
  color: var(--admin-muted);
  overflow-wrap: anywhere;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  font-size: 11px;
  line-height: 1.4;
  display: -webkit-box;
  overflow: hidden;
}

@media (max-width: 860px) {
  .admin-translation-row, .admin-translations-toolbar, .admin-translations-language-panel {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-translations-actions, .admin-translations-language-add {
    justify-content: flex-start;
  }

  .admin-translations-language-add {
    grid-template-columns: minmax(0, 1fr) auto;
  }
}

.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: hidden;
}

.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-payment-dialog {
  width: min(100%, 980px);
  max-height: min(100%, 760px);
}

.admin-payment-dialog-body {
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  min-width: 0;
  display: grid;
}

.admin-payment-aside, .admin-payment-main {
  flex-direction: column;
  gap: 12px;
  min-width: 0;
  display: flex;
}

.admin-payment-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-payment-icon {
  background: var(--accent);
  border-radius: 16px;
  place-items: center;
  width: 56px;
  height: 56px;
  display: grid;
}

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

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

.admin-payment-summary-meta {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.admin-payment-summary-meta strong {
  color: var(--admin-text);
  word-break: break-word;
  font-size: 17px;
  font-weight: 750;
}

.admin-payment-summary-meta small {
  color: var(--admin-muted);
  word-break: break-word;
  font-size: 12px;
  line-height: 1.35;
}

.admin-payment-summary-tags {
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
  display: flex;
}

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

.admin-payment-stat {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 10px;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: center;
  gap: 2px 8px;
  min-width: 0;
  padding: 10px 12px;
  display: grid;
}

.admin-payment-stat > svg {
  color: var(--admin-muted);
  grid-row: span 2;
}

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

.admin-payment-stat strong {
  min-width: 0;
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 700;
  overflow: hidden;
}

.admin-payment-panel {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 12px;
  gap: 10px;
  min-width: 0;
  padding: 12px 14px;
  display: grid;
}

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

.admin-payment-panel-head {
  min-width: 0;
  color: var(--admin-muted);
  align-items: center;
  gap: 8px;
  display: flex;
}

.admin-payment-panel-head h3 {
  color: var(--admin-text);
  margin: 0;
  font-size: 13px;
  font-weight: 700;
}

.admin-payment-meta-list li {
  grid-template-columns: 138px minmax(0, 1fr) auto;
}

.admin-payment-meta-list li > .admin-btn {
  width: 28px;
  min-width: 28px;
  height: 28px;
  min-height: 28px;
}

@media (max-width: 560px) {
  .admin-payment-meta-list li {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 4px 8px;
  }

  .admin-payment-meta-list li > span {
    grid-column: 1 / -1;
  }
}

.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(--info-border);
}

.admin-traffic-card-warning {
  border-color: var(--warning-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, var(--info), var(--info));
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-traffic-bar-premium span {
    background: linear-gradient(90deg, var(--info), color-mix(in srgb, var(--info) 64%, #fff));
  }
}

.admin-traffic-card-warning .admin-traffic-bar span {
  background: linear-gradient(90deg, var(--warning), var(--danger));
}

.admin-traffic-meta {
  color: var(--admin-muted);
  font-size: 11px;
  font-weight: 600;
}

@media (min-width: 860px) {
  .admin-user-dialog-body, .admin-payment-dialog-body {
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    align-items: start;
    gap: 20px;
  }

  .admin-user-aside, .admin-payment-aside {
    position: sticky;
    top: 0;
  }
}

.admin-tariff-management, .admin-tariff-overview-grid {
  gap: 14px;
  display: grid;
}

.admin-tariff-overview-grid > .admin-card {
  min-width: 0;
}

@media (min-width: 980px) {
  .admin-tariff-overview-grid {
    grid-template-columns: minmax(260px, .82fr) minmax(0, 1.6fr);
    align-items: stretch;
  }
}

.admin-tariff-panel-head > div, .admin-tariff-list-head > div {
  min-width: 0;
}

.admin-tariff-panel-head small, .admin-tariff-list-head small {
  max-width: 72ch;
}

.admin-tariff-path {
  width: fit-content;
  max-width: 100%;
  color: var(--admin-dim);
  font-family: var(--font-mono);
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-top: 6px;
  font-size: 11px;
  display: block;
  overflow: hidden;
}

.admin-tariff-currency-body {
  align-content: start;
  gap: 14px;
  display: grid;
}

.admin-tariff-currency-current {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 8px;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  min-width: 0;
  padding: 12px;
  display: flex;
}

.admin-tariff-currency-current span {
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 600;
}

.admin-tariff-currency-current strong {
  color: var(--admin-text);
  font-family: var(--font-mono);
  letter-spacing: 0;
  font-size: 18px;
}

.admin-tariff-catalog-bar {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 10px;
  display: grid;
}

.admin-tariff-currency-field {
  gap: 8px;
  min-width: 0;
  display: grid;
}

.admin-tariff-currency-field > span {
  color: var(--admin-text);
  font-size: 13px;
  font-weight: 500;
}

.admin-currency-input {
  text-transform: uppercase;
  width: 100%;
  max-width: 160px;
}

.admin-provider-summary {
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  min-width: 0;
  display: flex;
}

.admin-provider-currency-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
  display: grid;
}

.admin-provider-currency {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 8px;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  min-width: 0;
  padding: 10px 12px;
  display: flex;
}

.admin-provider-currency.is-supported {
  border-color: var(--success-border);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-provider-currency.is-supported {
    border-color: color-mix(in srgb, var(--success-border) 70%, var(--admin-border));
  }
}

.admin-provider-currency.is-unavailable {
  opacity: .74;
}

.admin-provider-currency-main {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.admin-provider-currency-main strong, .admin-provider-currency-main small {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.admin-provider-currency-main strong {
  color: var(--admin-text);
  font-size: 13px;
  font-weight: 700;
}

.admin-provider-currency-main small {
  color: var(--admin-muted);
  font-size: 11px;
}

.admin-provider-currency > .admin-badge {
  flex: none;
}

.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;
  align-content: start;
  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;
  min-width: 0;
}

.admin-tariff-top > div {
  min-width: 0;
}

.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 {
  overflow-wrap: anywhere;
  min-width: 0;
}

.admin-tariff-actions {
  flex-wrap: wrap;
}

.admin-tariff-settings-card {
  margin-top: 14px;
}

.admin-tariff-settings-form {
  gap: 14px;
}

.admin-trial-settings-body .admin-settings-field-groups {
  padding: 0;
}

.admin-trial-settings-groups .admin-settings-field-group-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
}

.admin-settings-field-group-head-copy {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.admin-trial-setting-row .input, .admin-trial-setting-row .admin-select-trigger {
  width: 100%;
}

.admin-trial-squad-control {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  display: grid;
}

.admin-trial-squad-control .admin-select-trigger, .admin-trial-squad-control .admin-chip-list {
  grid-column: 1 / -1;
}

.admin-tariff-settings-save-row {
  justify-content: flex-end;
  margin-bottom: 12px;
}

.admin-field-label-compact {
  gap: 8px;
}

.admin-field-label-compact .input, .admin-field-label-compact .admin-select-trigger {
  width: 100%;
}

.admin-legacy-tariff-table {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 8px;
  gap: 0;
  display: grid;
  overflow: hidden;
}

.admin-legacy-tariff-row {
  border-top: 1px solid var(--admin-border);
  grid-template-columns: minmax(58px, .7fr) minmax(74px, .8fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-width: 0;
  padding: 10px 12px;
  display: grid;
}

.admin-legacy-tariff-row:first-child {
  border-top: 0;
}

.admin-legacy-tariff-head {
  color: var(--admin-muted);
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 700;
}

.admin-legacy-tariff-row strong {
  color: var(--admin-text);
  font-size: 13px;
}

.admin-legacy-tariff-row .input {
  width: 100%;
  min-width: 0;
}

.admin-legacy-traffic-row {
  margin-top: 14px;
}

.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-row-editor-line.admin-row-editor-6 {
  grid-template-columns: minmax(72px, .8fr) minmax(90px, 1fr) minmax(90px, 1fr) minmax(120px, 1fr) minmax(120px, 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;
    width: 280px;
    box-shadow: var(--shadow-strong);
    flex: none;
    transition: transform .22s;
    position: fixed;
    inset: 0 auto 0 0;
    transform: translateX(-100%);
  }

  .admin-screen-wrap.is-sidebar-open .admin-sidebar {
    transform: translateX(0);
  }

  .admin-screen-wrap.is-admin-language-open .admin-sidebar {
    z-index: 120;
    pointer-events: none;
  }

  .admin-screen-wrap.is-admin-language-open .admin-language-switch {
    pointer-events: auto;
  }

  .admin-sidebar-backdrop {
    background: var(--overlay-scrim);
    z-index: 70;
    cursor: pointer;
    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, .admin-webhook-hint {
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
    padding: 14px;
  }

  .admin-webhook-value {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-webhook-value code {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .admin-webhook-copy {
    align-self: flex-start;
  }

  .admin-settings-warning {
    grid-template-columns: auto minmax(0, 1fr);
    margin: 12px 14px 4px;
  }

  .admin-settings-warning-link {
    grid-column: 2;
    justify-self: start;
  }

  .admin-settings-field-groups {
    padding: 10px 14px 14px;
  }

  .admin-settings-field-group-body .admin-setting {
    padding-inline: 12px;
  }

  .admin-card-head {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    padding: 12px 14px;
  }

  .admin-card-head > .admin-editor-section-actions {
    justify-self: start;
    width: 100%;
  }

  .admin-settings-field-group-head, .admin-trial-settings-groups .admin-settings-field-group-head {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-settings-field-group-head > .admin-badge {
    justify-self: start;
  }

  .admin-setting-meta strong {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-card-body {
    padding: 14px;
  }

  .admin-tariff-panel-head, .admin-tariff-list-head {
    gap: 10px;
  }

  .admin-provider-summary {
    justify-content: flex-start;
  }

  .admin-tariff-catalog-bar {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-currency-input {
    max-width: none;
  }

  .admin-provider-currency {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-provider-currency-main strong, .admin-provider-currency-main small {
    white-space: normal;
  }

  .admin-tariff-card {
    padding: 12px;
  }

  .admin-legacy-tariff-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-legacy-tariff-head {
    display: none;
  }

  .admin-tariff-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    display: grid;
  }

  .admin-tariff-actions .admin-btn {
    width: 100%;
    min-width: 0;
  }

  .admin-tariff-actions .admin-btn[aria-label] {
    width: 100%;
  }

  .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, .admin-row-editor-line.admin-row-editor-6 {
    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;
  }
}

.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: var(--shadow-soft);
}

.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(--success);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-switch-root[data-state="checked"] {
    background: color-mix(in srgb, var(--success) 82%, var(--admin-elev));
  }
}

.admin-switch-root[data-state="checked"] {
  border-color: var(--success);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-switch-root[data-state="checked"] {
    border-color: color-mix(in srgb, var(--success) 52%, 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 span {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.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-width: calc(100vw - 24px);
  max-height: var(--bits-select-content-available-height, 320px);
  border: 1px solid var(--admin-border);
  background: linear-gradient(135deg, var(--surface-sheen), var(--surface-sheen-soft)), var(--admin-surface);
  box-shadow: var(--shadow-popover);
  border-radius: 10px;
  outline: none;
  flex-direction: column;
  gap: 1px;
  padding: 4px;
  display: flex;
  overflow: hidden;
}

.admin-select-viewport {
  max-height: inherit;
  scrollbar-width: thin;
  scrollbar-color: var(--admin-muted) transparent;
  flex-direction: column;
  gap: 1px;
  display: flex;
  overflow-y: auto;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-select-viewport {
    scrollbar-color: color-mix(in srgb, var(--admin-muted) 34%, var(--admin-border)) transparent;
  }
}

.admin-select-viewport::-webkit-scrollbar {
  width: 8px;
}

.admin-select-viewport::-webkit-scrollbar-track {
  background: none;
}

.admin-select-viewport::-webkit-scrollbar-thumb {
  background: var(--admin-muted);
  border: 2px solid #0000;
  border-radius: 999px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-select-viewport::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--admin-muted) 34%, var(--admin-border));
  }
}

.admin-select-viewport::-webkit-scrollbar-thumb {
  background-clip: padding-box;
}

.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 span {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.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: hidden;
}

@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: start;
  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 {
  border: 1px solid var(--danger-border);
  background: var(--danger-soft);
  border-radius: 12px;
  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: var(--danger-text);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 13px;
  font-weight: 700;
}

.admin-danger-zone-head small {
  color: var(--danger-text);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-danger-zone-head small {
    color: color-mix(in srgb, var(--danger-text) 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);
  letter-spacing: 0;
  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;
  }
}

.support-admin-layout {
  min-height: min(820px, calc(100dvh - var(--admin-header-h) - 120px));
  grid-template-columns: minmax(300px, 360px) minmax(520px, 1fr) minmax(280px, 340px);
  align-items: stretch;
  gap: 16px;
  display: grid;
}

.support-admin-inbox, .support-admin-detail, .support-user-context {
  gap: 12px;
  min-width: 0;
  display: grid;
}

.support-admin-inbox, .support-admin-detail {
  align-self: stretch;
  min-height: 0;
}

.support-admin-inbox {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 14px;
  grid-template-rows: auto minmax(0, 1fr);
}

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

.support-admin-inbox {
  padding: 14px;
}

.support-admin-toolbar {
  grid-template-columns: 1fr;
  align-items: stretch;
  gap: 10px;
  display: grid;
}

.support-admin-search {
  min-width: 0;
  display: block;
  position: relative;
}

.support-admin-search svg {
  color: var(--admin-muted);
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 12px;
  transform: translateY(-50%);
}

.support-admin-search .input {
  width: 100%;
  padding-left: 36px;
}

.support-admin-filter-row {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: center;
  gap: 8px;
  display: grid;
}

.support-inbox-list-inner {
  gap: 8px;
  padding-right: 2px;
  display: grid;
}

.support-inbox-row {
  text-align: left;
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 12px;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  width: 100%;
  display: grid;
  position: relative;
}

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

.support-inbox-row {
  color: inherit;
  cursor: pointer;
  padding: 12px 12px 12px 14px;
  transition: border-color .16s, background .16s, box-shadow .16s;
}

.support-inbox-row:before {
  content: "";
  background: var(--admin-border-strong);
  border-radius: 3px;
  width: 3px;
  transition: background .16s;
  position: absolute;
  inset: 10px auto 10px 5px;
}

.support-inbox-row[data-status="open"]:before, .support-inbox-row[data-status="awaiting_admin"]:before {
  background: var(--accent);
}

.support-inbox-row[data-status="awaiting_user"]:before {
  background: var(--info);
}

.support-inbox-row[data-status="resolved"]:before, .support-inbox-row[data-status="closed"]:before {
  background: var(--muted);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-inbox-row[data-status="resolved"]:before, .support-inbox-row[data-status="closed"]:before {
    background: color-mix(in srgb, var(--muted) 70%, transparent);
  }
}

.support-inbox-row[data-priority="urgent"]:before {
  background: var(--danger);
}

.support-inbox-row:hover {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-inbox-row:hover {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--admin-border));
  }
}

.support-inbox-row:hover {
  background: var(--admin-surface);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-inbox-row:hover {
    background: color-mix(in srgb, var(--admin-surface) 78%, var(--accent) 6%);
  }
}

.support-inbox-row.active {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-inbox-row.active {
    border-color: color-mix(in srgb, var(--accent) 60%, var(--admin-border));
  }
}

.support-inbox-row.active {
  background: var(--admin-surface);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-inbox-row.active {
    background: color-mix(in srgb, var(--admin-surface) 82%, var(--accent) 10%);
  }
}

.support-inbox-row.active {
  box-shadow: inset 0 0 0 1px var(--accent);
}

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

.support-inbox-row-avatar {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 999px;
  place-items: center;
  width: 36px;
  height: 36px;
  display: grid;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-inbox-row-avatar {
    background: color-mix(in srgb, var(--admin-surface-2) 80%, transparent);
  }
}

.support-inbox-row-avatar {
  color: var(--admin-muted);
  letter-spacing: .02em;
  font-size: 12px;
  font-weight: 800;
}

.support-inbox-row-avatar img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.support-inbox-row-main {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.support-inbox-row-title {
  align-items: center;
  gap: 8px;
  min-width: 0;
  display: flex;
}

.support-inbox-row-title svg {
  color: var(--accent);
  flex: none;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-inbox-row-title svg {
    color: color-mix(in srgb, var(--accent) 72%, var(--admin-muted));
  }
}

.support-inbox-row-title strong {
  letter-spacing: -.01em;
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.25;
  overflow: hidden;
}

.support-inbox-row-main > small {
  color: var(--admin-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0;
  font-size: 12px;
  font-weight: 600;
  display: block;
  overflow: hidden;
}

.support-row-badges {
  flex-direction: column;
  flex: none;
  align-items: flex-end;
  gap: 6px;
  display: flex;
}

.support-row-badges small {
  color: var(--admin-muted);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  margin: 0;
  font-size: 11px;
}

.support-row-badges b {
  box-sizing: border-box;
  --numeric-badge-optical-y: .5px;
  background: var(--danger);
  color: #fff;
  text-align: center;
  font-variant-numeric: lining-nums;
  font-feature-settings: "lnum";
  min-width: 22px;
  height: 22px;
  box-shadow: 0 0 0 3px var(--danger);
  border-radius: 999px;
  place-items: center;
  padding: 0 7px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  display: inline-grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-row-badges b {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--danger) 22%, transparent);
  }
}

.support-ticket-header {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 14px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 14px 16px;
  display: grid;
}

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

.support-ticket-header {
  padding: 16px;
}

.support-ticket-title {
  gap: 8px;
  min-width: 0;
  display: grid;
}

.support-ticket-title small, .support-ticket-controls label > span {
  color: var(--admin-muted);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
}

.support-ticket-title h3 {
  overflow-wrap: anywhere;
  letter-spacing: -.01em;
  color: var(--admin-text);
  margin: 0;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.25;
}

.support-ticket-title-badges {
  flex-wrap: wrap;
  gap: 6px;
  display: flex;
}

.support-ticket-close {
  white-space: nowrap;
  place-self: start end;
}

.support-ticket-controls {
  border-top: 1px solid var(--admin-border);
  grid-column: 1 / -1;
  grid-template-columns: repeat(3, minmax(140px, 1fr));
  gap: 10px;
  padding-top: 12px;
  display: grid;
}

.support-ticket-controls label {
  gap: 6px;
  min-width: 0;
  display: grid;
}

.support-admin-message-scroll {
  border-color: var(--admin-border);
  background: var(--admin-bg);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-message-scroll {
    background: color-mix(in srgb, var(--admin-bg) 70%, transparent);
  }
}

.support-admin-messages .ticket-message-content {
  max-width: min(78%, 760px);
}

.support-admin-messages .ticket-message-bubble {
  --ticket-bubble-border: var(--admin-border);
  border-color: var(--admin-border);
}

.support-admin-composer {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 14px;
  gap: 10px;
  margin-top: 12px;
  padding: 14px;
  transition: border-color .16s;
  display: grid;
}

.support-admin-composer:focus-within {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-composer:focus-within {
    border-color: color-mix(in srgb, var(--accent) 48%, var(--admin-border));
  }
}

.support-admin-composer:focus-within {
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-composer:focus-within {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent);
  }
}

.support-admin-composer-textarea {
  resize: vertical;
  min-height: 118px;
}

.support-admin-composer-row {
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  display: flex;
}

.support-admin-note-toggle {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 999px;
  align-items: center;
  gap: 10px;
  min-width: 0;
  padding: 6px 10px 6px 6px;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-note-toggle {
    background: color-mix(in srgb, var(--admin-surface-2) 78%, transparent);
  }
}

.support-admin-note-toggle label {
  color: var(--admin-muted);
  cursor: pointer;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 700;
  display: inline-flex;
}

.support-admin-note-toggle label svg {
  color: var(--warning);
}

.support-user-context {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 14px;
  align-content: start;
  gap: 14px;
  display: grid;
}

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

.support-user-context {
  padding: 16px;
}

.support-user-context > h3 {
  letter-spacing: .08em;
  color: var(--admin-muted);
  text-transform: uppercase;
  margin: 0;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
}

.support-user-context-head {
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  display: grid;
}

.support-user-context-avatar {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  border-radius: 999px;
  place-items: center;
  width: 48px;
  height: 48px;
  display: grid;
  overflow: hidden;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-user-context-avatar {
    background: color-mix(in srgb, var(--admin-surface-2) 80%, transparent);
  }
}

.support-user-context-avatar {
  color: var(--admin-text);
  letter-spacing: .02em;
  font-size: 14px;
  font-weight: 800;
}

.support-user-context-avatar img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.support-user-context-identity strong {
  letter-spacing: -.01em;
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.2;
  overflow: hidden;
}

.support-user-context-identity small {
  color: var(--admin-muted);
  font-variant-numeric: tabular-nums;
  font-size: 12px;
}

.support-user-context-actions {
  gap: 8px;
  display: grid;
}

.support-user-context dl {
  border-top: 1px solid var(--admin-border);
  border-bottom: 1px solid var(--admin-border);
  grid-template-columns: minmax(80px, auto) 1fr;
  gap: 8px 12px;
  margin: 0;
  padding: 10px 0;
  display: grid;
}

.support-user-context dt {
  color: var(--admin-muted);
  letter-spacing: .06em;
  text-transform: uppercase;
  align-self: center;
  margin: 0;
  font-size: 11px;
  font-weight: 700;
}

.support-user-context dd {
  color: var(--admin-text);
  overflow-wrap: anywhere;
  align-self: center;
  margin: 0;
  font-size: 13px;
  font-weight: 600;
}

.support-user-context .admin-btn {
  justify-content: center;
  width: 100%;
}

@media (min-width: 981px) {
  .support-admin-layout {
    height: clamp(620px, calc(100dvh - var(--admin-header-h) - 120px), 820px);
  }

  .support-admin-detail {
    border: 1px solid var(--admin-border);
    background: var(--admin-surface);
    border-radius: 14px;
    grid-template-rows: auto minmax(0, 1fr) auto;
    gap: 0;
  }

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

  .support-admin-detail {
    padding: 16px;
  }

  .support-admin-detail > .admin-empty-state {
    align-self: stretch;
    min-height: 420px;
  }

  .support-admin-detail .support-ticket-header {
    border: 0;
    border-bottom: 1px solid var(--admin-border);
    background: none;
    border-radius: 0;
    padding: 0 0 14px;
  }

  .support-admin-detail .support-admin-message-scroll {
    background: none;
    border: 0;
    border-radius: 0;
    height: 100%;
    min-height: 0;
    padding: 16px 4px;
    max-height: none !important;
  }

  .support-admin-detail .support-admin-composer {
    border: 0;
    border-top: 1px solid var(--admin-border);
    background: none;
    border-radius: 0;
    margin-top: 0;
    padding: 14px 0 0;
  }

  .support-admin-detail .support-admin-composer:focus-within {
    box-shadow: none;
    border-color: #0000;
  }

  .support-user-context {
    align-self: start;
    position: sticky;
    top: 0;
  }
}

@media (max-width: 1420px) {
  .support-admin-layout {
    grid-template-columns: minmax(280px, 350px) minmax(0, 1fr);
  }

  .support-user-context {
    grid-column: 1 / -1;
    position: static;
  }
}

@media (max-width: 980px) {
  .support-admin-layout {
    grid-template-columns: 1fr;
    gap: 12px;
    height: auto;
    min-height: 0;
  }

  .support-admin-inbox {
    border-radius: 12px;
    padding: 12px;
  }

  .support-admin-filter-row, .support-ticket-controls {
    grid-template-columns: 1fr;
  }

  .support-ticket-header {
    border-radius: 12px;
    grid-template-columns: 1fr;
    padding: 14px;
  }

  .support-admin-composer, .support-user-context {
    border-radius: 12px;
    padding: 14px;
  }

  .support-inbox-row {
    grid-template-columns: 32px minmax(0, 1fr) auto;
    gap: 10px;
    padding: 11px 11px 11px 13px;
  }

  .support-inbox-row-avatar {
    width: 32px;
    height: 32px;
  }

  .support-row-badges {
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
  }

  .support-ticket-title h3 {
    font-size: 17px;
  }

  .support-ticket-controls {
    padding-top: 10px;
  }

  .support-admin-messages .ticket-message-content {
    max-width: min(86%, 100vw - 80px);
  }

  .support-admin-composer-row {
    flex-direction: column;
    align-items: stretch;
  }

  .support-admin-composer-row .admin-btn {
    width: 100%;
  }
}

.support-admin-layout {
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
  width: 100%;
  min-height: 0;
  display: grid;
}

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

.support-admin-summary span {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 12px;
  gap: 2px;
  min-width: 0;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-summary span {
    background: color-mix(in srgb, var(--admin-surface) 86%, var(--admin-bg));
  }
}

.support-admin-summary span {
  box-shadow: var(--admin-card-shadow);
  padding: 12px 14px;
}

.support-admin-summary strong {
  color: var(--admin-text);
  font-variant-numeric: tabular-nums;
  font-size: 24px;
  font-weight: 750;
  line-height: 1;
}

.support-admin-summary small {
  min-width: 0;
  color: var(--admin-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 650;
  line-height: 1.25;
  overflow: hidden;
}

.support-admin-workspace {
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
  min-height: 0;
  display: grid;
}

.support-admin-inbox, .support-admin-detail, .support-admin-detail .support-ticket-header, .support-admin-detail .support-admin-composer, .support-user-context {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 12px;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-inbox, .support-admin-detail, .support-admin-detail .support-ticket-header, .support-admin-detail .support-admin-composer, .support-user-context {
    background: color-mix(in srgb, var(--admin-surface) 88%, var(--admin-bg));
  }
}

.support-admin-inbox, .support-admin-detail, .support-admin-detail .support-ticket-header, .support-admin-detail .support-admin-composer, .support-user-context {
  box-shadow: var(--admin-card-shadow);
}

.support-admin-inbox {
  grid-template-rows: auto minmax(0, 1fr);
  gap: 12px;
  min-width: 0;
  min-height: 0;
  padding: 14px;
  display: grid;
}

.support-admin-inbox .support-admin-toolbar {
  box-shadow: none;
  background: none;
  border: 0;
  padding: 0;
}

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

.support-admin-filter-row > :last-child {
  grid-column: 1 / -1;
}

.support-inbox-list {
  min-height: 0;
  overflow: hidden;
}

.support-inbox-list-inner {
  align-content: start;
  padding-right: 2px;
}

.support-inbox-row {
  background: var(--admin-surface);
  border-radius: 10px;
  min-height: 82px;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-inbox-row {
    background: color-mix(in srgb, var(--admin-surface) 74%, var(--admin-bg));
  }
}

.support-inbox-row-title strong {
  letter-spacing: 0;
}

.support-row-badges {
  min-width: 86px;
  max-width: 132px;
}

.support-row-badges .admin-badge {
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
}

.support-admin-detail {
  grid-template-rows: auto;
  gap: 12px;
  min-width: 0;
  min-height: 0;
  padding: 14px;
  display: grid;
}

.support-admin-detail > .admin-empty-state {
  align-self: stretch;
  min-height: 360px;
}

.support-admin-detail .support-ticket-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 14px;
  padding: 14px;
  display: grid;
}

.support-ticket-actions {
  justify-content: flex-end;
  display: flex;
}

.support-ticket-close {
  white-space: nowrap;
}

.support-ticket-controls {
  border-top: 1px solid var(--admin-border);
  flex-wrap: wrap;
  grid-column: 1 / -1;
  gap: 10px;
  padding-top: 12px;
  display: flex;
}

.support-ticket-controls label {
  flex: 150px;
  gap: 6px;
  min-width: 0;
  display: grid;
}

.support-admin-detail .support-admin-message-scroll {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 12px;
  min-height: 240px;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-detail .support-admin-message-scroll {
    background: color-mix(in srgb, var(--admin-bg) 68%, transparent);
  }
}

.support-admin-detail .support-admin-message-scroll {
  padding: 16px;
}

.support-admin-detail .support-admin-composer {
  gap: 10px;
  margin-top: 0;
  padding: 14px;
  display: grid;
}

.support-admin-detail .support-admin-composer-textarea {
  min-height: 86px;
}

.support-admin-detail .support-admin-composer:focus-within {
  border-color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-detail .support-admin-composer:focus-within {
    border-color: color-mix(in srgb, var(--accent) 48%, var(--admin-border));
  }
}

.support-admin-detail .support-admin-composer:focus-within {
  box-shadow: var(--admin-card-shadow), 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-detail .support-admin-composer:focus-within {
    box-shadow: var(--admin-card-shadow), 0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent);
  }
}

.support-user-context {
  grid-column: auto;
  gap: 12px;
  min-width: 0;
  padding: 12px;
  display: grid;
  position: static;
}

.support-user-context-head {
  grid-template-columns: 44px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-width: 0;
  display: grid;
}

.support-user-context-avatar {
  width: 44px;
  height: 44px;
}

.support-user-context-identity {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.support-user-context-identity small {
  color: var(--admin-muted);
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 750;
  line-height: 1.1;
}

.support-user-context-identity strong, .support-user-context-identity span {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.support-user-context-identity strong {
  color: var(--admin-text);
  font-size: 14px;
  font-weight: 750;
  line-height: 1.15;
}

.support-user-context-identity span {
  color: var(--admin-muted);
  font-variant-numeric: tabular-nums;
  font-size: 12px;
}

.support-user-context-metrics {
  grid-template-columns: repeat(auto-fit, minmax(112px, 1fr));
  gap: 8px;
  min-width: 0;
  display: grid;
}

.support-user-context-metrics span {
  border: 1px solid var(--admin-border);
  gap: 4px;
  min-width: 0;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-user-context-metrics span {
    border: 1px solid color-mix(in srgb, var(--admin-border) 82%, transparent);
  }
}

.support-user-context-metrics span {
  background: var(--admin-surface-2);
  border-radius: 10px;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-user-context-metrics span {
    background: color-mix(in srgb, var(--admin-surface-2) 68%, var(--admin-bg));
  }
}

.support-user-context-metrics span {
  padding: 9px 10px;
}

.support-user-context-metrics small {
  color: var(--admin-muted);
  letter-spacing: .05em;
  text-transform: uppercase;
  font-size: 10px;
  font-weight: 750;
  line-height: 1.1;
}

.support-user-context-metrics strong {
  min-width: 0;
  color: var(--admin-text);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 650;
  line-height: 1.25;
  overflow: hidden;
}

.support-user-context-actions {
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  gap: 8px;
  display: flex;
}

.support-user-context-actions .admin-btn {
  justify-content: center;
  width: auto;
}

@media (min-width: 981px) {
  .support-admin-workspace {
    height: clamp(660px, calc(100dvh - var(--admin-header-h) - 112px), 840px);
    grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
  }

  .support-admin-inbox, .support-admin-detail {
    height: 100%;
  }

  .support-admin-detail {
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    overflow: hidden;
  }

  .support-admin-detail .support-admin-message-scroll {
    height: 100%;
    min-height: 0;
    overflow: hidden;
    max-height: none !important;
  }
}

@media (min-width: 1360px) {
  .support-user-context {
    grid-template-columns: minmax(170px, .65fr) minmax(260px, 1.35fr) auto;
    align-items: center;
  }

  .support-user-context-actions {
    justify-content: flex-end;
  }
}

@media (max-width: 640px) {
  .support-admin-summary, .support-admin-detail .support-ticket-header {
    grid-template-columns: minmax(0, 1fr);
  }

  .support-ticket-actions {
    justify-content: stretch;
  }

  .support-ticket-actions .admin-btn, .support-user-context-actions .admin-btn {
    width: 100%;
  }

  .support-ticket-controls, .support-admin-composer-row {
    flex-direction: column;
    align-items: stretch;
  }

  .support-ticket-controls label {
    flex-basis: auto;
  }

  .support-inbox-row {
    grid-template-columns: 32px minmax(0, 1fr);
  }

  .support-row-badges {
    flex-direction: row;
    grid-column: 2;
    justify-content: flex-start;
    align-items: center;
    min-width: 0;
    max-width: none;
  }
}

.support-admin-layout {
  flex: auto;
  grid-template-rows: auto minmax(0, 1fr);
  grid-template-columns: minmax(0, 1fr);
  align-content: start;
  gap: 14px;
  height: 100%;
  min-height: 0;
}

.support-admin-summary span {
  min-height: 66px;
}

.support-admin-list-panel {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 12px;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 12px;
  min-width: 0;
  min-height: 0;
  display: grid;
}

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

.support-admin-list-panel {
  box-shadow: var(--admin-card-shadow);
  padding: 14px;
}

.support-admin-ticket-tabs {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-ticket-tabs {
    background: color-mix(in srgb, var(--admin-bg) 78%, var(--admin-surface));
  }
}

.support-admin-ticket-tabs {
  padding: 4px;
}

.support-admin-ticket-tabs button {
  min-width: 0;
  min-height: 34px;
  color: var(--admin-muted);
  font: inherit;
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 750;
  display: inline-flex;
}

.support-admin-ticket-tabs button.active {
  background: var(--admin-surface);
  color: var(--admin-text);
  box-shadow: var(--admin-card-shadow);
}

.support-admin-ticket-tabs button b {
  background: var(--admin-surface-2);
  border-radius: 999px;
  place-items: center;
  min-width: 21px;
  height: 21px;
  display: inline-grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-ticket-tabs button b {
    background: color-mix(in srgb, var(--admin-surface-2) 76%, transparent);
  }
}

.support-admin-ticket-tabs button b {
  color: var(--admin-muted);
  padding-inline: 7px;
  font-size: 11px;
  font-weight: 850;
}

.support-admin-ticket-tabs button.active b {
  background: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-ticket-tabs button.active b {
    background: color-mix(in srgb, var(--accent) 18%, transparent);
  }
}

.support-admin-ticket-tabs button.active b {
  color: var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-ticket-tabs button.active b {
    color: color-mix(in srgb, var(--accent) 78%, white);
  }
}

.support-admin-list-panel .support-admin-toolbar {
  box-shadow: none;
  background: none;
  border: 0;
  grid-template-columns: minmax(260px, .85fr) minmax(0, 1.35fr);
  align-items: start;
  gap: 10px;
  padding: 0;
  display: grid;
}

.support-admin-list-panel .support-admin-search .input {
  box-sizing: border-box;
  height: 36px;
  padding-left: 42px;
}

.support-admin-list-panel .support-admin-filter-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  gap: 8px;
  display: grid;
}

.support-admin-list-panel .support-admin-filter-row .admin-select-trigger, .support-admin-list-panel .support-admin-filter-row .admin-btn {
  height: 46px;
  min-height: 46px;
}

.support-admin-list-panel .support-admin-filter-row > :last-child {
  grid-column: auto;
}

.support-admin-list-panel .support-inbox-list {
  height: 100%;
  min-height: 0;
  padding: 0;
  overflow: hidden;
}

.support-admin-list-panel .support-inbox-list-inner {
  align-content: start;
  gap: 8px;
  padding-right: 4px;
  display: grid;
}

.support-admin-list-panel > .admin-empty-state {
  border: 1px dashed var(--admin-border);
  align-self: stretch;
  place-items: center;
  height: 100%;
  min-height: 0;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-list-panel > .admin-empty-state {
    border: 1px dashed color-mix(in srgb, var(--admin-border) 84%, transparent);
  }
}

.support-admin-list-panel > .admin-empty-state {
  background: var(--admin-bg);
  border-radius: 10px;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-list-panel > .admin-empty-state {
    background: color-mix(in srgb, var(--admin-bg) 66%, transparent);
  }
}

.support-admin-list-panel .support-inbox-row {
  background: var(--admin-surface);
  border-radius: 10px;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  min-height: 74px;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-admin-list-panel .support-inbox-row {
    background: color-mix(in srgb, var(--admin-surface) 74%, var(--admin-bg));
  }
}

.support-admin-list-panel .support-inbox-row[data-priority="high"]:before {
  background: var(--warning);
}

.support-admin-list-panel .support-inbox-row[data-priority="urgent"]:before {
  background: var(--danger);
}

.support-admin-list-panel .support-inbox-row-avatar {
  width: 38px;
  height: 38px;
}

.support-admin-list-panel .support-row-badges {
  flex-flow: wrap;
  justify-content: flex-end;
  align-items: center;
  min-width: 168px;
  max-width: 240px;
}

.support-admin-list-panel .support-row-badges small {
  text-align: right;
  flex-basis: 100%;
}

.support-ticket-list-skeleton {
  gap: 8px;
  display: grid;
}

.support-ticket-row-skeleton {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 10px;
  grid-template-columns: 38px minmax(0, 1fr) minmax(120px, auto);
  align-items: center;
  gap: 12px;
  min-height: 74px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-ticket-row-skeleton {
    background: color-mix(in srgb, var(--admin-surface) 74%, var(--admin-bg));
  }
}

.support-ticket-row-skeleton {
  padding: 12px 14px;
}

.support-ticket-row-skeleton-main, .support-ticket-row-skeleton-side {
  gap: 8px;
  min-width: 0;
  display: grid;
}

.support-ticket-row-skeleton-side {
  justify-items: end;
}

.support-ticket-dialog {
  grid-template-rows: auto minmax(0, 1fr);
  width: min(1040px, 100vw - 28px);
  max-height: min(840px, 100dvh - 28px);
  display: grid;
  overflow: hidden;
}

.support-ticket-dialog .support-ticket-header, .support-ticket-dialog .support-user-context, .support-ticket-dialog .support-admin-composer {
  border: 1px solid var(--admin-border);
  background: var(--admin-surface);
  border-radius: 12px;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-ticket-dialog .support-ticket-header, .support-ticket-dialog .support-user-context, .support-ticket-dialog .support-admin-composer {
    background: color-mix(in srgb, var(--admin-surface) 88%, var(--admin-bg));
  }
}

.support-ticket-dialog .support-ticket-header, .support-ticket-dialog .support-user-context, .support-ticket-dialog .support-admin-composer {
  box-shadow: none;
}

.support-ticket-dialog .support-ticket-header {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  padding: 14px;
  display: grid;
}

.support-ticket-dialog .support-user-context {
  padding: 12px;
}

.support-ticket-dialog .support-admin-message-scroll {
  border: 1px solid var(--admin-border);
  background: var(--admin-bg);
  border-radius: 12px;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  max-height: none !important;
}

@supports (color: color-mix(in lab, red, red)) {
  .support-ticket-dialog .support-admin-message-scroll {
    background: color-mix(in srgb, var(--admin-bg) 68%, transparent);
  }
}

.support-ticket-dialog .support-admin-message-scroll {
  padding: 16px;
}

.support-ticket-dialog-skeleton {
  gap: 12px;
  min-width: 0;
  display: grid;
}

@media (max-width: 1120px) {
  .support-admin-list-panel .support-admin-toolbar, .support-admin-list-panel .support-admin-filter-row {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 720px) {
  .support-admin-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .support-admin-summary span {
    border-radius: 10px;
    min-height: 56px;
    padding: 9px 8px;
  }

  .support-admin-summary strong {
    font-size: 20px;
  }

  .support-admin-summary small {
    font-size: 10px;
  }

  .support-admin-list-panel {
    padding: 12px;
  }

  .support-admin-list-panel .support-inbox-row, .support-ticket-row-skeleton {
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 10px;
  }

  .support-admin-list-panel .support-row-badges, .support-ticket-row-skeleton-side {
    grid-column: 2;
    justify-content: flex-start;
    justify-items: start;
    min-width: 0;
    max-width: none;
  }

  .support-admin-list-panel .support-row-badges small {
    text-align: left;
    flex-basis: auto;
  }

  .support-ticket-dialog {
    border-radius: 14px;
    width: calc(100vw - 16px);
    max-height: calc(100dvh - 16px);
    overflow-y: auto;
  }

  .support-ticket-dialog-body {
    grid-template-rows: auto auto auto auto;
    gap: 10px;
    overflow: visible;
  }

  .support-ticket-dialog .support-ticket-header {
    grid-template-columns: minmax(0, 1fr);
    padding: 12px;
  }

  .support-ticket-dialog .support-ticket-actions {
    justify-content: stretch;
  }

  .support-ticket-dialog .support-ticket-actions .admin-btn {
    width: 100%;
  }

  .support-ticket-dialog .support-admin-message-scroll {
    height: auto;
    min-height: 180px;
    padding: 12px 10px;
    max-height: min(32dvh, 260px) !important;
  }

  .support-ticket-dialog .support-admin-composer-row {
    flex-direction: column;
    align-items: stretch;
  }

  .support-ticket-dialog .support-admin-composer-row .admin-btn {
    width: 100%;
  }
}

.dialog:has(.support-ticket-dialog) {
  align-items: start;
  overflow-y: auto;
}

.support-ticket-dialog {
  border-radius: 16px;
  grid-template-rows: auto;
  gap: 10px;
  width: min(940px, 100vw - 24px);
  max-height: none;
  margin-block: 0;
  padding: 14px;
  display: grid;
  overflow: visible;
}

.support-ticket-dialog .dialog-head {
  border-bottom: 1px solid var(--admin-border);
  align-items: center;
  gap: 10px;
  padding-bottom: 10px;
}

.support-ticket-dialog .dialog-head h2 {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 18px;
  line-height: 1.2;
  overflow: hidden;
}

.support-ticket-dialog .dialog-head p {
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.25;
}

.support-ticket-dialog-body {
  grid-template-rows: auto;
  gap: 10px;
  min-width: 0;
  min-height: 0;
  display: grid;
  overflow: visible;
}

.support-ticket-dialog .support-ticket-header, .support-ticket-dialog .support-user-context, .support-ticket-dialog .support-admin-composer {
  box-shadow: none;
  border-radius: 10px;
}

.support-ticket-dialog .support-ticket-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 10px;
  display: grid;
}

.support-ticket-statusbar {
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-width: 0;
  display: flex;
}

.support-ticket-statusbar .admin-badge {
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 180px;
  overflow: hidden;
}

.support-ticket-dialog .support-ticket-actions {
  justify-content: flex-end;
  display: flex;
}

.support-ticket-dialog .support-ticket-close {
  white-space: nowrap;
  min-height: 34px;
}

.support-ticket-dialog .support-ticket-controls {
  border-top: 1px solid var(--admin-border);
  grid-column: 1 / -1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding-top: 8px;
  display: grid;
}

.support-ticket-dialog .support-ticket-controls .admin-select-trigger {
  min-width: 0;
  height: 34px;
  padding-inline: 10px;
}

.support-ticket-dialog .support-ticket-controls .admin-select-trigger span {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.support-ticket-dialog .support-user-context {
  grid-template-columns: minmax(220px, .9fr) minmax(0, 1.4fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px;
  display: grid;
}

.support-ticket-dialog .support-user-context-head {
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 9px;
}

.support-ticket-dialog .support-user-context-avatar {
  width: 34px;
  height: 34px;
  font-size: 12px;
}

.support-ticket-dialog .support-user-context-identity {
  gap: 2px;
}

.support-ticket-dialog .support-user-context-identity strong {
  font-size: 13px;
}

.support-ticket-dialog .support-user-context-identity small {
  color: var(--admin-muted);
  letter-spacing: 0;
  text-overflow: ellipsis;
  text-transform: none;
  white-space: nowrap;
  font-size: 11px;
  font-weight: 600;
  overflow: hidden;
}

.support-ticket-dialog .support-user-context-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  display: grid;
}

.support-ticket-dialog .support-user-context-metrics span {
  border-radius: 8px;
  gap: 2px;
  min-height: 44px;
  padding: 6px 8px;
}

.support-ticket-dialog .support-user-context-metrics small {
  font-size: 9px;
  line-height: 1;
}

.support-ticket-dialog .support-user-context-metrics strong {
  font-size: 11px;
  line-height: 1.2;
}

.support-ticket-dialog .support-user-context-actions {
  justify-content: flex-end;
  gap: 6px;
  display: flex;
}

.support-ticket-dialog .support-user-context-actions .admin-btn {
  white-space: nowrap;
  border-radius: 7px;
  width: 30px;
  min-width: 30px;
  height: 30px;
  min-height: 30px;
  padding: 0;
}

.support-ticket-dialog .support-admin-message-scroll {
  border-radius: 10px;
  height: auto;
  min-height: 0;
  padding: 12px;
  overflow: visible;
  max-height: none !important;
}

.support-ticket-dialog .support-admin-messages {
  gap: 12px;
}

.support-ticket-dialog .support-admin-composer {
  margin: 0;
  padding: 10px;
}

.support-ticket-dialog .support-admin-composer-textarea {
  min-height: 74px;
}

.support-ticket-dialog .support-admin-composer-row {
  gap: 8px;
}

@media (min-width: 721px) {
  .dialog:has(.support-ticket-dialog) {
    align-items: start;
  }

  .support-ticket-dialog {
    grid-template-rows: auto minmax(0, 1fr);
    height: calc(100dvh - 28px);
    min-height: calc(100dvh - 28px);
    max-height: calc(100dvh - 28px);
    overflow: hidden;
  }

  .support-ticket-dialog-body {
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    min-height: 0;
    overflow: hidden;
  }

  .support-ticket-dialog .support-admin-message-scroll {
    height: 100%;
    min-height: 320px;
    overflow: hidden;
  }
}

@media (max-width: 720px) {
  .dialog:has(.support-ticket-dialog) {
    padding: max(8px, env(safe-area-inset-top)) max(8px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));
  }

  .support-ticket-dialog {
    border-radius: 14px;
    width: calc(100vw - 16px);
    max-height: none;
    padding: 12px;
    overflow: visible;
  }

  .support-ticket-dialog .dialog-head {
    padding-bottom: 8px;
  }

  .support-ticket-dialog .dialog-head h2 {
    font-size: 16px;
  }

  .support-ticket-dialog .support-ticket-header {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    padding: 9px;
  }

  .support-ticket-dialog .support-ticket-actions {
    justify-content: flex-start;
  }

  .support-ticket-dialog .support-ticket-actions .admin-btn {
    width: auto;
  }

  .support-ticket-dialog .support-ticket-controls {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }

  .support-ticket-dialog .support-ticket-controls .admin-select-trigger {
    height: 32px;
    padding-inline: 8px;
    font-size: 12px;
  }

  .support-ticket-dialog .support-user-context {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    padding: 9px;
  }

  .support-ticket-dialog .support-user-context-metrics {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .support-ticket-dialog .support-user-context-actions {
    grid-area: 1 / 2;
    justify-content: flex-start;
    align-self: center;
  }

  .support-ticket-dialog .support-admin-message-scroll {
    height: auto;
    min-height: 0;
    padding: 10px 8px;
    max-height: none !important;
  }

  .support-ticket-dialog .support-admin-composer-row {
    flex-direction: row;
    align-items: center;
  }

  .support-ticket-dialog .support-admin-composer-row .admin-btn {
    width: auto;
  }
}

.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 .admin-translations-search .input, .admin-screen-wrap .admin-icon-picker-search .input, .admin-screen-wrap .support-admin-search .input {
  padding-left: 38px;
}

.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: var(--accent-contrast);
  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) {
  background: var(--surface-hover);
  color: var(--admin-text);
}

.admin-btn.admin-btn-danger {
  background: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-btn.admin-btn-danger {
    background: color-mix(in srgb, var(--danger) 80%, #000);
  }
}

.admin-btn.admin-btn-danger {
  color: #fff;
  border-color: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-btn.admin-btn-danger {
    border-color: color-mix(in srgb, var(--danger) 60%, #000);
  }
}

.admin-btn.admin-btn-danger {
  font-weight: 600;
}

.admin-btn.admin-btn-danger:hover:not(:disabled) {
  background: var(--danger);
  border-color: var(--danger);
}

.admin-btn.admin-btn-danger-soft {
  color: var(--danger-text);
  background: var(--admin-surface-2);
  border-color: var(--danger-border);
}

.admin-btn.admin-btn-danger-soft:hover:not(:disabled) {
  background: var(--danger-soft);
  border-color: var(--danger);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-btn.admin-btn-danger-soft:hover:not(:disabled) {
    border-color: color-mix(in srgb, var(--danger) 50%, transparent);
  }
}

.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(--success-border);
  color: var(--success-text);
  background: var(--success-soft);
}

.admin-badge.admin-badge-danger {
  border-color: var(--danger-border);
  color: var(--danger-text);
  background: var(--danger-soft);
}

.admin-badge.admin-badge-warning {
  border-color: var(--warning-border);
  color: var(--warning-text);
  background: var(--warning-soft);
}

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

.admin-setting-control .input, .admin-setting-control .admin-setting-select, .admin-setting-control .admin-setting-textarea, .admin-setting-control input[type="text"], .admin-setting-control input[type="number"] {
  flex: 160px;
  width: 100%;
  min-width: 0;
}

.admin-setting-control .admin-setting-textarea {
  resize: vertical;
  border: 1px solid var(--admin-border-strong);
  background: var(--admin-bg);
  border-radius: 8px;
  min-height: 86px;
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-setting-control .admin-setting-textarea {
    background: color-mix(in srgb, var(--admin-bg) 82%, var(--admin-surface-2));
  }
}

.admin-setting-control .admin-setting-textarea {
  color: var(--admin-text);
  outline: none;
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.45;
  transition: border-color .12s, box-shadow .12s;
}

.admin-setting-control .admin-setting-textarea:focus {
  border-color: var(--admin-ring);
  box-shadow: 0 0 0 3px var(--accent);
}

@supports (color: color-mix(in lab, red, red)) {
  .admin-setting-control .admin-setting-textarea:focus {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
  }
}

.admin-setting-control .admin-setting-json-textarea {
  min-height: 240px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, monospace;
}

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

.admin-json-file-input {
  clip: rect(0 0 0 0);
  white-space: nowrap;
  width: 1px;
  height: 1px;
  position: absolute;
  overflow: hidden;
}

.admin-json-upload {
  cursor: pointer;
}

.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: var(--accent-contrast);
  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;
}

.admin-mount {
  display: contents;
}

@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*/