:root {
  --accent: #b3093f;
  --accent-strong: #8f0631;
  --danger: #c8192a;
  --success: #1f7a3d;
  --warning: #9a6200;
  --text: #20242a;
  --muted: #667085;
  --line: #dfe4ec;
  --soft-line: #edf1f6;
  --bg: #f7f8fa;
  --panel: #fff;
  --shadow: 0 12px 30px rgba(31, 35, 40, 0.06);
  --control-height: 38px;
  --control-compact-height: 34px;
  --control-radius: 6px;
  --control-padding-x: 12px;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
[v-cloak] { display: none !important; }
.is-hidden { display: none !important; }
html { color: var(--text); background: var(--bg); font-family: "Exo 2", "Google Sans", "Open Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; font-optical-sizing: auto; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: geometricPrecision; }
body { margin: 0; min-width: 320px; overflow-wrap: break-word; word-break: normal; }
a { color: inherit; text-decoration: none; }

.app-header { height: 64px; padding: 0 24px; border-bottom: 1px solid var(--line); background: #fff; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 20px; position: sticky; top: 0; z-index: 10; }
.brand { color: var(--accent); font-weight: 850; font-size: 18px; display: inline-flex; align-items: center; gap: 8px; min-height: 38px; }
.brand-logo { width: 30px; height: 30px; object-fit: contain; border-radius: 6px; }
.version-badge { min-height: 28px; padding: 5px 8px; border: 1px solid var(--soft-line); border-radius: 999px; color: var(--muted); font-size: 12px; font-weight: 800; background: #fbfcfe; white-space: nowrap; }
.header-nav { display: flex; gap: 4px; overflow-x: auto; }
.header-nav a, .side-nav a, .lang-link { min-height: 34px; padding: 8px 10px; border-radius: 6px; color: var(--muted); font-weight: 700; font-size: 14px; white-space: normal; overflow-wrap: anywhere; }
.header-nav a:hover, .side-nav a:hover, .lang-link:hover { color: var(--accent); background: #fff2f6; }
.header-actions { display: flex; align-items: center; gap: 6px; }
.header-actions form { margin: 0; }

.app-shell { width: calc(100vw - 24px); max-width: 1550px; margin: 28px auto 56px; display: grid; gap: 18px; align-items: start; }
.app-shell.with-sidebar { grid-template-columns: 248px minmax(0, 1fr); }
.app-shell.single { grid-template-columns: minmax(0, 1fr); max-width: 1120px; }
.side-nav { position: sticky; top: 86px; display: grid; gap: 4px; min-width: 0; border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 8px; box-shadow: var(--shadow); }
.side-nav a { display: flex; align-items: center; width: 100%; line-height: 1.25; }
.side-nav-divider { display: block; width: 100%; height: 1px; margin: 5px 0; background: var(--line); }
.content-shell { min-width: 0; }
.page-heading { margin-bottom: 18px; display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; }
.page-heading h1 { margin: 0; font-size: 28px; line-height: 1.2; letter-spacing: 0; }
.page-heading p { margin: 6px 0 0; color: var(--muted); }

.panel, .auth-card { border: 1px solid var(--line); border-radius: 8px; background: var(--panel); box-shadow: var(--shadow); }
.panel { padding: 18px; margin-bottom: 18px; }
.panel h2, .settings-item h3 { margin: 0 0 12px; letter-spacing: 0; }
.panel h2 { font-size: 20px; }
.settings-item h3 { font-size: 16px; }
.settings-item p, .muted { color: var(--muted); line-height: 1.45; overflow-wrap: break-word; word-break: normal; }
.section-head { margin-bottom: 14px; display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.section-head h2 { margin: 0 0 4px; }
.section-head p { margin: 0; line-height: 1.4; }
.section-head form { margin: 0; flex: 0 0 auto; }

.metrics-row { display: flex; align-items: stretch; flex-wrap: wrap; gap: 10px; margin-bottom: 18px; }
.metric { flex: 0 1 auto; min-width: 150px; max-width: min(100%, 360px); border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 12px; }
.metric span { display: block; margin-bottom: 4px; color: var(--muted); font-size: 12px; font-weight: 800; text-transform: uppercase; }
.metric strong { font-size: 24px; }
.metric small { display: block; margin-top: 4px; color: var(--muted); font-size: 12px; font-weight: 700; line-height: 1.35; }
.tariff-metric { max-width: min(100%, 420px); }
.tariff-metric strong { display: block; font-size: 18px; line-height: 1.25; overflow-wrap: anywhere; }
.cabinet-metrics-row { align-items: flex-start; }
.cabinet-metrics-row .metric { flex: 0 0 auto; align-self: flex-start; min-height: 0; }
.cabinet-metrics-row .metric:not(.tariff-metric) { width: max-content; min-width: 150px; }
.cabinet-metrics-row .tariff-metric { flex: 0 1 auto; width: max-content; min-width: 240px; max-width: min(100%, 520px); }
.cabinet-metrics-row .tariff-metric strong { overflow-wrap: anywhere; word-break: normal; }

.toolbar, .inline-form, .table-actions, .auth-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.toolbar input,
.toolbar select,
.toolbar button,
.inline-form input,
.inline-form select,
.inline-form button,
.table-actions input,
.table-actions select,
.table-actions button,
.auth-actions input,
.auth-actions select,
.auth-actions button {
  min-height: var(--control-height);
}
.compact-toolbar { margin-bottom: 14px; display: grid; grid-template-columns: minmax(260px, 1fr) 170px 190px auto; gap: 8px; align-items: center; }
.compact-toolbar input, .compact-toolbar select { min-width: 0; }
.toolbar.client-filter-toolbar { display: grid; grid-template-columns: minmax(320px, 1fr) minmax(190px, 210px) minmax(155px, 190px) minmax(150px, 155px) minmax(104px, 104px); justify-content: stretch; align-items: stretch; flex-wrap: nowrap; }
.client-filter-toolbar .filter-search, .client-filter-toolbar select, .client-filter-toolbar button { width: 100%; min-height: var(--control-height); height: var(--control-height); border-radius: var(--control-radius); }
.client-filter-toolbar .filter-search { max-width: none; }
.client-filter-toolbar .sort-mode-select { min-width: 0; }
.client-filter-toolbar .compact { padding-inline: 8px; }
.search-field { position: relative; min-width: 0; max-width: none; }
.search-field .filter-search { padding-right: 34px; }
.search-clear { position: absolute; right: 5px; top: 50%; transform: translateY(-50%); width: 28px; min-height: 28px; padding: 0; border: 1px solid transparent; background: transparent; color: var(--muted); border-radius: 999px; font-size: 18px; }
.search-clear:hover { color: var(--accent); background: #fff2f6; }
.bulk-actions { margin-bottom: 12px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, 0.85fr); gap: 10px; align-items: start; }
.bulk-bar { margin-bottom: 12px; padding: 10px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; display: grid; grid-template-columns: minmax(260px, 1fr) auto; gap: 8px; align-items: center; }
.form-stack, .settings-list { display: grid; gap: 12px; }
.form-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; align-items: end; }
.form-grid .wide { grid-column: span 2; }
.tox.tox-tinymce { width: 100%; max-width: 100%; border-color: var(--line); border-radius: 8px; font-family: inherit; box-shadow: none; }
.tox.tox-tinymce:focus,
.tox.tox-tinymce:focus-within { outline: 0; box-shadow: none; }
.tox.tox-tinymce .tox-edit-area::before,
.tox.tox-tinymce:focus-within .tox-edit-area::before {
  border: 0 !important;
  box-shadow: none !important;
}
.sync-inline { display: inline-flex; align-items: center; gap: 8px; margin: 8px 0 14px; color: var(--muted); font-size: 13px; }
.page-sync-actions { display: grid; gap: 6px; justify-items: end; }
.page-sync-actions form { margin: 0; }
.header-sync { margin: 0; font-size: 12px; font-weight: 800; line-height: 1; }
.sync-dot { display: inline-block; flex: 0 0 8px; width: 8px; height: 8px; border-radius: 50%; background: #16a34a; box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.12); }
.sync-dot.is-spinning { background: var(--accent); box-shadow: 0 0 0 4px rgba(179, 9, 63, 0.12); animation: pulse 1s linear infinite; }
.sync-refreshing .sync-dot, .header-sync .sync-dot { animation: pulse 1s linear infinite; }
.sync-error .sync-dot { background: var(--danger); box-shadow: 0 0 0 4px rgba(200, 25, 42, 0.12); }
.sync-ok .sync-dot { background: var(--success); box-shadow: 0 0 0 4px rgba(31, 122, 61, 0.12); }
@keyframes pulse { 50% { transform: scale(1.35); opacity: 0.65; } }
.broadcast-workspace { padding: 18px; }
.broadcast-vue-form { display: grid; gap: 16px; }
.broadcast-grid { display: grid; grid-template-columns: minmax(520px, 1fr) minmax(260px, 300px); gap: 16px; align-items: start; }
.broadcast-main, .broadcast-side, .broadcast-card { display: grid; gap: 12px; }
.broadcast-main .field-line { display: grid; gap: 6px; }
.broadcast-card { border: 1px solid var(--line); border-radius: 8px; padding: 14px; background: #fff; }
.broadcast-card.full { grid-column: 1 / -1; }
.broadcast-list-head { display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.broadcast-list-head h3, .broadcast-card h3 { margin: 0; }
.broadcast-client-search { max-width: 360px; margin-left: auto; }
.broadcast-availability { min-height: 22px; padding: 8px 10px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; color: var(--muted); }
.broadcast-client-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 8px; max-height: 454px; overflow: auto; padding: 0 8px 18px 0; scroll-padding-bottom: 18px; }
.broadcast-history-scroll { max-height: 520px; overflow: auto; }
.broadcast-client { border: 1px solid var(--line); border-radius: 8px; padding: 10px; align-items: flex-start; min-height: 72px; min-width: 0; overflow: hidden; }
.broadcast-client > span { min-width: 0; display: grid; gap: 3px; }
.broadcast-client strong { display: block; min-width: 0; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.broadcast-client small { min-width: 0; display: flex; flex-wrap: wrap; gap: 6px; color: var(--muted); margin-top: 3px; }
.broadcast-client small span { max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.broadcast-actions { justify-content: flex-end; }
.compact-input { width: 100%; }
.compact-stack { max-height: 220px; overflow: auto; }
.download-links { display: flex; flex-wrap: wrap; gap: 8px; margin: 14px 0; }
.guide-steps { margin: 0; padding-left: 22px; color: var(--text); }
.guide-steps li { margin: 8px 0; }
.form-actions { display: flex; justify-content: flex-end; gap: 8px; }
.form-actions.full { grid-column: 1 / -1; }
.form-actions.align-end { justify-content: flex-end; }
.row-form { display: grid; grid-template-columns: 1.3fr 0.9fr 0.8fr 0.7fr 0.7fr 0.8fr 1.4fr auto; gap: 8px; align-items: center; }
.tariff-row-form { grid-template-columns: 1.3fr 0.8fr 0.65fr 0.75fr 0.8fr 1.4fr auto; }
.danger-inline { margin-top: 8px; display: flex; justify-content: flex-end; }
.compact-settings-list { gap: 10px; }
.tariff-grid-list, .routing-grid-list { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
.tariff-card, .routing-card { position: relative; }
.tariff-create-form { display: grid; grid-template-columns: minmax(180px, 1fr) minmax(96px, 0.45fr) minmax(88px, 0.36fr) minmax(104px, 0.42fr); gap: 12px; align-items: end; }
.tariff-create-form .wide { grid-column: span 2; }
.tariff-create-form .form-actions { grid-column: 1 / -1; }
.tariff-edit-form { display: grid; grid-template-columns: minmax(180px, 1fr) minmax(96px, 0.45fr) minmax(88px, 0.36fr) minmax(104px, 0.42fr); gap: 12px; align-items: end; padding-top: 12px; }
.tariff-edit-form .full { grid-column: 1 / -1; }
.tariff-description { grid-column: 1 / -1; }
.tariff-description textarea { min-height: 126px; line-height: 1.45; }
.tariff-bulk-save { margin-top: 12px; }
.toggle-row { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.toggle-row.full { grid-column: 1 / -1; }
.catalog-card { min-height: 154px; padding: 0; border-color: #dce4ef; background: #fff; display: grid; grid-template-rows: minmax(112px, 1fr) auto; overflow: hidden; cursor: grab; }
.catalog-card:active { cursor: grabbing; }
.catalog-card.is-dragging { opacity: 0.58; border-color: var(--accent); box-shadow: 0 12px 30px rgba(24, 37, 54, 0.14); }
.catalog-card-body { min-width: 0; padding: 12px 14px 10px; display: grid; gap: 8px; align-content: start; }
.tariff-card .catalog-card-body { padding-right: 112px; }
.tariff-card .summary-statuses { position: absolute; top: 12px; right: 14px; max-width: 94px; justify-content: flex-end; }
.tariff-card .summary-statuses .status { min-height: 24px; padding: 3px 8px; font-size: 12px; }
.catalog-card-body h3 { margin: 0 0 6px; color: var(--text); font-size: 17px; font-weight: 750; line-height: 1.22; overflow-wrap: anywhere; }
.catalog-card-facts { margin: 0; display: flex; flex-wrap: wrap; gap: 6px 14px; }
.catalog-card-facts div { min-width: 0; display: flex; align-items: baseline; gap: 4px; }
.catalog-card-facts dt { margin: 0; color: var(--muted); font-size: 14px; font-weight: 650; line-height: 1.3; }
.catalog-card-facts dd { margin: 0; color: var(--text); font-size: 14px; font-weight: 650; line-height: 1.3; overflow-wrap: anywhere; }
.catalog-card-meta { display: grid; gap: 5px; color: var(--muted); font-size: 14px; line-height: 1.35; font-weight: 650; }
.catalog-card-meta p { margin: 0; overflow-wrap: anywhere; }
.catalog-card-meta b { color: var(--muted); font-weight: 650; }
.catalog-card-switches { display: flex; flex-wrap: wrap; gap: 7px; align-items: center; margin-top: 8px; }
.catalog-card .report-switch { min-height: var(--control-compact-height); padding: 0 9px; gap: 6px; border-radius: var(--control-radius); font-size: 13px; font-weight: 650; line-height: 1; }
.catalog-card .report-switch-control { flex: 0 0 26px; width: 26px; height: 15px; }
.catalog-card .report-switch-control::after { top: 3px; left: 3px; width: 9px; height: 9px; }
.catalog-card .report-switch input:checked + .report-switch-control::after { transform: translateX(11px); }

.catalog-card-actions {
  min-height: 48px;
  padding: 13px 12px 0;
  border-top: 1px solid var(--soft-line);
  background: #fff;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  cursor: default;
}
.catalog-card-actions form { margin: 0; }
.catalog-card-actions .compact { min-height: var(--control-compact-height); padding: 0 11px; font-size: 14px; border-radius: var(--control-radius); }
.inline-switch-form { margin: 0; display: inline-flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.routing-card, .tariff-card { min-height: 154px; }
.routing-card .catalog-card-body, .tariff-card .catalog-card-body { min-height: 104px; }
.routing-card .catalog-card-body, .tariff-card .catalog-card-body { gap: 8px; }
.routing-card .catalog-card-meta, .tariff-card .catalog-card-facts { gap: 6px 14px; }
.routing-card .catalog-card-switches, .tariff-card .catalog-card-switches { margin-top: 8px; align-items: center; }
.tariff-card .report-switch { min-width: 92px; justify-content: flex-start; }
.tariff-card .report-switch-text { white-space: nowrap; }
.paged-list-controls { display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: 10px; margin-top: 12px; }
.page-size-control { display: inline-flex; align-items: center; gap: 8px; color: var(--muted); font-weight: 650; }
.page-size-control select { width: auto; min-width: 92px; }
.modal-wide-form { padding-top: 0; }
.summary-statuses { display: inline-flex; flex-wrap: wrap; justify-content: flex-end; gap: 6px; }
.routing-form { display: grid; grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr); gap: 16px; align-items: start; }
.routing-fields, .routing-description { min-width: 0; display: grid; gap: 12px; align-content: start; }
.routing-description { padding-top: 22px; } /* Отступ чтобы выравнять блок ru/en c левыми полями */
.routing-fields textarea[name="value"] { min-height: 226px; font-family: ui-monospace, "SFMono-Regular", Consolas, "Liberation Mono", monospace; line-height: 1.45; }
.routing-switches { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.routing-modal-switches { flex-wrap: nowrap; gap: 6px; }
.routing-modal-switches .report-switch { flex: 0 0 auto; }
.routing-edit-form { align-items: start; padding: 0; border: 0; border-radius: 0; background: transparent; }
.routing-card .summary-statuses { justify-content: flex-start; }
.tariff-switch { align-content: center; }
.card-actions { justify-content: flex-start; }
.card-delete { position: absolute; right: 14px; bottom: 14px; margin: 0; display: flex; }
.admin-telegram-form { display: grid; grid-template-columns: minmax(128px, 1fr) auto; gap: 6px; align-items: center; }
.admin-telegram-form input { min-width: 128px; }
.admin-create-tabs { display: grid; gap: 14px; }
.tab-switcher { display: inline-flex; align-items: center; gap: 2px; width: fit-content; padding: 3px; border: 1px solid var(--line); border-radius: 8px; background: #f8fafc; }
.tab-button { border: 0; background: transparent; color: var(--muted); min-height: 32px; padding: 0 13px; border-radius: 5px; font-weight: 700; cursor: pointer; line-height: 1; display: inline-flex; align-items: center; justify-content: center; }
.tab-button:hover { color: var(--accent); background: #fff; }
.tab-button.is-active { color: var(--accent); background: #fff; box-shadow: 0 1px 4px rgba(15, 23, 42, 0.08); }
.admin-tab-panel[hidden] { display: none; }
.admin-create-form { grid-template-columns: minmax(260px, 360px) minmax(260px, 340px) minmax(180px, 220px) minmax(220px, 1fr); }
.admin-existing-form {
    grid-template-columns: 220px 220px 1fr;
}
.admin-create-form .admin-candidate-picker { grid-column: 1 / -1; }
.admin-create-form .admin-email-field { grid-column: span 1; max-width: 360px; }
.admin-create-form .admin-password-field { max-width: 340px; }
.admin-create-form .admin-tg-field { max-width: 220px; }
.admin-create-form .admin-role-field { max-width: 260px; }
.admin-existing-form .admin-role-field { grid-column: 1; grid-row: 2; }
.admin-existing-form .admin-tg-field { grid-column: 2; grid-row: 2; max-width: 220px; }
.admin-existing-form .admin-role-field,
.admin-existing-form .admin-tg-field { width: 100%; max-width: 220px; }
.admin-existing-form .admin-role-field select,
.admin-existing-form .admin-tg-field input { width: 100%; max-width: 220px; }
.admin-create-form .form-actions.full { grid-column: 1 / -1; }
.admin-telegram-input { width: 132px; max-width: 132px; }
.admin-candidate-picker { grid-column: 1 / -1; display: grid; gap: 8px; align-items: start; }
.admin-candidate-list { max-height: 292px; overflow: auto; border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 6px 8px 18px 6px; scroll-padding-bottom: 18px; display: grid; gap: 6px; }
.admin-candidate-option { min-height: 58px; padding: 9px 10px; border: 1px solid var(--soft-line); border-radius: 6px; background: #fbfcfe; display: grid; grid-template-columns: auto minmax(0, 1fr); gap: 18px; align-items: center; overflow: hidden; }
.admin-candidate-option input[type="radio"] { accent-color: var(--accent); outline: 0; box-shadow: none; }
.admin-candidate-option input[type="radio"]:focus { outline: 0; box-shadow: none; }
.admin-candidate-option:hover { border-color: #f0b3c8; background: #fff8fb; }
.admin-candidate-option span { min-width: 0; display: grid; gap: 2px; }
.admin-candidate-option strong, .admin-candidate-option small { min-width: 0; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.admin-candidate-option small { color: var(--muted); font-weight: 550; }
.admin-bulk-save { margin-top: 12px; }
.admin-table { min-width: 820px; table-layout: fixed; }
.admin-table th:nth-child(1), .admin-table td:nth-child(1) { width: 30%; }
.admin-table th:nth-child(2), .admin-table td:nth-child(2) { width: 150px; }
.admin-table th:nth-child(3), .admin-table td:nth-child(3) { width: 150px; }
.admin-table th:nth-child(4), .admin-table td:nth-child(4) { width: 140px; }
.admin-table th:nth-child(5), .admin-table td:nth-child(5) { width: 140px; }
.admin-table th:nth-child(6), .admin-table td:nth-child(6) { width: 190px; }
.admin-table td { vertical-align: middle; }
.admin-table .status { white-space: nowrap; }
.admin-table .table-actions { flex-wrap: nowrap; justify-content: flex-end; }
.admin-table .table-actions form { margin: 0; }
.admin-table input[type="email"] { min-width: 0; }
.reject-form { display: grid; grid-template-columns: minmax(160px, 1fr) auto; gap: 8px; align-items: center; }
.settings-help { margin: 0 0 14px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; }
.settings-help summary { min-height: 38px; padding: 9px 12px; color: var(--accent); font-weight: 650; cursor: pointer; }
.settings-help .info-grid { padding: 0 12px 12px; grid-template-columns: 1fr; }
.settings-help .info-card { min-width: 0; }
.settings-help .info-card p { overflow-wrap: anywhere; }
.settings-form { display: grid; gap: 12px; }
.runtime-settings-group { display: grid; gap: 12px; }
.runtime-settings-group h3 { margin: 0; }
.settings-group-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.runtime-settings-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.runtime-setting-label { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.field-help {
  display: inline-grid;
  place-items: center;
  width: 16px;
  height: 16px;
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--muted);
  background: #fff;
  font-size: 11px;
  font-weight: 650;
  line-height: 1;
  cursor: help;
}
.field-help:hover,
.field-help:focus-visible { color: var(--accent); border-color: var(--accent); outline: none; }
.runtime-setting-wide { grid-column: 1 / -1; }
.runtime-setting-wide textarea { min-height: 118px; line-height: 1.45; }
.promo-code-panel { display: grid; gap: 14px; }
.promocode-form { align-items: end; padding: 12px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; }
.promocode-form .report-switch { align-self: end; }
.promocode-form .promo-form-actions { grid-column: 3; justify-self: end; }
.promo-code-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.promo-code-card { position: relative; min-height: 116px; align-content: stretch; grid-template-rows: minmax(0, 1fr) auto; padding-right: 96px; }
.promo-code-card h3 { margin: 0 0 6px; overflow-wrap: anywhere; }
.promo-code-card .status { position: absolute; top: 12px; right: 12px; min-height: 24px; padding: 3px 8px; font-size: 12px; justify-self: auto; }
.promo-code-card .catalog-card-actions { margin: 0; min-height: 42px; }
.callback-list { margin: 0 12px 12px; padding: 10px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fff; display: grid; gap: 7px; }
.callback-list > strong { font-size: 14px; }
.callback-list div { display: grid; grid-template-columns: 90px minmax(0, 1fr); gap: 8px; align-items: center; }
.callback-list span { color: var(--muted); font-size: 12px; font-weight: 850; }
.callback-list code { min-width: 0; padding: 6px 8px; border: 1px solid var(--soft-line); border-radius: 6px; background: #fbfcfe; color: var(--text); overflow-wrap: anywhere; }
.callback-list p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.35; }
.history-details summary { color: var(--accent); font-weight: 800; cursor: pointer; }
.history-details pre { margin: 8px 0 0; white-space: pre-wrap; color: var(--muted); font: inherit; font-size: 12px; }
.history-list { margin: 8px 0 0; padding: 0; list-style: none; display: grid; gap: 6px; color: var(--muted); font-size: 13px; }
.history-list li { padding: 7px 8px; border: 1px solid var(--soft-line); border-radius: 6px; background: #fbfcfe; }
.activity-filter-toolbar { margin-bottom: 14px; display: grid; grid-template-columns: minmax(220px, 1fr) minmax(180px, 0.7fr) auto; align-items: stretch; }
.activity-filter-toolbar select, .activity-filter-toolbar button { min-height: var(--control-height); }
.compact-section-head { margin-bottom: 6px; }
.compact-section-head h3 { margin: 0; }
.compact-section-head p { margin: 2px 0 0; color: var(--muted); }
.activity-mini-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 7px; }
.activity-mini-list li { padding: 9px 10px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fff; display: grid; gap: 2px; }
.activity-mini-list span { color: var(--muted); font-size: 12px; font-weight: 750; }
.activity-mini-list strong { font-size: 13px; }
.activity-mini-list p { margin: 0; color: var(--muted); line-height: 1.35; }
.info-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.info-card { border: 1px solid var(--soft-line); border-radius: 8px; padding: 12px; background: #fbfcfe; display: grid; gap: 6px; }
.info-card strong { font-size: 15px; }
.info-card p { margin: 0; color: var(--muted); line-height: 1.4; }
.payment-list { display: grid; gap: 12px; }
.payment-filter-form { margin: 14px 0 8px; display: grid; grid-template-columns: minmax(240px, 1.25fr) minmax(170px, 0.85fr) minmax(150px, 0.65fr) minmax(150px, 0.65fr) auto; gap: 10px; align-items: end; }
.payment-filter-form label { min-width: 0; }
.payment-filter-form input, .payment-filter-form select { width: 100%; }
.payment-filter-actions { display: flex; gap: 8px; justify-content: flex-end; flex-wrap: nowrap; }
.payment-filter-form input,
.payment-filter-form select,
.payment-filter-form button,
.payment-filter-form .ghost-button,
.payment-filter-form .primary-button {
  min-height: var(--control-height);
}
.payment-list-summary { margin: 0 0 12px; }
.payment-card { border: 1px solid var(--line); border-radius: 8px; background: #fff; overflow: hidden; }
.payment-card-head { padding: 12px 14px; border-bottom: 1px solid var(--soft-line); display: flex; align-items: center; justify-content: space-between; gap: 12px; background: #fbfcfe; }
.payment-title { display: flex; align-items: center; gap: 10px; min-width: 0; }
.payment-title strong { font-size: 17px; }
.payment-amount { font-size: 20px; font-weight: 850; white-space: nowrap; }
.payment-card-grid { padding: 14px; display: grid; grid-template-columns: minmax(260px, 1.1fr) minmax(170px, 0.7fr) minmax(230px, 0.9fr) minmax(210px, 0.75fr); gap: 12px; align-items: stretch; }
.payment-client-box, .payment-meta-box { min-width: 0; border: 1px solid var(--soft-line); border-radius: 8px; background: #fff; padding: 10px; display: grid; align-content: start; gap: 6px; }
.payment-tariff-box small { color: var(--muted); line-height: 1.35; }
.field-caption { color: var(--muted); font-size: 11px; font-weight: 850; text-transform: uppercase; letter-spacing: 0; }
.payment-client-meta { display: flex; flex-wrap: wrap; gap: 6px; min-width: 0; }
.payment-client-meta span { min-height: 24px; padding: 2px 8px; border: 1px solid var(--soft-line); border-radius: 4px; color: var(--muted); background: #fbfcfe; font-size: 12px; font-weight: 550; overflow-wrap: anywhere; }
.receipt-actions { display: flex; flex-wrap: nowrap; gap: 8px; align-items: center; }
.receipt-actions .compact { min-width: 84px; }
.payment-card-bottom { padding: 12px 14px; border-top: 1px solid var(--soft-line); display: grid; grid-template-columns: minmax(260px, 1fr) minmax(220px, auto); gap: 12px; align-items: start; }
.payment-actions { display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 8px; }
.payment-actions form { margin: 0; }
.payment-method-picker { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; align-self: stretch; }
.payment-method-picker .field-caption { grid-column: 1 / -1; }
.method-card { position: relative; min-height: 58px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 8px; background: #fff; display: grid; gap: 3px; cursor: pointer; }
.method-card input { position: absolute; inline-size: 1px; block-size: 1px; opacity: 0; pointer-events: none; }
.method-card strong { color: var(--text); }
.method-card small { color: var(--muted); }
.method-card.active { border-color: var(--accent); background: #fff5f8; box-shadow: 0 0 0 3px rgba(179, 9, 63, 0.08); }
.payment-bank-hint { grid-column: 1 / -1; padding: 14px 16px; border: 1px solid var(--soft-line); border-left: 3px solid var(--accent); border-radius: 8px; background: #fbfcfe; color: #46546a; line-height: 1.5; }
.cabinet-payment-panel { display: grid; gap: 16px; }
.cabinet-payment-panel > h2 { margin-bottom: 0; }
.cabinet-subsection { min-width: 0; display: grid; gap: 12px; padding-top: 16px; border-top: 1px solid var(--soft-line); }
.cabinet-subsection:first-of-type { padding-top: 0; border-top: 0; }
.cabinet-subsection h3 { margin: 0; font-size: 17px; }
.pagination-bar { margin-top: 14px; display: flex; align-items: center; justify-content: flex-end; gap: 10px; flex-wrap: wrap; }
.pagination-pages { display: inline-flex; align-items: center; gap: 6px; }
.pagination-page, .pagination-ellipsis { min-width: 34px; min-height: 34px; padding: 0 9px; border: 1px solid var(--line); border-radius: 4px; background: #fff; display: inline-flex; align-items: center; justify-content: center; font-weight: 550; color: var(--muted); }
.pagination-page.active { color: var(--accent); border-color: #f0b3c8; background: #fff3f7; }
.pagination-ellipsis { border-color: transparent; background: transparent; }
.form-subtitle { margin: 4px 0 0; font-size: 16px; }
.form-subtitle.full, .form-divider.full { grid-column: 1 / -1; }
.form-divider { height: 1px; background: var(--soft-line); margin: 15px 0; }
.payment-settings-form { grid-template-columns: repeat(3, minmax(190px, 1fr)); align-items: start; padding-top: 15px;}
.payment-settings-form .full, .payment-settings-form .wide { grid-column: 1 / -1; }
.payment-settings-form .report-switch { max-width: 420px; }
.payment-settings-form label:not(.report-switch) { min-width: 0; }
.payment-settings-form input, .payment-settings-form textarea { width: 100%; }
.payment-settings-form textarea { min-height: 96px; }
.payment-settings-subhead { display: grid; gap: 4px; padding-top: 2px; max-width: 760px; }
.payment-settings-head { max-width: none; grid-template-columns: minmax(0, 1fr) auto; align-items: start; gap: 16px; }
.payment-settings-head .report-switch { justify-self: end; margin-top: 0; white-space: nowrap; }
.payment-settings-subhead h3 { margin: 0; font-size: 18px; line-height: 1.25; }
.payment-settings-subhead p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.4; overflow-wrap: anywhere; }
.muted-option { color: var(--muted); }
.activity-scroll { max-height: 720px; overflow: auto; }
.admin-login-scroll { max-height: 360px; overflow: auto; }
.backup-check-form { grid-template-columns: minmax(260px, 420px) auto; justify-content: start; align-items: end; }
.backup-check-form .form-actions { align-self: end; }
.backup-check-form input[type="file"], .backup-check-form button { min-height: var(--control-height); }

label { display: grid; gap: 6px; font-weight: 750; font-size: 14px; }
input, select, textarea { width: 100%; min-height: var(--control-height); border: 1px solid var(--line); border-radius: var(--control-radius); padding: 8px var(--control-padding-x); font: inherit; color: var(--text); background: #fff; }
input:disabled, textarea:disabled { color: var(--muted); background: #fbfcfe; cursor: default; opacity: 1; }
input[type="file"] { padding: 6px var(--control-padding-x); }
select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  min-height: var(--control-height);
  padding: 8px 34px 8px var(--control-padding-x);
  border-radius: var(--control-radius);
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"), linear-gradient(180deg, #fff 0%, #fbfcfe 100%);
  background-repeat: no-repeat;
  background-position: right 11px center, 0 0;
  background-size: 14px 14px, auto;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.02);
  cursor: pointer;
  font-weight: 500;
}
select:hover {
  border-color: #cfd7e4;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%23b3093f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"), linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}
select:disabled {
  color: var(--muted);
  background-color: #f8fafc;
  cursor: not-allowed;
}
select::-ms-expand { display: none; }
select option {
  min-height: 34px;
  padding: 8px 12px;
  color: var(--text);
  background: #fff;
  font-weight: 500;
}
select option:disabled {
  color: var(--muted);
}
textarea { resize: vertical; min-height: 76px; }
input:focus, select:focus, textarea:focus { outline: 3px solid rgba(179, 9, 63, 0.12); border-color: var(--accent); }

.checkline, .switch-line { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; }
.checkline input, .switch-line input { width: 16px; height: 16px; min-height: 16px; accent-color: var(--accent); }
.switch-line span { color: var(--text); }
.switch-line.with-help { align-items: flex-start; }
.switch-line.with-help span { display: grid; gap: 3px; min-width: 0; line-height: 1.3; }
.switch-line.with-help small { display: block; max-width: 620px; color: var(--muted); font-size: 13px; font-weight: 500; line-height: 1.35; overflow-wrap: anywhere; }
.report-switch { position: relative; width: fit-content; min-height: var(--control-height); padding: 0 var(--control-padding-x); border: 1px solid var(--line); border-radius: var(--control-radius); background: #fbfcfe; display: inline-flex; align-items: center; justify-content: flex-start; gap: 8px; font-size: 14px; font-weight: 650; cursor: pointer; transition: border-color .16s ease, background-color .16s ease, box-shadow .16s ease; }
.report-switch input { position: absolute; inline-size: 1px; block-size: 1px; opacity: 0; pointer-events: none; }
.report-switch-control { position: relative; flex: 0 0 34px; width: 34px; height: 19px; border-radius: 999px; background: #d7dee8; transition: background 0.16s ease; }
.report-switch-control::after { content: ""; position: absolute; top: 3px; left: 3px; width: 13px; height: 13px; border-radius: 50%; background: #fff; box-shadow: 0 1px 3px rgba(31, 35, 40, 0.18); transition: transform 0.16s ease; }
.report-switch input:checked + .report-switch-control { background: var(--accent); }
.report-switch input:checked + .report-switch-control::after { transform: translateX(15px); }
.report-switch input:focus-visible + .report-switch-control { outline: 3px solid rgba(179, 9, 63, 0.14); outline-offset: 2px; }
.report-switch:hover { border-color: #cfd7e4; background: #fff; }
.report-switch-text { color: var(--text); line-height: 1.2; white-space: normal; overflow-wrap: anywhere; }
.form-grid .report-switch { align-self: end; }
.form-grid .payment-settings-head .report-switch { align-self: start; }
.locale-tabs { grid-column: 1 / -1; min-width: 0; display: grid; gap: 8px; }
.locale-tabs > input { position: absolute; inline-size: 1px; block-size: 1px; margin: 0; padding: 0; opacity: 0; overflow: hidden; pointer-events: none; clip: rect(0 0 0 0); }
.locale-tab-buttons { width: fit-content; gap: 0; padding: 2px; }
.locale-tab-buttons .tab-button { min-width: 46px; min-height: 30px; padding: 0 12px; }
.locale-tabs .tab-button { cursor: pointer; }
.locale-panel { display: none; min-width: 0; }
.locale-tabs input:nth-of-type(1):checked ~ .locale-panel-ru,
.locale-tabs input:nth-of-type(2):checked ~ .locale-panel-en { display: block; }
.locale-tabs input:nth-of-type(1):checked ~ .locale-tab-buttons label:nth-child(1),
.locale-tabs input:nth-of-type(2):checked ~ .locale-tab-buttons label:nth-child(2) { color: var(--accent); background: #fff; box-shadow: 0 1px 4px rgba(31, 35, 40, 0.08); }

button, .primary-button, .ghost-button, .danger-button { min-height: var(--control-height); border-radius: var(--control-radius); padding: 0 13px; font: inherit; font-weight: 650; line-height: 1.2; text-align: center; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; white-space: nowrap; transition: border-color .16s ease, background-color .16s ease, color .16s ease, box-shadow .16s ease; }
.compact { min-height: var(--control-height); padding: 0 11px; font-size: 14px; }
.primary-button { border: 1px solid #cfd7e4; background: #f8fafc; color: var(--text); }
.primary-button:hover { border-color: var(--accent); background: #fff5f8; color: var(--accent); }
.ghost-button { border: 1px solid var(--line); background: #fff; color: var(--text); }
.ghost-button:hover { border-color: #cfd7e4; background: #fbfcfe; color: var(--accent); }
.danger-button { border: 1px solid #ffc7ce; background: #fff; color: var(--danger); }
.danger-button:hover { border-color: #ff9baa; background: #fff1f3; }
button:disabled { opacity: 0.55; cursor: not-allowed; }
button:focus-visible,
.primary-button:focus-visible,
.ghost-button:focus-visible,
.danger-button:focus-visible,
.link-button:focus-visible,
.edit-icon-button:focus-visible,
.icon-button:focus-visible,
.pagination-page:focus-visible,
.route-picker-toggle:focus-visible {
  outline: 3px solid rgba(179, 9, 63, 0.14);
  outline-offset: 2px;
}
.telegram-disabled { width: 100%; }
.telegram-login-button { width: 100%; }

.alert, .notice { margin: 0 0 14px; padding: 11px 12px; border-radius: 8px; }
.alert { color: #96101f; background: #fff0f2; border: 1px solid #ffc9d0; }
.notice { color: #205c2e; background: #edf9f0; border: 1px solid #ccebd4; }
.toast-host {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 10000;
  display: grid;
  gap: 10px;
  width: min(380px, calc(100vw - 24px));
  pointer-events: none;
}
.toast {
  pointer-events: auto;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: #fff;
  box-shadow: var(--shadow);
  padding: 12px 14px;
  font-size: 14px;
  font-weight: 550;
  line-height: 1.4;
  color: var(--text);
  opacity: 1;
  transform: translateY(0);
  transition: opacity .18s ease, transform .18s ease;
}
.toast-success { border-color: #b8e9ca; background: #f0fff6; color: #116332; }
.toast-error { border-color: #ffc1ca; background: #fff1f3; color: #a20732; }
.toast-info { border-color: var(--line); background: #fff; color: var(--text); }
.toast.is-leaving { opacity: 0; transform: translateY(8px); }
.review-summary { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.review-summary .compact { flex: 0 0 auto; }

.table-wrap { border: 1px solid var(--line); border-radius: 8px; overflow-x: auto; background: #fff; }
table { width: 100%; border-collapse: collapse; min-width: 760px; }
th { color: var(--muted); font-size: 12px; text-align: left; text-transform: uppercase; }
th, td { padding: 12px; border-bottom: 1px solid var(--soft-line); vertical-align: middle; }
tbody tr:last-child td { border-bottom: 0; }
.empty-state {
    min-height: 110px;
    border: 1px dashed var(--line);
    border-radius: 0 0 8px 8px;
    display: grid;
    place-items: center;
    color: var(--muted);
}

.client-groups, .device-list { display: grid; gap: 10px; }
.client-workspace { position: relative; }
.client-list-head { margin-bottom: 12px; padding: 12px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.client-list-head div { display: grid; gap: 2px; }
.client-list-head small { color: #3f434b; }
.admin-client-list { gap: 12px; }
.client-card { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background: #fff; }
.client-card.over-limit { border-color: #ffc0c7; }
.client-card-main { padding: 12px; display: grid; grid-template-columns: minmax(260px, 1fr) auto auto; gap: 12px; align-items: center; border-bottom: 1px solid var(--soft-line); }
.client-card-title { display: grid; gap: 2px; min-width: 0; }
.client-card-title strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.client-card-title small { color: var(--muted); overflow-wrap: anywhere; }
.client-card-status, .client-card-actions { display: flex; align-items: center; justify-content: flex-end; gap: 8px; }
.client-card-preview { padding: 8px 12px 12px; display: grid; gap: 8px; background: #fff; }
.config-chip-row {
  /*display: grid; grid-template-columns: minmax(180px, 0.85fr) minmax(0, 1.6fr);*/
  gap: 10px; align-items: center;
}
.client-card-preview .config-chip-row + .config-chip-row { padding-top: 8px; border-top: 1px solid var(--soft-line); }
.config-name-cell { min-width: 0; display: block; }
.config-title-inline { display: inline-flex; align-items: center; gap: 6px; min-width: 0; max-width: 100%; }
.config-title-inline > span,
.config-title-inline > strong { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.edit-icon-button { width: 26px; min-height: 26px; padding: 0; border: 0; border-radius: 4px; background: transparent; color: var(--muted); display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.edit-icon-button:hover { color: var(--accent); background: #fff2f6; }
.edit-icon-button svg { width: 15px; height: 15px; }
.config-name-edit { display: grid; grid-template-columns: minmax(220px, 1fr) auto auto; gap: 6px; align-items: center; width: min(100%, 640px); }
.config-name-edit input { min-height: 38px; min-width: 0; width: 100%; }
.config-header .checkline { flex: 1 1 auto; min-width: 0; }
.config-header .config-name-cell { width: 100%; }
.link-button { min-height: auto; padding: 4px 0; border: 0; background: transparent; color: var(--accent); font-weight: 800; justify-content: flex-start; }
.client-group { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background: #fff; }
.client-group.over-limit { border-color: #ffc0c7; }
.group-main { display: flex; justify-content: space-between; gap: 16px; padding: 12px; border-bottom: 1px solid var(--soft-line); cursor: pointer; }
.group-check span { display: grid; gap: 2px; }
.group-check small, .device-row small { color: var(--muted); }
.group-actions { display: flex; align-items: center; gap: 8px; }
.group-controls { padding: 10px 12px; border-bottom: 1px solid var(--soft-line); background: #fbfcfe; display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.group-link-form { display: grid; grid-template-columns: minmax(160px, 1fr) minmax(150px, 0.9fr) 130px auto; gap: 8px; }
.group-config-form { display: grid; grid-template-columns: minmax(170px, 1fr) auto; gap: 8px; }
.group-extend-form { display: grid; grid-template-columns: minmax(180px, 1fr) auto; gap: 8px; }
.group-days-form { display: grid; grid-template-columns: minmax(90px, 1fr) auto; gap: 8px; }
.group-code-form { display: flex; }
.group-link-form { flex: 1 1 430px; }
.group-config-form { flex: 1 1 300px; }
.group-extend-form { flex: 1 1 310px; }
.group-days-form { flex: 0 1 230px; }
.group-code-form { flex: 0 0 auto; }
.group-controls > form:not(.group-link-form):not(.group-config-form):not(.group-extend-form):not(.group-days-form):not(.group-code-form) { flex: 0 0 auto; }
.group-controls input,
.group-controls select,
.group-controls button,
.group-controls .primary-button,
.group-controls .ghost-button,
.group-controls .danger-button,
.device-row .inline-form input,
.device-row .inline-form select,
.device-row .inline-form button,
.modal-add-config input,
.modal-add-config button,
.cabinet-create-config input,
.cabinet-create-config button,
.selection-tray-actions button {
  min-height: var(--control-height);
}
.slot-badge { min-height: 30px; display: inline-flex; align-items: center; justify-content: center; padding: 0 10px; border-radius: 4px; font-weight: 550; }
.slot-badge.ok { color: var(--success); background: #e9f8ef; }
.slot-badge.warn { color: var(--danger); background: #fff0f2; }
.slot-badge.neutral { color: var(--muted); background: #f3f5f8; }
.review-badge { min-height: 30px; display: inline-flex; align-items: center; padding: 0 10px; border-radius: 4px; color: var(--warning); background: #fff8e6; font-weight: 550; font-size: 12px; white-space: nowrap; }
.accordion-toggle { width: 32px; min-height: 32px; padding: 0; border: 1px solid var(--line); background: #fff; color: var(--muted); border-radius: 999px; font-size: 18px; transition: transform 0.15s ease; }
.client-group.is-open .accordion-toggle { transform: rotate(180deg); }
.device-row { display: grid; grid-template-columns: minmax(180px, 0.8fr) minmax(0, 1.6fr); gap: 12px; align-items: start; padding: 10px 12px; border-bottom: 1px solid var(--soft-line); }
.device-row:last-child { border-bottom: 0; }
.device-row .link-form { display: grid; grid-template-columns: minmax(170px, 1fr) 130px auto; gap: 8px; }
.device-row .extend-form { display: grid; grid-template-columns: minmax(150px, 1fr) auto; gap: 8px; }
.device-row .inline-form input, .device-row .inline-form select { min-width: 0; }
.limit-warning { margin: 0; padding: 10px 12px; color: var(--danger); background: #fff0f2; border-top: 1px solid #ffc0c7; }
.config-meta { display: flex; flex-wrap: wrap; gap: 6px; color: var(--muted); font-size: 13px; line-height: 1.35; min-width: 0; padding: 5px;}
.config-meta span { display: inline-flex; align-items: center; min-height: 24px; padding: 2px 8px; border: 1px solid var(--soft-line); border-radius: 4px; background: #fff; font-weight: 550; white-space: nowrap; }
.config-meta .config-state.enabled { color: #15803d; border-color: #bbf7d0; background: #ecfdf3; }
.config-meta .config-state.disabled { color: #9f1239; border-color: #fecdd3; background: #fff1f2; }
.config-meta .expiry-normal {
    color: #b45309;
    border-color: #fcd34d;
    background: #fffbeb;
}
.config-meta .expiry-danger {
    color: #b91c1c;
    border-color: #fca5a5;
    background: #fef2f2;
}
.compact-device-row { grid-template-columns: minmax(180px, 0.8fr) minmax(0, 1.6fr); }

.modal-dialog { width: min(1040px, calc(100vw - 28px)); max-height: calc(100vh - 28px); padding: 0; border: 0; border-radius: 10px; background: transparent; color: var(--text); }
.modal-dialog::backdrop { background: rgba(17, 24, 39, 0.42); backdrop-filter: blur(2px); }
.confirm-modal-dialog { width: fit-content; min-width: min(300px, calc(100vw - 28px)); max-width: min(620px, calc(100vw - 28px)); }
.confirm-message { margin: 0; color: var(--text); line-height: 1.45; white-space: pre-line; }
.backup-sections-form { display: grid; gap: 14px; }
.checkbox-grid { display: grid; grid-template-columns: repeat(2, minmax(180px, 1fr)); gap: 10px 14px; }
.log-table-wrap { max-height: 620px; overflow: auto; }
.system-log-table { min-width: 1080px; table-layout: fixed; }
.system-log-table th:nth-child(1), .system-log-table td:nth-child(1) { width: 150px; }
.system-log-table th:nth-child(2), .system-log-table td:nth-child(2) { width: 130px; }
.system-log-table th:nth-child(3), .system-log-table td:nth-child(3) { width: 310px; }
.system-log-table th:nth-child(4), .system-log-table td:nth-child(4) { width: auto; }
.system-log-table .status { max-width: 100%; white-space: normal; overflow-wrap: normal; word-break: normal; }
.system-log-table td:last-child { overflow-wrap: anywhere; }
.qr-media { width: min(420px, 70vw); height: min(420px, 70vw); }
.modal-card { max-height: inherit; overflow-y: auto; overflow-x: hidden; border: 1px solid var(--line); border-radius: 10px; background: #fff; box-shadow: 0 24px 70px rgba(15, 23, 42, 0.22); padding: 18px; display: grid; gap: 16px; }
.modal-card form, .modal-card label, .modal-card input, .modal-card textarea, .modal-card select, .modal-card .tox { min-width: 0; max-width: 100%; }
.confirm-modal-dialog .modal-card { width: fit-content; min-width: min(300px, calc(100vw - 28px)); max-width: inherit; gap: 14px; }
.confirm-modal-dialog .confirm-message,
.confirm-modal-dialog .modal-card > p { max-width: 58ch; overflow-wrap: break-word; }
.modal-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; border-bottom: 1px solid var(--soft-line); padding-bottom: 12px; }
.modal-head h2 { margin: 0; font-size: 22px; }
.modal-head p { margin: 4px 0 0; color: var(--muted); }
.icon-button { width: 36px; min-height: 36px; padding: 0; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--muted); font-size: 22px; line-height: 1; }
.modal-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 12px; }
.modal-section { border: 1px solid var(--soft-line); border-radius: 8px; padding: 14px; background: #fbfcfe; display: grid; gap: 10px; align-content: start; }
.modal-section h3 { margin: 0; font-size: 16px; }
.subscription-summary { display: grid; gap: 7px; padding: 10px 12px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fff; }
.subscription-summary p { margin: 0; display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.subscription-summary strong { color: var(--text); font-weight: 650; text-align: right; }
.modal-wide { grid-column: 1 / -1; }
.modal-add-config { display: grid; grid-template-columns: minmax(180px, 1fr) auto; }
.modal-config-list, .checkbox-stack { display: grid; gap: 8px; }
.modal-config-row { padding: 10px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fff; display: grid; gap: 6px; }
.download-layout { display: grid; grid-template-columns: minmax(0, 0.85fr) minmax(0, 1fr); gap: 12px; }
.modal-actions { display: flex; align-items: center; justify-content: flex-end; flex-wrap: wrap; gap: 8px; border-top: 1px solid var(--soft-line); padding-top: 12px; }
.modal-actions form { margin: 0; }
.active-until { margin: 0; }
.receipt-modal-card { min-height: min(760px, calc(100vh - 60px)); }
.receipt-tools { display: flex; align-items: center; justify-content: flex-end; flex-wrap: wrap; gap: 8px; }
.receipt-viewer { min-height: min(620px, calc(100vh - 220px)); overflow: auto; border: 1px solid var(--soft-line); border-radius: 8px; background: #fff; display: flex; align-items: flex-start; justify-content: center; padding: 18px; }
.receipt-media { display: block; max-width: 100%; height: auto; transform-origin: 50% 50%; transition: transform 0.16s ease; }
.qr-viewer { min-height: min(520px, calc(100vh - 220px)); align-items: center; }
.qr-media { width: min(420px, 82vw); background: #fff; }
.table-actions { align-items: center; justify-content: flex-start; }
.form-actions.full { justify-content: flex-start; }
.form-actions.full.align-end { justify-content: flex-end; }
.settings-item .form-actions { justify-content: flex-end; }
.settings-item .form-actions.align-end { justify-content: flex-end; }
.cabinet-create-config { margin: 0 0 14px; padding: 10px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; display: grid; grid-template-columns: minmax(220px, 1fr) auto auto; gap: 8px; align-items: center; }
.selection-tray { position: sticky; bottom: 14px; z-index: 9; margin: 16px auto 0; max-width: 1040px; padding: 12px; border: 1px solid var(--line); border-radius: 10px; background: rgba(255, 255, 255, 0.97); box-shadow: 0 18px 48px rgba(15, 23, 42, 0.16); display: grid; grid-template-columns: minmax(180px, 0.45fr) minmax(0, 1fr); gap: 10px; align-items: center; }
.selection-tray[hidden] { display: none; }
.selection-tray span { color: var(--muted); font-weight: 800; }
.selection-tray-summary { display: grid; gap: 2px; }
.selection-tray-summary small { color: var(--muted); font-size: 12px; font-weight: 700; }
.selection-tray-actions { display: flex; justify-content: flex-end; gap: 8px; flex-wrap: wrap; }

.settings-item { border: 1px solid var(--soft-line); border-radius: 8px; padding: 14px; display: grid; gap: 10px; background: #fff; }
.cabinet-config-item { background: #efe2e21a; }
.section-pattern-head small,
.section-pattern-head p,
.settings-item p,
.muted { white-space: pre-line; }
.profile-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; align-items: start; }
.profile-card { gap: 14px; }
.profile-form { align-content: start; display: grid; gap: 12px; min-width: 0; }
.profile-contact-form { max-width: none; }
.profile-fields-stack { display: grid; grid-template-columns: minmax(180px, 0.7fr) minmax(300px, 1fr) minmax(220px, 0.82fr); gap: 12px; align-items: end; }
.profile-fields-stack label { min-width: 0; }
.profile-fields-stack input[readonly] { color: var(--muted); background: #fbfcfe; }
.field-with-status { grid-template-columns: minmax(0, 1fr) auto; align-items: center; column-gap: 10px; }
.field-with-status input { grid-column: 1 / -1; }
.field-with-status .status { align-self: center; }
.profile-telegram-id input { font-weight: 750; }
.profile-security-row { display: contents; }
.profile-actions-row { grid-column: 1; display: grid; justify-items: start; gap: 8px; padding-top: 4px; }
.profile-save-actions { margin-top: 10px; }
.section-pattern-head { margin-bottom: 14px; padding: 12px; border: 1px solid var(--soft-line); border-radius: 8px; background-color: #fbfcfe; background-image: radial-gradient(#e6ebf3 0.8px, transparent 0.8px); background-size: 10px 10px; }
.cabinet-payment-history-head { padding: 12px; border: 1px solid var(--soft-line); border-radius: 8px; background-color: #fbfcfe; background-image: radial-gradient(#e6ebf3 0.8px, transparent 0.8px); background-size: 10px 10px; }
.cabinet-payment-form { grid-template-columns: minmax(220px, 360px) minmax(220px, 320px); justify-content: start; align-items: end; }
.cabinet-payment-form label { max-width: 360px; }
.cabinet-payment-form select { min-height: var(--control-height); padding: 8px 34px 8px var(--control-padding-x); font-weight: 500; background-position: right 11px center, 0 0; }
.cabinet-payment-form button,
.cabinet-payment-form input,
.cabinet-payment-form select {
  min-height: var(--control-height);
}
.cabinet-payment-form .payment-bank-hint,
.cabinet-payment-form .receipt-upload-field,
.cabinet-payment-form .tariff-payment-section,
.cabinet-payment-form .tariff-choice-card,
.cabinet-payment-form .form-actions.full { grid-column: 1 / -1; max-width: 760px; }
.config-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.config-header h3 { margin: 0 0 4px; }
.config-header p { margin: 0; color: var(--muted); }
.config-details { margin: 0; display: flex; flex-wrap: wrap; gap: 8px; align-items: stretch; }
.config-details div { width: max-content; max-width: 100%; padding: 8px 10px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; min-width: 112px; }
.config-details dt { margin: 0 0 2px; color: var(--muted); font-size: 11px; font-weight: 850; text-transform: uppercase; }
.config-details dd { margin: 0; color: var(--text); font-size: 14px; font-weight: 750; overflow-wrap: normal; white-space: nowrap; line-height: 1.35; }
.preset-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.preset-option { align-items: flex-start; border: 1px solid var(--soft-line); border-radius: 8px; padding: 10px; background: #fbfcfe; }
.preset-option span { display: grid; gap: 3px; }
.preset-option small { color: var(--muted); font-weight: 500; overflow-wrap: anywhere; }
.route-options { border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; }
.route-options summary { min-height: 38px; padding: 9px 12px; color: var(--accent); font-weight: 850; cursor: pointer; }
.route-options[open] { padding: 0 12px 12px; }
.route-options[open] summary { margin: 0 -12px 10px; border-bottom: 1px solid var(--soft-line); }
.route-picker { margin: 0 0 14px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fff; overflow: hidden; }
.route-picker-toggle { width: 100%; min-height: var(--control-height); border: 0; border-radius: 0; padding: 10px var(--control-padding-x); background: #fbfcfe; color: var(--accent); display: flex; align-items: center; justify-content: space-between; gap: 10px; text-align: left; }
.route-picker-toggle > span:first-child { display: grid; gap: 2px; }
.route-picker-toggle small { color: var(--muted); font-weight: 500; }
.route-picker-toggle strong { color: #243247; font-size: 14px; font-weight: 750; }
.route-picker-meta { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; }
.route-picker-body { padding: 12px; border-top: 1px solid var(--soft-line); display: grid; gap: 10px; }
.tariff-flow { display: grid; gap: 10px; margin: 0 0 12px; }
.current-tariff-card,
.tariff-choice-card { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: start; gap: 16px; padding: 16px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; }
.current-tariff-card > div,
.tariff-choice-card > div { min-width: 0; }
.tariff-summary-badges { display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: 8px; min-width: 0; }
.tariff-summary-title { margin: 0; color: var(--muted); display: flex; flex-wrap: wrap; gap: 6px; align-items: baseline; }
.tariff-summary-title strong { color: #243247; font-size: 19px; line-height: 1.25; font-weight: 700; overflow-wrap: break-word; word-break: normal; }
.tariff-action-row { display: flex; flex-wrap: wrap; gap: 10px; }
.current-tariff-card h3,
.tariff-choice-card h3 { margin: 4px 0 0; color: #243247; font-size: 19px; line-height: 1.25; font-weight: 700; overflow-wrap: break-word; word-break: normal; }
.current-tariff-card p,
.tariff-choice-card p { margin: 0; color: var(--muted); }
.current-tariff-card .notice { margin-top: 8px; color: #205c2e; }
.modal-payment-form { grid-template-columns: minmax(220px, 360px) minmax(220px, 320px); }
.rich-description { padding: 10px 0 0; color: var(--text); line-height: 1.55; overflow-wrap: break-word; word-break: normal; }
.rich-description p { margin: 0 0 10px; }
.rich-description p:last-child { margin-bottom: 0; }
.tariff-modal-summary { display: grid; gap: 10px; }
.wide-modal-card { max-width: min(1180px, calc(100vw - 48px)); }
.tariff-renew-modal { max-width: min(760px, calc(100vw - 48px)); }
.tariff-renew-summary { display: grid; grid-template-columns: repeat(4, minmax(120px, 1fr)); gap: 8px; margin-bottom: 12px; }
.tariff-modal-summary-grid > div,
.tariff-renew-summary > div { border: 1px solid var(--soft-line); border-radius: 8px; padding: 10px 12px; background: #fbfcfe; }
.tariff-renew-summary strong { display: block; margin-top: 2px; font-size: 16px; }
.tariff-modal-note { margin: 0 0 12px; padding: 12px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fbfcfe; color: var(--muted); line-height: 1.5; overflow-wrap: break-word; word-break: normal; }
.tariff-modal-note p { margin: 0 0 8px; }
.tariff-modal-note p:last-child { margin-bottom: 0; }
.tariff-switch-modal .modal-payment-form { display: grid; grid-template-columns: 1fr; align-items: start; }
.tariff-renew-modal .modal-payment-form { display: grid; grid-template-columns: 1fr; align-items: start; }
.tariff-switch-modal .tariff-picker,
.tariff-switch-modal .tariff-choice-card,
.tariff-switch-modal .tariff-payment-section,
.tariff-renew-modal .tariff-payment-section,
.tariff-renew-modal .payment-bank-hint,
.tariff-renew-modal .receipt-upload-field,
.tariff-renew-modal .modal-actions.full,
.tariff-switch-modal .payment-bank-hint,
.tariff-switch-modal .receipt-upload-field,
.tariff-switch-modal .modal-actions.full { grid-column: 1 / -1; max-width: none; }
.tariff-switch-payment-method { width: min(360px, 100%); }
.tariff-payment-section { border-top: 1px solid var(--soft-line); padding-top: 18px; margin-top: 8px; display: grid; justify-items: start; gap: 10px; }
.tariff-picker {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.tariff-picker-filters {
    width: 240px;
    min-width: 240px;
    max-width: 240px;

    box-sizing: border-box;
    border: 1px solid var(--soft-line);
    border-radius: 8px;
    background: #fbfcfe;

    padding: 14px;
    display: grid;
    gap: 12px;
    align-content: start;
}

.tariff-picker-filters h3 {
    margin: 0;
}

.tariff-picker-filters label {
    margin: 0;
}

.tariff-picker-filters input,
.tariff-picker-filters select,
.tariff-picker-filters button {
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.tariff-picker-pagination {
    display: grid;
    grid-template-columns: 70px 50px 70px;
    justify-content: center;
    align-items: center;
    gap: 6px;

    margin-top: 4px;
    padding-top: 10px;
    border-top: 1px solid var(--soft-line);
}
.tariff-picker-pagination span { width: 50px; justify-self: center; color: var(--muted); font-weight: 700; text-align: center; white-space: nowrap; }
.tariff-picker-main { min-width: 0; height: 482px; display: grid; gap: 10px; align-content: start; }
.tariff-card-grid { display: grid; grid-template-columns: repeat(2, minmax(260px, 1fr)); grid-template-rows: repeat(3, 154px); gap: 10px; min-width: 0; height: 482px; }
.tariff-select-card { min-width: 0; min-height: 0; height: 154px; padding: 12px; border: 1px solid var(--soft-line); border-radius: 8px; background: #fff; color: var(--text); display: grid; grid-template-columns: minmax(0, 1fr); gap: 8px; align-content: start; text-align: left; box-shadow: 0 8px 22px rgba(24, 37, 54, 0.04); overflow: hidden; }
.tariff-select-card:hover { border-color: rgba(194, 9, 68, 0.32); box-shadow: 0 12px 28px rgba(24, 37, 54, 0.08); }
.tariff-select-card.selected { border-color: var(--accent); background: #fff8fb; }
.tariff-select-card .status { justify-self: start; max-width: 100%; }
.tariff-select-card strong { display: -webkit-box; max-width: 100%; min-width: 0; font-size: 16px; line-height: 1.3; font-weight: 700; overflow: hidden; overflow-wrap: break-word; word-break: normal; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
.tariff-select-card span:not(.status),
.tariff-select-card small { display: block; max-width: 100%; min-width: 0; color: var(--muted); line-height: 1.45; overflow-wrap: break-word; word-break: normal; }
.tariff-picker-main .empty-state { min-height: 482px; display: grid; place-items: center; }
.tariff-card-details { margin: 4px 0 0; display: grid; gap: 6px; }
.tariff-card-details div { display: grid; grid-template-columns: 136px minmax(0, 1fr); gap: 10px; align-items: baseline; }
.tariff-card-details dt { color: var(--muted); font-size: 12px; font-weight: 700; }
.tariff-card-details dt::after { content: ":"; }
.tariff-card-details dd { margin: 0; color: #243247; font-weight: 650; overflow-wrap: break-word; word-break: normal; }
.tariff-choice-details { margin-top: 14px; }
.tariff-summary-card { margin-top: 2px; }
.tariff-card-description {
  /*margin-top: 12px; убираю чтобы убрать отступ в названии в смене тарифа*/
  padding-top: 0;
  color: var(--muted);
}
p.tariff-summary-title {
    margin-top: 12px;
}
.tariff-modal-notice { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--soft-line); }
.tariff-payment-details { margin: 16px 0 0; padding-top: 14px; border-top: 1px solid var(--soft-line); display: grid; gap: 9px; }
.tariff-payment-details div {
    display: grid;
    grid-template-columns: max-content max-content;
    gap: 12px;
    align-items: baseline;
}
.tariff-payment-details dt { color: var(--muted); font-weight: 650; line-height: 1.4; overflow-wrap: break-word; word-break: normal; }
.tariff-payment-details dt::after { content: ":"; }
.tariff-payment-details dd { margin: 0; color: #243247; font-size: 16px; font-weight: 700; line-height: 1.45; overflow-wrap: break-word; word-break: normal; }
.payment-bank-hint p { margin: 0 0 8px; }
.payment-bank-hint p:last-child { margin-bottom: 0; }
.receipt-upload-field { display: grid; gap: 8px; }
.compact-alert { margin: 0; font-size: 13px; }
.plain-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.plain-list li { border: 1px solid var(--soft-line); border-radius: 8px; padding: 10px 12px; color: var(--muted); background: #fff; }
.plain-list strong { color: var(--text); }
.status { display: inline-flex; min-height: 26px; align-items: center; padding: 0 9px; border: 1px solid transparent; border-radius: 4px; font-size: 12px; font-weight: 550; background: #eef2ff; color: #33408f; }
.status.paid { background: #e9f8ef; color: var(--success); }
.status.review, .status.pending { background: #fff8e6; color: var(--warning); }
.status.rejected, .status.failed { background: #fff0f2; color: var(--danger); }

.auth-body { background: #fff; }
.auth-shell { width: 100%; max-width: 552px; min-height: 100vh; margin: 0 auto; display: grid; align-items: center; padding: 32px 16px; }
.auth-card { padding: 24px; display: grid; gap: 16px; }
.auth-captcha { margin-top: 2px; min-height: 92px; }
.mobile-block-card { text-align: center; }
.auth-header h1 { margin: 8px 0 6px; font-size: 30px; }
.auth-header p { margin: 0; color: var(--muted); }
.eyebrow { color: var(--accent); font-weight: 850; font-size: 13px; text-transform: uppercase; }
.language-row { display: flex; gap: 8px; }
.language-row a { color: var(--accent); font-weight: 800; }
.password-field { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px; }
.password-field--icon { position: relative; display: block; }
.password-field--icon input { width: 100%; padding-right: 38px; }
.password-eye-button {
  position: absolute;
  right: 9px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  min-height: 24px;
  padding: 0;
  border: 0;
  border-radius: 4px;
  background: transparent;
  color: #182536;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.password-eye-button:hover,
.password-eye-button.is-active { color: var(--accent); background: transparent; }
.password-eye-button:focus-visible { outline: 2px solid rgba(194, 9, 68, 0.28); outline-offset: 2px; }
.password-eye-button svg { width: 18px; height: 18px; fill: currentColor; }
.separated { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--soft-line); }

@media (max-width: 980px) {
  .config-details div { width: 100%; }
  .config-details dd { white-space: normal; overflow-wrap: anywhere; }
  .tariff-renew-summary,
  .tariff-picker,
  .tariff-switch-modal .modal-payment-form,
  .tariff-card-grid { grid-template-columns: 1fr; }
  .app-header { height: auto; min-height: 64px; grid-template-columns: 1fr; padding: 12px 16px; }
  .app-shell { width: calc(100% - 24px); margin: 18px auto 40px; grid-template-columns: 1fr; }
  .app-shell.with-sidebar, .app-shell.single { grid-template-columns: 1fr; }
  .side-nav { position: static; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); max-width: 100%; overflow: visible; }
  .side-nav a { min-width: 0; white-space: normal; }
  .side-nav-divider { grid-column: 1 / -1; }
  .broadcast-grid { grid-template-columns: 1fr; }
  .broadcast-client-list { grid-template-columns: 1fr; }
  .metrics-row, .form-grid, .profile-grid, .info-grid, .payment-card-grid, .payment-card-bottom, .payment-method-picker, .payment-filter-form, .runtime-settings-grid, .promo-code-grid, .tariff-create-form, .tariff-edit-form, .routing-form, .routing-switches { grid-template-columns: 1fr; }
  .promocode-form .promo-form-actions { grid-column: auto; justify-self: stretch; }
  .promocode-form .promo-form-actions button { width: 100%; }
  .promo-code-card { padding-right: 16px; padding-top: 44px; }
  .promo-code-card .status { left: 12px; right: auto; }
  .routing-description { padding-top: 0; }
  .routing-modal-switches { flex-wrap: wrap; }
  .payment-settings-head { grid-template-columns: 1fr; }
  .payment-settings-head .report-switch { justify-self: start; }
  .section-head { display: grid; grid-template-columns: 1fr; }
  .section-head form, .section-head button { width: 100%; }
  .tariff-grid-list, .routing-grid-list { grid-template-columns: 1fr; }
  .tariff-summary { grid-template-columns: 1fr; }
  .tariff-card-side, .routing-card-side { align-items: flex-start; flex-direction: column; }
  .tariff-card-switches { flex-direction: column; align-items: flex-start; }
  .card-delete { position: static; justify-content: flex-start; }
  .payment-card-head { align-items: flex-start; flex-direction: column; }
  .payment-actions { justify-content: stretch; }
  .payment-filter-actions { justify-content: stretch; }
  .payment-actions button, .payment-actions form, .receipt-actions a, .receipt-actions button { width: 100%; }
  .payment-filter-actions button, .payment-filter-actions a { width: 100%; }
  .profile-contact-form { max-width: none; }
  .profile-fields-stack { grid-template-columns: 1fr; }
  .profile-field-name,
  .profile-security-row { grid-column: auto; }
  .profile-security-row { grid-template-columns: 1fr; align-items: stretch; }
  .compact-toolbar, .bulk-actions, .bulk-bar { grid-template-columns: 1fr; }
  .client-list-head, .client-card-main, .config-chip-row, .download-layout, .modal-grid, .modal-add-config { grid-template-columns: 1fr; }
  .cabinet-create-config { grid-template-columns: 1fr; }
  .client-list-head, .client-card-actions, .client-card-status { align-items: stretch; justify-content: flex-start; flex-wrap: wrap; }
  .client-card-actions button:not(.accordion-toggle) { width: 100%; }
  .modal-card { padding: 14px; }
  .modal-actions { justify-content: stretch; }
  .modal-actions button, .modal-actions form { width: 100%; }
  .selection-tray { left: 12px; right: 12px; grid-template-columns: 1fr; align-items: stretch; }
  .selection-tray-actions { justify-content: stretch; }
  .selection-tray-actions button { flex: 1 1 100%; }
  .preset-grid { grid-template-columns: 1fr; }
  .form-grid .wide { grid-column: auto; }
  .row-form, .device-row, .device-row .link-form, .device-row .extend-form, .group-link-form, .group-config-form, .group-extend-form, .group-days-form { grid-template-columns: 1fr; }
  .group-controls { display: grid; grid-template-columns: 1fr; }
  .config-meta span { white-space: normal; overflow-wrap: anywhere; }
  .page-heading, .group-main { align-items: flex-start; flex-direction: column; }
  .password-field { grid-template-columns: 1fr; }
  .auth-actions { display: grid; grid-template-columns: 1fr; align-items: stretch; }
  .auth-actions button { width: 100%; white-space: normal; min-height: var(--control-height); padding: 8px 12px; text-align: center; }
}

/* Бейджи у тарифов в модульном окне клиента */
.tariff-card-badges {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.tariff-card-badges .status {
  width: auto;
  max-width: max-content;
  justify-self: unset;
}
