@font-face {
  font-family: "InterVariable";
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("/static/fonts/inter-cyrillic-ext-wght-normal.woff2") format("woff2-variations");
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "InterVariable";
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("/static/fonts/inter-cyrillic-wght-normal.woff2") format("woff2-variations");
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
  font-family: "InterVariable";
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("/static/fonts/inter-latin-ext-wght-normal.woff2") format("woff2-variations");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "InterVariable";
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("/static/fonts/inter-latin-wght-normal.woff2") format("woff2-variations");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

body.ios-redesign {
  --rdx-bg: #eef3fb;
  --rdx-bg-2: #dce7f8;
  --rdx-panel: rgba(255, 255, 255, 0.84);
  --rdx-panel-strong: rgba(255, 255, 255, 0.96);
  --rdx-panel-soft: rgba(248, 251, 255, 0.74);
  --rdx-chip: rgba(255, 255, 255, 0.78);
  --rdx-border: rgba(72, 94, 128, 0.36);
  --rdx-border-soft: rgba(72, 94, 128, 0.24);
  --rdx-card-bg: rgba(255, 255, 255, 0.68);
  --rdx-card-border: rgba(70, 94, 130, 0.4);
  --rdx-card-shadow: 0 14px 30px rgba(63, 87, 125, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.74);
  --rdx-field-bg: rgba(255, 255, 255, 0.66);
  --rdx-field-bg-focus: rgba(255, 255, 255, 0.82);
  --rdx-plan-line: rgba(76, 92, 118, 0.46);
  --rdx-plan-line-strong: rgba(66, 82, 110, 0.58);
  --rdx-plan-cell-bg: rgba(255, 255, 255, 0.72);
  --rdx-plan-cell-alt-bg: rgba(238, 243, 250, 0.86);
  --rdx-plan-master-bg: rgba(244, 248, 253, 0.9);
  --rdx-plan-master-alt-bg: rgba(231, 238, 248, 0.9);
  --rdx-plan-head-bg: rgba(233, 239, 248, 0.94);
  --rdx-plan-weekend-bg: rgba(224, 230, 239, 0.78);
  --rdx-plan-hover-bg: rgba(218, 235, 255, 0.72);
  --rdx-plan-grid-shadow: 0 18px 38px rgba(65, 91, 130, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.68);
  --rdx-plan-master-top: rgba(255, 255, 255, 0.52);
  --rdx-plan-master-inset: rgba(72, 94, 128, 0.18);
  --rdx-plan-cell-top: rgba(255, 255, 255, 0.58);
  --rdx-plan-cell-inset: rgba(255, 255, 255, 0.48);
  --rdx-table-line: rgba(72, 94, 128, 0.32);
  --rdx-table-line-strong: rgba(66, 88, 122, 0.46);
  --rdx-table-head-bg: rgba(236, 242, 250, 0.94);
  --rdx-table-row-bg: rgba(255, 255, 255, 0.64);
  --rdx-table-row-alt-bg: rgba(244, 248, 253, 0.82);
  --rdx-table-row-hover-bg: rgba(222, 237, 255, 0.82);
  --rdx-table-cell-inset: rgba(255, 255, 255, 0.46);
  --rdx-text: #0f172a;
  --rdx-text-soft: #5b667a;
  --rdx-text-muted: #8b97ae;
  --rdx-accent: #0a84ff;
  --rdx-accent-2: #34c8ff;
  --rdx-accent-3: #7c5cff;
  --rdx-good: #2fb772;
  --rdx-warn: #ff9f0a;
  --rdx-danger: #ff5f57;
  --rdx-shadow-sm: 0 10px 24px rgba(65, 91, 130, 0.14);
  --rdx-shadow-md: 0 22px 48px rgba(65, 91, 130, 0.2);
  --rdx-shadow-lg: 0 34px 70px rgba(65, 91, 130, 0.26);
  --rdx-glow-a: rgba(10, 132, 255, 0.24);
  --rdx-glow-b: rgba(124, 92, 255, 0.18);
  --rdx-glow-c: rgba(52, 199, 255, 0.14);

  --bg: var(--rdx-bg);
  --surface: var(--rdx-panel-strong);
  --surface-2: var(--rdx-panel-soft);
  --surface-translucent: var(--rdx-panel);
  --surface-tint: rgba(255, 255, 255, 0.58);
  --sf: var(--rdx-panel-strong);
  --sf-solid: var(--rdx-panel-strong);
  --s2: var(--rdx-panel-soft);
  --s3: rgba(214, 226, 244, 0.72);
  --bd: var(--rdx-border);
  --separator: var(--rdx-border-soft);
  --hairline: rgba(72, 94, 128, 0.2);
  --tx: var(--rdx-text);
  --t2: var(--rdx-text-soft);
  --t3: var(--rdx-text-muted);
  --ac: var(--rdx-accent);
  --ac-bg: rgba(10, 132, 255, 0.12);
  --ac-bg-2: rgba(10, 132, 255, 0.2);
  --ac-glow: rgba(10, 132, 255, 0.26);
  --gr: var(--rdx-good);
  --gr-bg: rgba(47, 183, 114, 0.14);
  --yl: var(--rdx-warn);
  --yl-bg: rgba(255, 159, 10, 0.16);
  --rd: var(--rdx-danger);
  --rd-bg: rgba(255, 95, 87, 0.16);
  --shadow-sm: var(--rdx-shadow-sm);
  --shadow-md: var(--rdx-shadow-md);
  --shadow-lg: var(--rdx-shadow-lg);
  --blur-bar: saturate(160%) blur(24px);
  --blur-card: saturate(145%) blur(18px);
  --ios-radius-xl: 32px;
  --ios-radius-lg: 28px;
  --ios-radius-md: 22px;
  --ios-radius-sm: 18px;
  --ios-pill: 999px;
}

html[data-theme="dark"] body.ios-redesign {
  --rdx-bg: #0a0c11;
  --rdx-bg-2: #111623;
  --rdx-panel: rgba(19, 24, 35, 0.68);
  --rdx-panel-strong: rgba(22, 28, 40, 0.9);
  --rdx-panel-soft: rgba(18, 24, 34, 0.58);
  --rdx-chip: rgba(255, 255, 255, 0.06);
  --rdx-border: rgba(255, 255, 255, 0.08);
  --rdx-border-soft: rgba(255, 255, 255, 0.06);
  --rdx-card-bg: rgba(255, 255, 255, 0.18);
  --rdx-card-border: rgba(255, 255, 255, 0.08);
  --rdx-card-shadow: none;
  --rdx-field-bg: rgba(255, 255, 255, 0.22);
  --rdx-field-bg-focus: rgba(255, 255, 255, 0.3);
  --rdx-plan-line: rgba(167, 139, 250, 0.28);
  --rdx-plan-line-strong: rgba(167, 139, 250, 0.45);
  --rdx-plan-cell-bg: rgba(255, 255, 255, 0.025);
  --rdx-plan-cell-alt-bg: rgba(255, 255, 255, 0.05);
  --rdx-plan-master-bg: linear-gradient(135deg, rgba(167, 139, 250, 0.18), rgba(124, 58, 237, 0.1));
  --rdx-plan-master-alt-bg: linear-gradient(135deg, rgba(124, 58, 237, 0.1), rgba(167, 139, 250, 0.06));
  --rdx-plan-head-bg: linear-gradient(135deg, rgba(167, 139, 250, 0.25), rgba(124, 58, 237, 0.15));
  --rdx-plan-weekend-bg: rgba(255, 255, 255, 0.02);
  --rdx-plan-hover-bg: rgba(167, 139, 250, 0.1);
  --rdx-plan-grid-shadow: 0 8px 32px rgba(0, 0, 0, 0.4), inset 0 0 0 1px rgba(255, 255, 255, 0.05);
  --rdx-plan-master-top: rgba(255, 255, 255, 0.06);
  --rdx-plan-master-inset: rgba(0, 0, 0, 0.15);
  --rdx-plan-cell-top: rgba(255, 255, 255, 0.04);
  --rdx-plan-cell-inset: rgba(0, 0, 0, 0.15);
  --rdx-table-line: rgba(255, 255, 255, 0.08);
  --rdx-table-line-strong: rgba(255, 255, 255, 0.12);
  --rdx-table-head-bg: rgba(255, 255, 255, 0.04);
  --rdx-table-row-bg: rgba(255, 255, 255, 0.01);
  --rdx-table-row-alt-bg: rgba(255, 255, 255, 0.03);
  --rdx-table-row-hover-bg: rgba(88, 166, 255, 0.1);
  --rdx-table-cell-inset: rgba(255, 255, 255, 0.04);
  --rdx-text: #f6f8ff;
  --rdx-text-soft: #8b97ae;
  --rdx-text-muted: #6e7b92;
  --rdx-accent: #58a6ff;
  --rdx-accent-2: #5eead4;
  --rdx-accent-3: #9b8cff;
  --rdx-good: #41d38f;
  --rdx-warn: #ffb547;
  --rdx-danger: #ff7b72;
  --rdx-shadow-sm: 0 10px 24px rgba(0, 0, 0, 0.34);
  --rdx-shadow-md: 0 26px 56px rgba(0, 0, 0, 0.42);
  --rdx-shadow-lg: 0 38px 78px rgba(0, 0, 0, 0.54);
  --rdx-glow-a: rgba(88, 166, 255, 0.16);
  --rdx-glow-b: rgba(155, 140, 255, 0.14);
  --rdx-glow-c: rgba(94, 234, 212, 0.12);

  --bg: var(--rdx-bg);
  --surface: var(--rdx-panel-strong);
  --surface-2: var(--rdx-panel-soft);
  --surface-translucent: var(--rdx-panel);
  --surface-tint: rgba(255, 255, 255, 0.08);
  --sf: var(--rdx-panel-strong);
  --sf-solid: var(--rdx-panel-strong);
  --s2: var(--rdx-panel-soft);
  --s3: rgba(255, 255, 255, 0.06);
  --bd: rgba(255, 255, 255, 0.08);
  --separator: rgba(255, 255, 255, 0.06);
  --hairline: rgba(255, 255, 255, 0.05);
  --tx: var(--rdx-text);
  --t2: var(--rdx-text-soft);
  --t3: var(--rdx-text-muted);
  --ac: var(--rdx-accent);
  --ac-bg: rgba(88, 166, 255, 0.16);
  --ac-bg-2: rgba(88, 166, 255, 0.24);
  --ac-glow: rgba(88, 166, 255, 0.32);
  --gr: var(--rdx-good);
  --gr-bg: rgba(65, 211, 143, 0.18);
  --yl: var(--rdx-warn);
  --yl-bg: rgba(255, 181, 71, 0.18);
  --rd: var(--rdx-danger);
  --rd-bg: rgba(255, 123, 114, 0.18);
}

body.ios-redesign {
  font-family: "InterVariable", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  color: var(--tx);
  background:
    radial-gradient(circle at 12% 16%, var(--rdx-glow-a), transparent 24%),
    radial-gradient(circle at 86% 18%, var(--rdx-glow-b), transparent 20%),
    radial-gradient(circle at 72% 84%, var(--rdx-glow-c), transparent 20%),
    linear-gradient(180deg, var(--rdx-bg), var(--rdx-bg-2));
}

body.ios-redesign::before,
body.ios-redesign::after {
  content: "";
  position: fixed;
  inset: auto;
  pointer-events: none;
  z-index: 0;
  filter: blur(26px);
  opacity: 0.84;
}

body.ios-redesign::before {
  width: 260px;
  height: 260px;
  left: -60px;
  top: 72px;
  border-radius: 50%;
  background: var(--rdx-glow-a);
}

body.ios-redesign::after {
  width: 320px;
  height: 320px;
  right: -110px;
  top: 180px;
  border-radius: 50%;
  background: var(--rdx-glow-b);
}

body.ios-redesign > * {
  position: relative;
  z-index: 1;
}

body.ios-redesign a,
body.ios-redesign button,
body.ios-redesign input,
body.ios-redesign select,
body.ios-redesign textarea {
  transition:
    background-color 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.18s ease;
}

body.ios-redesign .theme-switch {
  padding: 4px;
  border-radius: var(--ios-pill);
  background: var(--rdx-chip);
  border: 1px solid var(--rdx-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
  backdrop-filter: var(--blur-bar);
  -webkit-backdrop-filter: var(--blur-bar);
}

body.ios-redesign .theme-switch .ts-pill {
  background: var(--rdx-panel-strong);
  border: 1px solid var(--rdx-border);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
}

body.ios-redesign .theme-switch .ts-seg {
  color: var(--t2);
  min-width: 38px;
}

body.ios-redesign .theme-switch .ts-seg.ts-on {
  color: var(--tx);
}

body.page-login.ios-redesign {
  background:
    radial-gradient(circle at 18% 18%, var(--rdx-glow-a), transparent 26%),
    radial-gradient(circle at 84% 20%, var(--rdx-glow-b), transparent 22%),
    radial-gradient(circle at 60% 86%, var(--rdx-glow-c), transparent 18%),
    linear-gradient(180deg, var(--rdx-bg), var(--rdx-bg-2));
}

body.page-login.ios-redesign .auth-topbar {
  width: min(1240px, calc(100% - 28px));
  margin: 18px auto 0;
  padding: 16px 18px 0;
}

body.page-login.ios-redesign .auth-wrap {
  max-width: 430px;
  gap: 30px;
}

body.page-login.ios-redesign .auth-logo {
  width: 86px;
  height: 86px;
  border-radius: 26px;
  background: linear-gradient(135deg, rgba(10, 132, 255, 0.94), rgba(124, 92, 255, 0.84));
  box-shadow: 0 24px 48px rgba(72, 107, 176, 0.24);
}

body.page-login.ios-redesign .auth-logo img {
  width: 58px;
  height: 58px;
  filter: brightness(1.08) contrast(1.06);
}

body.page-login.ios-redesign .auth-title {
  font-size: 34px;
  line-height: 0.98;
  letter-spacing: -0.03em;
}

body.page-login.ios-redesign .auth-sub {
  color: var(--t2);
  font-size: 14px;
}

body.page-login.ios-redesign .auth-card {
  padding: 26px;
  border-radius: 34px;
  background: var(--rdx-panel);
  border: 1px solid var(--rdx-border);
  box-shadow: var(--rdx-shadow-lg);
  backdrop-filter: var(--blur-bar);
  -webkit-backdrop-filter: var(--blur-bar);
}

body.page-login.ios-redesign .field-input {
  min-height: 60px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.26);
  border: 1px solid var(--rdx-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

body.page-login.ios-redesign .field-input:focus-within {
  border-color: rgba(10, 132, 255, 0.34);
  box-shadow:
    0 0 0 4px rgba(10, 132, 255, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

body.page-login.ios-redesign .field-input input {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: var(--tx) !important;
}

body.page-login.ios-redesign .auth-btn {
  min-height: 58px;
  border-radius: 22px;
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3));
  border: none;
  box-shadow: 0 18px 34px rgba(76, 108, 172, 0.28);
}

body.page-login.ios-redesign .auth-btn:hover {
  transform: translateY(-1px);
}

body.page-login.ios-redesign .auth-btn:active {
  transform: scale(0.985);
}

body.page-login.ios-redesign .auth-err {
  border-radius: 18px;
  border: 1px solid rgba(255, 95, 87, 0.18);
  background: rgba(255, 95, 87, 0.12);
  color: var(--rd);
}

body.page-login.ios-redesign .auth-footer {
  color: var(--t2);
}

body.page-manager.ios-redesign {
  /* Header не sticky — при скролле уходит за границу. Sidebar и
     pv2-side прилипают к самому верху viewport (14px от верха). */
  --manager-header-offset: 14px;
  --sidebar-sticky-top: 14px;
  background:
    radial-gradient(circle at 10% 10%, var(--rdx-glow-a), transparent 24%),
    radial-gradient(circle at 90% 12%, var(--rdx-glow-b), transparent 20%),
    radial-gradient(circle at 76% 88%, var(--rdx-glow-c), transparent 18%),
    linear-gradient(180deg, var(--rdx-bg), var(--rdx-bg-2));
}

body.page-manager.ios-redesign::before {
  left: -80px;
  top: 120px;
}

body.page-manager.ios-redesign::after {
  right: -120px;
  top: 340px;
}

body.page-manager.ios-redesign .hdr {
  /* Header НЕ sticky — обычный header в потоке документа, скроллится с контентом.
     Но position:relative + z-index нужны, чтобы выпадашки внутри шапки
     (online-dropdown, gs-results) рисовались поверх остальной страницы.
     Сам .hdr имеет backdrop-filter (stacking context), и без явного z-index
     контент под шапкой перекрывает её детей-absolute. */
  position: relative !important;
  z-index: 50;
  margin: 18px 18px 0;
  min-height: 72px;
  padding: 14px 18px;
  border: 1px solid var(--rdx-border);
  border-radius: 30px;
  background: var(--rdx-panel);
  box-shadow: var(--rdx-shadow-md);
  backdrop-filter: var(--blur-bar);
  -webkit-backdrop-filter: var(--blur-bar);
}

body.page-manager.ios-redesign .pill,
body.page-manager.ios-redesign .online-wrap,
body.page-manager.ios-redesign .gs-wrap,
body.page-manager.ios-redesign .logout,
body.page-manager.ios-redesign .hdr-home-btn,
body.page-manager.ios-redesign .sidebar-toggle {
  border-radius: 999px;
  border: 1px solid var(--rdx-border);
  background: var(--rdx-chip);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

/* Единая высота всех интерактивных элементов в правой части шапки
   (online-wrap, theme-switch, pill с именем, logout). Эталон — высота
   theme-switch (36px). Делаем все inline-flex с одинаковой height и
   центрируем содержимое. */
body.page-manager.ios-redesign .hdr-r .online-wrap,
body.page-manager.ios-redesign .hdr-r .pill,
body.page-manager.ios-redesign .hdr-r .logout,
body.page-manager.ios-redesign .hdr-r .theme-switch {
  height: 36px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 14px !important;
  font-size: 12px !important;
  line-height: 1 !important;
}
/* theme-switch — контейнер с внутренними segments; padding должен быть 3px
   чтобы ts-pill-индикатор имел место для скругления */
body.page-manager.ios-redesign .hdr-r .theme-switch {
  padding: 3px !important;
  gap: 0;
}
body.page-manager.ios-redesign .hdr-r .theme-switch .ts-seg {
  height: 30px;
  min-width: 38px;
  padding: 0 10px !important;
}
/* logout — ссылка с иконкой и текстом, чтобы иконка не прижимала height */
body.page-manager.ios-redesign .hdr-r .logout {
  gap: 6px;
}

body.page-manager.ios-redesign .pill {
  color: var(--t2);
}

body.page-manager.ios-redesign .pill b {
  color: var(--tx);
}

body.page-manager.ios-redesign .logout,
body.page-manager.ios-redesign .hdr-home-btn,
body.page-manager.ios-redesign .sidebar-toggle {
  color: var(--tx);
}

body.page-manager.ios-redesign .logout:hover,
body.page-manager.ios-redesign .hdr-home-btn:hover,
body.page-manager.ios-redesign .sidebar-toggle:hover {
  transform: translateY(-1px);
}

/* Dropdown списка онлайна — поднимаем над любым соседним контентом */
body.page-manager.ios-redesign .online-dropdown {
  z-index: 60 !important;
}

body.page-manager.ios-redesign .avatar {
  width: 38px;
  height: 38px;
  box-shadow: 0 18px 34px rgba(72, 107, 176, 0.24);
}

body.page-manager.ios-redesign .app-layout {
  display: flex;
  gap: 18px;
  padding: 18px;
  min-height: calc(100vh - 52px);
}

body.page-manager.ios-redesign .sidebar {
  /* Sticky к самому верху viewport (минус небольшой отступ),
     чтобы при скролле не было видимой пустоты над меню.
     Header имеет z-index:20, sidebar — 15, поэтому header всегда
     перекроет верхнюю часть sidebar, когда они визуально
     пересекаются. Это даёт эффект «прилипания» к шапке. */
  top: var(--sidebar-sticky-top);
  height: calc(100vh - var(--sidebar-sticky-top) * 2);
  width: 248px;
  min-width: 248px;
  border: 1px solid var(--rdx-border);
  border-radius: 32px;
  background: var(--rdx-panel);
  box-shadow: var(--rdx-shadow-md);
  backdrop-filter: var(--blur-bar);
  -webkit-backdrop-filter: var(--blur-bar);
  padding: 10px 0 14px;
  z-index: 15;
}

/* Первая группа в sidebar без лишнего margin-top (верхний отступ
   уже задаётся padding-ом самого .sidebar) */
body.page-manager.ios-redesign .sidebar .sb-group:first-child,
body.page-manager.ios-redesign .sidebar .sb-group:first-child .sb-group-title {
  margin-top: 0;
  padding-top: 4px;
}

body.page-manager.ios-redesign .sb-group {
  margin-bottom: 10px;
}

body.page-manager.ios-redesign .sb-group-title {
  padding: 6px 18px 8px;
  color: var(--t2);
  letter-spacing: 0.12em;
}

body.page-manager.ios-redesign .sb-item {
  margin: 0 10px 6px;
  padding: 12px 14px;
  border-left: none;
  border-radius: 18px;
  color: var(--t2);
  background: transparent;
}

body.page-manager.ios-redesign .sb-item:hover {
  color: var(--tx);
  background: rgba(255, 255, 255, 0.12);
}

body.page-manager.ios-redesign .sb-item.on {
  color: var(--tx);
  background: linear-gradient(135deg, rgba(10, 132, 255, 0.94), rgba(124, 92, 255, 0.84));
  box-shadow: 0 18px 34px rgba(76, 108, 172, 0.24);
}

body.page-manager.ios-redesign .sb-item.on .sb-badge {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

body.page-manager.ios-redesign .wrap {
  max-width: none;
  padding: 0;
}

body.page-manager.ios-redesign .card,
body.page-manager.ios-redesign .sc,
body.page-manager.ios-redesign .modal,
body.page-manager.ios-redesign .menu-box,
body.page-manager.ios-redesign .online-dropdown,
body.page-manager.ios-redesign .gs-results,
body.page-manager.ios-redesign .pv2-ctx,
body.page-manager.ios-redesign .pv2-side,
body.page-manager.ios-redesign .pv2-summary,
body.page-manager.ios-redesign .pv2-scroll,
body.page-manager.ios-redesign .tw,
body.page-manager.ios-redesign .ss-table-wrap,
body.page-manager.ios-redesign .mc-widget-list,
body.page-manager.ios-redesign .helper-card {
  border-radius: 30px !important;
  border: 1px solid var(--rdx-border) !important;
  background: var(--rdx-panel) !important;
  box-shadow: var(--rdx-shadow-md);
  backdrop-filter: var(--blur-card);
  -webkit-backdrop-filter: var(--blur-card);
}

body.page-manager.ios-redesign .card-title,
body.page-manager.ios-redesign .sum-title,
body.page-manager.ios-redesign .view-title {
  letter-spacing: -0.02em;
}

body.page-manager.ios-redesign .sc {
  min-width: 138px;
  padding: 18px;
}

body.page-manager.ios-redesign .sc .n {
  font-size: 30px;
}

body.page-manager.ios-redesign .btn,
body.page-manager.ios-redesign .bp,
body.page-manager.ios-redesign .bs,
body.page-manager.ios-redesign .back,
body.page-manager.ios-redesign .pv2-chip,
body.page-manager.ios-redesign .inc-pill {
  border-radius: 999px !important;
}

body.page-manager.ios-redesign .btn,
body.page-manager.ios-redesign .back {
  border: 1px solid var(--rdx-border) !important;
  background: var(--rdx-chip) !important;
  color: var(--tx) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

body.page-manager.ios-redesign .btn:hover,
body.page-manager.ios-redesign .back:hover {
  transform: translateY(-1px);
}

body.page-manager.ios-redesign .bp,
body.page-manager.ios-redesign .btn.bp {
  color: #fff !important;
  border: none !important;
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3)) !important;
  box-shadow: 0 18px 34px rgba(76, 108, 172, 0.24);
}

body.page-manager.ios-redesign .bs,
body.page-manager.ios-redesign .btn.bs {
  background: var(--rdx-chip) !important;
  color: var(--tx) !important;
}

body.page-manager.ios-redesign .inp,
body.page-manager.ios-redesign input,
body.page-manager.ios-redesign select,
body.page-manager.ios-redesign textarea {
  min-height: 48px;
  border-radius: 18px !important;
  border: 1px solid var(--rdx-border) !important;
  background: var(--rdx-field-bg) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

body.page-manager.ios-redesign .inp:focus,
body.page-manager.ios-redesign input:focus,
body.page-manager.ios-redesign select:focus,
body.page-manager.ios-redesign textarea:focus {
  background: var(--rdx-field-bg-focus) !important;
  box-shadow: 0 0 0 4px rgba(10, 132, 255, 0.12) !important;
}

/* Исключение: input/select внутри плотных таблиц (ЗП, аналитика) должны
   оставаться компактными — иначе 48px min-height раздувает каждую строку
   и таблица занимает в 2 раза больше вертикального места, чем нужно. */
body.page-manager.ios-redesign .ss-table input,
body.page-manager.ios-redesign .ss-table select,
body.page-manager.ios-redesign .ss-table textarea,
body.page-manager.ios-redesign .tw input,
body.page-manager.ios-redesign .tw select,
body.page-manager.ios-redesign .fin-table input,
body.page-manager.ios-redesign .fin-table select {
  min-height: 0 !important;
  height: auto !important;
  padding: 3px 6px !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  background: rgba(255, 255, 255, 0.08) !important;
}
body.page-manager.ios-redesign .ss-table td {
  padding: 2px 3px !important;
}

/* Блок «Распределение прибыли» — inputs % должны быть компактными, чтобы
   соответствовать высоте progress-бара рядом. Сохраняем round+glass-вид,
   но без распирающей 48px-высоты и 18px-radius. */
body.page-manager.ios-redesign #acc-profit-block input {
  min-height: 0 !important;
  height: 28px !important;
  padding: 4px 10px !important;
  border-radius: 10px !important;
  font-size: 13px !important;
  font-weight: 700;
  text-align: right;
  background: rgba(255, 255, 255, 0.10) !important;
  border: 1px solid var(--rdx-border) !important;
}

body.page-manager.ios-redesign .toolbar {
  gap: 10px;
}

body.page-manager.ios-redesign .rv2-card,
body.page-manager.ios-redesign .mc-card,
body.page-manager.ios-redesign .pv2-req,
body.page-manager.ios-redesign .pv2-req-item,
body.page-manager.ios-redesign .ts-card,
body.page-manager.ios-redesign .cl-card,
body.page-manager.ios-redesign .tree-row,
body.page-manager.ios-redesign .dir-row,
body.page-manager.ios-redesign .mc-obj-item,
body.page-manager.ios-redesign .plan-item,
body.page-manager.ios-redesign .ws-card,
body.page-manager.ios-redesign #dash-masters > *,
body.page-manager.ios-redesign #dash-mc > *,
body.page-manager.ios-redesign #rv2-list > *,
body.page-manager.ios-redesign #pv2-unassigned-list > *,
body.page-manager.ios-redesign #pv2-requests-list > * {
  border-radius: 22px !important;
  border: 1px solid var(--rdx-card-border) !important;
  background: var(--rdx-card-bg) !important;
  box-shadow: var(--rdx-card-shadow) !important;
}

body.page-manager.ios-redesign #rv2-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

body.page-manager.ios-redesign .rv2-card {
  display: grid !important;
  grid-template-columns:
    minmax(220px, 1.15fr)
    minmax(360px, 2fr)
    minmax(180px, 0.85fr)
    max-content;
  gap: 24px;
  align-items: center;
  min-height: 124px;
  margin-bottom: 0 !important;
  padding: 18px !important;
}

body.page-manager.ios-redesign .rv2-card > div {
  min-width: 0;
}

body.page-manager.ios-redesign .rv2-card > div:last-child {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

body.page-manager.ios-redesign .rv2-card .btn {
  white-space: nowrap;
}

@media (max-width: 1100px) {
  body.page-manager.ios-redesign .rv2-card {
    grid-template-columns: minmax(220px, 1fr) minmax(280px, 1.35fr);
    align-items: start;
  }

  body.page-manager.ios-redesign .rv2-card > div:last-child {
    justify-content: flex-start;
  }
}

@media (max-width: 700px) {
  body.page-manager.ios-redesign .rv2-card {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}
/* NB: из этого общего правила намеренно исключены дашборд-блоки, у которых
   структура не «список карточек», а внутренняя разметка:
   - #dash-statuses, #dash-finance — KPI-блоки (label+value, pill+progress-bar)
   - #dash-events — timeline (dash-tl) c тонкой border-bottom линией
   Для них лишние border/radius/background создают визуальный мусор: текст
   и pills выглядят так, будто выходят за рамки родительской карточки. */

body.page-manager.ios-redesign .rv2-card:hover,
body.page-manager.ios-redesign .mc-card:hover,
body.page-manager.ios-redesign .pv2-req:hover,
body.page-manager.ios-redesign .cl-card:hover,
body.page-manager.ios-redesign .tree-row:hover,
body.page-manager.ios-redesign .dir-row:hover {
  transform: translateY(-1px);
  border-color: rgba(10, 132, 255, 0.28) !important;
  box-shadow: 0 18px 34px rgba(76, 108, 172, 0.12) !important;
}

/* NB: НЕ ставить overflow:hidden на .planner-card — это ломает
   position:sticky у .pv2-side (grid-ребёнок). Sticky считает
   ближайший overflow-не-visible контейнер своим scroll-ancestor и
   перестаёт выпадать из grid-ячейки. Внутренние блоки (pv2-side,
   pv2-scroll, pv2-summary) сами круглые и с фоном, так что визуально
   обрезать содержимое карточки не нужно. */
body.page-manager.ios-redesign .planner-card {
  overflow: visible;
}

body.page-manager.ios-redesign .pv2-layout {
  gap: 16px;
}

body.page-manager.ios-redesign .pv2-side,
body.page-manager.ios-redesign .pv2-scroll,
body.page-manager.ios-redesign .pv2-summary {
  border-radius: 24px;
}

body.page-manager.ios-redesign .pv2-grid {
  background: var(--rdx-plan-line) !important;
  border: 1px solid var(--rdx-plan-line-strong) !important;
  box-shadow: var(--rdx-plan-grid-shadow) !important;
}

body.page-manager.ios-redesign .pv2-hdr-master,
body.page-manager.ios-redesign .pv2-hdr-cell {
  background: var(--rdx-plan-head-bg) !important;
  border-bottom: 2px solid var(--rdx-plan-line-strong) !important;
  color: var(--tx) !important;
}

body.page-manager.ios-redesign .pv2-hdr-master,
body.page-manager.ios-redesign .pv2-master {
  border-right: 2px solid var(--rdx-plan-line-strong) !important;
}

body.page-manager.ios-redesign .pv2-master {
  background: var(--rdx-plan-master-bg) !important;
  border-bottom: 2px solid var(--rdx-plan-line) !important;
  border-top: 1px solid var(--rdx-plan-master-top) !important;
  box-shadow: inset 0 -1px 0 var(--rdx-plan-master-inset) !important;
}

body.page-manager.ios-redesign .pv2-master.pv2-row-alt {
  background: var(--rdx-plan-master-alt-bg) !important;
}

body.page-manager.ios-redesign .pv2-cell {
  background: var(--rdx-plan-cell-bg) !important;
  border-right: 1px solid var(--rdx-plan-line) !important;
  border-bottom: 2px solid var(--rdx-plan-line) !important;
  border-top: 1px solid var(--rdx-plan-cell-top) !important;
  box-shadow: inset 0 1px 0 var(--rdx-plan-cell-inset);
}

body.page-manager.ios-redesign .pv2-cell:hover {
  background: var(--rdx-plan-hover-bg) !important;
  border-right-color: var(--rdx-plan-line-strong) !important;
}

body.page-manager.ios-redesign .pv2-cell.pv2-row-alt {
  background: var(--rdx-plan-cell-alt-bg) !important;
}

body.page-manager.ios-redesign .pv2-hdr-cell.weekend {
  background:
    repeating-linear-gradient(45deg, rgba(255, 159, 10, 0.18), rgba(255, 159, 10, 0.18) 6px, rgba(255, 159, 10, 0.28) 6px, rgba(255, 159, 10, 0.28) 8px),
    var(--rdx-plan-weekend-bg) !important;
}

body.page-manager.ios-redesign .pv2-cell.weekend {
  background:
    repeating-linear-gradient(45deg, rgba(255, 159, 10, 0.08), rgba(255, 159, 10, 0.08) 8px, rgba(255, 159, 10, 0.15) 8px, rgba(255, 159, 10, 0.15) 16px),
    var(--rdx-plan-weekend-bg) !important;
}

body.page-manager.ios-redesign .pv2-cell.pv2-row-alt.weekend {
  background:
    repeating-linear-gradient(45deg, rgba(255, 159, 10, 0.1), rgba(255, 159, 10, 0.1) 8px, rgba(255, 159, 10, 0.17) 8px, rgba(255, 159, 10, 0.17) 16px),
    var(--rdx-plan-weekend-bg) !important;
}

/* ── Sticky боковая панель планировщика ──
   Блок «Задачи без мастера + Заявки к планированию» прилипает к
   верху при скролле — чтобы было удобно тащить задачи в план работ
   независимо от того, куда проскроллили страницу.
   Прилипает прямо под sticky-шапкой CRM (та на top: 14px + высота
   ≈ 90px, поэтому pv2-side садится на ~110px). z-index ниже чем у
   шапки — чтобы шапка его не перекрывала визуально. */
body.page-manager.ios-redesign .pv2-side {
  position: sticky !important;
  top: 14px !important;        /* прилипает к верху viewport при скролле */
  align-self: start;           /* не растягиваться на всю высоту grid cell */
  max-height: calc(100vh - 28px) !important;
  overflow-y: auto !important;
  z-index: 14;                 /* главный sidebar = 15 */
}

/* Режим привязки заявки к ячейке (активен когда пользователь нажал
   «Запланировать выезд» в карточке заявки и ждёт клика по ячейке).
   Подсвечиваем все ячейки единой рамкой, чтобы было очевидно: можно
   кликать ЛЮБУЮ, в том числе занятую задачами. */
body.page-manager.ios-redesign .pv2-attach-mode .pv2-cell:not(.pv2-day-closed) {
  cursor: crosshair !important;
  animation: pv2-attach-pulse 1.6s ease-in-out infinite;
}
body.page-manager.ios-redesign .pv2-attach-mode .pv2-cell:hover:not(.pv2-day-closed) {
  outline: 2px solid var(--rdx-accent) !important;
  outline-offset: -2px;
  background: rgba(10, 132, 255, 0.12) !important;
}
@keyframes pv2-attach-pulse {
  0%, 100% { box-shadow: inset 0 0 0 0 rgba(10, 132, 255, 0); }
  50%      { box-shadow: inset 0 0 0 1px rgba(10, 132, 255, 0.25); }
}

/* На мобильных (где .pv2-layout становится одноколоночной) sticky
   отключаем — pv2-side и planner друг под другом, sticky мешал бы */
@media (max-width: 1100px) {
  body.page-manager.ios-redesign .pv2-side {
    position: static !important;
    max-height: none !important;
    top: auto !important;
  }
}

/* ─── Горизонтальный скролл планировщика ─────────────────
   При увеличении масштаба (125%+) правый край таблицы мастеров
   уходит за границу экрана. Гарантируем что скроллбар всегда
   виден и заметен — не auto-hide, с iOS-style ручкой. Работает
   и в planner v2 (swimlanes, .pv2-scroll), и в legacy v1
   (.planner-scroll). */
body.page-manager.ios-redesign .pv2-scroll,
body.page-manager.ios-redesign .planner-scroll {
  overflow-x: auto;
  overflow-y: visible;
  scrollbar-width: auto;               /* Firefox */
  scrollbar-color: var(--rdx-accent) var(--rdx-chip);
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;   /* iOS momentum */
  padding-bottom: 6px;                 /* чтобы thumb не резался по низу */
}

/* WebKit (Chrome / Edge / Safari) — явный видимый скроллбар */
body.page-manager.ios-redesign .pv2-scroll::-webkit-scrollbar,
body.page-manager.ios-redesign .planner-scroll::-webkit-scrollbar {
  height: 14px;
  background: transparent;
}

body.page-manager.ios-redesign .pv2-scroll::-webkit-scrollbar-track,
body.page-manager.ios-redesign .planner-scroll::-webkit-scrollbar-track {
  background: var(--rdx-chip);
  border-radius: 999px;
  margin: 0 24px;                      /* отступ чтобы «рельсы» не упирались в края */
  border: 1px solid var(--rdx-border-soft);
}

body.page-manager.ios-redesign .pv2-scroll::-webkit-scrollbar-thumb,
body.page-manager.ios-redesign .planner-scroll::-webkit-scrollbar-thumb {
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3));
  border-radius: 999px;
  border: 2px solid var(--rdx-chip);   /* «воздух» вокруг ручки */
  background-clip: padding-box;
  min-width: 56px;                     /* минимум чтобы видно было */
}

body.page-manager.ios-redesign .pv2-scroll::-webkit-scrollbar-thumb:hover,
body.page-manager.ios-redesign .planner-scroll::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(135deg, var(--rdx-accent-2), var(--rdx-accent));
  background-clip: padding-box;
}

body.page-manager.ios-redesign .pv2-scroll::-webkit-scrollbar-thumb:active,
body.page-manager.ios-redesign .planner-scroll::-webkit-scrollbar-thumb:active {
  background: var(--rdx-accent);
  background-clip: padding-box;
}

/* Тот же скроллбар для горизонтально-прокручиваемых таблиц
   (табель, бухгалтерия) — чтобы был единообразный UX */
body.page-manager.ios-redesign .ss-wrap,
body.page-manager.ios-redesign .tw {
  scrollbar-color: var(--rdx-accent) var(--rdx-chip);
}
body.page-manager.ios-redesign .ss-wrap::-webkit-scrollbar,
body.page-manager.ios-redesign .tw::-webkit-scrollbar {
  height: 12px;
  width: 12px;
}
body.page-manager.ios-redesign .ss-wrap::-webkit-scrollbar-track,
body.page-manager.ios-redesign .tw::-webkit-scrollbar-track {
  background: var(--rdx-chip);
  border-radius: 999px;
}
body.page-manager.ios-redesign .ss-wrap::-webkit-scrollbar-thumb,
body.page-manager.ios-redesign .tw::-webkit-scrollbar-thumb {
  background: var(--rdx-accent);
  border-radius: 999px;
  border: 2px solid var(--rdx-chip);
  background-clip: padding-box;
  min-width: 40px;
  min-height: 40px;
}

/* Fade-подсказка справа: когда контент уходит за край, пользователь
   видит градиент, намекающий что можно проскроллить вправо */
body.page-manager.ios-redesign .pv2-main {
  position: relative;
}
body.page-manager.ios-redesign .pv2-main::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 28px;
  height: calc(100% - 18px);
  pointer-events: none;
  background: linear-gradient(to left, var(--rdx-bg), transparent);
  opacity: 0.35;
  border-radius: 0 24px 24px 0;
  z-index: 2;
}

/* ─── Floating horizontal scrollbar (fixed bottom) ───────────
   Дублирующая скролл-полоса для планировщика. position: fixed
   относительно viewport — всегда внизу экрана независимо от
   прокрутки страницы. JS рассчитывает left/width по
   getBoundingClientRect #planner-box и синхронизирует scrollLeft.
   Видна только когда контент planner-box шире своего контейнера. */
body.page-manager.ios-redesign .pv2-sticky-scroll {
  display: none;                /* включается классом --show из JS */
  position: fixed;
  bottom: 18px;
  z-index: 35;
  height: 20px;
  overflow-x: auto;
  overflow-y: hidden;
  border-radius: 999px;
  background: var(--rdx-panel-strong);
  border: 1px solid var(--rdx-border);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.24);
  backdrop-filter: var(--blur-bar);
  -webkit-backdrop-filter: var(--blur-bar);
  scrollbar-width: auto;
  scrollbar-color: var(--rdx-accent) transparent;
  transition: opacity 0.2s ease;
}
body.page-manager.ios-redesign .pv2-sticky-scroll.pv2-sticky-scroll--show {
  display: block;
}
body.page-manager.ios-redesign .pv2-sticky-scroll > div {
  height: 1px;                  /* "призрак" — задаёт ширину */
  pointer-events: none;
}
/* WebKit-скроллбар внутри floating-полосы — та же iOS-style ручка */
body.page-manager.ios-redesign .pv2-sticky-scroll::-webkit-scrollbar {
  height: 18px;
  background: transparent;
}
body.page-manager.ios-redesign .pv2-sticky-scroll::-webkit-scrollbar-track {
  background: transparent;
  margin: 0 8px;
}
body.page-manager.ios-redesign .pv2-sticky-scroll::-webkit-scrollbar-thumb {
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3));
  border-radius: 999px;
  border: 3px solid transparent;
  background-clip: padding-box;
  min-width: 64px;
  cursor: grab;
}
body.page-manager.ios-redesign .pv2-sticky-scroll::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(135deg, var(--rdx-accent-2), var(--rdx-accent));
  background-clip: padding-box;
}
body.page-manager.ios-redesign .pv2-sticky-scroll::-webkit-scrollbar-thumb:active {
  cursor: grabbing;
}

body.page-manager.ios-redesign .pv2-chip.on {
  color: #fff !important;
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3)) !important;
  box-shadow: 0 14px 28px rgba(76, 108, 172, 0.18);
}

body.page-manager.ios-redesign .pv2-range,
body.page-manager.ios-redesign .plan-range {
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--rdx-chip);
  border: 1px solid var(--rdx-border);
}

body.page-manager.ios-redesign .modal,
body.page-manager.ios-redesign .menu-box,
body.page-manager.ios-redesign .online-dropdown,
body.page-manager.ios-redesign .gs-results {
  background: var(--rdx-panel-strong) !important;
}

body.page-manager.ios-redesign .mbg,
body.page-manager.ios-redesign .menu-bg,
body.page-manager.ios-redesign .sb-overlay {
  background: rgba(7, 10, 16, 0.28) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* ── Жёсткое позиционирование .mbg-модалок ──
   Гарантируем что overlay всегда fixed на весь viewport,
   а не ведёт себя как обычный div в потоке документа.
   Баг у пользователя: модалка появлялась внизу страницы
   (значит позиционирование терялось где-то в каскаде). */
body.page-manager.ios-redesign .mbg {
  position: fixed !important;
  inset: 0 !important;
  z-index: 100 !important;
  padding: 20px;
}
/* Confirm-модалка должна быть поверх любой другой модалки, в т.ч. rv2-modal
   и intake-modal. Inline style="z-index:9999" раньше перебивался правилом
   выше из-за !important; теперь явно поднимаем её на более высокий слой. */
body.page-manager.ios-redesign #confirm-modal {
  z-index: 10000 !important;
}
body.page-manager.ios-redesign .mbg:not(.open) {
  display: none !important;
}
body.page-manager.ios-redesign .mbg.open {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
/* .modal внутри overlay — авто-ширина под контент, с max-width */
body.page-manager.ios-redesign .mbg .modal {
  width: min(1040px, 100%);
  max-height: 90vh;
  overflow: auto;
}

body.page-manager.ios-redesign table {
  border-collapse: separate;
  border-spacing: 0;
}

body.page-manager.ios-redesign table th {
  color: var(--t2) !important;
  background: transparent;
}

body.page-manager.ios-redesign table td {
  border-color: var(--rdx-border-soft) !important;
}

body.page-manager.ios-redesign .tw {
  overflow: hidden;
}

body.page-manager.ios-redesign .tw table,
body.page-manager.ios-redesign .fin-table {
  background: transparent !important;
}

body.page-manager.ios-redesign #p-accounting .tw {
  border-color: var(--rdx-table-line-strong) !important;
}

body.page-manager.ios-redesign #p-accounting .ts-table {
  width: 100%;
  background: var(--rdx-panel-strong) !important;
}

body.page-manager.ios-redesign #p-accounting .ts-table thead th {
  background: var(--rdx-table-head-bg) !important;
  border-bottom: 2px solid var(--rdx-table-line-strong) !important;
}

body.page-manager.ios-redesign #p-accounting .ts-table tbody tr {
  background: var(--rdx-table-row-bg);
}

body.page-manager.ios-redesign #p-accounting .ts-table tbody tr:nth-child(even) {
  background: var(--rdx-table-row-alt-bg);
}

body.page-manager.ios-redesign #p-accounting .ts-table tbody tr:hover {
  background: var(--rdx-table-row-hover-bg) !important;
}

body.page-manager.ios-redesign #p-accounting .ts-table tbody td {
  border-bottom: 1px solid var(--rdx-table-line) !important;
  box-shadow: inset 0 -1px 0 var(--rdx-table-cell-inset);
}

body.page-manager.ios-redesign #p-accounting .ts-table tbody tr:last-child td {
  border-bottom-color: transparent !important;
}

body.page-manager.ios-redesign .tabs,
body.page-manager.ios-redesign .tab {
  display: none;
}

body.page-master.ios-redesign {
  --app-width: 560px;
  background:
    radial-gradient(circle at 12% 8%, var(--rdx-glow-a), transparent 26%),
    radial-gradient(circle at 88% 18%, var(--rdx-glow-b), transparent 20%),
    radial-gradient(circle at 70% 90%, var(--rdx-glow-c), transparent 18%),
    linear-gradient(180deg, var(--rdx-bg), var(--rdx-bg-2));
}

body.page-master.ios-redesign .hdr {
  margin: 14px 14px 0;
  padding: 14px 16px;
  min-height: 68px;
  border: 1px solid var(--rdx-border);
  border-radius: 28px;
  background: var(--rdx-panel);
  box-shadow: var(--rdx-shadow-md);
  backdrop-filter: var(--blur-bar);
  -webkit-backdrop-filter: var(--blur-bar);
  top: 12px;
}

body.page-master.ios-redesign .hdr-home-btn,
body.page-master.ios-redesign .avatar {
  box-shadow: 0 16px 30px rgba(76, 108, 172, 0.2);
}

body.page-master.ios-redesign .scr {
  padding-top: 18px;
}

body.page-master.ios-redesign .quick-grid {
  gap: 14px;
}

body.page-master.ios-redesign .quick-btn,
body.page-master.ios-redesign .sum-card,
body.page-master.ios-redesign .tw-sheet,
body.page-master.ios-redesign .menu-box,
body.page-master.ios-redesign .notice-box,
body.page-master.ios-redesign #task-list > *,
body.page-master.ios-redesign #plan-day-list > *,
body.page-master.ios-redesign #ws-m-list > *,
body.page-master.ios-redesign #ws-unit-body > * {
  border-radius: 28px !important;
  border: 1px solid var(--rdx-border) !important;
  background: var(--rdx-panel) !important;
  box-shadow: var(--rdx-shadow-md);
  backdrop-filter: var(--blur-card);
  -webkit-backdrop-filter: var(--blur-card);
}

body.page-master.ios-redesign .quick-btn {
  min-height: 126px;
  padding: 18px 16px;
}

body.page-master.ios-redesign .quick-btn .ic,
body.page-master.ios-redesign .act-btn .ic {
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(10, 132, 255, 0.18), rgba(124, 92, 255, 0.14));
}

body.page-master.ios-redesign .sum-card,
body.page-master.ios-redesign .act-header,
body.page-master.ios-redesign .tw-card,
body.page-master.ios-redesign .fin-row,
body.page-master.ios-redesign .plan-task {
  border-radius: 24px;
}

body.page-master.ios-redesign .act-btn,
body.page-master.ios-redesign .submit,
body.page-master.ios-redesign .back,
body.page-master.ios-redesign .photo-btn {
  border-radius: 22px !important;
}

body.page-master.ios-redesign .act-btn {
  border: 1px solid var(--rdx-border);
  background: var(--rdx-panel) !important;
  box-shadow: var(--rdx-shadow-sm);
}

body.page-master.ios-redesign .act-btn:hover {
  transform: translateY(-1px);
}

body.page-master.ios-redesign .act-btn[data-intent="done"],
body.page-master.ios-redesign .submit-green {
  border: none !important;
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3)) !important;
  color: #fff !important;
  box-shadow: 0 18px 34px rgba(76, 108, 172, 0.24);
}

body.page-master.ios-redesign #task-list > .submit.submit-green {
  border: none !important;
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3)) !important;
  color: #fff !important;
  box-shadow: 0 18px 34px rgba(76, 108, 172, 0.24) !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

body.page-master.ios-redesign #ws-unit-body > .ws-unit-panel {
  padding: 16px !important;
}

body.page-master.ios-redesign #ws-unit-body .ws-add-work-btn {
  border: none !important;
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3)) !important;
  color: #fff !important;
  box-shadow: 0 18px 34px rgba(76, 108, 172, 0.24) !important;
  text-shadow: 0 1px 1px rgba(15, 23, 42, 0.22);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

body.page-master.ios-redesign #ws-unit-body .ws-add-work-btn .icn {
  color: #fff !important;
  stroke: currentColor;
}

/* Текст внутри градиентных кнопок — принудительно белый.
   У внутренних .lb/.ds в HTML стоит inline `color:var(--gr|rd)` (для светлого
   состояния кнопки), который перебивает color:#fff родителя. Чтобы на градиенте
   текст оставался читаемым в обеих темах — возвращаем белый через более
   специфичный селектор. Второстепенный описательный текст слегка прозрачный. */
body.page-master.ios-redesign .act-btn[data-intent="done"] .lb,
body.page-master.ios-redesign .act-btn[data-intent="cancel"] .lb,
body.page-master.ios-redesign .submit-green .lb,
body.page-master.ios-redesign .submit-red .lb {
  color: #fff !important;
}
body.page-master.ios-redesign .act-btn[data-intent="done"] .ds,
body.page-master.ios-redesign .act-btn[data-intent="cancel"] .ds,
body.page-master.ios-redesign .submit-green .ds,
body.page-master.ios-redesign .submit-red .ds {
  color: rgba(255, 255, 255, 0.85) !important;
}
body.page-master.ios-redesign .act-btn[data-intent="done"] .ic,
body.page-master.ios-redesign .act-btn[data-intent="cancel"] .ic {
  color: #fff !important;
}

body.page-master.ios-redesign .submit-red,
body.page-master.ios-redesign .act-btn[data-intent="cancel"],
body.page-master.ios-redesign #btn-cancel {
  border: none !important;
  background: linear-gradient(135deg, var(--rdx-danger), #ff7f6d) !important;
  color: #fff !important;
  box-shadow: 0 18px 34px rgba(255, 95, 87, 0.24);
}

body.page-master.ios-redesign .back {
  border: 1px solid var(--rdx-border) !important;
  background: var(--rdx-chip) !important;
  color: var(--tx) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

body.page-master.ios-redesign .photo-btn {
  border: 1px dashed rgba(10, 132, 255, 0.24);
  background: rgba(255, 255, 255, 0.18);
  color: var(--ac);
}

body.page-master.ios-redesign .mat-ta,
body.page-master.ios-redesign input,
body.page-master.ios-redesign select,
body.page-master.ios-redesign textarea {
  border-radius: 20px !important;
  border: 1px solid var(--rdx-border) !important;
  background: var(--rdx-field-bg) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

body.page-master.ios-redesign .mat-ta:focus,
body.page-master.ios-redesign input:focus,
body.page-master.ios-redesign select:focus,
body.page-master.ios-redesign textarea:focus {
  background: var(--rdx-field-bg-focus) !important;
  box-shadow: 0 0 0 4px rgba(10, 132, 255, 0.12) !important;
}

body.page-master.ios-redesign .fin-table,
body.page-master.ios-redesign table {
  background: transparent !important;
}

body.page-master.ios-redesign .fin-table th,
body.page-master.ios-redesign .fin-table td {
  border-color: var(--rdx-border-soft) !important;
}

body.page-master.ios-redesign .plan-toolbar {
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  align-items: center;
  gap: 10px;
  margin-top: 16px;
  padding: 8px;
  border-radius: 999px;
  border: 1px solid rgba(72, 94, 128, 0.42);
  background: rgba(225, 235, 249, 0.82);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62), 0 16px 34px rgba(65, 91, 130, 0.14);
}

body.page-master.ios-redesign .plan-nav {
  width: 42px !important;
  height: 42px !important;
  min-width: 42px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(72, 94, 128, 0.48);
  background: rgba(255, 255, 255, 0.94);
  color: var(--tx);
  box-shadow: 0 10px 22px rgba(65, 91, 130, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

body.page-master.ios-redesign .plan-range {
  min-width: 0;
  height: 42px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(72, 94, 128, 0.5);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(236, 244, 255, 0.94));
  color: var(--tx);
  font-size: 14px;
  font-weight: 800;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9), 0 8px 18px rgba(65, 91, 130, 0.08);
  white-space: nowrap;
}

html[data-theme="dark"] body.page-master.ios-redesign .plan-toolbar {
  border-color: rgba(167, 139, 250, 0.32);
  background: rgba(28, 35, 52, 0.86);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 16px 34px rgba(0, 0, 0, 0.38);
}

html[data-theme="dark"] body.page-master.ios-redesign .plan-nav {
  border-color: rgba(167, 139, 250, 0.34);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] body.page-master.ios-redesign .plan-range {
  border-color: rgba(167, 139, 250, 0.38);
  background: rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

@media (prefers-color-scheme: dark) {
  html:not([data-theme]) body.page-master.ios-redesign .plan-toolbar {
    border-color: rgba(167, 139, 250, 0.32);
    background: rgba(28, 35, 52, 0.86);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 16px 34px rgba(0, 0, 0, 0.38);
  }
  html:not([data-theme]) body.page-master.ios-redesign .plan-nav {
    border-color: rgba(167, 139, 250, 0.34);
    background: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
  }
  html:not([data-theme]) body.page-master.ios-redesign .plan-range {
    border-color: rgba(167, 139, 250, 0.38);
    background: rgba(255, 255, 255, 0.1);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  }
}

body.page-master.ios-redesign .tw-sheet {
  background: var(--rdx-panel-strong) !important;
}

body.page-master.ios-redesign .menu-bg,
body.page-master.ios-redesign .notice-bg {
  background: rgba(7, 10, 16, 0.42) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 40 !important;
}

/* Popover-меню профиля — непрозрачный фон (strong), чтобы контент
   страницы не просвечивал сквозь него. Базовый .menu-box стиль для
   карточек-листов ставит rdx-panel (68%), что хорошо для больших
   surfaces, но плохо для всплывающего меню. */
body.page-master.ios-redesign .menu-box,
body.page-manager.ios-redesign .menu-box,
body.page-manager.ios-redesign .online-dropdown,
body.page-manager.ios-redesign .gs-results,
body.page-manager.ios-redesign .pv2-ctx {
  background: var(--rdx-panel-strong) !important;
  z-index: 50;
}

/* Тёмная тема — меню становится ещё плотнее, чтобы точно не сливалось */
html[data-theme="dark"] body.page-master.ios-redesign .menu-box,
html[data-theme="dark"] body.page-manager.ios-redesign .menu-box,
html[data-theme="dark"] body.page-manager.ios-redesign .online-dropdown,
html[data-theme="dark"] body.page-manager.ios-redesign .gs-results {
  background: rgba(24, 30, 44, 0.96) !important;
}

/* В auto-режиме при тёмной ОС — то же правило */
@media (prefers-color-scheme: dark) {
  html:not([data-theme]) body.page-master.ios-redesign .menu-box,
  html:not([data-theme]) body.page-manager.ios-redesign .menu-box,
  html:not([data-theme]) body.page-manager.ios-redesign .online-dropdown,
  html:not([data-theme]) body.page-manager.ios-redesign .gs-results {
    background: rgba(24, 30, 44, 0.96) !important;
  }
}

@media (max-width: 1180px) {
  body.page-manager.ios-redesign .sidebar {
    position: fixed;
    left: 18px;
    top: 96px;
    height: calc(100vh - 118px);
    z-index: 24;
  }
}

@media (max-width: 900px) {
  body.page-manager.ios-redesign .hdr {
    margin: 12px 12px 0;
    border-radius: 24px;
    padding: 12px 14px;
  }

  body.page-manager.ios-redesign .app-layout {
    padding: 14px 12px 24px;
  }

  body.page-master.ios-redesign .hdr {
    margin: 12px 12px 0;
  }
}

@media (max-width: 640px) {
  body.page-login.ios-redesign .auth-topbar {
    width: calc(100% - 18px);
    padding: 14px 10px 0;
  }

  body.page-login.ios-redesign .auth-card {
    padding: 22px 18px;
    border-radius: 28px;
  }

  body.page-master.ios-redesign .quick-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.page-master.ios-redesign .quick-btn {
    min-width: 0;
    overflow: hidden;
  }

  body.page-master.ios-redesign .quick-btn .t,
  body.page-master.ios-redesign .quick-btn .d {
    max-width: 100%;
  }

  body.page-master.ios-redesign .quick-btn .t {
    overflow-wrap: normal;
    word-break: normal;
    hyphens: none;
  }

  body.page-master.ios-redesign .quick-btn .d {
    overflow-wrap: break-word;
  }

  body.page-master.ios-redesign .hdr-r {
    min-width: 0;
    flex-shrink: 1;
  }

  body.page-master.ios-redesign .avatar {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
  }
}

@media (max-width: 430px) {
  body.page-master.ios-redesign #btn-go-home {
    width: 40px;
    height: 40px;
    padding: 0 !important;
    font-size: 0 !important;
    flex: 0 0 40px;
  }

  body.page-master.ios-redesign #btn-go-home .icn {
    width: 18px;
    height: 18px;
    margin: 0;
  }
}

@media (max-width: 380px) {
  body.page-master.ios-redesign .hdr {
    gap: 8px;
    padding-left: 12px;
    padding-right: 12px;
  }

  body.page-master.ios-redesign .hdr img {
    width: 54px;
    height: auto;
    flex: 0 1 54px;
  }

  body.page-master.ios-redesign .hdr-r {
    gap: 6px;
  }

  body.page-master.ios-redesign #btn-go-home {
    width: 40px;
    height: 40px;
    padding: 0 !important;
    font-size: 0 !important;
    flex: 0 0 40px;
  }

  body.page-master.ios-redesign #btn-go-home .icn {
    width: 18px;
    height: 18px;
    margin: 0;
  }

  body.page-master.ios-redesign .theme-switch .ts-seg {
    min-width: 34px;
    padding-left: 8px;
    padding-right: 8px;
  }

  body.page-master.ios-redesign .quick-grid {
    gap: 10px;
  }

  body.page-master.ios-redesign .quick-btn {
    min-height: 118px;
    padding: 16px 10px;
  }

  body.page-master.ios-redesign .quick-btn .t {
    font-size: 13px;
    line-height: 1.15;
  }

  body.page-master.ios-redesign .quick-btn .d {
    font-size: 10.5px;
    line-height: 1.3;
  }
}

@media (max-width: 340px) {
  body.page-master.ios-redesign .hdr img {
    display: none;
  }

  body.page-master.ios-redesign .hdr-r {
    width: 100%;
    justify-content: flex-end;
  }

  body.page-master.ios-redesign .quick-btn {
    padding-left: 8px;
    padding-right: 8px;
  }

  body.page-master.ios-redesign .quick-btn .t {
    font-size: 12.5px;
  }
}

body.page-print.ios-redesign {
  background:
    radial-gradient(circle at 16% 12%, var(--rdx-glow-a), transparent 24%),
    radial-gradient(circle at 82% 18%, var(--rdx-glow-b), transparent 18%),
    linear-gradient(180deg, var(--rdx-bg), var(--rdx-bg-2));
}

body.page-print.ios-redesign .toolbar {
  width: min(1080px, calc(100% - 28px));
  margin: 18px auto 0;
  padding: 14px 16px;
  border-radius: 26px;
  border: 1px solid var(--rdx-border);
  background: var(--rdx-panel);
  box-shadow: var(--rdx-shadow-md);
  backdrop-filter: var(--blur-bar);
  -webkit-backdrop-filter: var(--blur-bar);
}

body.page-print.ios-redesign .toolbar button {
  border-radius: 18px;
  background: var(--rdx-chip);
  border: 1px solid var(--rdx-border);
  color: var(--tx);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

body.page-print.ios-redesign .toolbar button:first-of-type {
  color: #fff;
  border: none;
  background: linear-gradient(135deg, var(--rdx-accent), var(--rdx-accent-3));
  box-shadow: 0 18px 34px rgba(76, 108, 172, 0.24);
}

body.page-print.ios-redesign .toolbar .hint {
  color: var(--t2);
}

body.page-print.ios-redesign .page {
  margin-top: 18px;
  margin-bottom: 28px;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 26px 56px rgba(15, 23, 42, 0.14);
}

@media print {
  body.page-print.ios-redesign .page {
    margin: 0 auto;
    border-radius: 0;
    box-shadow: none;
  }
}

/* Manager mobile shell: Android-first layout for the executive account. */
@media (max-width: 900px) {
  body.page-manager.ios-redesign {
    width: 100%;
    max-width: 100vw;
    overflow-x: hidden;
  }

  body.page-manager.ios-redesign .hdr {
    position: sticky;
    top: 0;
    z-index: 70;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    grid-template-areas:
      "left online theme logout"
      "search search search search";
    align-items: center;
    gap: 10px 8px;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 14px 12px !important;
    min-height: 0;
  }

  body.page-manager.ios-redesign .hdr-left {
    grid-area: left;
    gap: 10px;
    min-width: 0;
  }

  body.page-manager.ios-redesign .hdr-left img {
    width: auto;
    max-width: 112px;
    height: 32px;
    object-fit: contain;
  }

  body.page-manager.ios-redesign .hdr-r {
    display: contents !important;
  }

  body.page-manager.ios-redesign .gs-wrap {
    grid-area: search;
    width: 100%;
    max-width: none;
    min-width: 0;
  }

  body.page-manager.ios-redesign .gs-input {
    width: 100%;
    min-height: 48px;
    padding-left: 44px;
    font-size: 16px !important;
  }

  body.page-manager.ios-redesign .gs-icon {
    left: 16px;
  }

  body.page-manager.ios-redesign .gs-results {
    left: 0;
    right: 0;
    width: auto;
    max-height: 62vh;
    overflow: auto;
  }

  body.page-manager.ios-redesign .online-wrap {
    grid-area: online;
    min-width: 40px;
    min-height: 40px;
    justify-content: center;
    padding: 0 10px;
  }

  body.page-manager.ios-redesign .theme-switch {
    grid-area: theme;
    min-height: 40px;
    align-self: center;
  }

  body.page-manager.ios-redesign .theme-switch .ts-seg {
    min-width: 34px;
    min-height: 36px;
    padding: 0 8px;
  }

  body.page-manager.ios-redesign .hdr-r > .pill {
    display: none !important;
  }

  body.page-manager.ios-redesign .logout {
    grid-area: logout;
    width: 40px;
    height: 40px;
    padding: 0 !important;
    justify-content: center;
    font-size: 0 !important;
  }

  body.page-manager.ios-redesign .logout .icn {
    width: 18px;
    height: 18px;
    margin: 0;
  }

  body.page-manager.ios-redesign .app-layout {
    display: block;
    min-height: calc(100dvh - 120px);
  }

  body.page-manager.ios-redesign .wrap {
    width: 100%;
    max-width: none;
    min-width: 0;
    padding: 14px 14px 30px;
  }

  body.page-manager.ios-redesign .sidebar {
    position: fixed !important;
    top: 0 !important;
    left: 0;
    width: min(86vw, 300px) !important;
    min-width: 0 !important;
    height: 100dvh !important;
    padding-top: calc(18px + env(safe-area-inset-top, 0px));
    z-index: 82;
    transform: translateX(0);
    transition: transform .2s ease, opacity .2s ease, visibility .2s ease;
  }

  body.page-manager.ios-redesign .sidebar.collapsed {
    margin-left: 0 !important;
    transform: translateX(calc(-100% - 14px));
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  body.page-manager.ios-redesign .sb-overlay {
    top: 0 !important;
    z-index: 81;
  }

  body.page-manager.ios-redesign .card {
    min-width: 0;
    max-width: 100%;
    padding: 16px !important;
    border-radius: 24px !important;
  }

  body.page-manager.ios-redesign .pnl,
  body.page-manager.ios-redesign .grid-4 > *,
  body.page-manager.ios-redesign .grid-3 > *,
  body.page-manager.ios-redesign .grid-2 > *,
  body.page-manager.ios-redesign .dash-grid-2 > *,
  body.page-manager.ios-redesign .dash-grid-3 > * {
    min-width: 0;
    max-width: 100%;
  }

  body.page-manager.ios-redesign .card + .card {
    margin-top: 14px;
  }

  body.page-manager.ios-redesign .toolbar {
    gap: 10px;
    align-items: stretch !important;
  }

  body.page-manager.ios-redesign .toolbar .spacer,
  body.page-manager.ios-redesign .pv2-head .spacer {
    display: none !important;
  }

  body.page-manager.ios-redesign .toolbar > .inp,
  body.page-manager.ios-redesign .toolbar > input.inp,
  body.page-manager.ios-redesign .toolbar > select.inp {
    flex: 1 1 100%;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
  }

  body.page-manager.ios-redesign .toolbar > .btn {
    flex: 1 1 auto;
    min-height: 44px;
    justify-content: center;
  }

  body.page-manager.ios-redesign .inc-counters {
    width: 100%;
  }

  body.page-manager.ios-redesign .btn,
  body.page-manager.ios-redesign .inp,
  body.page-manager.ios-redesign input:not([type="checkbox"]):not([type="radio"]),
  body.page-manager.ios-redesign select,
  body.page-manager.ios-redesign textarea {
    font-size: 16px !important;
  }

  body.page-manager.ios-redesign .btn {
    min-height: 44px;
    letter-spacing: 0;
  }

  body.page-manager.ios-redesign .hdr-r .logout,
  body.page-manager.ios-redesign .logout {
    flex: 0 0 40px;
    width: 40px !important;
    padding: 0 !important;
    font-size: 0 !important;
  }

  body.page-manager.ios-redesign .hdr-r .logout {
    gap: 0;
  }

  body.page-manager.ios-redesign .logout .icn {
    width: 18px;
    height: 18px;
  }

  body.page-manager.ios-redesign .grid-4,
  body.page-manager.ios-redesign .grid-3,
  body.page-manager.ios-redesign .grid-2,
  body.page-manager.ios-redesign .dash-grid-2,
  body.page-manager.ios-redesign .dash-grid-3 {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  body.page-manager.ios-redesign #dash-kpi {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  body.page-manager.ios-redesign .dash-kpi {
    min-width: 0;
    padding: 16px 18px;
    border-radius: 22px;
  }

  body.page-manager.ios-redesign .dash-kpi-val {
    font-size: 34px;
    letter-spacing: 0;
  }

  body.page-manager.ios-redesign .dash-alert {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 10px;
  }

  body.page-manager.ios-redesign .dash-alert .btn {
    width: 100%;
  }

  body.page-manager.ios-redesign .rv2-card {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 16px !important;
    border-radius: 22px !important;
  }

  body.page-manager.ios-redesign .rv2-col-title,
  body.page-manager.ios-redesign .rv2-item-title {
    letter-spacing: 0;
  }

  body.page-manager.ios-redesign .rv2-item-chip {
    max-width: 100%;
  }

  body.page-manager.ios-redesign .rv2-item-actions,
  body.page-manager.ios-redesign .dir-row-actions,
  body.page-manager.ios-redesign .m-actions {
    width: 100%;
  }

  body.page-manager.ios-redesign .rv2-item-actions .btn,
  body.page-manager.ios-redesign .dir-row-actions .btn,
  body.page-manager.ios-redesign .m-actions .btn {
    flex: 1 1 100%;
    justify-content: center;
  }

  body.page-manager.ios-redesign .pv2-head {
    align-items: stretch;
  }

  body.page-manager.ios-redesign .pv2-range {
    flex: 1 1 100%;
    min-width: 0 !important;
    width: 100%;
  }

  body.page-manager.ios-redesign .pv2-head > .btn,
  body.page-manager.ios-redesign .pv2-head > .inp {
    min-height: 44px;
  }

  body.page-manager.ios-redesign .pv2-filters {
    align-items: stretch;
    gap: 8px;
  }

  body.page-manager.ios-redesign .pv2-search-wrap {
    flex: 1 1 100%;
    width: 100%;
  }

  body.page-manager.ios-redesign .pv2-search-wrap input {
    width: 100%;
  }

  body.page-manager.ios-redesign .pv2-chip,
  body.page-manager.ios-redesign .pv2-chk {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  body.page-manager.ios-redesign .pv2-summary {
    min-width: 0;
    overflow: hidden;
  }

  body.page-manager.ios-redesign #mc-widget-list {
    min-width: 0;
    overflow: hidden;
  }

  body.page-manager.ios-redesign .pv2-summary-item {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    flex-wrap: wrap;
    white-space: normal;
    line-height: 1.25;
    overflow-wrap: anywhere;
  }

  body.page-manager.ios-redesign .pv2-layout {
    grid-template-columns: 1fr !important;
  }

  body.page-manager.ios-redesign .pv2-side {
    position: static !important;
    max-height: none !important;
    top: auto !important;
  }

  body.page-manager.ios-redesign .pv2-side-list {
    max-height: 50vh;
  }

  body.page-manager.ios-redesign .pv2-scroll,
  body.page-manager.ios-redesign .tw,
  body.page-manager.ios-redesign .ss-wrap {
    overflow: auto !important;
    max-width: 100%;
    contain: layout paint;
    -webkit-overflow-scrolling: touch;
  }

  body.page-manager.ios-redesign .pv2-main::after,
  body.page-manager.ios-redesign .pv2-sticky-scroll,
  body.page-manager.ios-redesign .pv2-sticky-scroll.pv2-sticky-scroll--show {
    display: none !important;
  }

  body.page-manager.ios-redesign .tw table {
    min-width: 720px;
  }

  body.page-manager.ios-redesign #p-accounting .ts-table,
  body.page-manager.ios-redesign .ts-table {
    width: max-content;
    min-width: 720px;
  }

  body.page-manager.ios-redesign .ss-wrap {
    max-height: 70dvh !important;
  }

  body.page-manager.ios-redesign .ss-table td.ss-cell input {
    width: 96px !important;
    min-height: 36px;
    font-size: 16px !important;
  }

  body.page-manager.ios-redesign .ss-table select.ss-pay {
    min-height: 36px;
    font-size: 16px !important;
  }

  body.page-manager.ios-redesign #acc-div-pct-1,
  body.page-manager.ios-redesign #acc-div-pct-2,
  body.page-manager.ios-redesign #acc-div-pct-3 {
    width: 96px !important;
    min-height: 40px;
    padding: 8px 10px !important;
    font-size: 16px !important;
  }

  body.page-manager.ios-redesign #acc-profit-block #acc-div-pct-1,
  body.page-manager.ios-redesign #acc-profit-block #acc-div-pct-2,
  body.page-manager.ios-redesign #acc-profit-block #acc-div-pct-3 {
    height: auto !important;
    min-height: 40px !important;
    font-size: 16px !important;
    border-radius: 14px !important;
  }

  body.page-manager.ios-redesign #acc-profit-block > div:nth-child(2) > div[style*="grid-template-columns:120px"] {
    grid-template-columns: minmax(0, 1fr) 84px 86px !important;
    gap: 8px !important;
    min-width: 0;
  }

  body.page-manager.ios-redesign #acc-profit-block > div:nth-child(2) > div[style*="grid-template-columns:120px"] > span:nth-child(2),
  body.page-manager.ios-redesign #acc-profit-block > div:nth-child(2) > div[style*="grid-template-columns:120px"] > div:nth-child(2) {
    display: none !important;
  }

  body.page-manager.ios-redesign #acc-profit-block > div:nth-child(2) > div[style*="grid-template-columns:120px"] > span:first-child {
    min-width: 0;
    overflow-wrap: anywhere;
  }

  body.page-manager.ios-redesign #p-finance .grid-2 {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  body.page-manager.ios-redesign #p-finance .grid-2 > .card,
  body.page-manager.ios-redesign #acc-profit-block {
    min-width: 0;
    overflow: hidden;
  }

  body.page-manager.ios-redesign #email-list-wrap {
    max-width: 100%;
    overflow: hidden;
    contain: layout paint;
    border: 1px solid var(--rdx-border);
    border-radius: 24px;
    background: var(--rdx-panel);
    -webkit-overflow-scrolling: touch;
  }

  body.page-manager.ios-redesign #email-list-table {
    display: block;
    width: 100% !important;
    min-width: 0 !important;
  }

  body.page-manager.ios-redesign #email-list-table thead {
    display: none;
  }

  body.page-manager.ios-redesign #email-list-table tbody {
    display: block;
  }

  body.page-manager.ios-redesign #email-list-table tr {
    display: block;
    padding: 12px 14px;
    border-bottom: 1px solid var(--rdx-border-soft);
  }

  body.page-manager.ios-redesign #email-list-table tr:last-child {
    border-bottom: 0;
  }

  body.page-manager.ios-redesign #email-list-table td {
    display: block;
    width: 100% !important;
    min-width: 0 !important;
    padding: 3px 0 !important;
    border: 0 !important;
    white-space: normal;
    overflow-wrap: anywhere;
  }

  body.page-manager.ios-redesign #email-list-table td:nth-child(1),
  body.page-manager.ios-redesign #email-list-table td:nth-child(6),
  body.page-manager.ios-redesign #email-list-table td:nth-child(7),
  body.page-manager.ios-redesign #email-list-table td:nth-child(8) {
    display: none;
  }

  body.page-manager.ios-redesign #email-list-table td:nth-child(2) {
    font-weight: 800;
    color: var(--tx);
  }

  body.page-manager.ios-redesign #email-list-table td:nth-child(3) {
    color: var(--ac);
    font-weight: 800;
  }

  body.page-manager.ios-redesign #email-list-table td:nth-child(4) {
    color: var(--t2);
  }

  body.page-manager.ios-redesign #email-list-table td:nth-child(5) {
    font-size: 14px;
    font-weight: 800;
    color: var(--tx);
  }

  body.page-manager.ios-redesign #email-list-table th {
    position: static !important;
  }

  body.page-manager.ios-redesign #supplier-table {
    display: block;
    width: 100% !important;
    min-width: 0 !important;
  }

  body.page-manager.ios-redesign #supplier-table thead {
    display: none;
  }

  body.page-manager.ios-redesign #supplier-table tbody,
  body.page-manager.ios-redesign #supplier-table tr,
  body.page-manager.ios-redesign #supplier-table td {
    display: block;
    width: 100% !important;
    min-width: 0 !important;
  }

  body.page-manager.ios-redesign #supplier-table tr {
    padding: 12px 14px;
    border: 1px solid var(--rdx-border-soft);
    border-radius: 18px;
    margin-bottom: 10px;
    background: var(--rdx-chip);
  }

  body.page-manager.ios-redesign #supplier-table td {
    padding: 3px 0 !important;
    border: 0 !important;
    white-space: normal;
    overflow-wrap: anywhere;
  }

  body.page-manager.ios-redesign #supplier-table td:first-child {
    font-weight: 800;
  }

  body.page-manager.ios-redesign .ts-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body.page-manager.ios-redesign .ts-kpi {
    min-width: 0;
    padding: 14px 16px;
    border-radius: 20px;
    background: var(--rdx-chip);
    border: 1px solid var(--rdx-border);
  }

  body.page-manager.ios-redesign .ts-kpi-label {
    font-size: 12px;
    font-weight: 700;
    color: var(--t2);
    line-height: 1.25;
  }

  body.page-manager.ios-redesign .ts-kpi-value {
    margin-top: 6px;
    font-size: 22px;
    font-weight: 800;
    color: var(--tx);
    line-height: 1.15;
    overflow-wrap: anywhere;
  }

  body.page-manager.ios-redesign .dir-row {
    align-items: flex-start;
    flex-direction: column;
  }

  body.page-manager.ios-redesign .mbg {
    padding: 10px !important;
  }

  body.page-manager.ios-redesign .mbg .modal {
    width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 20px) !important;
    padding: 16px !important;
    border-radius: 22px !important;
  }
}

@media (max-width: 380px) {
  body.page-manager.ios-redesign .hdr {
    grid-template-columns: minmax(0, 1fr) 40px auto 40px;
    gap: 8px 6px;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  body.page-manager.ios-redesign .hdr-left img {
    max-width: 96px;
  }

  body.page-manager.ios-redesign .online-wrap {
    padding: 0;
  }

  body.page-manager.ios-redesign .online-label {
    display: none;
  }

  body.page-manager.ios-redesign .theme-switch .ts-seg {
    min-width: 32px;
    padding: 0 6px;
  }

  body.page-manager.ios-redesign .wrap {
    padding-left: 12px;
    padding-right: 12px;
  }
}

@media (max-width: 340px) {
  body.page-manager.ios-redesign .hdr-left img {
    max-width: 76px;
  }

  body.page-manager.ios-redesign .theme-switch .ts-seg {
    min-width: 30px;
    padding: 0 5px;
  }

  body.page-manager.ios-redesign #dash-kpi,
  body.page-manager.ios-redesign .ts-grid {
    gap: 10px !important;
  }
}
