/* FORMA mobile app shell. Loaded last on app pages. */
@media (max-width: 820px) {
  html {
    scroll-padding-bottom: calc(104px + env(safe-area-inset-bottom, 0px));
  }

  body.trainer-ops-page,
  body.client-ops-page,
  body.auth-page {
    min-width: 320px !important;
    overflow-x: hidden !important;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(246, 248, 249, 0.98)),
      #f6f8f9 !important;
  }

  body.trainer-ops-page::before,
  body.trainer-ops-page::after,
  body.trainer-ops-page.app-body::before,
  body.trainer-ops-page.app-body::after,
  body.trainer-ops-page .ops-main::before,
  body.client-ops-page .ops-main::before {
    content: none !important;
    display: none !important;
  }

  body.trainer-ops-page .ops-shell,
  body.client-ops-page .ops-shell {
    display: block !important;
    width: 100% !important;
    min-height: 100dvh !important;
    grid-template-columns: 1fr !important;
    background: transparent !important;
  }

  body.trainer-ops-page .ops-main,
  body.client-ops-page .ops-main {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 12px 12px calc(108px + env(safe-area-inset-bottom, 0px)) !important;
  }

  body.trainer-ops-page .ops-rail,
  body.client-ops-page .ops-rail {
    position: fixed !important;
    inset: auto 0 0 0 !important;
    z-index: 100 !important;
    display: block !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 8px 9px calc(8px + env(safe-area-inset-bottom, 0px)) !important;
    border-width: 1px 0 0 !important;
    border-radius: 0 !important;
    backdrop-filter: blur(18px) saturate(1.2) !important;
  }

  body.trainer-ops-page .ops-rail {
    border-color: rgba(255, 255, 255, 0.08) !important;
    background: rgba(16, 23, 29, 0.94) !important;
    box-shadow: 0 -18px 44px rgba(11, 16, 20, 0.24) !important;
  }

  body.client-ops-page .ops-rail {
    border-color: rgba(17, 24, 30, 0.1) !important;
    background: rgba(255, 255, 255, 0.96) !important;
    box-shadow: 0 -18px 44px rgba(24, 33, 39, 0.1) !important;
  }

  body.trainer-ops-page .ops-brand,
  body.client-ops-page .ops-brand,
  body.trainer-ops-page .ops-rail-profile,
  body.client-ops-page .ops-rail-profile {
    display: none !important;
  }

  body.trainer-ops-page .ops-rail-nav,
  body.client-ops-page .ops-rail-nav,
  body.client-ops-page .ops-rail-nav.section-tabs {
    display: grid !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
    gap: 5px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body.trainer-ops-page .ops-rail-nav {
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  }

  body.client-ops-page .ops-rail-nav,
  body.client-ops-page .ops-rail-nav.section-tabs {
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  }

  body.trainer-ops-page .ops-rail-link,
  body.client-ops-page .ops-rail-link {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 62px !important;
    min-height: 62px !important;
    padding: 6px 2px !important;
    gap: 4px !important;
    border: 1px solid transparent !important;
    border-radius: 18px !important;
    box-shadow: none !important;
    text-decoration: none !important;
    transform: none !important;
  }

  body.trainer-ops-page .ops-rail-link {
    color: rgba(255, 255, 255, 0.62) !important;
    background: transparent !important;
  }

  body.client-ops-page .ops-rail-link {
    color: #77838e !important;
    background: transparent !important;
  }

  body.trainer-ops-page .ops-rail-link.active {
    border-color: rgba(33, 195, 154, 0.3) !important;
    background: rgba(33, 195, 154, 0.12) !important;
    color: #ffffff !important;
  }

  body.client-ops-page .ops-rail-link.active {
    border-color: rgba(33, 195, 154, 0.2) !important;
    background: rgba(33, 195, 154, 0.11) !important;
    color: #168f74 !important;
  }

  body.trainer-ops-page .ops-rail-icon,
  body.client-ops-page .ops-rail-icon,
  body.trainer-ops-page .ops-rail-icon svg,
  body.client-ops-page .ops-rail-icon svg {
    width: 20px !important;
    height: 20px !important;
    flex-basis: 20px !important;
  }

  body.trainer-ops-page .ops-rail-link::after,
  body.client-ops-page .ops-rail-link::after {
    position: static !important;
    display: block !important;
    max-width: 100% !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: transparent !important;
    box-shadow: none !important;
    color: currentColor !important;
    font-size: 9px !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
    opacity: 1 !important;
    text-align: center !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    transform: none !important;
  }

  body.trainer-ops-page .ops-rail-link:nth-child(1)::after { content: "Главная" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(2)::after { content: "Клиенты" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(3)::after { content: "Трен." !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(4)::after { content: "Профиль" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(5)::after { content: "Видео" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(6)::after { content: "Чат" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(7)::after { content: "Увед." !important; }

  body.client-ops-page .ops-rail-label {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    font-size: 9px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    text-align: center !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  body.client-ops-page .ops-rail-link[href="#ai-calories"] .ops-rail-label {
    font-size: 0 !important;
  }

  body.client-ops-page .ops-rail-link[href="#ai-calories"] .ops-rail-label::after {
    content: "AI";
    font-size: 9px;
  }

  body.trainer-chat-page .ops-chat-head {
    align-items: stretch !important;
  }

  body.trainer-chat-page .ops-chat-head-state {
    min-width: 0 !important;
    min-height: 54px !important;
    grid-template-columns: auto 1fr !important;
    justify-items: start !important;
    gap: 8px !important;
    padding: 12px 14px !important;
    border-radius: 18px !important;
  }

  body.trainer-chat-page .ops-chat-head-state strong {
    font-size: 24px !important;
  }

  .ops-chat-shell {
    display: block !important;
    min-height: calc(100dvh - 142px - env(safe-area-inset-bottom, 0px)) !important;
  }

  body.trainer-chat-page .ops-chat-shell .ops-chat-panel {
    display: none !important;
  }

  body.trainer-chat-page .ops-chat-shell.has-active-chat .ops-chat-sidebar {
    display: none !important;
  }

  body.trainer-chat-page .ops-chat-shell.has-active-chat .ops-chat-panel {
    display: grid !important;
  }

  .ops-chat-sidebar,
  .ops-chat-panel,
  .ops-chat-client-card {
    border-radius: 24px !important;
    box-shadow: 0 14px 34px rgba(31, 37, 43, 0.08) !important;
  }

  .ops-chat-sidebar,
  .ops-chat-panel,
  .ops-chat-client-card {
    min-height: calc(100dvh - 168px - env(safe-area-inset-bottom, 0px)) !important;
  }

  .ops-chat-panel,
  .ops-chat-client-card {
    grid-template-rows: auto minmax(0, 1fr) auto !important;
  }

  .ops-chat-back {
    display: grid !important;
    place-items: center !important;
    flex: 0 0 36px !important;
  }

  .ops-chat-sidebar-head,
  .ops-chat-panel-head {
    padding: 14px !important;
  }

  .ops-chat-conversation-list {
    padding: 8px !important;
  }

  .ops-chat-conversation {
    grid-template-columns: 42px minmax(0, 1fr) auto !important;
    padding: 10px !important;
    border-radius: 18px !important;
  }

  .ops-chat-avatar {
    width: 42px !important;
    height: 42px !important;
    flex-basis: 42px !important;
    border-radius: 15px !important;
  }

  .ops-chat-messages {
    padding: 14px !important;
    gap: 9px !important;
  }

  .ops-chat-bubble {
    max-width: 88% !important;
    border-radius: 18px 18px 18px 7px !important;
  }

  .ops-chat-message.is-mine .ops-chat-bubble {
    border-radius: 18px 18px 7px 18px !important;
  }

  .ops-chat-composer {
    padding: 10px !important;
  }

  .ops-chat-composer-row {
    grid-template-columns: 44px minmax(0, 1fr) !important;
  }

  .ops-chat-composer-row .ops-button {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    min-height: 46px !important;
  }

  .ops-chat-client-pill {
    display: none !important;
  }

  body.trainer-ops-page .ops-page-head,
  body.client-ops-page .ops-page-head,
  body.client-ops-page .client-header,
  body.trainer-builder-page .ops-builder-topbar {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
    min-height: 0 !important;
    margin: 0 0 12px !important;
    padding: 18px 16px !important;
    border-radius: 24px !important;
    background: rgba(255, 255, 255, 0.92) !important;
    box-shadow: 0 12px 32px rgba(31, 37, 43, 0.08) !important;
    overflow: hidden !important;
  }

  body.trainer-ops-page .ops-page-head::before,
  body.trainer-ops-page .ops-page-head::after,
  body.trainer-ops-page .ops-page-head:not(.client-header)::before,
  body.trainer-ops-page .ops-page-head:not(.client-header)::after,
  body.client-ops-page .ops-page-head::before,
  body.client-ops-page .ops-page-head::after,
  body.trainer-builder-page .ops-builder-topbar::before,
  body.trainer-builder-page .ops-builder-topbar::after {
    content: none !important;
    display: none !important;
  }

  body.trainer-ops-page .ops-title-block,
  body.client-ops-page .ops-title-block {
    min-width: 0 !important;
  }

  body.trainer-ops-page .ops-title-block h1,
  body.client-ops-page .ops-title-block h1,
  body.client-ops-page .client-header .ops-title-block h1,
  body.trainer-builder-page .ops-builder-topbar h1 {
    max-width: none !important;
    margin: 0 !important;
    font-size: clamp(25px, 8vw, 34px) !important;
    line-height: 1.02 !important;
    letter-spacing: 0 !important;
  }

  body.trainer-ops-page .ops-title-block p,
  body.client-ops-page .ops-title-block p {
    max-width: none !important;
    margin-top: 8px !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
  }

  body.trainer-ops-page .ops-head-actions,
  body.client-ops-page .ops-head-actions,
  body.trainer-ops-page .ops-dashboard-actions,
  body.client-ops-page .client-header-actions,
  body.trainer-builder-page .ops-builder-top-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
    gap: 8px !important;
  }

  body.client-ops-page .client-header-person {
    width: 100% !important;
  }

  body.trainer-ops-page .ops-button,
  body.client-ops-page .ops-button,
  body.trainer-ops-page .ops-chip-link,
  body.trainer-ops-page .ops-back-link,
  body.trainer-ops-page .ops-icon-button,
  body.client-ops-page .client-icon-action,
  body.client-ops-page .client-date-action {
    min-height: 48px !important;
    border-radius: 16px !important;
    font-size: 14px !important;
  }

  body.trainer-ops-page .ops-input,
  body.trainer-ops-page .ops-select,
  body.trainer-ops-page .ops-textarea,
  body.client-ops-page .plain-input,
  body.client-ops-page input,
  body.client-ops-page select,
  body.client-ops-page textarea {
    min-height: 48px !important;
    border-radius: 16px !important;
    font-size: 16px !important;
  }

  body.trainer-ops-page .ops-surface,
  body.client-ops-page .ops-surface,
  body.client-ops-page .content-card,
  body.trainer-ops-page .ops-link-box,
  body.trainer-ops-page .ops-banner {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 18px 16px !important;
    border-radius: 24px !important;
    box-shadow: 0 12px 34px rgba(31, 37, 43, 0.07) !important;
    overflow: hidden !important;
  }

  body.trainer-ops-page .ops-toolbar-home,
  body.trainer-home-page .ops-home-toolbar-controls,
  body.trainer-ops-page .ops-table-toolbar,
  body.trainer-ops-page .ops-inline-actions,
  body.trainer-ops-page .ops-client-invite-form,
  body.trainer-ops-page .ops-dashboard-calendar-shell,
  body.trainer-ops-page .ops-dashboard-bottom-grid,
  body.trainer-ops-page .ops-dashboard-metrics,
  body.trainer-ops-page .ops-notifications-layout,
  body.trainer-ops-page .ops-billing-summary,
  body.trainer-builder-page .ops-builder-layout,
  body.trainer-builder-page .ops-builder-stack,
  body.trainer-builder-page .ops-template-panel,
  body.client-ops-page .client-home-layout,
  body.client-ops-page .client-calorie-plan-layout,
  body.client-ops-page .client-calorie-plan-fields,
  body.client-ops-page .client-calorie-plan-fields.is-two,
  body.client-ops-page .client-calorie-plan-kpis,
  body.client-ops-page .client-calorie-targets,
  body.client-ops-page .client-ai-calorie-grid,
  body.client-ops-page .client-food-layout,
  body.client-ops-page .client-assignment-layout,
  body.client-ops-page .client-nutrition-row,
  body.client-ops-page .client-macro-grid,
  body.client-ops-page .client-result-strip,
  body.client-ops-page .client-food-macro-grid,
  body.client-ops-page .client-ai-fields-row,
  body.client-ops-page .client-ai-macros,
  body.client-ops-page .progress-item,
  body.client-ops-page .profile-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    min-width: 0 !important;
  }

  body.trainer-home-page .ops-home-toolbar-controls > * {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.trainer-home-page .ops-home-toolbar-nav {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  body.trainer-home-page .ops-home-toolbar-nav > * {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.trainer-ops-page .ops-chip-row,
  body.trainer-ops-page .ops-tabbar,
  body.client-ops-page .subtle-tabs,
  body.client-ops-page .client-ai-mode-tabs {
    display: flex !important;
    gap: 8px !important;
    width: calc(100% + 8px) !important;
    max-width: none !important;
    margin-right: -8px !important;
    padding-bottom: 2px !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
  }

  body.trainer-ops-page .ops-chip-row::-webkit-scrollbar,
  body.trainer-ops-page .ops-tabbar::-webkit-scrollbar,
  body.client-ops-page .subtle-tabs::-webkit-scrollbar,
  body.client-ops-page .client-ai-mode-tabs::-webkit-scrollbar {
    display: none !important;
  }

  body.trainer-ops-page .ops-chip,
  body.trainer-ops-page .ops-tabbar button,
  body.client-ops-page .subtle-tab {
    flex: 0 0 auto !important;
    min-height: 40px !important;
    white-space: nowrap !important;
  }

  body.trainer-client-page .ops-tabbar {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-right: 0 !important;
    overflow: visible !important;
  }

  body.trainer-client-page .ops-tabbar button {
    width: 100% !important;
    min-width: 0 !important;
    padding: 0 6px !important;
    justify-content: center !important;
    overflow: hidden !important;
    font-size: clamp(12px, 3.6vw, 14px) !important;
    text-overflow: ellipsis !important;
  }

  body.trainer-client-page .ops-tab-label-full {
    display: none !important;
  }

  body.trainer-client-page .ops-tab-label-short {
    display: inline !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  body.trainer-home-page .ops-progress-rings span {
    min-width: 0 !important;
    padding: 12px 8px !important;
    overflow: hidden !important;
  }

  body.trainer-home-page .ops-progress-rings small {
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
    font-size: 10px !important;
    line-height: 1.15 !important;
    white-space: normal !important;
  }

  body.trainer-home-page .ops-dashboard-metrics,
  body.trainer-billing-page .ops-billing-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body.trainer-home-page .ops-dashboard-metrics article,
  body.trainer-home-page .ops-progress-rings span {
    padding: 14px !important;
  }

  body.trainer-home-page.trainer-ops-page .ops-page-head.ops-dashboard-head,
  body.trainer-home-page .ops-dashboard-head {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
    min-height: 0 !important;
    margin: 0 0 12px !important;
    padding: 18px 16px !important;
    border: 1px solid rgba(31, 37, 43, 0.08) !important;
    border-radius: 24px !important;
    background: #ffffff !important;
    box-shadow: 0 12px 32px rgba(31, 37, 43, 0.08) !important;
    overflow: hidden !important;
  }

  body.trainer-home-page.trainer-ops-page .ops-page-head.ops-dashboard-head::before,
  body.trainer-home-page.trainer-ops-page .ops-page-head.ops-dashboard-head::after,
  body.trainer-home-page .ops-dashboard-head::before,
  body.trainer-home-page .ops-dashboard-head::after {
    content: none !important;
    display: none !important;
  }

  body.trainer-home-page .ops-dashboard-head .ops-title-block h1 {
    color: #1f252b !important;
    font-size: clamp(26px, 8vw, 34px) !important;
    letter-spacing: 0 !important;
  }

  body.trainer-home-page .ops-dashboard-head .ops-title-block p {
    color: #6f7a86 !important;
  }

  body.trainer-home-page .ops-dashboard-actions .ops-head-link,
  body.trainer-home-page .ops-dashboard-actions .ops-notification-link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 48px !important;
    padding: 0 16px !important;
    border: 1px solid rgba(31, 37, 43, 0.08) !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    color: #1f252b !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    box-shadow: none !important;
  }

  body.trainer-home-page .ops-dashboard-calendar-shell {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  body.trainer-home-page .ops-dashboard-calendar-main {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
  }

  body.trainer-home-page .ops-dashboard-calendar-main .ops-week-shell,
  body.trainer-home-page .ops-week-shell {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 12px !important;
    border-radius: 24px !important;
    overflow: hidden !important;
  }

  body.trainer-home-page .ops-week-nav {
    display: none !important;
  }

  body.trainer-home-page .ops-week-grid {
    display: flex !important;
    gap: 10px !important;
    width: calc(100% + 2px) !important;
    max-width: none !important;
    min-width: 0 !important;
    padding: 0 2px 4px 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory !important;
    scrollbar-width: none !important;
  }

  body.trainer-home-page .ops-week-grid::-webkit-scrollbar {
    display: none !important;
  }

  body.trainer-home-page .ops-day-column {
    flex: 0 0 100% !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 260px !important;
    max-height: none !important;
    padding: 14px !important;
    border-radius: 20px !important;
    scroll-snap-align: start !important;
    overflow: hidden !important;
  }

  body.trainer-home-page .ops-day-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    margin-top: 10px !important;
  }

  body.trainer-home-page .ops-day-actions .ops-button {
    width: 100% !important;
    min-height: 42px !important;
    white-space: normal !important;
  }

  body.trainer-home-page .ops-month-shell {
    min-height: 0 !important;
    padding: 12px !important;
    overflow: hidden !important;
  }

  body.trainer-home-page .ops-month-weekdays,
  body.trainer-home-page .ops-month-grid {
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
    gap: 4px !important;
    min-width: 0 !important;
  }

  body.trainer-home-page .ops-month-weekdays span {
    min-width: 0 !important;
    padding: 0 !important;
    text-align: center !important;
  }

  body.trainer-home-page .ops-month-cell,
  body.trainer-home-page .ops-month-empty {
    min-width: 0 !important;
    min-height: 46px !important;
    padding: 2px !important;
    border-radius: 14px !important;
  }

  body.trainer-home-page .ops-month-copy,
  body.trainer-home-page .ops-month-actions {
    display: none !important;
  }

  body.trainer-home-page .ops-month-cell .ops-chip {
    justify-self: start !important;
    width: 24px !important;
    min-width: 0 !important;
    min-height: 24px !important;
    padding: 0 !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  body.trainer-home-page .ops-month-cell .ops-chip::after {
    content: "" !important;
    width: 7px !important;
    height: 7px !important;
    border-radius: 999px !important;
    background: currentColor !important;
  }

  body.trainer-home-page .ops-month-cell .ops-day-progress-chip {
    width: 24px !important;
    min-width: 0 !important;
    min-height: 24px !important;
    padding: 0 !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  body.trainer-home-page .ops-month-cell .ops-day-progress-chip::after {
    content: "✓" !important;
    color: currentColor !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
  }

  body.trainer-home-page .ops-dashboard-day-detail {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 20px 16px !important;
    border-radius: 24px !important;
  }

  body.trainer-home-page .ops-dashboard-day-detail h2 {
    font-size: clamp(26px, 8vw, 34px) !important;
    letter-spacing: 0 !important;
  }

  body.trainer-builder-page .ops-builder-blocks {
    display: grid !important;
    gap: 10px !important;
    border: 0 !important;
    background: transparent !important;
    overflow: visible !important;
  }

  body.trainer-builder-page .ops-builder-table-head {
    display: none !important;
  }

  body.trainer-builder-page .ops-builder-row {
    display: grid !important;
    grid-template-columns: 32px minmax(0, 1fr) 42px !important;
    gap: 10px !important;
    min-width: 0 !important;
    padding: 14px !important;
    border: 1px solid rgba(31, 37, 43, 0.08) !important;
    border-radius: 20px !important;
    background: #ffffff !important;
  }

  body.trainer-builder-page .ops-builder-thumb {
    display: none !important;
  }

  body.trainer-builder-page .ops-builder-title-cell,
  body.trainer-builder-page .ops-builder-badge,
  body.trainer-builder-page .ops-builder-pair,
  body.trainer-builder-page .ops-builder-weight-cell,
  body.trainer-builder-page .ops-builder-rest-cell,
  body.trainer-builder-page .ops-builder-row-notes {
    grid-column: 1 / -1 !important;
  }

  body.trainer-builder-page .ops-builder-row-notes,
  body.trainer-builder-page .ops-builder-video-row,
  body.trainer-builder-page .ops-builder-video-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  body.trainer-builder-page .ops-builder-row-menu {
    grid-column: 3 !important;
    grid-row: 1 !important;
    justify-content: end !important;
  }

  body.trainer-builder-page .ops-builder-footer {
    position: sticky !important;
    bottom: calc(82px + env(safe-area-inset-bottom, 0px)) !important;
    z-index: 60 !important;
    margin: 0 -4px !important;
    padding: 10px !important;
    border-radius: 20px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    backdrop-filter: blur(14px) !important;
    box-shadow: 0 12px 36px rgba(31, 37, 43, 0.12) !important;
  }

  body.trainer-ops-page .ops-library-row,
  body.trainer-ops-page .ops-notification-row,
  body.trainer-ops-page .ops-detail-row,
  body.trainer-ops-page .ops-template-panel,
  body.trainer-ops-page .ops-side-list article,
  body.client-ops-page .client-upcoming-card,
  body.client-ops-page .client-workout-card,
  body.client-ops-page .client-support-item {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 14px !important;
    border-radius: 18px !important;
  }

  body.client-ops-page .client-today-hero {
    min-height: 0 !important;
    padding: 22px 18px !important;
    border-radius: 26px !important;
  }

  body.client-ops-page .client-today-hero-head {
    grid-template-columns: 1fr !important;
  }

  body.client-ops-page .client-today-question {
    max-width: 11ch !important;
    margin: 12px 0 20px !important;
    font-size: clamp(40px, 14vw, 58px) !important;
    line-height: 0.94 !important;
  }

  body.client-ops-page .client-day-actions,
  body.client-ops-page .client-ai-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  body.client-ops-page .client-day-actions .ops-button,
  body.client-ops-page .client-ai-actions .ops-button {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.client-ops-page .client-calorie-ring {
    width: 148px !important;
    height: 148px !important;
    margin: 0 auto !important;
  }

  body.client-ops-page .client-calendar-card {
    overflow: hidden !important;
  }

  body.client-ops-page .month-weekdays,
  body.client-ops-page .month-grid {
    width: 100% !important;
    min-width: 0 !important;
    gap: 4px !important;
  }

  body.client-ops-page .client-month-day,
  body.client-ops-page .month-empty {
    min-height: 42px !important;
  }

  body.client-ops-page .client-month-day .month-day-number {
    width: 34px !important;
    height: 34px !important;
    font-size: 13px !important;
  }

  body.client-ops-page .client-ai-result-card {
    position: static !important;
  }

  body.client-ops-page .client-ai-upload {
    min-height: 92px !important;
    border-radius: 20px !important;
  }

  body.client-register-page .register-shell,
  .auth-stage {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: min(100% - 24px, 560px) !important;
    min-height: 100dvh !important;
    padding: 20px 0 !important;
  }

  body.client-register-page .register-shell-copy,
  body.client-register-page .register-shell-panel,
  .auth-scene,
  .auth-panel {
    width: 100% !important;
    min-width: 0 !important;
    padding: 22px 18px !important;
    border-radius: 26px !important;
  }
}

/* AI calories final mobile-safe upload control */
body.client-ops-page .client-ai-mode-hidden {
  display: none !important;
}

body.client-ops-page .client-ai-fields-row.is-product-mode {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

body.client-ops-page .client-ai-upload {
  position: relative !important;
  display: grid !important;
  gap: 6px !important;
  min-height: 96px !important;
  padding: 18px !important;
  border: 1px dashed rgba(47, 111, 95, 0.28) !important;
  border-radius: 18px !important;
  background: rgba(247, 250, 249, 0.88) !important;
  cursor: pointer !important;
}

body.client-ops-page .client-ai-upload::after {
  content: "Выбрать фото" !important;
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 36px !important;
  padding: 0 12px !important;
  border: 1px solid rgba(31, 37, 43, 0.08) !important;
  border-radius: 12px !important;
  background: #ffffff !important;
  color: #1f252b !important;
  font-size: 13px !important;
  font-weight: 620 !important;
}

body.client-ops-page .client-ai-upload input {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  opacity: 0 !important;
  cursor: pointer !important;
}

body.client-ops-page .client-ai-upload span,
body.client-ops-page .client-ai-upload strong {
  max-width: calc(100% - 130px) !important;
  pointer-events: none !important;
}

body.client-ops-page .client-ai-upload span {
  color: #71808c !important;
  font-size: 13px !important;
  font-weight: 760 !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
}

body.client-ops-page .client-ai-upload strong {
  color: #1f252b !important;
  font-size: 16px !important;
  font-weight: 600 !important;
}

@media (max-width: 620px) {
  body.client-ops-page .client-ai-upload {
    padding-top: 74px !important;
  }

  body.client-ops-page .client-ai-upload::after {
    right: auto !important;
    left: 16px !important;
  }

  body.client-ops-page .client-ai-upload span,
  body.client-ops-page .client-ai-upload strong {
    max-width: none !important;
  }

  body.client-ops-page .client-ai-fields-row.is-product-mode {
    grid-template-columns: 1fr !important;
  }

  /* AI calorie photo-zone — mobile */
  body.client-ops-page .client-ai-photo-empty {
    padding: 20px 14px !important;
    gap: 4px !important;
  }
  body.client-ops-page .client-ai-photo-icon {
    width: 48px !important;
    height: 48px !important;
  }
  body.client-ops-page .client-ai-photo-empty strong {
    font-size: 15px !important;
  }
  body.client-ops-page .client-ai-photo-buttons {
    width: 100% !important;
    flex-direction: row !important;
  }
  body.client-ops-page .client-ai-photo-btn {
    flex: 1 1 0 !important;
    min-height: 46px !important;
    font-size: 14px !important;
  }
  body.client-ops-page .client-ai-photo-preview img {
    max-height: 240px !important;
  }
  body.client-ops-page .client-ai-fields-row-quick {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr) !important;
  }
  body.client-ops-page .client-ai-fields-row-advanced {
    grid-template-columns: 1fr !important;
    padding: 4px 14px 14px !important;
  }
  body.client-ops-page .client-ai-advanced > summary {
    padding: 12px 14px !important;
    font-size: 14px !important;
  }
}

@media (max-width: 520px) {
  body.trainer-home-page .ops-dashboard-metrics,
  body.trainer-billing-page .ops-billing-summary {
    grid-template-columns: 1fr !important;
  }

  body.trainer-ops-page .ops-rail-link,
  body.client-ops-page .ops-rail-link {
    height: 58px !important;
    min-height: 58px !important;
    border-radius: 16px !important;
  }

  body.trainer-ops-page .ops-rail-icon,
  body.client-ops-page .ops-rail-icon,
  body.trainer-ops-page .ops-rail-icon svg,
  body.client-ops-page .ops-rail-icon svg {
    width: 19px !important;
    height: 19px !important;
  }

  body.trainer-ops-page .ops-rail-link::after,
  body.client-ops-page .ops-rail-link::after,
  body.client-ops-page .ops-rail-label,
  body.client-ops-page .ops-rail-link[href="#ai-calories"] .ops-rail-label::after {
    font-size: 8px !important;
  }

  body.trainer-ops-page .ops-main,
  body.client-ops-page .ops-main {
    padding-right: 10px !important;
    padding-left: 10px !important;
  }
}

/* Account/logout chrome. Loaded last so the old initials link cannot win the cascade. */
body.trainer-ops-page .ops-rail-profile.is-hidden-auth-avatar,
body.trainer-home-page .ops-rail-profile.is-hidden-auth-avatar,
body.trainer-builder-page .ops-rail-profile.is-hidden-auth-avatar,
body.client-ops-page .ops-rail-profile.is-hidden-auth-avatar {
  display: none !important;
  pointer-events: none !important;
}

body.trainer-ops-page .ops-rail-account,
body.trainer-home-page .ops-rail-account,
body.trainer-builder-page .ops-rail-account,
body.client-ops-page .ops-rail-account {
  display: grid !important;
  width: 100% !important;
  margin: auto 0 0 !important;
  padding: 10px !important;
  gap: 8px !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, 0.045) !important;
  color: #ffffff !important;
  box-shadow: none !important;
}

body.trainer-ops-page .ops-rail-account-user,
body.trainer-home-page .ops-rail-account-user,
body.trainer-builder-page .ops-rail-account-user,
body.client-ops-page .ops-rail-account-user {
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
  gap: 9px !important;
}

body.trainer-ops-page .ops-rail-account-avatar,
body.trainer-home-page .ops-rail-account-avatar,
body.trainer-builder-page .ops-rail-account-avatar,
body.client-ops-page .ops-rail-account-avatar,
.profile-logout-avatar {
  display: grid !important;
  flex: 0 0 36px !important;
  place-items: center !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 11px !important;
  background: rgba(255, 255, 255, 0.12) !important;
  color: #ffffff !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
}

body.client-ops-page .ops-rail-account-avatar,
body.client-ops-page .profile-logout-avatar {
  background: rgba(33, 195, 154, 0.22) !important;
}

body.trainer-ops-page .ops-rail-account-user div,
body.trainer-home-page .ops-rail-account-user div,
body.trainer-builder-page .ops-rail-account-user div,
body.client-ops-page .ops-rail-account-user div,
.profile-logout-copy div {
  display: grid !important;
  min-width: 0 !important;
  gap: 2px !important;
}

body.trainer-ops-page .ops-rail-account-user strong,
body.trainer-home-page .ops-rail-account-user strong,
body.trainer-builder-page .ops-rail-account-user strong,
body.client-ops-page .ops-rail-account-user strong,
.profile-logout-copy strong {
  overflow: hidden !important;
  color: currentColor !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body.trainer-ops-page .ops-rail-account-user small,
body.trainer-home-page .ops-rail-account-user small,
body.trainer-builder-page .ops-rail-account-user small,
body.client-ops-page .ops-rail-account-user small,
.profile-logout-copy small {
  overflow: hidden !important;
  color: rgba(255, 255, 255, 0.58) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body.trainer-ops-page .ops-rail-logout,
body.trainer-home-page .ops-rail-logout,
body.trainer-builder-page .ops-rail-logout,
body.client-ops-page .ops-rail-logout,
.profile-logout-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 40px !important;
  padding: 0 10px !important;
  gap: 7px !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 11px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  cursor: pointer !important;
  font: inherit !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  box-shadow: none !important;
  transition: background-color 160ms ease, border-color 160ms ease, opacity 160ms ease !important;
}

body.trainer-ops-page .ops-rail-logout:hover,
body.trainer-home-page .ops-rail-logout:hover,
body.trainer-builder-page .ops-rail-logout:hover,
body.client-ops-page .ops-rail-logout:hover,
.profile-logout-button:hover,
body.trainer-ops-page .ops-rail-logout:focus-visible,
body.trainer-home-page .ops-rail-logout:focus-visible,
body.trainer-builder-page .ops-rail-logout:focus-visible,
body.client-ops-page .ops-rail-logout:focus-visible,
.profile-logout-button:focus-visible {
  border-color: rgba(255, 255, 255, 0.2) !important;
  background: rgba(255, 255, 255, 0.13) !important;
}

body.trainer-ops-page .ops-rail-logout svg,
body.trainer-home-page .ops-rail-logout svg,
body.trainer-builder-page .ops-rail-logout svg,
body.client-ops-page .ops-rail-logout svg,
.profile-logout-button svg {
  width: 18px !important;
  height: 18px !important;
  stroke: currentColor !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

body.trainer-ops-page .ops-rail-logout.is-loading,
body.trainer-home-page .ops-rail-logout.is-loading,
body.trainer-builder-page .ops-rail-logout.is-loading,
body.client-ops-page .ops-rail-logout.is-loading,
body.trainer-ops-page .ops-mobile-logout.is-loading,
body.client-ops-page .ops-mobile-logout.is-loading,
.profile-logout-button.is-loading {
  opacity: 0.62 !important;
  pointer-events: none !important;
}

.profile-logout-card {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 18px 20px !important;
}

.profile-logout-copy {
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
  gap: 12px !important;
}

body.client-ops-page .profile-logout-card {
  border-color: rgba(32, 50, 75, 0.08) !important;
  background: rgba(255, 255, 255, 0.92) !important;
}

body.client-ops-page .profile-logout-copy {
  color: var(--ops-text, #1f252b) !important;
}

body.client-ops-page .profile-logout-copy small {
  color: var(--ops-text-soft, #6d7680) !important;
}

body.client-ops-page .profile-logout-avatar {
  color: #0f4c3f !important;
}

body.client-ops-page .profile-logout-button {
  width: auto !important;
  min-width: 170px !important;
  border-color: rgba(31, 37, 43, 0.1) !important;
  background: #1f252b !important;
  color: #ffffff !important;
}

body.client-ops-page .profile-logout-button:hover,
body.client-ops-page .profile-logout-button:focus-visible {
  border-color: #10171d !important;
  background: #10171d !important;
}

@media (max-width: 820px) {
  body.trainer-ops-page .ops-rail-account,
  body.trainer-home-page .ops-rail-account,
  body.trainer-builder-page .ops-rail-account,
  body.client-ops-page .ops-rail-account {
    display: none !important;
  }

  .profile-logout-card {
    display: grid !important;
    grid-template-columns: 1fr !important;
    padding: 16px !important;
  }

  body.client-ops-page .profile-logout-button {
    width: 100% !important;
    min-width: 0 !important;
  }
}

@media (max-width: 600px) {
  .ops-modal-backdrop {
    align-items: end !important;
    padding: 12px !important;
  }

  .ops-modal.ops-measurement-modal {
    width: 100% !important;
    max-height: calc(100dvh - 24px) !important;
    overflow-y: auto !important;
    padding: 20px !important;
    border-radius: 18px !important;
  }

  .ops-measurement-modal .ops-modal-head {
    gap: 6px !important;
    margin-bottom: 14px !important;
    padding-right: 42px !important;
  }

  .ops-measurement-modal .ops-modal-head h2 {
    font-size: 23px !important;
    line-height: 1.08 !important;
  }

  .ops-measurement-topline {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .ops-measurement-summary {
    min-height: 62px !important;
    padding: 10px 12px !important;
  }

  .ops-measurement-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .ops-measurement-field {
    gap: 6px !important;
  }

  .ops-measurement-field > span {
    font-size: 10px !important;
    line-height: 1.1 !important;
  }

  .ops-measurement-input-wrap .ops-input {
    min-height: 48px !important;
    padding-left: 12px !important;
    padding-right: 34px !important;
    font-size: 15px !important;
  }

  .ops-measurement-input-wrap em {
    right: 11px !important;
    font-size: 11px !important;
  }

  .ops-measurement-form > .ops-inline-actions {
    position: sticky !important;
    bottom: -20px !important;
    z-index: 2 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    margin: 6px -20px -20px !important;
    padding: 12px 20px 20px !important;
    border-top: 1px solid rgba(31, 37, 43, 0.08) !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.82), #ffffff 32%) !important;
  }

  .ops-measurement-form > .ops-inline-actions .ops-button {
    width: 100% !important;
  }
}

@media (max-width: 340px) {
  .ops-measurement-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Trainer navigation refresh for seven-item rail. */
@media (max-width: 820px) {
  body.trainer-ops-page .ops-rail {
    border-color: rgba(31, 37, 43, 0.08) !important;
    background: rgba(255, 255, 255, 0.97) !important;
    box-shadow: 0 -18px 44px rgba(31, 37, 43, 0.12) !important;
  }

  body.trainer-ops-page .ops-rail-nav {
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
    gap: 3px !important;
  }

  body.trainer-ops-page .ops-rail-link {
    height: 56px !important;
    min-height: 56px !important;
    padding: 5px 1px !important;
    border-radius: 14px !important;
    color: #72808a !important;
  }

  body.trainer-ops-page .ops-rail-link.active {
    border-color: rgba(82, 188, 158, 0.18) !important;
    background: #e7f6f0 !important;
    color: #2f8c76 !important;
  }

  body.trainer-ops-page .ops-rail-icon,
  body.trainer-ops-page .ops-rail-icon svg {
    display: block !important;
    width: 17px !important;
    height: 17px !important;
    flex-basis: 17px !important;
  }

  body.trainer-ops-page .ops-rail-link::after {
    font-size: 7.5px !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
  }

  body.trainer-ops-page .ops-rail-link:nth-child(1)::after { content: "Дом" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(2)::after { content: "Клиенты" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(3)::after { content: "Трен." !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(4)::after { content: "Проф." !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(5)::after { content: "Видео" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(6)::after { content: "Чат" !important; }
  body.trainer-ops-page .ops-rail-link:nth-child(7)::after { content: "Увед." !important; }
}

@media (max-width: 360px) {
  body.trainer-ops-page .ops-rail {
    padding-right: 6px !important;
    padding-left: 6px !important;
  }

  body.trainer-ops-page .ops-rail-nav {
    gap: 2px !important;
  }

  body.trainer-ops-page .ops-rail-link {
    height: 52px !important;
    min-height: 52px !important;
    border-radius: 12px !important;
  }

  body.trainer-ops-page .ops-rail-icon,
  body.trainer-ops-page .ops-rail-icon svg {
    width: 16px !important;
    height: 16px !important;
    flex-basis: 16px !important;
  }

  body.trainer-ops-page .ops-rail-link::after {
    font-size: 7px !important;
  }
}

/* Loaded last: desktop trainer sidebar and mobile cleanup. */
@media (min-width: 821px) {
  body.trainer-ops-page {
    background: #f6f8f8 !important;
  }

  body.trainer-ops-page::before,
  body.trainer-ops-page::after,
  body.trainer-ops-page.app-body::before,
  body.trainer-ops-page.app-body::after,
  body.trainer-ops-page .ops-main::before,
  body.trainer-ops-page .ops-main::after {
    content: none !important;
    display: none !important;
  }

  body.trainer-ops-page .ops-shell,
  body.trainer-builder-page .ops-shell {
    display: grid !important;
    grid-template-columns: 320px minmax(0, 1fr) !important;
    width: 100% !important;
    min-height: 100dvh !important;
    background: #f6f8f8 !important;
  }

  body.trainer-ops-page .ops-rail,
  body.trainer-builder-page .ops-rail {
    position: sticky !important;
    top: 24px !important;
    display: flex !important;
    flex-direction: column !important;
    align-self: start !important;
    width: 272px !important;
    min-width: 272px !important;
    height: calc(100dvh - 48px) !important;
    min-height: 620px !important;
    margin: 24px 0 24px 24px !important;
    padding: 30px 22px 20px !important;
    border: 1px solid rgba(31, 37, 43, 0.06) !important;
    border-radius: 30px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    box-shadow: 0 28px 90px rgba(31, 37, 43, 0.09) !important;
    backdrop-filter: blur(16px) saturate(1.08) !important;
  }

  body.trainer-ops-page .ops-brand,
  body.trainer-builder-page .ops-brand {
    display: block !important;
    flex: 0 0 auto !important;
    width: 202px !important;
    height: 52px !important;
    margin: 0 0 26px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: url("assets/forma-lockup-ref.png") left center / contain no-repeat !important;
    box-shadow: none !important;
    color: transparent !important;
    font-size: 0 !important;
    overflow: hidden !important;
  }

  body.trainer-ops-page .ops-rail-nav,
  body.trainer-builder-page .ops-rail-nav {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-content: start !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 10px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body.trainer-ops-page .ops-rail-link,
  body.trainer-builder-page .ops-rail-link {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 50px !important;
    min-height: 50px !important;
    padding: 0 18px !important;
    border: 1px solid transparent !important;
    border-radius: 22px !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #6f7a84 !important;
    text-decoration: none !important;
    transform: none !important;
  }

  body.trainer-ops-page .ops-rail-link:hover,
  body.trainer-ops-page .ops-rail-link:focus-visible,
  body.trainer-builder-page .ops-rail-link:hover,
  body.trainer-builder-page .ops-rail-link:focus-visible {
    border-color: rgba(31, 37, 43, 0.06) !important;
    background: rgba(245, 248, 248, 0.88) !important;
    color: #273139 !important;
  }

  body.trainer-ops-page .ops-rail-link.active,
  body.trainer-builder-page .ops-rail-link.active {
    border-color: rgba(82, 188, 158, 0.14) !important;
    background: #e5f6ef !important;
    color: #2f8c76 !important;
    box-shadow: none !important;
  }

  body.trainer-ops-page .ops-rail-icon,
  body.trainer-builder-page .ops-rail-icon {
    display: none !important;
  }

  body.trainer-ops-page .ops-rail-link::after,
  body.trainer-builder-page .ops-rail-link::after {
    content: attr(data-label) !important;
    position: static !important;
    display: block !important;
    max-width: 100% !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: transparent !important;
    box-shadow: none !important;
    color: currentColor !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
    opacity: 1 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    transform: none !important;
  }

  body.trainer-ops-page .ops-rail-profile,
  body.trainer-builder-page .ops-rail-profile {
    display: none !important;
  }

  body.trainer-ops-page .ops-rail-account,
  body.trainer-builder-page .ops-rail-account {
    display: grid !important;
    width: 100% !important;
    margin: auto 0 0 !important;
    padding: 12px !important;
    gap: 10px !important;
    border: 1px solid rgba(31, 37, 43, 0.07) !important;
    border-radius: 18px !important;
    background: #f7faf9 !important;
    color: #1f252b !important;
    box-shadow: none !important;
  }

  body.trainer-ops-page .ops-rail-account-avatar,
  body.trainer-builder-page .ops-rail-account-avatar {
    background: #e0f3ec !important;
    color: #287b68 !important;
  }

  body.trainer-ops-page .ops-rail-account-user strong,
  body.trainer-builder-page .ops-rail-account-user strong {
    color: #1f252b !important;
  }

  body.trainer-ops-page .ops-rail-account-user small,
  body.trainer-builder-page .ops-rail-account-user small {
    color: #77828c !important;
  }

  body.trainer-ops-page .ops-rail-logout,
  body.trainer-builder-page .ops-rail-logout {
    border-color: rgba(31, 37, 43, 0.08) !important;
    background: #1f252b !important;
    color: #ffffff !important;
  }

  body.trainer-ops-page .ops-main,
  body.trainer-builder-page .ops-main {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 24px 28px 36px 0 !important;
    overflow: visible !important;
  }
}

@media (max-width: 820px) {
  body.trainer-ops-page .ops-main {
    padding-top: 10px !important;
  }

  body.trainer-builder-page .ops-builder-flow {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 12px !important;
  }
  body.trainer-builder-page .ops-builder-flow > article {
    padding: 8px !important;
    gap: 4px !important;
  }
  body.trainer-builder-page .ops-builder-flow > article strong {
    font-size: 12px !important;
    line-height: 1.15 !important;
  }
  body.trainer-builder-page .ops-builder-flow > article small {
    display: none !important;
  }
}

/* Client cabinet refresh: same calm light shell as trainer home. */
@media (min-width: 821px) {
  body.client-ops-page {
    background: #f6f8f8 !important;
  }

  body.client-ops-page::before,
  body.client-ops-page::after,
  body.client-ops-page.app-body::before,
  body.client-ops-page.app-body::after,
  body.client-ops-page .ops-main::before,
  body.client-ops-page .ops-main::after {
    content: none !important;
    display: none !important;
  }

  body.client-ops-page .ops-shell {
    display: grid !important;
    grid-template-columns: 320px minmax(0, 1fr) !important;
    width: 100% !important;
    min-height: 100dvh !important;
    background: #f6f8f8 !important;
  }

  body.client-ops-page .ops-rail {
    position: sticky !important;
    top: 24px !important;
    display: flex !important;
    flex-direction: column !important;
    align-self: start !important;
    width: 272px !important;
    min-width: 272px !important;
    height: calc(100dvh - 48px) !important;
    min-height: 620px !important;
    margin: 24px 0 24px 24px !important;
    padding: 30px 22px 20px !important;
    border: 1px solid rgba(31, 37, 43, 0.06) !important;
    border-radius: 30px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    box-shadow: 0 28px 90px rgba(31, 37, 43, 0.09) !important;
    backdrop-filter: blur(16px) saturate(1.08) !important;
  }

  body.client-ops-page .ops-brand {
    display: block !important;
    flex: 0 0 auto !important;
    width: 202px !important;
    height: 52px !important;
    margin: 0 0 28px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: url("assets/forma-lockup-ref.png") left center / contain no-repeat !important;
    box-shadow: none !important;
    color: transparent !important;
    font-size: 0 !important;
    overflow: hidden !important;
  }

  body.client-ops-page .ops-rail-nav,
  body.client-ops-page .ops-rail-nav.section-tabs {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-content: start !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 10px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body.client-ops-page .ops-rail-link {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 50px !important;
    min-height: 50px !important;
    padding: 0 18px !important;
    border: 1px solid transparent !important;
    border-radius: 22px !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #6f7a84 !important;
    text-decoration: none !important;
    transform: none !important;
  }

  body.client-ops-page .ops-rail-link:hover,
  body.client-ops-page .ops-rail-link:focus-visible {
    border-color: rgba(31, 37, 43, 0.06) !important;
    background: rgba(245, 248, 248, 0.88) !important;
    color: #273139 !important;
  }

  body.client-ops-page .ops-rail-link.active {
    border-color: rgba(82, 188, 158, 0.14) !important;
    background: #e5f6ef !important;
    color: #2f8c76 !important;
    box-shadow: none !important;
  }

  body.client-ops-page .ops-rail-icon,
  body.client-ops-page .ops-rail-link::after {
    display: none !important;
    content: none !important;
  }

  body.client-ops-page .ops-rail-label {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    color: currentColor !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  body.client-ops-page .ops-rail-profile {
    display: none !important;
  }

  body.client-ops-page .ops-rail-account {
    display: grid !important;
    width: 100% !important;
    margin: auto 0 0 !important;
    padding: 12px !important;
    gap: 10px !important;
    border: 1px solid rgba(31, 37, 43, 0.07) !important;
    border-radius: 18px !important;
    background: #f7faf9 !important;
    color: #1f252b !important;
    box-shadow: none !important;
  }

  body.client-ops-page .ops-rail-account-avatar {
    background: #e0f3ec !important;
    color: #287b68 !important;
  }

  body.client-ops-page .ops-rail-account-user strong {
    color: #1f252b !important;
  }

  body.client-ops-page .ops-rail-account-user small {
    color: #77828c !important;
  }

  body.client-ops-page .ops-rail-logout {
    border-color: rgba(31, 37, 43, 0.08) !important;
    background: #1f252b !important;
    color: #ffffff !important;
  }

  body.client-ops-page .ops-main {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 24px 28px 36px 0 !important;
    overflow: visible !important;
  }

  body.client-ops-page .minimal-panel {
    width: 100% !important;
    max-width: 1540px !important;
    min-height: calc(100dvh - 48px) !important;
    margin: 0 auto !important;
    padding: 36px 40px 34px !important;
    gap: 22px !important;
    border: 1px solid rgba(31, 37, 43, 0.06) !important;
    border-radius: 30px !important;
    background: rgba(255, 255, 255, 0.96) !important;
    box-shadow: 0 32px 110px rgba(31, 37, 43, 0.08) !important;
  }

  body.client-ops-page .client-header,
  body.client-ops-page .ops-page-head {
    min-height: 0 !important;
    margin: 0 0 30px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body.client-ops-page .client-header .ops-kicker,
  body.client-ops-page .ops-page-head .ops-kicker {
    display: block !important;
  }

  body.client-ops-page .client-header .ops-title-block h1,
  body.client-ops-page .ops-page-head .ops-title-block h1 {
    max-width: none !important;
    margin: 0 !important;
    color: #1f252b !important;
    font-size: clamp(34px, 3vw, 48px) !important;
    font-weight: 900 !important;
    line-height: 1.02 !important;
    letter-spacing: 0 !important;
  }

  body.client-ops-page .client-header .ops-title-block p,
  body.client-ops-page .ops-page-head .ops-title-block p {
    max-width: 680px !important;
    color: #6f7a84 !important;
    font-size: 16px !important;
    font-weight: 650 !important;
    line-height: 1.35 !important;
  }

  body.client-ops-page .client-header-actions {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
  }

  body.client-ops-page .client-icon-action,
  body.client-ops-page .client-date-action {
    border-color: rgba(31, 37, 43, 0.07) !important;
    background: #ffffff !important;
    color: #2f8c76 !important;
    box-shadow: 0 18px 52px rgba(31, 37, 43, 0.08) !important;
  }

  body.client-ops-page .client-header-person {
    min-height: 62px !important;
    padding: 8px 16px 8px 8px !important;
    border: 1px solid rgba(31, 37, 43, 0.06) !important;
    border-radius: 999px !important;
    background: #ffffff !important;
    box-shadow: 0 18px 52px rgba(31, 37, 43, 0.08) !important;
  }

  body.client-ops-page .client-header-person > span {
    background: #e0f3ec !important;
    color: #1f252b !important;
  }

  body.client-ops-page .client-home-layout {
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr) !important;
    gap: 20px !important;
  }

  body.client-ops-page .client-home-main,
  body.client-ops-page .client-home-side {
    gap: 16px !important;
  }

  body.client-ops-page .client-today-hero {
    min-height: 0 !important;
    padding: 30px !important;
    border: 1px solid rgba(31, 37, 43, 0.05) !important;
    border-radius: 18px !important;
    background: #f5f8f8 !important;
    color: #1f252b !important;
    box-shadow: none !important;
  }

  body.client-ops-page .client-today-hero-head {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 20px !important;
  }

  body.client-ops-page .client-today-kicker {
    color: #3b9b82 !important;
  }

  body.client-ops-page .client-today-question {
    max-width: 11ch !important;
    margin: 14px 0 22px !important;
    color: #1f252b !important;
    font-size: clamp(44px, 5vw, 70px) !important;
    font-weight: 900 !important;
    line-height: 0.94 !important;
  }

  body.client-ops-page .client-workout-label {
    color: #6f7a84 !important;
  }

  body.client-ops-page .client-today-title {
    color: #1f252b !important;
    font-size: 28px !important;
    font-weight: 900 !important;
  }

  body.client-ops-page .client-day-summary,
  body.client-ops-page .client-day-statuses {
    display: block !important;
  }

  body.client-ops-page .client-day-summary {
    max-width: 620px !important;
    color: #5f6d77 !important;
  }

  body.client-ops-page .client-coach-note {
    width: min(620px, 100%) !important;
    margin: 24px 0 !important;
    padding: 18px 20px !important;
    border: 1px solid rgba(31, 37, 43, 0.08) !important;
    border-radius: 14px !important;
    background: #ffffff !important;
  }

  body.client-ops-page .client-coach-note strong,
  body.client-ops-page .client-coach-note p {
    color: #1f252b !important;
  }

  body.client-ops-page .client-day-actions {
    display: flex !important;
    gap: 12px !important;
  }

  body.client-ops-page .client-day-actions .ops-button {
    min-width: 190px !important;
    min-height: 54px !important;
  }

  body.client-ops-page .client-nutrition-snapshot,
  body.client-ops-page .client-results-card,
  body.client-ops-page .client-goal-strip,
  body.client-ops-page .client-calendar-card,
  body.client-ops-page .client-side-card,
  body.client-ops-page .calories-card,
  body.client-ops-page .profile-card,
  body.client-ops-page .client-progress-card,
  body.client-ops-page .client-calorie-plan-card,
  body.client-ops-page .client-calorie-plan-form,
  body.client-ops-page .client-calorie-plan-result,
  body.client-ops-page .client-ai-form-card,
  body.client-ops-page .client-ai-result-card,
  body.client-ops-page .client-ai-history-card {
    border: 1px solid rgba(31, 37, 43, 0.07) !important;
    border-radius: 18px !important;
    background: #ffffff !important;
    box-shadow: none !important;
  }

  body.client-ops-page .client-calendar-card,
  body.client-ops-page .client-side-card {
    padding: 28px !important;
  }
}

@media (max-width: 1180px) and (min-width: 821px) {
  body.client-ops-page .client-home-layout {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 820px) {
  body.client-ops-page .ops-main {
    padding-top: 10px !important;
  }

  body.client-ops-page .minimal-panel:not(.is-hidden-panel) {
    display: grid !important;
    width: 100% !important;
    padding: 18px 16px !important;
    gap: 14px !important;
    border: 1px solid rgba(31, 37, 43, 0.06) !important;
    border-radius: 24px !important;
    background: rgba(255, 255, 255, 0.96) !important;
    box-shadow: 0 18px 48px rgba(31, 37, 43, 0.08) !important;
  }

  body.client-ops-page .client-header,
  body.client-ops-page .ops-page-head {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body.client-ops-page .client-header .ops-title-block h1,
  body.client-ops-page .ops-page-head .ops-title-block h1 {
    font-size: 32px !important;
  }

  body.client-ops-page .client-header-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  body.client-ops-page .client-header-person {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    border-radius: 20px !important;
    background: #ffffff !important;
  }

  body.client-ops-page .client-today-hero {
    min-height: 0 !important;
    padding: 20px !important;
    border: 1px solid rgba(31, 37, 43, 0.05) !important;
    border-radius: 18px !important;
    background: #f5f8f8 !important;
    color: #1f252b !important;
  }

  body.client-ops-page .client-today-question {
    max-width: 11ch !important;
    color: #1f252b !important;
    font-size: 42px !important;
    font-weight: 900 !important;
    line-height: 0.96 !important;
  }

  body.client-ops-page .client-workout-label {
    color: #6f7a84 !important;
  }

  body.client-ops-page .client-today-title {
    color: #1f252b !important;
  }

  body.client-ops-page .client-day-summary,
  body.client-ops-page .client-day-statuses {
    display: block !important;
  }

  body.client-ops-page .client-coach-note {
    padding: 16px !important;
    border: 1px solid rgba(31, 37, 43, 0.08) !important;
    border-radius: 14px !important;
    background: #ffffff !important;
  }

  body.client-ops-page .client-coach-note strong,
  body.client-ops-page .client-coach-note p {
    color: #1f252b !important;
  }

  body.client-ops-page .client-day-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
}

/* Client cabinet refinement: clean up light hero text inherited from the old dark card. */
body.client-ops-page .client-today-hero::before,
body.client-ops-page .client-today-hero::after {
  opacity: 0.05 !important;
}

body.client-ops-page .client-today-hero .client-day-summary {
  color: #5f6d77 !important;
}

body.client-ops-page .client-today-hero .client-day-statuses,
body.client-ops-page .client-today-hero .client-day-meta {
  color: #64717c !important;
}

body.client-ops-page .client-today-hero .status-pill,
body.client-ops-page .client-today-hero .client-day-pill {
  border-color: rgba(31, 37, 43, 0.08) !important;
  background: rgba(255, 255, 255, 0.82) !important;
  color: #53616b !important;
  box-shadow: none !important;
}

@media (min-width: 821px) {
  body.client-ops-page .client-today-hero-head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  body.client-ops-page .client-day-statuses {
    justify-self: start !important;
    max-width: 100% !important;
  }

  body.client-ops-page .client-day-statuses .detail-pills,
  body.client-ops-page .client-day-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
}

@media (max-width: 820px) {
  body.client-ops-page .client-header-actions {
    grid-template-columns: 52px 52px minmax(0, 1fr) !important;
    align-items: center !important;
  }

  body.client-ops-page .client-icon-action,
  body.client-ops-page .client-date-action {
    width: 52px !important;
    min-width: 52px !important;
    height: 52px !important;
    min-height: 52px !important;
  }

  body.client-ops-page .client-header-person {
    grid-column: auto !important;
    min-height: 52px !important;
    padding: 6px 10px 6px 6px !important;
    border-radius: 999px !important;
  }

  body.client-ops-page .client-header-person > span {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
  }

  body.client-ops-page .client-header-person strong {
    font-size: 14px !important;
    line-height: 1.1 !important;
  }

  body.client-ops-page .client-header-person small {
    font-size: 12px !important;
  }

  body.client-ops-page .client-today-hero-head {
    gap: 18px !important;
  }

  body.client-ops-page .client-day-summary {
    margin-top: 12px !important;
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  body.client-ops-page .client-day-statuses {
    display: grid !important;
    gap: 8px !important;
  }

  body.client-ops-page .client-day-statuses .detail-pills,
  body.client-ops-page .client-day-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  body.client-ops-page .client-coach-note {
    margin: 14px 0 !important;
    min-height: 0 !important;
  }

  body.client-ops-page .client-coach-note .note-copy {
    min-height: 0 !important;
  }

  body.client-ops-page .client-day-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  body.client-ops-page .client-day-actions .ops-button {
    min-width: 0 !important;
    min-height: 48px !important;
    padding: 0 12px !important;
    font-size: 14px !important;
  }
}

/* Client main overview tab. */
body.client-ops-page .client-overview-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.06fr) minmax(350px, 0.9fr) !important;
  gap: 20px !important;
  align-items: start !important;
}

body.client-ops-page .client-overview-grid > * {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

body.client-ops-page .client-overview-hero {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 460px !important;
  padding: 34px !important;
  display: grid !important;
  align-content: space-between !important;
  gap: 28px !important;
  border: 1px solid rgba(31, 37, 43, 0.06) !important;
  border-radius: 22px !important;
  background: #f5f8f8 !important;
  box-shadow: none !important;
}

body.client-ops-page .client-overview-kicker {
  display: block;
  margin-bottom: 18px;
  color: #3b9b82;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

body.client-ops-page .client-overview-hero h2 {
  max-width: 10ch;
  margin: 0 0 22px;
  color: #1f252b;
  font-size: clamp(42px, 5vw, 68px);
  font-weight: 950;
  line-height: 0.95;
  letter-spacing: 0;
}

body.client-ops-page .client-overview-hero-copy > strong {
  display: block;
  color: #1f252b;
  font-size: 28px;
  font-weight: 900;
  line-height: 1.08;
}

body.client-ops-page .client-overview-hero-copy p {
  max-width: 560px;
  margin: 12px 0 0;
  color: #5f6d77;
  font-size: 16px;
  line-height: 1.45;
}

body.client-ops-page .client-overview-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

body.client-ops-page .client-overview-meta span {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 12px;
  border: 1px solid rgba(31, 37, 43, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: #53616b;
  font-size: 13px;
  font-weight: 850;
  line-height: 1;
}

body.client-ops-page .client-overview-actions {
  display: flex;
  gap: 12px;
}

body.client-ops-page .client-overview-actions .ops-button {
  min-width: 180px;
  min-height: 54px;
}

body.client-ops-page .client-overview-side {
  display: grid !important;
  gap: 16px !important;
}

body.client-ops-page .client-overview-card {
  width: 100% !important;
  max-width: 100% !important;
  padding: 28px !important;
  border: 1px solid rgba(31, 37, 43, 0.07) !important;
  border-radius: 22px !important;
  background: #ffffff !important;
  box-shadow: none !important;
}

body.client-ops-page .client-overview-progress {
  display: grid;
  gap: 14px;
}

body.client-ops-page .client-overview-progress-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.9fr) minmax(90px, 1fr) auto;
  gap: 12px;
  align-items: center;
}

body.client-ops-page .client-overview-progress-row span,
body.client-ops-page .client-overview-nutrition-card > span,
body.client-ops-page .client-overview-record span {
  color: #6f7a84;
  font-size: 13px;
  font-weight: 850;
}

body.client-ops-page .client-overview-progress-row small {
  display: block;
  margin-top: 3px;
  color: #8a95a0;
  font-size: 12px;
  font-weight: 750;
}

body.client-ops-page .client-overview-progress-row strong {
  color: #1f252b;
  font-size: 18px;
  font-weight: 900;
}

body.client-ops-page .client-overview-progress-bar {
  height: 10px;
  overflow: hidden;
  border-radius: 999px;
  background: #edf1f0;
}

body.client-ops-page .client-overview-progress-bar i {
  display: block;
  width: var(--value, 0%);
  height: 100%;
  border-radius: inherit;
  background: #62c19f;
}

body.client-ops-page .client-overview-nutrition-card {
  display: grid;
  gap: 8px;
}

body.client-ops-page .client-overview-nutrition-card strong {
  color: #1f252b;
  font-size: 42px;
  font-weight: 950;
  line-height: 1;
}

body.client-ops-page .client-overview-nutrition-card p {
  margin: 0 0 8px;
  color: #65727d;
  line-height: 1.45;
}

body.client-ops-page .client-overview-agenda-card {
  grid-column: 1;
}

body.client-ops-page .client-overview-next-card {
  grid-column: 2;
}

body.client-ops-page .client-overview-record-card {
  grid-column: 1 / -1;
}

body.client-ops-page .client-overview-agenda,
body.client-ops-page .client-overview-records {
  display: grid;
  gap: 12px;
}

body.client-ops-page .client-overview-agenda-item,
body.client-ops-page .client-overview-upcoming-item {
  width: 100%;
  border: 1px solid rgba(31, 37, 43, 0.08);
  background: #fbfcfb;
  color: #1f252b;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

body.client-ops-page .client-overview-agenda-item {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  min-height: 92px;
  padding: 16px;
  border-radius: 18px;
}

body.client-ops-page .client-overview-agenda-item.has-entry {
  background: #f3faf7;
}

body.client-ops-page .client-overview-agenda-item > span {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  padding: 8px 10px;
  border-radius: 999px;
  background: #e5f6ef;
  color: #2f8c76;
  font-size: 13px;
  font-weight: 900;
}

body.client-ops-page .client-overview-agenda-item strong,
body.client-ops-page .client-overview-record strong {
  display: block;
  color: #1f252b;
  font-size: 17px;
  font-weight: 900;
  line-height: 1.15;
}

body.client-ops-page .client-overview-agenda-item p,
body.client-ops-page .client-overview-agenda-item small,
body.client-ops-page .client-overview-record p {
  margin: 4px 0 0;
  color: #6f7a84;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
}

body.client-ops-page .client-overview-upcoming-item {
  display: block;
  padding: 16px;
  border-radius: 18px;
}

body.client-ops-page .client-overview-record {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 15px 0;
  border-bottom: 1px solid rgba(31, 37, 43, 0.08);
}

body.client-ops-page .client-overview-record:last-child {
  border-bottom: 0;
}

body.client-ops-page .client-overview-record b {
  color: #1f252b;
  font-size: 17px;
  font-weight: 950;
  text-align: right;
}

@media (max-width: 1180px) and (min-width: 821px) {
  body.client-ops-page .client-overview-grid {
    grid-template-columns: 1fr;
  }

  body.client-ops-page .client-overview-agenda-card,
  body.client-ops-page .client-overview-next-card,
  body.client-ops-page .client-overview-record-card {
    grid-column: auto;
  }
}

@media (max-width: 820px) {
  body.client-ops-page .ops-rail-nav,
  body.client-ops-page .ops-rail-nav.section-tabs {
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
    gap: 3px !important;
  }

  body.client-ops-page .ops-rail-link {
    height: 60px !important;
    min-height: 60px !important;
    padding-inline: 1px !important;
  }

  body.client-ops-page .ops-rail-label,
  body.client-ops-page .ops-rail-link[href="#ai-calories"] .ops-rail-label::after {
    font-size: 8px !important;
  }

  body.client-ops-page .client-overview-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  body.client-ops-page .client-overview-agenda-card,
  body.client-ops-page .client-overview-next-card,
  body.client-ops-page .client-overview-record-card {
    grid-column: auto !important;
  }

  body.client-ops-page .client-overview-hero {
    min-height: 0 !important;
    padding: 20px !important;
    gap: 20px !important;
    border-radius: 18px !important;
  }

  body.client-ops-page .client-overview-hero h2 {
    max-width: 11ch !important;
    margin-bottom: 18px !important;
    font-size: 42px !important;
    line-height: 0.96 !important;
  }

  body.client-ops-page .client-overview-hero-copy > strong {
    font-size: 26px !important;
  }

  body.client-ops-page .client-overview-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  body.client-ops-page .client-overview-actions .ops-button {
    min-width: 0 !important;
    min-height: 48px !important;
    padding: 0 10px !important;
    font-size: 14px !important;
  }

  body.client-ops-page .client-overview-side {
    display: grid !important;
    gap: 14px !important;
  }

  body.client-ops-page .client-overview-card {
    padding: 18px 16px !important;
  }

  body.client-ops-page .client-overview-progress-row,
  body.client-ops-page .client-overview-agenda-item,
  body.client-ops-page .client-overview-record {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  body.client-ops-page .client-overview-agenda-item {
    min-height: 0 !important;
  }

  body.client-ops-page .client-overview-record b {
    text-align: left !important;
  }
}

/* Client cabinet typography normalization */
body.client-ops-page {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body.client-ops-page .ops-rail-label,
body.client-ops-page .ops-rail-link[href="#ai-calories"] .ops-rail-label::after {
  font-weight: 600 !important;
}

body.client-ops-page .ops-rail-link.active .ops-rail-label {
  font-weight: 680 !important;
}

body.client-ops-page .client-header .ops-kicker,
body.client-ops-page .ops-page-head .ops-kicker,
body.client-ops-page .client-overview-kicker {
  color: #72808b !important;
  font-size: 14px !important;
  font-weight: 620 !important;
  letter-spacing: 0.13em !important;
}

body.client-ops-page .client-header .ops-title-block h1,
body.client-ops-page .ops-page-head .ops-title-block h1 {
  max-width: 13ch !important;
  color: #20262d !important;
  font-size: clamp(30px, 2.7vw, 42px) !important;
  font-weight: 720 !important;
  letter-spacing: 0 !important;
  line-height: 1.14 !important;
}

body.client-ops-page .client-header .ops-title-block p,
body.client-ops-page .ops-page-head .ops-title-block p {
  max-width: 620px !important;
  color: #687681 !important;
  font-size: clamp(16px, 1.25vw, 20px) !important;
  font-weight: 450 !important;
  line-height: 1.35 !important;
}

body.client-ops-page .client-header-person strong,
body.client-ops-page .client-header-person small {
  font-weight: 650 !important;
}

body.client-ops-page .client-overview-hero {
  min-height: 390px !important;
  padding: clamp(28px, 4vw, 42px) !important;
}

body.client-ops-page .client-overview-hero h2,
body.client-ops-page .client-today-question {
  max-width: 12.5ch !important;
  color: #20262d !important;
  font-size: clamp(36px, 4.2vw, 52px) !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  line-height: 1.07 !important;
}

body.client-ops-page .client-overview-hero-copy > strong,
body.client-ops-page .client-today-title {
  color: #20262d !important;
  font-size: clamp(24px, 2.3vw, 32px) !important;
  font-weight: 680 !important;
  line-height: 1.12 !important;
}

body.client-ops-page .client-overview-hero-copy p,
body.client-ops-page .client-today-hero .client-day-summary,
body.client-ops-page .client-today-hero #client-selected-context {
  color: #64727d !important;
  font-size: clamp(16px, 1.45vw, 19px) !important;
  font-weight: 480 !important;
  line-height: 1.5 !important;
}

body.client-ops-page .client-overview-meta span,
body.client-ops-page .client-today-hero .status-pill,
body.client-ops-page .client-today-hero .client-day-pill {
  font-weight: 580 !important;
}

body.client-ops-page .content-card-head h2,
body.client-ops-page .client-calendar-card h2,
body.client-ops-page .client-side-card h2,
body.client-ops-page .client-overview-card .content-card-head h2 {
  color: #20262d !important;
  font-size: clamp(24px, 2.2vw, 32px) !important;
  font-weight: 680 !important;
  letter-spacing: 0 !important;
  line-height: 1.12 !important;
}

body.client-ops-page .content-card-head p,
body.client-ops-page .client-side-card p,
body.client-ops-page .client-overview-card p {
  color: #6a7782 !important;
  font-weight: 480 !important;
}

body.client-ops-page .client-overview-progress-row span,
body.client-ops-page .client-overview-nutrition-card > span,
body.client-ops-page .client-overview-record span,
body.client-ops-page .client-overview-agenda-item p,
body.client-ops-page .client-overview-agenda-item small,
body.client-ops-page .client-overview-record p {
  font-weight: 560 !important;
}

body.client-ops-page .client-overview-progress-row small {
  font-weight: 520 !important;
}

body.client-ops-page .client-overview-progress-row strong,
body.client-ops-page .client-overview-agenda-item strong,
body.client-ops-page .client-overview-record strong,
body.client-ops-page .client-overview-record b,
body.client-ops-page .client-overview-nutrition-card strong {
  font-weight: 700 !important;
}

body.client-ops-page .client-overview-nutrition-card strong {
  font-size: clamp(32px, 3.2vw, 40px) !important;
}

body.client-ops-page .client-overview-agenda-item > span,
body.client-ops-page .client-month-day,
body.client-ops-page .client-month-day .month-day-number {
  font-weight: 620 !important;
}

body.client-ops-page .ops-button,
body.client-ops-page button {
  font-weight: 620 !important;
}

body.client-ops-page .client-today-hero {
  min-height: 0 !important;
  padding: clamp(28px, 4vw, 42px) !important;
}

body.client-ops-page .client-today-hero .client-coach-note strong,
body.client-ops-page .client-today-hero .note-copy p {
  font-weight: 580 !important;
}

@media (max-width: 820px) {
  body.client-ops-page .ops-main {
    padding-top: 14px !important;
    padding-bottom: 92px !important;
  }

  body.client-ops-page .minimal-panel:not(.is-hidden-panel) {
    padding-top: 24px !important;
  }

  body.client-ops-page .client-header,
  body.client-ops-page .ops-page-head {
    overflow: visible !important;
    padding-top: 2px !important;
  }

  body.client-ops-page .ops-rail-label,
  body.client-ops-page .ops-rail-link[href="#ai-calories"] .ops-rail-label::after {
    font-size: 8px !important;
    font-weight: 580 !important;
    line-height: 1.05 !important;
  }

  body.client-ops-page .ops-rail-link.active .ops-rail-label {
    font-weight: 680 !important;
  }

  body.client-ops-page .client-header .ops-title-block h1,
  body.client-ops-page .ops-page-head .ops-title-block h1 {
    max-width: none !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
  }

  body.client-ops-page .client-header .ops-title-block p,
  body.client-ops-page .ops-page-head .ops-title-block p {
    font-size: 15px !important;
    line-height: 1.4 !important;
  }

  body.client-ops-page .client-overview-hero {
    min-height: 0 !important;
    padding: 22px !important;
  }

  body.client-ops-page .client-overview-hero h2,
  body.client-ops-page .client-today-question {
    max-width: 12ch !important;
    font-size: 31px !important;
    font-weight: 700 !important;
    line-height: 1.08 !important;
  }

  body.client-ops-page .client-overview-hero-copy > strong,
  body.client-ops-page .client-today-title {
    font-size: 21px !important;
    font-weight: 680 !important;
    line-height: 1.16 !important;
  }

  body.client-ops-page .client-overview-hero-copy p,
  body.client-ops-page .client-today-hero .client-day-summary,
  body.client-ops-page .client-today-hero #client-selected-context {
    font-size: 15px !important;
  }

  body.client-ops-page .content-card-head h2,
  body.client-ops-page .client-calendar-card h2,
  body.client-ops-page .client-side-card h2,
  body.client-ops-page .client-overview-card .content-card-head h2 {
    font-size: 24px !important;
    font-weight: 680 !important;
  }

  body.client-ops-page .client-overview-nutrition-card strong {
    font-size: 34px !important;
  }
}

/* Client live workout checklist and final block alignment */
body.client-ops-page .client-overview-grid {
  grid-template-columns: minmax(0, 1fr) minmax(340px, 420px) !important;
  align-items: stretch !important;
}

body.client-ops-page .client-overview-side {
  align-self: stretch !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
}

body.client-ops-page .client-home-layout {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 420px) !important;
  align-items: start !important;
}

body.client-ops-page .client-home-main,
body.client-ops-page .client-home-side {
  min-width: 0 !important;
  align-content: start !important;
}

body.client-ops-page .client-today-hero,
body.client-ops-page .client-calendar-card,
body.client-ops-page .client-side-card,
body.client-ops-page .client-workout-check-card,
body.client-ops-page .client-overview-card {
  width: 100% !important;
  box-sizing: border-box !important;
}

body.client-ops-page .client-workout-check-card {
  overflow: hidden !important;
}

body.client-ops-page .client-workout-check-card .content-card-head {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 16px !important;
  align-items: start !important;
}

body.client-ops-page .client-workout-checklist {
  display: grid !important;
  gap: 14px !important;
  align-content: start !important;
  padding: 0 28px 24px !important;
}

body.client-ops-page .client-workout-progress-panel {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 16px !important;
  align-items: center !important;
  padding: 16px !important;
  border: 1px solid rgba(47, 140, 118, 0.14) !important;
  border-radius: 18px !important;
  background: #f3faf7 !important;
}

body.client-ops-page .client-workout-progress-panel span {
  display: block !important;
  margin-bottom: 4px !important;
  color: #66737e !important;
  font-size: 12px !important;
  font-weight: 620 !important;
}

body.client-ops-page .client-workout-progress-panel strong {
  display: block !important;
  color: #20262d !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
}

body.client-ops-page .client-workout-progress-panel p {
  margin: 6px 0 0 !important;
  color: #687681 !important;
  font-size: 13px !important;
  font-weight: 480 !important;
  line-height: 1.4 !important;
}

body.client-ops-page .client-workout-progress-track {
  grid-column: 1 / -1 !important;
  height: 10px !important;
  overflow: hidden !important;
  border-radius: 999px !important;
  background: rgba(31, 37, 43, 0.08) !important;
}

body.client-ops-page .client-workout-progress-track i {
  display: block !important;
  width: var(--value, 0%) !important;
  height: 100% !important;
  border-radius: inherit !important;
  background: #62c19f !important;
}

body.client-ops-page .client-workout-progress-actions {
  display: flex !important;
  gap: 8px !important;
  justify-content: flex-end !important;
}

body.client-ops-page .client-workout-progress-actions .ops-button {
  min-width: 120px !important;
  min-height: 42px !important;
  padding: 0 14px !important;
  font-size: 13px !important;
  white-space: nowrap !important;
}

body.client-ops-page .client-workout-card.is-trackable {
  display: grid !important;
  gap: 14px !important;
  padding: 18px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(31, 37, 43, 0.08) !important;
  background: #ffffff !important;
  transition: border-color 0.18s ease, background-color 0.18s ease, transform 0.18s ease !important;
}

body.client-ops-page .client-workout-card.is-trackable.status-done {
  border-color: rgba(47, 140, 118, 0.28) !important;
  background: #f4fbf8 !important;
}

body.client-ops-page .client-workout-card.is-trackable.status-partial {
  border-color: rgba(176, 126, 46, 0.28) !important;
  background: #fffaf1 !important;
}

body.client-ops-page .client-workout-card.is-trackable.status-skipped {
  border-color: rgba(128, 137, 145, 0.24) !important;
  background: #f8f9f9 !important;
}

body.client-ops-page .client-workout-card.is-trackable .client-workout-card-head {
  grid-template-columns: 36px minmax(0, 1fr) !important;
  align-items: start !important;
  gap: 12px !important;
}

body.client-ops-page .client-workout-card.is-trackable .client-workout-step {
  width: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;
  background: #1f252b !important;
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

body.client-ops-page .client-workout-card.is-trackable.status-done .client-workout-step {
  background: #3fae8c !important;
}

body.client-ops-page .client-workout-card.is-trackable.status-partial .client-workout-step {
  background: #b48335 !important;
}

body.client-ops-page .client-workout-card.is-trackable.status-skipped .client-workout-step {
  background: #7e878e !important;
}

body.client-ops-page .client-workout-card.is-trackable .client-workout-card-head strong {
  font-size: 17px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}

body.client-ops-page .client-workout-card.is-trackable .client-workout-meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
}

body.client-ops-page .client-workout-card.is-trackable .client-workout-meta span,
body.client-ops-page .client-workout-card.is-trackable .client-video-chip {
  min-height: 28px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 560 !important;
}

body.client-ops-page .client-exercise-check {
  display: grid !important;
  gap: 12px !important;
  padding-top: 14px !important;
  border-top: 1px solid rgba(31, 37, 43, 0.08) !important;
}

body.client-ops-page .client-exercise-statuses {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

body.client-ops-page .client-exercise-status {
  min-height: 38px !important;
  padding: 0 14px !important;
  border: 1px solid rgba(31, 37, 43, 0.1) !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  color: #55636e !important;
  font: inherit !important;
  font-size: 13px !important;
  font-weight: 620 !important;
  cursor: pointer !important;
}

body.client-ops-page .client-exercise-status[data-client-exercise-status="done"].is-active {
  border-color: rgba(47, 140, 118, 0.3) !important;
  background: #dff5ed !important;
  color: #247b67 !important;
}

body.client-ops-page .client-exercise-status[data-client-exercise-status="partial"].is-active {
  border-color: rgba(176, 126, 46, 0.28) !important;
  background: #fff0d2 !important;
  color: #7b551d !important;
}

body.client-ops-page .client-exercise-status[data-client-exercise-status="skipped"].is-active {
  border-color: rgba(128, 137, 145, 0.28) !important;
  background: #e9edf0 !important;
  color: #56606a !important;
}

body.client-ops-page .client-exercise-fact {
  display: grid !important;
  grid-template-columns: minmax(150px, 0.38fr) minmax(0, 1fr) !important;
  gap: 10px !important;
}

body.client-ops-page .client-exercise-fact label {
  display: grid !important;
  gap: 6px !important;
  min-width: 0 !important;
}

body.client-ops-page .client-exercise-fact span {
  color: #73818b !important;
  font-size: 12px !important;
  font-weight: 600 !important;
}

body.client-ops-page .client-exercise-fact input {
  width: 100% !important;
  min-height: 42px !important;
  padding: 0 12px !important;
  border: 1px solid rgba(31, 37, 43, 0.1) !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, 0.86) !important;
  color: #20262d !important;
  font: inherit !important;
  font-size: 14px !important;
  font-weight: 520 !important;
  outline: none !important;
}

body.client-ops-page .client-exercise-fact input:focus {
  border-color: rgba(47, 140, 118, 0.38) !important;
  box-shadow: 0 0 0 4px rgba(47, 140, 118, 0.1) !important;
}

@media (min-width: 1181px) {
  body.client-ops-page[data-active-tab="calendar"] .client-home-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: 524px 524px auto auto !important;
    grid-auto-rows: auto !important;
    gap: 20px !important;
    align-items: stretch !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-home-main,
  body.client-ops-page[data-active-tab="calendar"] .client-home-side {
    display: contents !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-today-hero,
  body.client-ops-page[data-active-tab="calendar"] .client-calendar-card,
  body.client-ops-page[data-active-tab="calendar"] .client-nutrition-snapshot,
  body.client-ops-page[data-active-tab="calendar"] .client-side-card-bottom {
    min-height: 524px !important;
    height: 100% !important;
    align-self: stretch !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-today-hero {
    order: 1 !important;
    display: grid !important;
    grid-template-rows: auto minmax(58px, 1fr) auto !important;
    gap: 14px !important;
    align-content: stretch !important;
    padding: 28px !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-calendar-card {
    order: 2 !important;
    display: grid !important;
    grid-template-rows: auto auto minmax(0, 1fr) !important;
    align-content: stretch !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-nutrition-snapshot {
    order: 3 !important;
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-side-card-bottom {
    order: 4 !important;
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-workout-check-card {
    order: 5 !important;
    grid-column: 1 / -1 !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-goal-strip {
    order: 6 !important;
    grid-column: 1 / -1 !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-today-hero-head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    align-self: start !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-today-question {
    max-width: 13ch !important;
    margin: 10px 0 14px !important;
    font-size: 42px !important;
    line-height: 0.98 !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-today-title {
    font-size: 25px !important;
    line-height: 1.14 !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-day-summary {
    margin-top: 10px !important;
    font-size: 15px !important;
    line-height: 1.38 !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-day-statuses {
    gap: 8px !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-coach-note {
    align-self: stretch !important;
    min-height: 68px !important;
    margin: 0 !important;
    padding: 14px 16px !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-coach-note strong,
  body.client-ops-page[data-active-tab="calendar"] .client-coach-note p {
    font-size: 13px !important;
    line-height: 1.35 !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-day-actions {
    align-self: end !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-day-actions .ops-button {
    min-width: 0 !important;
    min-height: 48px !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-calendar-card .month-grid {
    align-self: stretch !important;
    align-content: space-between !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-nutrition-row {
    align-self: center !important;
    padding-bottom: 0 !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-side-card-bottom .content-card-body {
    display: grid !important;
    align-content: center !important;
    min-height: 0 !important;
  }

  body.client-ops-page[data-active-tab="calendar"] .client-upcoming-card.is-empty {
    margin: 0 !important;
  }
}

@media (max-width: 1180px) and (min-width: 821px) {
  body.client-ops-page .client-overview-grid,
  body.client-ops-page .client-home-layout {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 820px) {
  body.client-ops-page .client-overview-grid,
  body.client-ops-page .client-home-layout {
    grid-template-columns: 1fr !important;
  }

  body.client-ops-page .client-workout-check-card .content-card-head {
    grid-template-columns: 1fr !important;
  }

  body.client-ops-page .client-workout-check-card .content-card-head .ops-button {
    width: 100% !important;
  }

  body.client-ops-page .client-workout-checklist {
    padding: 0 16px 18px !important;
  }

  body.client-ops-page .client-workout-progress-panel {
    grid-template-columns: 1fr !important;
    padding: 14px !important;
  }

  body.client-ops-page .client-workout-progress-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    justify-content: stretch !important;
  }

  body.client-ops-page .client-workout-progress-actions .ops-button {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.client-ops-page .client-workout-card.is-trackable {
    padding: 14px !important;
  }

  body.client-ops-page .client-exercise-statuses {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  body.client-ops-page .client-exercise-status {
    min-width: 0 !important;
    padding: 0 6px !important;
    font-size: 12px !important;
  }

  body.client-ops-page .client-exercise-fact {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 820px) {
  body.client-ops-page .client-day-summary-card.client-today-hero {
    display: grid !important;
    gap: 18px !important;
    min-height: 0 !important;
    padding: 22px 18px !important;
    border-radius: 24px !important;
    background: #f6f8f8 !important;
    color: #1f252b !important;
    overflow: hidden !important;
  }

  body.client-ops-page .client-day-summary-card.client-today-hero::after {
    display: none !important;
  }

  body.client-ops-page .client-day-summary-card .client-today-hero-head,
  body.client-ops-page .client-day-summary-card .client-day-heading,
  body.client-ops-page .client-day-summary-card .client-day-statuses {
    display: grid !important;
    grid-template-columns: 1fr !important;
    justify-items: start !important;
    min-width: 0 !important;
  }

  body.client-ops-page .client-day-summary-card .client-today-question {
    max-width: 9.5ch !important;
    margin: 12px 0 10px !important;
    color: #1f252b !important;
    font-size: clamp(40px, 14vw, 56px) !important;
    font-weight: 680 !important;
    letter-spacing: -0.045em !important;
    line-height: 0.98 !important;
  }

  body.client-ops-page .client-day-summary-card .client-workout-label,
  body.client-ops-page .client-day-summary-card .client-today-title,
  body.client-ops-page .client-day-summary-card .client-day-summary {
    display: block !important;
    color: #1f252b !important;
  }

  body.client-ops-page .client-day-summary-card .client-workout-label {
    color: #788590 !important;
    font-size: 13px !important;
    letter-spacing: 0 !important;
  }

  body.client-ops-page .client-day-summary-card .client-today-title {
    font-size: clamp(28px, 8vw, 38px) !important;
    font-weight: 640 !important;
    letter-spacing: -0.035em !important;
  }

  body.client-ops-page .client-day-summary-card .client-day-summary {
    color: #64727d !important;
    font-size: 17px !important;
    line-height: 1.38 !important;
  }

  body.client-ops-page .client-day-summary-card .detail-pills,
  body.client-ops-page .client-day-summary-card .client-day-meta {
    justify-content: flex-start !important;
    width: 100% !important;
  }

  body.client-ops-page .client-day-summary-card .status-pill,
  body.client-ops-page .client-day-summary-card .client-day-pill {
    min-height: 36px !important;
    max-width: 100% !important;
    padding: 0 12px !important;
    font-size: 13px !important;
    overflow-wrap: anywhere !important;
  }

  body.client-ops-page .client-day-summary-card .client-coach-note {
    width: 100% !important;
    min-height: 104px !important;
    margin: 0 !important;
    padding: 20px !important;
    border: 1px solid rgba(31, 37, 43, 0.08) !important;
    border-radius: 18px !important;
    background: #ffffff !important;
  }

  body.client-ops-page .client-day-summary-card .client-coach-note strong,
  body.client-ops-page .client-day-summary-card .client-coach-note p {
    color: #1f252b !important;
  }

  body.client-ops-page .client-day-summary-card .client-day-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    width: 100% !important;
  }

  body.client-ops-page .client-day-summary-card .client-day-actions .ops-button {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 56px !important;
    font-size: 18px !important;
  }
}

/* =============================================================
 * APP-LOOK REFRESH (mobile only, cabinet pages)
 * Tokens mirror iOS FORMA app (Brand.* in ContentView.swift).
 * Functions/IDs/handlers untouched — pure visual layer.
 * ============================================================= */
@media (max-width: 820px) {
  /* Body palette */
  body.trainer-ops-page,
  body.client-ops-page {
    background: linear-gradient(180deg, #ffffff 0%, #f7faf8 100%) !important;
    color: #182127 !important;
    font-family:
      -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text",
      "Helvetica Neue", system-ui, sans-serif !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
  }

  /* Large title (iOS Settings style) */
  body.trainer-ops-page .ops-page-head h1,
  body.client-ops-page .ops-page-head h1,
  body.client-ops-page .client-page-head h1,
  body.client-ops-page .client-header h1,
  body.client-ops-page .minimal-panel > header h1 {
    font-size: 32px !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
    line-height: 1.05 !important;
    color: #182127 !important;
    margin: 0 0 4px !important;
  }
  body.trainer-ops-page .ops-page-head p,
  body.client-ops-page .ops-page-head p,
  body.client-ops-page .minimal-panel > header p {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #667178 !important;
    margin: 0 !important;
    line-height: 1.45 !important;
  }

  /* Kicker: small bold uppercase label above titles */
  body.trainer-ops-page .ops-kicker,
  body.client-ops-page .ops-kicker {
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: #667178 !important;
    margin: 0 0 6px !important;
  }

  /* Cards — soft, white, subtle shadow, rounded 20 */
  body.trainer-ops-page .ops-surface,
  body.client-ops-page .ops-surface,
  body.client-ops-page .content-card,
  body.client-ops-page .minimal-panel > section.content-card,
  body.client-ops-page .minimal-panel > section.ops-surface {
    background: #ffffff !important;
    border: 1px solid rgba(228, 233, 230, 0.7) !important;
    border-radius: 20px !important;
    padding: 18px !important;
    box-shadow:
      0 1px 2px rgba(24, 33, 39, 0.04),
      0 6px 16px rgba(24, 33, 39, 0.03) !important;
    margin-bottom: 14px !important;
  }
  body.trainer-ops-page .ops-surface:last-child,
  body.client-ops-page .ops-surface:last-child,
  body.client-ops-page .content-card:last-child {
    margin-bottom: 0 !important;
  }

  /* Buttons — iOS app styles (FilledButtonStyle / DarkButtonStyle / SecondaryButtonStyle).
     Press feedback mirrors `.opacity(isPressed ? 0.78 : 1)` from ContentView.swift. */
  body.trainer-ops-page .ops-button,
  body.client-ops-page .ops-button,
  body.trainer-ops-page button.ops-button,
  body.client-ops-page button.ops-button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    height: auto !important;
    gap: 8px !important;
    min-height: 50px !important;
    max-height: 56px !important;
    padding: 0 22px !important;
    border-radius: 16px !important;
    font-family: inherit !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    letter-spacing: -0.01em !important;
    line-height: 1 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: opacity 100ms ease, background-color 100ms ease !important;
    touch-action: manipulation !important;
    -webkit-tap-highlight-color: transparent !important;
  }
  body.trainer-ops-page .ops-button:active:not([disabled]),
  body.client-ops-page .ops-button:active:not([disabled]) {
    opacity: 0.78 !important;
  }
  body.trainer-ops-page .ops-button[disabled],
  body.client-ops-page .ops-button[disabled] {
    opacity: 0.42 !important;
    cursor: default !important;
  }

  /* Full-width in action rows / by themselves in a card / inside form */
  body.trainer-ops-page .ops-head-actions,
  body.client-ops-page .ops-head-actions,
  body.trainer-ops-page .client-ai-actions,
  body.client-ops-page .client-ai-actions,
  body.trainer-ops-page .ops-builder-footer,
  body.trainer-ops-page form .ops-button,
  body.client-ops-page form .ops-button {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
  }
  body.trainer-ops-page .ops-head-actions > .ops-button,
  body.client-ops-page .ops-head-actions > .ops-button,
  body.trainer-ops-page .client-ai-actions > .ops-button,
  body.client-ops-page .client-ai-actions > .ops-button,
  body.trainer-ops-page .ops-builder-footer > .ops-button {
    width: 100% !important;
  }

  /* Primary (dark) — DarkButtonStyle from iOS */
  body.trainer-ops-page .ops-button.is-primary,
  body.client-ops-page .ops-button.is-primary {
    background: #101820 !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
  }

  /* Filled mint — FilledButtonStyle (used inside AI photo zone "Снять") */
  body.client-ops-page .client-ai-photo-buttons .ops-button.is-primary,
  body.trainer-ops-page .ops-button.is-mint,
  body.client-ops-page .ops-button.is-mint {
    background: #62bd9b !important;
    color: #ffffff !important;
  }

  /* Secondary / ghost / outlined — SecondaryButtonStyle */
  body.trainer-ops-page .ops-button.is-ghost,
  body.client-ops-page .ops-button.is-ghost {
    background: #ffffff !important;
    color: #182127 !important;
    border: 1px solid #e4e9e6 !important;
  }

  /* Small button (table-row actions etc.) */
  body.trainer-ops-page .ops-button.is-small,
  body.client-ops-page .ops-button.is-small {
    min-height: 34px !important;
    padding: 0 14px !important;
    border-radius: 11px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
  }

  /* Chip-link (small inline action like "Календарь" / "Профиль" in client row) */
  body.trainer-ops-page .ops-chip-link,
  body.client-ops-page .ops-chip-link {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 30px !important;
    padding: 0 12px !important;
    border-radius: 999px !important;
    background: #f7faf8 !important;
    color: #182127 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    border: 1px solid #e4e9e6 !important;
    transition: opacity 100ms ease !important;
  }
  body.trainer-ops-page .ops-chip-link:active,
  body.client-ops-page .ops-chip-link:active {
    opacity: 0.78 !important;
  }

  /* Icon-only button (calendar navigation arrows etc.) */
  body.trainer-ops-page .ops-icon-button,
  body.client-ops-page .ops-icon-button {
    display: inline-grid !important;
    place-items: center !important;
    width: 44px !important;
    height: 44px !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    border: 1px solid #e4e9e6 !important;
    color: #182127 !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: opacity 100ms ease !important;
  }
  body.trainer-ops-page .ops-icon-button:active,
  body.client-ops-page .ops-icon-button:active {
    opacity: 0.78 !important;
  }

  /* "Уведомления" head link with badge — pill outlined */
  body.trainer-ops-page .ops-head-link,
  body.trainer-ops-page .ops-notification-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    width: 100% !important;
    min-height: 50px !important;
    padding: 0 18px !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    border: 1px solid #e4e9e6 !important;
    color: #182127 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
  }
  body.trainer-ops-page .ops-head-link strong,
  body.trainer-ops-page .ops-notification-link strong {
    min-width: 24px !important;
    height: 22px !important;
    padding: 0 7px !important;
    border-radius: 999px !important;
    background: #62bd9b !important;
    color: #ffffff !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    display: inline-grid !important;
    place-items: center !important;
  }

  /* Inputs / selects / textareas — iOS rounded */
  body.trainer-ops-page input[type="text"],
  body.trainer-ops-page input[type="email"],
  body.trainer-ops-page input[type="password"],
  body.trainer-ops-page input[type="number"],
  body.trainer-ops-page input[type="date"],
  body.trainer-ops-page select,
  body.trainer-ops-page textarea,
  body.client-ops-page input[type="text"],
  body.client-ops-page input[type="email"],
  body.client-ops-page input[type="password"],
  body.client-ops-page input[type="number"],
  body.client-ops-page input[type="date"],
  body.client-ops-page select,
  body.client-ops-page textarea {
    width: 100% !important;
    min-height: 46px !important;
    padding: 12px 14px !important;
    border-radius: 12px !important;
    border: 1px solid #e4e9e6 !important;
    background: #ffffff !important;
    color: #182127 !important;
    font-size: 16px !important; /* prevent iOS Safari zoom */
    font-weight: 500 !important;
    box-shadow: none !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
  }
  body.trainer-ops-page input:focus,
  body.trainer-ops-page select:focus,
  body.trainer-ops-page textarea:focus,
  body.client-ops-page input:focus,
  body.client-ops-page select:focus,
  body.client-ops-page textarea:focus {
    border-color: #62bd9b !important;
    box-shadow: 0 0 0 3px rgba(98, 189, 155, 0.18) !important;
  }
  body.trainer-ops-page select,
  body.client-ops-page select {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%23667178' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    padding-right: 36px !important;
  }

  /* Field labels (small caps above input) */
  body.client-ops-page .client-ai-field > span,
  body.trainer-ops-page label > span {
    display: block !important;
    margin-bottom: 6px !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: #667178 !important;
  }

  /* Bottom tab bar — native iOS TabView look */
  body.trainer-ops-page .ops-rail,
  body.client-ops-page .ops-rail {
    background: rgba(249, 249, 251, 0.78) !important;
    backdrop-filter: blur(28px) saturate(1.8) !important;
    -webkit-backdrop-filter: blur(28px) saturate(1.8) !important;
    border-top: 0.5px solid rgba(60, 60, 67, 0.18) !important;
    box-shadow: none !important;
    padding: 6px 4px calc(6px + env(safe-area-inset-bottom, 0px)) !important;
  }
  body.trainer-ops-page .ops-rail-link,
  body.client-ops-page .ops-rail-link {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    color: #8e8e93 !important;
    padding: 4px 0 !important;
    gap: 3px !important;
    height: 50px !important;
    min-height: 50px !important;
    transition: color 120ms ease !important;
  }
  body.trainer-ops-page .ops-rail-link.is-active,
  body.client-ops-page .ops-rail-link.is-active,
  body.trainer-ops-page .ops-rail-link.active,
  body.client-ops-page .ops-rail-link.active {
    color: #269875 !important;
    background: transparent !important;
  }
  /* Icons: native size, stroke-only */
  body.trainer-ops-page .ops-rail-icon,
  body.client-ops-page .ops-rail-icon,
  body.trainer-ops-page .ops-rail-icon svg,
  body.client-ops-page .ops-rail-icon svg {
    width: 26px !important;
    height: 26px !important;
    flex-basis: 26px !important;
  }
  body.trainer-ops-page .ops-rail-link svg,
  body.client-ops-page .ops-rail-link svg {
    stroke: currentColor !important;
    fill: none !important;
    stroke-width: 1.7 !important;
  }
  body.trainer-ops-page .ops-rail-link.is-active svg,
  body.client-ops-page .ops-rail-link.is-active svg,
  body.trainer-ops-page .ops-rail-link.active svg,
  body.client-ops-page .ops-rail-link.active svg {
    stroke-width: 2.2 !important;
  }
  /* Labels — small SF Caption2 size, never wraps */
  body.trainer-ops-page .ops-rail-link::after,
  body.client-ops-page .ops-rail-link::after,
  body.client-ops-page .ops-rail-label {
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: -0.005em !important;
    line-height: 1 !important;
  }
  body.trainer-ops-page .ops-rail-link.is-active::after,
  body.client-ops-page .ops-rail-link.is-active::after,
  body.trainer-ops-page .ops-rail-link.active::after,
  body.client-ops-page .ops-rail-link.active::after,
  body.client-ops-page .ops-rail-link.is-active .ops-rail-label,
  body.client-ops-page .ops-rail-link.active .ops-rail-label {
    color: #269875 !important;
    font-weight: 600 !important;
  }

  /* Account strip — iOS-card look */
  body.trainer-ops-page .ops-mobile-account,
  body.client-ops-page .ops-mobile-account {
    border-radius: 18px !important;
    border: 1px solid rgba(228, 233, 230, 0.7) !important;
    background: #ffffff !important;
    box-shadow:
      0 1px 2px rgba(24, 33, 39, 0.04),
      0 6px 16px rgba(24, 33, 39, 0.03) !important;
    padding: 10px 12px !important;
    margin-bottom: 14px !important;
  }
  body.trainer-ops-page .ops-mobile-account-avatar,
  body.client-ops-page .ops-mobile-account-avatar {
    width: 40px !important;
    height: 40px !important;
    border-radius: 14px !important;
    background: #182127 !important;
    color: #ffffff !important;
    font-size: 15px !important;
    font-weight: 800 !important;
  }
  body.trainer-ops-page .ops-mobile-account-user strong,
  body.client-ops-page .ops-mobile-account-user strong {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #182127 !important;
  }
  body.trainer-ops-page .ops-mobile-account-user small,
  body.client-ops-page .ops-mobile-account-user small {
    color: #667178 !important;
    font-size: 12px !important;
  }
  body.trainer-ops-page .ops-mobile-billing,
  body.client-ops-page .ops-mobile-billing {
    background: rgba(98, 189, 155, 0.14) !important;
    color: #269875 !important;
    border-color: transparent !important;
  }
  body.trainer-ops-page .ops-mobile-logout,
  body.client-ops-page .ops-mobile-logout {
    background: #ffffff !important;
    border-color: #e4e9e6 !important;
  }

  /* Chip / pill */
  body.trainer-ops-page .ops-chip,
  body.client-ops-page .ops-chip {
    border-radius: 999px !important;
    padding: 6px 12px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    background: rgba(98, 189, 155, 0.12) !important;
    color: #269875 !important;
    border: none !important;
  }
  body.trainer-ops-page .ops-chip.is-static,
  body.client-ops-page .ops-chip.is-static {
    background: #f7faf8 !important;
    color: #667178 !important;
  }

  /* Segmented tabs (Активные/Неактивные, Блюдо/Продукт, Неделя/Месяц) */
  body.trainer-ops-page .ops-segment,
  body.client-ops-page .subtle-tabs,
  body.client-ops-page .client-ai-mode-tabs {
    background: #f7faf8 !important;
    border-radius: 12px !important;
    padding: 4px !important;
    gap: 0 !important;
  }
  body.trainer-ops-page .ops-segment > button,
  body.client-ops-page .subtle-tab {
    border-radius: 9px !important;
    background: transparent !important;
    color: #667178 !important;
    border: none !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    min-height: 36px !important;
    padding: 0 14px !important;
  }
  body.trainer-ops-page .ops-segment > button.is-active,
  body.client-ops-page .subtle-tab.active {
    background: #ffffff !important;
    color: #182127 !important;
    box-shadow: 0 1px 2px rgba(24, 33, 39, 0.06) !important;
  }

  /* Metrics tile (Клиенты, Тренировки, Выполнено on dashboard) */
  body.trainer-ops-page .ops-dashboard-metrics > article,
  body.trainer-ops-page .ops-trainer-home-board article.ops-metric {
    border-radius: 18px !important;
    background: #ffffff !important;
    border: 1px solid rgba(228, 233, 230, 0.7) !important;
    box-shadow: 0 1px 2px rgba(24, 33, 39, 0.04) !important;
    padding: 16px !important;
  }
  body.trainer-ops-page .ops-dashboard-metrics article > span,
  body.trainer-ops-page .ops-trainer-home-board article.ops-metric > span {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #667178 !important;
  }
  body.trainer-ops-page .ops-dashboard-metrics article > strong,
  body.trainer-ops-page .ops-trainer-home-board article.ops-metric > strong {
    font-size: 34px !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
    color: #182127 !important;
    line-height: 1 !important;
    display: block !important;
    margin: 8px 0 6px !important;
  }
  body.trainer-ops-page .ops-dashboard-metrics article > small,
  body.trainer-ops-page .ops-trainer-home-board article.ops-metric > small {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #667178 !important;
  }

  /* Status banner */
  body.trainer-ops-page .ops-banner,
  body.client-ops-page .ops-banner {
    background: rgba(98, 189, 155, 0.14) !important;
    color: #1c5d44 !important;
    border-radius: 14px !important;
    border: none !important;
    padding: 12px 14px !important;
    font-weight: 600 !important;
  }

  /* Spacing rhythm — closer to native */
  body.trainer-ops-page .ops-main,
  body.client-ops-page .ops-main {
    padding: 14px 14px calc(108px + env(safe-area-inset-bottom, 0px)) !important;
    gap: 12px !important;
  }
}

/* Smaller phones — slightly tighter cards */
@media (max-width: 380px) {
  body.trainer-ops-page .ops-surface,
  body.client-ops-page .ops-surface,
  body.client-ops-page .content-card {
    padding: 14px !important;
    border-radius: 18px !important;
  }
  body.trainer-ops-page .ops-page-head h1,
  body.client-ops-page .ops-page-head h1 {
    font-size: 28px !important;
  }
  body.trainer-ops-page .ops-dashboard-metrics article > strong {
    font-size: 30px !important;
  }
}
